CavalliumDBEngine/src/main/java/it/cavallium/dbengine/database/serialization/Serializer.java

64 lines
2.1 KiB
Java
Raw Normal View History

2021-02-02 19:40:37 +01:00
package it.cavallium.dbengine.database.serialization;
2021-08-29 23:18:03 +02:00
import io.netty.buffer.api.Buffer;
import io.netty.buffer.api.BufferAllocator;
import io.netty.buffer.api.Send;
import it.cavallium.dbengine.database.LLUtils;
import java.nio.charset.StandardCharsets;
2021-02-02 19:40:37 +01:00
import org.jetbrains.annotations.NotNull;
2021-09-01 00:01:56 +02:00
public interface Serializer<A> {
2021-02-02 19:40:37 +01:00
2021-09-01 00:01:56 +02:00
record DeserializationResult<T>(T deserializedData, int bytesRead) {}
2021-02-02 19:40:37 +01:00
2021-09-01 00:01:56 +02:00
@NotNull DeserializationResult<A> deserialize(@NotNull Send<Buffer> serialized) throws SerializationException;
2021-02-02 19:40:37 +01:00
2021-09-01 00:01:56 +02:00
@NotNull Send<Buffer> serialize(@NotNull A deserialized) throws SerializationException;
Serializer<Send<Buffer>> NOOP_SERIALIZER = new Serializer<>() {
2021-03-14 03:13:19 +01:00
@Override
2021-09-01 00:01:56 +02:00
public @NotNull DeserializationResult<Send<Buffer>> deserialize(@NotNull Send<Buffer> serialized) {
try (var serializedBuf = serialized.receive()) {
var readableBytes = serializedBuf.readableBytes();
return new DeserializationResult<>(serializedBuf.send(), readableBytes);
}
2021-03-14 03:13:19 +01:00
}
@Override
2021-08-29 23:18:03 +02:00
public @NotNull Send<Buffer> serialize(@NotNull Send<Buffer> deserialized) {
return deserialized;
2021-03-14 03:13:19 +01:00
}
};
2021-02-02 19:40:37 +01:00
2021-09-01 00:01:56 +02:00
static Serializer<Send<Buffer>> noop() {
2021-03-14 03:13:19 +01:00
return NOOP_SERIALIZER;
2021-02-02 19:40:37 +01:00
}
2021-09-01 00:01:56 +02:00
static Serializer<String> utf8(BufferAllocator allocator) {
2021-05-03 21:41:51 +02:00
return new Serializer<>() {
@Override
2021-09-01 00:01:56 +02:00
public @NotNull DeserializationResult<String> deserialize(@NotNull Send<Buffer> serializedToReceive) {
2021-08-29 23:18:03 +02:00
try (Buffer serialized = serializedToReceive.receive()) {
2021-09-02 17:15:40 +02:00
assert serialized.isAccessible();
2021-08-29 23:18:03 +02:00
int length = serialized.readInt();
2021-09-01 00:01:56 +02:00
var readerOffset = serialized.readerOffset();
return new DeserializationResult<>(LLUtils.deserializeString(serialized.send(),
2021-09-02 17:15:40 +02:00
readerOffset, length, StandardCharsets.UTF_8), Integer.BYTES + length);
2021-05-03 21:41:51 +02:00
}
}
@Override
2021-08-29 23:18:03 +02:00
public @NotNull Send<Buffer> serialize(@NotNull String deserialized) {
2021-08-31 09:14:46 +02:00
var bytes = deserialized.getBytes(StandardCharsets.UTF_8);
try (Buffer buf = allocator.allocate(Integer.BYTES + bytes.length)) {
2021-09-02 17:15:40 +02:00
assert buf.isAccessible();
2021-08-31 09:14:46 +02:00
buf.writeInt(bytes.length);
buf.writeBytes(bytes);
2021-09-02 17:15:40 +02:00
assert buf.isAccessible();
2021-08-29 23:18:03 +02:00
return buf.send();
}
2021-05-03 21:41:51 +02:00
}
};
}
2021-02-02 19:40:37 +01:00
}