/* * Copyright (c) 2013-2015 Josef Hardi <josef.hardi@gmail.com> * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.obidea.semantika.util; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import com.obidea.semantika.exception.SemantikaRuntimeException; import com.obidea.semantika.io.FastByteArrayStream; public class Serializer { public static Object copy(Object target) { FastByteArrayStream streamer = new FastByteArrayStream(); Object toReturn = null; try { ObjectOutputStream out = new ObjectOutputStream(streamer.getOutputStream()); out.writeObject(target); out.flush(); out.close(); ObjectInputStream in = new ObjectInputStream(streamer.getInputStream()); toReturn = in.readObject(); } catch (IOException e) { final String msg = String.format("Error during object serialization: %s", target); throw new SemantikaRuntimeException(msg, e); } catch (ClassNotFoundException e) { final String msg = String.format("Error during object deserialization: %s", target); throw new SemantikaRuntimeException(msg, e); } return toReturn; } }