package org.ehcache.impl.internal.store.offheap.portability;
import org.ehcache.impl.internal.store.BinaryValueHolder;
import org.ehcache.impl.internal.store.offheap.LazyOffHeapValueHolder;
import org.ehcache.impl.internal.store.offheap.OffHeapValueHolder;
import org.ehcache.spi.serialization.Serializer;
import org.terracotta.offheapstore.storage.portability.WriteBackPortability;
import org.terracotta.offheapstore.storage.portability.WriteContext;
import java.nio.ByteBuffer;
import java.util.concurrent.TimeUnit;
public class OffHeapValueHolderPortability<V> implements WriteBackPortability<OffHeapValueHolder<V>> {
public static final int ACCESS_TIME_OFFSET = 16;
public static final int EXPIRE_TIME_OFFSET = 24;
private static final int FIELDS_OVERHEAD = 40;
private final Serializer<V> serializer;
public OffHeapValueHolderPortability(Serializer<V> serializer) {
this.serializer = serializer;
}
@Override
public ByteBuffer encode(OffHeapValueHolder<V> valueHolder) {
ByteBuffer serialized;
if (valueHolder instanceof BinaryValueHolder && ((BinaryValueHolder)valueHolder).isBinaryValueAvailable()) {
serialized = ((BinaryValueHolder)valueHolder).getBinaryValue();
} else {
serialized = serializer.serialize(valueHolder.get());
}
ByteBuffer byteBuffer = ByteBuffer.allocate(serialized.remaining() + FIELDS_OVERHEAD);
byteBuffer.putLong(valueHolder.getId());
byteBuffer.putLong(valueHolder.creationTime());
byteBuffer.putLong(valueHolder.lastAccessTime());
byteBuffer.putLong(valueHolder.expirationTime());
byteBuffer.putLong(0L);
byteBuffer.put(serialized);
byteBuffer.flip();
return byteBuffer;
}
@Override
public OffHeapValueHolder<V> decode(ByteBuffer byteBuffer) {
return decode(byteBuffer, null);
}
@Override
public boolean equals(Object o, ByteBuffer byteBuffer) {
return o.equals(decode(byteBuffer));
}
@Override
public OffHeapValueHolder<V> decode(ByteBuffer byteBuffer, WriteContext writeContext) {
long id = byteBuffer.getLong();
long creationTime = byteBuffer.getLong();
long lastAccessTime = byteBuffer.getLong();
long expireTime = byteBuffer.getLong();
byteBuffer.getLong();
return createLazyOffHeapValueHolder(id, byteBuffer.slice(), serializer, creationTime, expireTime, lastAccessTime, writeContext);
}
protected OffHeapValueHolder<V> createLazyOffHeapValueHolder(long id, ByteBuffer byteBuffer, Serializer<V> serializer, long creationTime, long expireTime, long lastAccessTime, WriteContext writeContext) {
return new LazyOffHeapValueHolder<>(id, byteBuffer, serializer, creationTime, expireTime, lastAccessTime, writeContext);
}
}