Async LLInt and LLLong
This commit is contained in:
parent
b1612cb20f
commit
3ad9efe71f
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user