/*
*
* * Copyright 2014 Orient Technologies LTD (info(at)orientechnologies.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.
* *
* * For more information: http://www.orientechnologies.com
*
*/
package com.orientechnologies.orient.core.serialization;
import java.io.Serializable;
import com.orientechnologies.orient.core.exception.OSerializationException;
/**
* Base interface of serialization.
*
* @author Luca Garulli (l.garulli--at--orientechnologies.com)
*
*/
public interface OSerializableStream extends Serializable {
/**
* Marshalls the object. Transforms the current object in byte[] form to being stored or transferred over the network.
*
* @return The byte array representation of the object
* @see #fromStream(byte[])
* @throws OSerializationException
* if the marshalling does not succeed
*/
byte[] toStream() throws OSerializationException;
/**
* Unmarshalls the object. Fills the current object with the values contained in the byte array representation restoring a
* previous state. Usually byte[] comes from the storage or network.
*
* @param iStream
* byte array representation of the object
* @return The Object instance itself giving a "fluent interface". Useful to call multiple methods in chain.
* @throws OSerializationException
* if the unmarshalling does not succeed
*/
OSerializableStream fromStream(byte[] iStream) throws OSerializationException;
}