Fix Compilation errors when using IBM Java

Summary:
PR to fix this issue -> https://github.com/facebook/rocksdb/issues/1926
Closes https://github.com/facebook/rocksdb/pull/1965

Differential Revision: D4682411

Pulled By: siying

fbshipit-source-id: a519be1
This commit is contained in:
Ayappan 2017-03-22 18:05:39 -07:00 committed by Sagar Vemuri
parent 90ee46e194
commit 00b558312d
6 changed files with 11 additions and 11 deletions

View File

@ -132,7 +132,7 @@ jbyteArray Java_org_rocksdb_RocksIterator_key0(
return nullptr; return nullptr;
} }
env->SetByteArrayRegion(jkey, 0, static_cast<jsize>(key_slice.size()), env->SetByteArrayRegion(jkey, 0, static_cast<jsize>(key_slice.size()),
reinterpret_cast<const jbyte*>(key_slice.data())); const_cast<jbyte*>(reinterpret_cast<const jbyte*>(key_slice.data())));
return jkey; return jkey;
} }
@ -153,6 +153,6 @@ jbyteArray Java_org_rocksdb_RocksIterator_value0(
return nullptr; return nullptr;
} }
env->SetByteArrayRegion(jkeyValue, 0, static_cast<jsize>(value_slice.size()), env->SetByteArrayRegion(jkeyValue, 0, static_cast<jsize>(value_slice.size()),
reinterpret_cast<const jbyte*>(value_slice.data())); const_cast<jbyte*>(reinterpret_cast<const jbyte*>(value_slice.data())));
return jkeyValue; return jkeyValue;
} }

View File

@ -2257,7 +2257,7 @@ class JniUtil {
} }
env->SetByteArrayRegion(jbytes, 0, jlen, env->SetByteArrayRegion(jbytes, 0, jlen,
reinterpret_cast<const jbyte*>(bytes.c_str())); const_cast<jbyte*>(reinterpret_cast<const jbyte*>(bytes.c_str())));
if(env->ExceptionCheck()) { if(env->ExceptionCheck()) {
// exception thrown: ArrayIndexOutOfBoundsException // exception thrown: ArrayIndexOutOfBoundsException
env->DeleteLocalRef(jbytes); env->DeleteLocalRef(jbytes);
@ -2384,7 +2384,7 @@ class JniUtil {
env->SetByteArrayRegion( env->SetByteArrayRegion(
jbyte_string_ary, 0, str_len, jbyte_string_ary, 0, str_len,
reinterpret_cast<const jbyte*>(str->c_str())); const_cast<jbyte*>(reinterpret_cast<const jbyte*>(str->c_str())));
if(env->ExceptionCheck()) { if(env->ExceptionCheck()) {
// exception thrown: ArrayIndexOutOfBoundsException // exception thrown: ArrayIndexOutOfBoundsException
env->DeleteLocalRef(jbyte_string_ary); env->DeleteLocalRef(jbyte_string_ary);
@ -2509,7 +2509,7 @@ class JniUtil {
} }
env->SetByteArrayRegion(jret_value, 0, static_cast<jsize>(value.size()), env->SetByteArrayRegion(jret_value, 0, static_cast<jsize>(value.size()),
reinterpret_cast<const jbyte*>(value.c_str())); const_cast<jbyte*>(reinterpret_cast<const jbyte*>(value.c_str())));
if(env->ExceptionCheck()) { if(env->ExceptionCheck()) {
// exception thrown: ArrayIndexOutOfBoundsException // exception thrown: ArrayIndexOutOfBoundsException
if(jret_value != nullptr) { if(jret_value != nullptr) {

View File

@ -702,7 +702,7 @@ jint rocksdb_get_helper(JNIEnv* env, rocksdb::DB* db,
const jint length = std::min(jval_len, cvalue_len); const jint length = std::min(jval_len, cvalue_len);
env->SetByteArrayRegion(jval, jval_off, length, env->SetByteArrayRegion(jval, jval_off, length,
reinterpret_cast<const jbyte*>(cvalue.c_str())); const_cast<jbyte*>(reinterpret_cast<const jbyte*>(cvalue.c_str())));
if(env->ExceptionCheck()) { if(env->ExceptionCheck()) {
// exception thrown: OutOfMemoryError // exception thrown: OutOfMemoryError
*has_exception = true; *has_exception = true;
@ -843,7 +843,7 @@ jobjectArray multi_get_helper(JNIEnv* env, jobject jdb, rocksdb::DB* db,
} }
env->SetByteArrayRegion(jentry_value, 0, static_cast<jsize>(jvalue_len), env->SetByteArrayRegion(jentry_value, 0, static_cast<jsize>(jvalue_len),
reinterpret_cast<const jbyte*>(value->c_str())); const_cast<jbyte*>(reinterpret_cast<const jbyte*>(value->c_str())));
if(env->ExceptionCheck()) { if(env->ExceptionCheck()) {
// exception thrown: ArrayIndexOutOfBoundsException // exception thrown: ArrayIndexOutOfBoundsException
env->DeleteLocalRef(jentry_value); env->DeleteLocalRef(jentry_value);
@ -1608,7 +1608,7 @@ jlongArray Java_org_rocksdb_RocksDB_iterators(
for (std::vector<rocksdb::Iterator*>::size_type i = 0; for (std::vector<rocksdb::Iterator*>::size_type i = 0;
i < iterators.size(); i++) { i < iterators.size(); i++) {
env->SetLongArrayRegion(jLongArray, static_cast<jsize>(i), 1, env->SetLongArrayRegion(jLongArray, static_cast<jsize>(i), 1,
reinterpret_cast<const jlong*>(&iterators[i])); const_cast<jlong*>(reinterpret_cast<const jlong*>(&iterators[i])));
if(env->ExceptionCheck()) { if(env->ExceptionCheck()) {
// exception thrown: ArrayIndexOutOfBoundsException // exception thrown: ArrayIndexOutOfBoundsException
env->DeleteLocalRef(jLongArray); env->DeleteLocalRef(jLongArray);

View File

@ -185,7 +185,7 @@ jbyteArray Java_org_rocksdb_Slice_data0(
} }
env->SetByteArrayRegion(data, 0, len, env->SetByteArrayRegion(data, 0, len,
reinterpret_cast<const jbyte*>(slice->data())); const_cast<jbyte*>(reinterpret_cast<const jbyte*>(slice->data())));
if(env->ExceptionCheck()) { if(env->ExceptionCheck()) {
// exception thrown: ArrayIndexOutOfBoundsException // exception thrown: ArrayIndexOutOfBoundsException
env->DeleteLocalRef(data); env->DeleteLocalRef(data);

View File

@ -107,7 +107,7 @@ jbyteArray Java_org_rocksdb_WriteBatchTest_getContents(
} }
env->SetByteArrayRegion(jstate, 0, static_cast<jsize>(state.size()), env->SetByteArrayRegion(jstate, 0, static_cast<jsize>(state.size()),
reinterpret_cast<const jbyte*>(state.c_str())); const_cast<jbyte*>(reinterpret_cast<const jbyte*>(state.c_str())));
if(env->ExceptionCheck()) { if(env->ExceptionCheck()) {
// exception thrown: ArrayIndexOutOfBoundsException // exception thrown: ArrayIndexOutOfBoundsException
env->DeleteLocalRef(jstate); env->DeleteLocalRef(jstate);

View File

@ -286,7 +286,7 @@ jbyteArray WriteBatchHandlerJniCallback::sliceToJArray(const Slice& s) {
m_env->SetByteArrayRegion( m_env->SetByteArrayRegion(
ja, 0, static_cast<jsize>(s.size()), ja, 0, static_cast<jsize>(s.size()),
reinterpret_cast<const jbyte*>(s.data())); const_cast<jbyte*>(reinterpret_cast<const jbyte*>(s.data())));
if(m_env->ExceptionCheck()) { if(m_env->ExceptionCheck()) {
if(ja != nullptr) { if(ja != nullptr) {
m_env->DeleteLocalRef(ja); m_env->DeleteLocalRef(ja);