@nxtedition/rocksdb 10.1.1 → 10.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/binding.cc
CHANGED
|
@@ -958,67 +958,6 @@ NAPI_METHOD(db_close) {
|
|
|
958
958
|
return 0;
|
|
959
959
|
}
|
|
960
960
|
|
|
961
|
-
NAPI_METHOD(db_get_many_sync) {
|
|
962
|
-
NAPI_ARGV(4);
|
|
963
|
-
|
|
964
|
-
Database* database;
|
|
965
|
-
NAPI_STATUS_THROWS(napi_get_value_external(env, argv[0], reinterpret_cast<void**>(&database)));
|
|
966
|
-
|
|
967
|
-
uint32_t size;
|
|
968
|
-
NAPI_STATUS_THROWS(napi_get_array_length(env, argv[1], &size));
|
|
969
|
-
|
|
970
|
-
const auto options = argv[2];
|
|
971
|
-
|
|
972
|
-
bool fillCache = true;
|
|
973
|
-
NAPI_STATUS_THROWS(GetProperty(env, options, "fillCache", fillCache));
|
|
974
|
-
|
|
975
|
-
bool ignoreRangeDeletions = false;
|
|
976
|
-
NAPI_STATUS_THROWS(GetProperty(env, options, "ignoreRangeDeletions", ignoreRangeDeletions));
|
|
977
|
-
|
|
978
|
-
rocksdb::ColumnFamilyHandle* column = database->db->DefaultColumnFamily();
|
|
979
|
-
NAPI_STATUS_THROWS(GetProperty(env, options, "column", column));
|
|
980
|
-
|
|
981
|
-
auto callback = argv[3];
|
|
982
|
-
|
|
983
|
-
std::vector<rocksdb::Slice> keys{size};
|
|
984
|
-
std::vector<rocksdb::Status> statuses{size};
|
|
985
|
-
std::vector<rocksdb::PinnableSlice> values{size};
|
|
986
|
-
|
|
987
|
-
for (uint32_t n = 0; n < size; n++) {
|
|
988
|
-
napi_value element;
|
|
989
|
-
char* buf;
|
|
990
|
-
size_t length;
|
|
991
|
-
NAPI_STATUS_THROWS(napi_get_element(env, argv[1], n, &element));
|
|
992
|
-
NAPI_STATUS_THROWS(napi_get_buffer_info(env, element, reinterpret_cast<void**>(&buf), &length));
|
|
993
|
-
keys[n] = rocksdb::Slice{ buf, length };
|
|
994
|
-
}
|
|
995
|
-
|
|
996
|
-
rocksdb::ReadOptions readOptions;
|
|
997
|
-
readOptions.fill_cache = fillCache;
|
|
998
|
-
readOptions.ignore_range_deletions = ignoreRangeDeletions;
|
|
999
|
-
|
|
1000
|
-
database->db->MultiGet(readOptions, column, size, keys.data(), values.data(), statuses.data());
|
|
1001
|
-
|
|
1002
|
-
napi_value ret;
|
|
1003
|
-
NAPI_STATUS_THROWS(napi_create_array_with_length(env, size, &ret));
|
|
1004
|
-
|
|
1005
|
-
for (uint32_t idx = 0; idx < size; idx++) {
|
|
1006
|
-
const auto& status = statuses[idx];
|
|
1007
|
-
const auto& value = values[idx];
|
|
1008
|
-
|
|
1009
|
-
napi_value element;
|
|
1010
|
-
if (status.IsNotFound()) {
|
|
1011
|
-
NAPI_STATUS_THROWS(napi_get_undefined(env, &element));
|
|
1012
|
-
} else {
|
|
1013
|
-
ROCKS_STATUS_THROWS_NAPI(status);
|
|
1014
|
-
NAPI_STATUS_THROWS(napi_create_buffer_copy(env, value.size(), value.data(), nullptr, &element));
|
|
1015
|
-
}
|
|
1016
|
-
NAPI_STATUS_THROWS(napi_set_element(env, argv[1], idx, element));
|
|
1017
|
-
}
|
|
1018
|
-
|
|
1019
|
-
return ret;
|
|
1020
|
-
}
|
|
1021
|
-
|
|
1022
961
|
NAPI_METHOD(db_get_many) {
|
|
1023
962
|
NAPI_ARGV(4);
|
|
1024
963
|
|
|
@@ -1693,7 +1632,6 @@ NAPI_INIT() {
|
|
|
1693
1632
|
NAPI_EXPORT_FUNCTION(db_get_location);
|
|
1694
1633
|
NAPI_EXPORT_FUNCTION(db_close);
|
|
1695
1634
|
NAPI_EXPORT_FUNCTION(db_get_many);
|
|
1696
|
-
NAPI_EXPORT_FUNCTION(db_get_many_sync);
|
|
1697
1635
|
NAPI_EXPORT_FUNCTION(db_clear);
|
|
1698
1636
|
NAPI_EXPORT_FUNCTION(db_get_property);
|
|
1699
1637
|
NAPI_EXPORT_FUNCTION(db_get_latest_sequence);
|
package/index.js
CHANGED
|
@@ -171,10 +171,6 @@ class RocksLevel extends AbstractLevel {
|
|
|
171
171
|
return callback[kPromise]
|
|
172
172
|
}
|
|
173
173
|
|
|
174
|
-
_getManySync (keys, options) {
|
|
175
|
-
return binding.db_get_many_sync(this[kContext], keys, options ?? EMPTY)
|
|
176
|
-
}
|
|
177
|
-
|
|
178
174
|
_getMergeOperands (key, options, callback) {
|
|
179
175
|
callback = fromCallback(callback, kPromise)
|
|
180
176
|
|
package/package.json
CHANGED
|
Binary file
|
|
Binary file
|