org.infinispan.protostream.MessageMarshaller Maven / Gradle / Ivy
package org.infinispan.protostream;
import java.io.IOException;
import java.io.InputStream;
import java.time.Instant;
import java.util.Collection;
import java.util.Date;
/**
* Contract to be implemented by marshallers for entity types. The marshaller implementation must be stateless and
* thread-safe.
*
* @author [email protected]
* @since 1.0
*/
public interface MessageMarshaller extends BaseMarshaller {
T readFrom(ProtoStreamReader reader) throws IOException;
void writeTo(ProtoStreamWriter writer, T t) throws IOException;
/**
* An high-level interface for the wire encoding of a protobuf stream that allows reading named and typed message
* fields.
*/
interface ProtoStreamReader {
ImmutableSerializationContext getSerializationContext();
/**
* Can't return an {@code int} here because the field might be declared optional and missing so we might need to
* return a {@code null}.
*/
Integer readInt(String fieldName) throws IOException;
int[] readInts(String fieldName) throws IOException;
Long readLong(String fieldName) throws IOException;
long[] readLongs(String fieldName) throws IOException;
Date readDate(String fieldName) throws IOException;
Instant readInstant(String fieldName) throws IOException;
Float readFloat(String fieldName) throws IOException;
float[] readFloats(String fieldName) throws IOException;
Double readDouble(String fieldName) throws IOException;
double[] readDoubles(String fieldName) throws IOException;
Boolean readBoolean(String fieldName) throws IOException;
boolean[] readBooleans(String fieldName) throws IOException;
String readString(String fieldName) throws IOException;
byte[] readBytes(String fieldName) throws IOException;
InputStream readBytesAsInputStream(String fieldName) throws IOException;
> E readEnum(String fieldName, Class clazz) throws IOException;
E readObject(String fieldName, Class clazz) throws IOException;
> C readCollection(String fieldName, C collection, Class elementClass) throws IOException;
E[] readArray(String fieldName, Class extends E> elementClass) throws IOException;
}
/**
* An high-level interface for the wire encoding of a protobuf stream that allows writing named and typed message
* fields.
*/
interface ProtoStreamWriter {
ImmutableSerializationContext getSerializationContext();
void writeInt(String fieldName, int value) throws IOException;
void writeInt(String fieldName, Integer value) throws IOException;
void writeInts(String fieldName, int[] values) throws IOException;
void writeLong(String fieldName, long value) throws IOException;
void writeLong(String fieldName, Long value) throws IOException;
void writeLongs(String fieldName, long[] values) throws IOException;
void writeDate(String fieldName, Date value) throws IOException;
void writeInstant(String fieldName, Instant value) throws IOException;
void writeDouble(String fieldName, double value) throws IOException;
void writeDouble(String fieldName, Double value) throws IOException;
void writeDoubles(String fieldName, double[] values) throws IOException;
void writeFloat(String fieldName, float value) throws IOException;
void writeFloat(String fieldName, Float value) throws IOException;
void writeFloats(String fieldName, float[] values) throws IOException;
void writeBoolean(String fieldName, boolean value) throws IOException;
void writeBoolean(String fieldName, Boolean value) throws IOException;
void writeBooleans(String fieldName, boolean[] values) throws IOException;
void writeString(String fieldName, String value) throws IOException;
void writeBytes(String fieldName, byte[] value) throws IOException;
void writeBytes(String fieldName, InputStream input) throws IOException;
void writeObject(String fieldName, E value, Class extends E> clazz) throws IOException;
> void writeEnum(String fieldName, E value, Class clazz) throws IOException;
void writeCollection(String fieldName, Collection super E> collection, Class elementClass) throws IOException;
void writeArray(String fieldName, E[] array, Class extends E> elementClass) throws IOException;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy