Async LLInt and LLLong

This commit is contained in:
Andrea Cavalli 2021-01-30 10:52:14 +01:00
parent b1612cb20f
commit 3ad9efe71f
4 changed files with 34 additions and 30 deletions

View File

@ -1,11 +1,11 @@
package it.cavallium.dbengine.database; package it.cavallium.dbengine.database;
import java.io.IOException;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
import reactor.core.publisher.Mono;
public interface LLSingleton extends LLKeyValueDatabaseStructure { public interface LLSingleton extends LLKeyValueDatabaseStructure {
byte[] get(@Nullable LLSnapshot snapshot) throws IOException; Mono<byte[]> get(@Nullable LLSnapshot snapshot);
void set(byte[] value) throws IOException; Mono<Void> set(byte[] value);
} }

View File

@ -10,6 +10,8 @@ import org.rocksdb.RocksDBException;
import org.rocksdb.Snapshot; import org.rocksdb.Snapshot;
import it.cavallium.dbengine.database.LLSingleton; import it.cavallium.dbengine.database.LLSingleton;
import it.cavallium.dbengine.database.LLSnapshot; import it.cavallium.dbengine.database.LLSnapshot;
import reactor.core.publisher.Mono;
import reactor.core.scheduler.Schedulers;
public class LLLocalSingleton implements LLSingleton { public class LLLocalSingleton implements LLSingleton {
@ -44,21 +46,22 @@ public class LLLocalSingleton implements LLSingleton {
} }
@Override @Override
public byte[] get(@Nullable LLSnapshot snapshot) throws IOException { public Mono<byte[]> get(@Nullable LLSnapshot snapshot) {
try { return Mono
return db.get(cfh, resolveSnapshot(snapshot), name); .fromCallable(() -> db.get(cfh, resolveSnapshot(snapshot), name))
} catch (RocksDBException e) { .onErrorMap(IOException::new)
throw new IOException(e); .subscribeOn(Schedulers.boundedElastic());
}
} }
@Override @Override
public void set(byte[] value) throws IOException { public Mono<Void> set(byte[] value) {
try { return Mono
db.put(cfh, name, value); .<Void>fromCallable(() -> {
} catch (RocksDBException e) { db.put(cfh, name, value);
throw new IOException(e); return null;
} })
.onErrorMap(IOException::new)
.subscribeOn(Schedulers.boundedElastic());
} }
@Override @Override

View File

@ -4,8 +4,8 @@ import com.google.common.primitives.Ints;
import it.cavallium.dbengine.database.LLKeyValueDatabaseStructure; import it.cavallium.dbengine.database.LLKeyValueDatabaseStructure;
import it.cavallium.dbengine.database.LLSingleton; import it.cavallium.dbengine.database.LLSingleton;
import it.cavallium.dbengine.database.LLSnapshot; import it.cavallium.dbengine.database.LLSnapshot;
import java.io.IOException;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
import reactor.core.publisher.Mono;
public class LLInt implements LLKeyValueDatabaseStructure { public class LLInt implements LLKeyValueDatabaseStructure {
@ -15,12 +15,12 @@ public class LLInt implements LLKeyValueDatabaseStructure {
this.singleton = singleton; this.singleton = singleton;
} }
public int get(@Nullable LLSnapshot snapshot) throws IOException { public Mono<Integer> get(@Nullable LLSnapshot snapshot) {
return Ints.fromByteArray(singleton.get(snapshot)); return singleton.get(snapshot).map(Ints::fromByteArray);
} }
public void set(int value) throws IOException { public Mono<Void> set(int value) {
singleton.set(Ints.toByteArray(value)); return singleton.set(Ints.toByteArray(value));
} }
@Override @Override

View File

@ -5,8 +5,8 @@ import com.google.common.primitives.Longs;
import it.cavallium.dbengine.database.LLKeyValueDatabaseStructure; import it.cavallium.dbengine.database.LLKeyValueDatabaseStructure;
import it.cavallium.dbengine.database.LLSingleton; import it.cavallium.dbengine.database.LLSingleton;
import it.cavallium.dbengine.database.LLSnapshot; import it.cavallium.dbengine.database.LLSnapshot;
import java.io.IOException;
import org.jetbrains.annotations.Nullable; import org.jetbrains.annotations.Nullable;
import reactor.core.publisher.Mono;
public class LLLong implements LLKeyValueDatabaseStructure { public class LLLong implements LLKeyValueDatabaseStructure {
@ -16,17 +16,18 @@ public class LLLong implements LLKeyValueDatabaseStructure {
this.singleton = singleton; this.singleton = singleton;
} }
public long get(@Nullable LLSnapshot snapshot) throws IOException { public Mono<Long> get(@Nullable LLSnapshot snapshot) {
var array = singleton.get(snapshot); return singleton.get(snapshot).map(array -> {
if (array.length == 4) { if (array.length == 4) {
return Ints.fromByteArray(array); return (long) Ints.fromByteArray(array);
} else { } else {
return Longs.fromByteArray(array); return Longs.fromByteArray(array);
} }
});
} }
public void set(long value) throws IOException { public Mono<Void> set(long value) {
singleton.set(Longs.toByteArray(value)); return singleton.set(Longs.toByteArray(value));
} }
@Override @Override