| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395 |
- // 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 <jni.h>
- #include <stdio.h>
- #include <stdlib.h>
- #include "include/org_rocksdb_SstFileReaderIterator.h"
- #include "rocksdb/iterator.h"
- #include "rocksjni/portal.h"
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: disposeInternal
- * Signature: (J)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_disposeInternalJni(JNIEnv* /*env*/,
- jclass /*jobj*/,
- jlong handle) {
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- assert(it != nullptr);
- delete it;
- }
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: isValid0
- * Signature: (J)Z
- */
- jboolean Java_org_rocksdb_SstFileReaderIterator_isValid0Jni(JNIEnv* /*env*/,
- jclass /*cls*/,
- jlong handle) {
- return reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle)->Valid();
- }
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: seekToFirst0
- * Signature: (J)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_seekToFirst0Jni(JNIEnv* /*env*/,
- jclass /*cls*/,
- jlong handle) {
- reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle)->SeekToFirst();
- }
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: seekToLast0
- * Signature: (J)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_seekToLast0Jni(JNIEnv* /*env*/,
- jclass /*cls*/,
- jlong handle) {
- reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle)->SeekToLast();
- }
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: next0
- * Signature: (J)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_next0Jni(JNIEnv* /*env*/,
- jclass /*cls*/,
- jlong handle) {
- reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle)->Next();
- }
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: prev0
- * Signature: (J)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_prev0Jni(JNIEnv* /*env*/,
- jclass /*cls*/,
- jlong handle) {
- reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle)->Prev();
- }
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: seek0
- * Signature: (J[BI)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_seek0Jni(JNIEnv* env,
- jclass /*cls*/,
- jlong handle,
- jbyteArray jtarget,
- jint jtarget_len) {
- jbyte* target = env->GetByteArrayElements(jtarget, nullptr);
- if (target == nullptr) {
- // exception thrown: OutOfMemoryError
- return;
- }
- ROCKSDB_NAMESPACE::Slice target_slice(reinterpret_cast<char*>(target),
- jtarget_len);
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- it->Seek(target_slice);
- env->ReleaseByteArrayElements(jtarget, target, JNI_ABORT);
- }
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: seekForPrev0
- * Signature: (J[BI)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_seekForPrev0Jni(JNIEnv* env,
- jclass /*cls*/,
- jlong handle,
- jbyteArray jtarget,
- jint jtarget_len) {
- jbyte* target = env->GetByteArrayElements(jtarget, nullptr);
- if (target == nullptr) {
- // exception thrown: OutOfMemoryError
- return;
- }
- ROCKSDB_NAMESPACE::Slice target_slice(reinterpret_cast<char*>(target),
- jtarget_len);
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- it->SeekForPrev(target_slice);
- env->ReleaseByteArrayElements(jtarget, target, JNI_ABORT);
- }
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: status0
- * Signature: (J)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_status0Jni(JNIEnv* env,
- jclass /*cls*/,
- 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_SstFileReaderIterator
- * Method: key0
- * Signature: (J)[B
- */
- jbyteArray Java_org_rocksdb_SstFileReaderIterator_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_SstFileReaderIterator
- * Method: value0
- * Signature: (J)[B
- */
- jbyteArray Java_org_rocksdb_SstFileReaderIterator_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_SstFileReaderIterator
- * Method: keyDirect0
- * Signature: (JLjava/nio/ByteBuffer;II)I
- */
- jint Java_org_rocksdb_SstFileReaderIterator_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_SstFileReaderIterator
- * Method: keyByteArray0
- * Signature: (J[BII)I
- */
- jint Java_org_rocksdb_SstFileReaderIterator_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();
- auto slice_size = key_slice.size();
- jsize copy_size = std::min(static_cast<uint32_t>(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>(slice_size);
- }
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: valueDirect0
- * Signature: (JLjava/nio/ByteBuffer;II)I
- */
- jint Java_org_rocksdb_SstFileReaderIterator_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_SstFileReaderIterator
- * Method: valueByteArray0
- * Signature: (J[BII)I
- */
- jint Java_org_rocksdb_SstFileReaderIterator_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();
- auto slice_size = value_slice.size();
- jsize copy_size = std::min(static_cast<uint32_t>(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>(slice_size);
- }
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: seekDirect0
- * Signature: (JLjava/nio/ByteBuffer;II)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_seekDirect0Jni(
- JNIEnv* env, jclass /*cls*/, 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_SstFileReaderIterator
- * Method: seekForPrevDirect0
- * Signature: (JLjava/nio/ByteBuffer;II)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_seekForPrevDirect0Jni(
- JNIEnv* env, jclass /*cls*/, 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);
- }
- /*
- * This method supports fetching into indirect byte buffers;
- * the Java wrapper extracts the byte[] and passes it here.
- *
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: seekByteArray0
- * Signature: (J[BII)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_seekByteArray0Jni(
- JNIEnv* env, jclass /*cls*/, jlong handle, jbyteArray jtarget,
- jint jtarget_off, jint jtarget_len) {
- const std::unique_ptr<char[]> target(new char[jtarget_len]);
- if (target == nullptr) {
- jclass oom_class = env->FindClass("/lang/java/OutOfMemoryError");
- env->ThrowNew(oom_class,
- "Memory allocation failed in RocksDB JNI function");
- return;
- }
- env->GetByteArrayRegion(jtarget, jtarget_off, jtarget_len,
- reinterpret_cast<jbyte*>(target.get()));
- ROCKSDB_NAMESPACE::Slice target_slice(target.get(), jtarget_len);
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- it->Seek(target_slice);
- }
- /*
- * This method supports fetching into indirect byte buffers;
- * the Java wrapper extracts the byte[] and passes it here.
- *
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: seekForPrevByteArray0
- * Signature: (J[BII)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_seekForPrevByteArray0Jni(
- JNIEnv* env, jclass /*cls*/, jlong handle, jbyteArray jtarget,
- jint jtarget_off, jint jtarget_len) {
- const std::unique_ptr<char[]> target(new char[jtarget_len]);
- if (target == nullptr) {
- jclass oom_class = env->FindClass("/lang/java/OutOfMemoryError");
- env->ThrowNew(oom_class,
- "Memory allocation failed in RocksDB JNI function");
- return;
- }
- env->GetByteArrayRegion(jtarget, jtarget_off, jtarget_len,
- reinterpret_cast<jbyte*>(target.get()));
- ROCKSDB_NAMESPACE::Slice target_slice(target.get(), jtarget_len);
- auto* it = reinterpret_cast<ROCKSDB_NAMESPACE::Iterator*>(handle);
- it->SeekForPrev(target_slice);
- }
- /*
- * Class: org_rocksdb_SstFileReaderIterator
- * Method: refresh0
- * Signature: (J)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_refresh0Jni(JNIEnv* env,
- jclass /*cls*/,
- 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_SstFileReaderIterator
- * Method: refresh1
- * Signature: (JJ)V
- */
- void Java_org_rocksdb_SstFileReaderIterator_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);
- }
|