org.infinispan.persistence.remote.wrapper.HotRodEntryMarshaller Maven / Gradle / Ivy
package org.infinispan.persistence.remote.wrapper;
import org.infinispan.commons.io.ByteBuffer;
import org.infinispan.commons.io.ByteBufferFactory;
import org.infinispan.commons.marshall.BufferSizePredictor;
import org.infinispan.commons.marshall.Marshaller;
import java.io.IOException;
import java.util.Arrays;
/**
* HotRodEntryMarshaller.
*
* @author Tristan Tarrant
* @since 5.2
*/
public class HotRodEntryMarshaller implements Marshaller {
private final ByteBufferFactory byteBufferFactory;
BufferSizePredictor predictor = new IdentityBufferSizePredictor();
public HotRodEntryMarshaller(ByteBufferFactory byteBufferFactory) {
this.byteBufferFactory = byteBufferFactory;
}
@Override
public byte[] objectToByteBuffer(Object obj, int estimatedSize) throws IOException, InterruptedException {
return (byte[]) obj;
}
@Override
public byte[] objectToByteBuffer(Object obj) throws IOException, InterruptedException {
return (byte[]) obj;
}
@Override
public Object objectFromByteBuffer(byte[] buf) throws IOException, ClassNotFoundException {
return buf;
}
@Override
public Object objectFromByteBuffer(byte[] buf, int offset, int length) throws IOException, ClassNotFoundException {
return Arrays.copyOfRange(buf, offset, offset+length);
}
@Override
public ByteBuffer objectToBuffer(Object o) throws IOException, InterruptedException {
byte[] b = (byte[])o;
return byteBufferFactory.newByteBuffer(b, 0, b.length);
}
@Override
public boolean isMarshallable(Object o) throws Exception {
return o instanceof byte[];
}
@Override
public BufferSizePredictor getBufferSizePredictor(Object o) {
return predictor;
}
class IdentityBufferSizePredictor implements BufferSizePredictor {
@Override
public int nextSize(Object obj) {
return ((byte[])obj).length;
}
@Override
public void recordSize(int previousSize) {
// NOOP
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy