| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362 |
- // Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
- // This source code is licensed under both the GPLv2 (found in the
- // COPYING file in the root directory) and Apache 2.0 License
- // (found in the LICENSE.Apache file in the root directory).
- //
- // This file implements the "bridge" between Java and C++ and enables
- // calling c++ ROCKSDB_NAMESPACE::Iterator methods from Java side.
- #include "rocksdb/iterator.h"
- #include <jni.h>
- #include <stdio.h>
- #include <stdlib.h>
- #include <algorithm>
- #include "include/org_rocksdb_RocksIterator.h"
- #include "rocksjni/portal.h"
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: disposeInternal
- * Signature: (J)V
- */
- void Java_org_rocksdb_RocksIterator_disposeInternalJni(JNIEnv* /*env*/,
- jclass /*cls*/,
- jlong handle) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- assert(it != nullptr);
- delete it;
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: isValid0
- * Signature: (J)Z
- */
- jboolean Java_org_rocksdb_RocksIterator_isValid0Jni(JNIEnv* /*env*/,
- jclass /*jcls*/,
- jlong handle) {
- return reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle)->Valid();
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: seekToFirst0
- * Signature: (J)V
- */
- void Java_org_rocksdb_RocksIterator_seekToFirst0Jni(JNIEnv* /*env*/,
- jclass /*jcls*/,
- jlong handle) {
- reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle)->SeekToFirst();
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: seekToLast0
- * Signature: (J)V
- */
- void Java_org_rocksdb_RocksIterator_seekToLast0Jni(JNIEnv* /*env*/,
- jclass /*jcls*/,
- jlong handle) {
- reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle)->SeekToLast();
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: next0
- * Signature: (J)V
- */
- void Java_org_rocksdb_RocksIterator_next0Jni(JNIEnv* /*env*/, jclass /*jcls*/,
- jlong handle) {
- reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle)->Next();
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: prev0
- * Signature: (J)V
- */
- void Java_org_rocksdb_RocksIterator_prev0Jni(JNIEnv* /*env*/, jclass /*jobj*/,
- jlong handle) {
- reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle)->Prev();
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: refresh0
- * Signature: (J)V
- */
- void Java_org_rocksdb_RocksIterator_refresh0Jni(JNIEnv* env, jclass /*jcls*/,
- jlong handle) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- ROCKSDB_NAMESPACE::Status s = it->Refresh();
- if (s.ok()) {
- return;
- }
- ROCKSDB_NAMESPACE::RocksDBExceptionJni::ThrowNew(env, s);
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: refresh1
- * Signature: (JJ)V
- */
- void Java_org_rocksdb_RocksIterator_refresh1(JNIEnv* env, jobject /*jobj*/,
- jlong handle,
- jlong snapshot_handle) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- auto* snapshot =
- reinterpret_cast<ROCKSDB_NAMESPACE::Snapshot*>(snapshot_handle);
- ROCKSDB_NAMESPACE::Status s = it->Refresh(snapshot);
- if (s.ok()) {
- return;
- }
- ROCKSDB_NAMESPACE::RocksDBExceptionJni::ThrowNew(env, s);
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: seek0
- * Signature: (J[BI)V
- */
- void Java_org_rocksdb_RocksIterator_seek0Jni(JNIEnv* env, jclass /*jcls*/,
- jlong handle, jbyteArray jtarget,
- jint jtarget_len) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- auto seek = [&it](ROCKSDB_NAMESPACE::Slice& target_slice) {
- it->Seek(target_slice);
- };
- ROCKSDB_NAMESPACE::JniUtil::k_op_region(seek, env, jtarget, 0, jtarget_len);
- }
- /*
- * This method supports fetching into indirect byte buffers;
- * the Java wrapper extracts the byte[] and passes it here.
- * In this case, the buffer offset of the key may be non-zero.
- *
- * Class: org_rocksdb_RocksIterator
- * Method: seek0
- * Signature: (J[BII)V
- */
- void Java_org_rocksdb_RocksIterator_seekByteArray0Jni(
- JNIEnv* env, jclass /*jcls*/, jlong handle, jbyteArray jtarget,
- jint jtarget_off, jint jtarget_len) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- auto seek = [&it](ROCKSDB_NAMESPACE::Slice& target_slice) {
- it->Seek(target_slice);
- };
- ROCKSDB_NAMESPACE::JniUtil::k_op_region(seek, env, jtarget, jtarget_off,
- jtarget_len);
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: seekDirect0
- * Signature: (JLjava/nio/ByteBuffer;II)V
- */
- void Java_org_rocksdb_RocksIterator_seekDirect0Jni(JNIEnv* env, jclass /*jobj*/,
- jlong handle,
- jobject jtarget,
- jint jtarget_off,
- jint jtarget_len) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- auto seek = [&it](ROCKSDB_NAMESPACE::Slice& target_slice) {
- it->Seek(target_slice);
- };
- ROCKSDB_NAMESPACE::JniUtil::k_op_direct(seek, env, jtarget, jtarget_off,
- jtarget_len);
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: seekForPrevDirect0
- * Signature: (JLjava/nio/ByteBuffer;II)V
- */
- void Java_org_rocksdb_RocksIterator_seekForPrevDirect0Jni(
- JNIEnv* env, jclass /*jcls*/, jlong handle, jobject jtarget,
- jint jtarget_off, jint jtarget_len) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- auto seekPrev = [&it](ROCKSDB_NAMESPACE::Slice& target_slice) {
- it->SeekForPrev(target_slice);
- };
- ROCKSDB_NAMESPACE::JniUtil::k_op_direct(seekPrev, env, jtarget, jtarget_off,
- jtarget_len);
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: seekForPrev0
- * Signature: (J[BI)V
- */
- void Java_org_rocksdb_RocksIterator_seekForPrev0Jni(JNIEnv* env,
- jclass /*jcls*/,
- jlong handle,
- jbyteArray jtarget,
- jint jtarget_len) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- auto seek = [&it](ROCKSDB_NAMESPACE::Slice& target_slice) {
- it->SeekForPrev(target_slice);
- };
- ROCKSDB_NAMESPACE::JniUtil::k_op_region(seek, env, jtarget, 0, jtarget_len);
- }
- /*
- * This method supports fetching into indirect byte buffers;
- * the Java wrapper extracts the byte[] and passes it here.
- * In this case, the buffer offset of the key may be non-zero.
- *
- * Class: org_rocksdb_RocksIterator
- * Method: seek0
- * Signature: (J[BII)V
- */
- void Java_org_rocksdb_RocksIterator_seekForPrevByteArray0Jni(
- JNIEnv* env, jclass /*jcls*/, jlong handle, jbyteArray jtarget,
- jint jtarget_off, jint jtarget_len) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- auto seek = [&it](ROCKSDB_NAMESPACE::Slice& target_slice) {
- it->SeekForPrev(target_slice);
- };
- ROCKSDB_NAMESPACE::JniUtil::k_op_region(seek, env, jtarget, jtarget_off,
- jtarget_len);
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: status0
- * Signature: (J)V
- */
- void Java_org_rocksdb_RocksIterator_status0Jni(JNIEnv* env, jclass /*jcls*/,
- jlong handle) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- ROCKSDB_NAMESPACE::Status s = it->status();
- if (s.ok()) {
- return;
- }
- ROCKSDB_NAMESPACE::RocksDBExceptionJni::ThrowNew(env, s);
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: key0
- * Signature: (J)[B
- */
- jbyteArray Java_org_rocksdb_RocksIterator_key0(JNIEnv* env, jclass /*jcls*/,
- jlong handle) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- ROCKSDB_NAMESPACE::Slice key_slice = it->key();
- jbyteArray jkey = env->NewByteArray(static_cast<jsize>(key_slice.size()));
- if (jkey == nullptr) {
- // exception thrown: OutOfMemoryError
- return nullptr;
- }
- env->SetByteArrayRegion(
- jkey, 0, static_cast<jsize>(key_slice.size()),
- const_cast<jbyte*>(reinterpret_cast<const jbyte*>(key_slice.data())));
- return jkey;
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: keyDirect0
- * Signature: (JLjava/nio/ByteBuffer;II)I
- */
- jint Java_org_rocksdb_RocksIterator_keyDirect0(JNIEnv* env, jclass /*jcls*/,
- jlong handle, jobject jtarget,
- jint jtarget_off,
- jint jtarget_len) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- ROCKSDB_NAMESPACE::Slice key_slice = it->key();
- return ROCKSDB_NAMESPACE::JniUtil::copyToDirect(env, key_slice, jtarget,
- jtarget_off, jtarget_len);
- }
- /*
- * This method supports fetching into indirect byte buffers;
- * the Java wrapper extracts the byte[] and passes it here.
- *
- * Class: org_rocksdb_RocksIterator
- * Method: keyByteArray0
- * Signature: (J[BII)I
- */
- jint Java_org_rocksdb_RocksIterator_keyByteArray0(JNIEnv* env, jclass /*jcls*/,
- jlong handle, jbyteArray jkey,
- jint jkey_off,
- jint jkey_len) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- ROCKSDB_NAMESPACE::Slice key_slice = it->key();
- jsize copy_size = std::min(static_cast<uint32_t>(key_slice.size()),
- static_cast<uint32_t>(jkey_len));
- env->SetByteArrayRegion(
- jkey, jkey_off, copy_size,
- const_cast<jbyte*>(reinterpret_cast<const jbyte*>(key_slice.data())));
- return static_cast<jsize>(key_slice.size());
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: value0
- * Signature: (J)[B
- */
- jbyteArray Java_org_rocksdb_RocksIterator_value0(JNIEnv* env, jclass /*jcls*/,
- jlong handle) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- ROCKSDB_NAMESPACE::Slice value_slice = it->value();
- jbyteArray jkeyValue =
- env->NewByteArray(static_cast<jsize>(value_slice.size()));
- if (jkeyValue == nullptr) {
- // exception thrown: OutOfMemoryError
- return nullptr;
- }
- env->SetByteArrayRegion(
- jkeyValue, 0, static_cast<jsize>(value_slice.size()),
- const_cast<jbyte*>(reinterpret_cast<const jbyte*>(value_slice.data())));
- return jkeyValue;
- }
- /*
- * Class: org_rocksdb_RocksIterator
- * Method: valueDirect0
- * Signature: (JLjava/nio/ByteBuffer;II)I
- */
- jint Java_org_rocksdb_RocksIterator_valueDirect0(JNIEnv* env, jclass /*jcls*/,
- jlong handle, jobject jtarget,
- jint jtarget_off,
- jint jtarget_len) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- ROCKSDB_NAMESPACE::Slice value_slice = it->value();
- return ROCKSDB_NAMESPACE::JniUtil::copyToDirect(env, value_slice, jtarget,
- jtarget_off, jtarget_len);
- }
- /*
- * This method supports fetching into indirect byte buffers;
- * the Java wrapper extracts the byte[] and passes it here.
- *
- * Class: org_rocksdb_RocksIterator
- * Method: valueByteArray0
- * Signature: (J[BII)I
- */
- jint Java_org_rocksdb_RocksIterator_valueByteArray0(
- JNIEnv* env, jclass /*jcls*/, jlong handle, jbyteArray jvalue_target,
- jint jvalue_off, jint jvalue_len) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- ROCKSDB_NAMESPACE::Slice value_slice = it->value();
- jsize copy_size = std::min(static_cast<uint32_t>(value_slice.size()),
- static_cast<uint32_t>(jvalue_len));
- env->SetByteArrayRegion(
- jvalue_target, jvalue_off, copy_size,
- const_cast<jbyte*>(reinterpret_cast<const jbyte*>(value_slice.data())));
- return static_cast<jsize>(value_slice.size());
- }
|