mirror of
https://github.com/facebook/rocksdb.git
synced 2024-11-30 22:41:48 +00:00
bb474e9a02
Summary: This is my latest round of changes to add missing items to RocksJava. More to come in future PRs. Pull Request resolved: https://github.com/facebook/rocksdb/pull/4833 Differential Revision: D14152266 Pulled By: sagar0 fbshipit-source-id: d6cff67e26da06c131491b5cf6911a8cd0db0775
78 lines
2.5 KiB
C++
78 lines
2.5 KiB
C++
// 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++ for
|
|
// rocksdb::CompactionOptionsFIFO.
|
|
|
|
#include <jni.h>
|
|
|
|
#include "include/org_rocksdb_CompactionOptionsFIFO.h"
|
|
#include "rocksdb/advanced_options.h"
|
|
|
|
/*
|
|
* Class: org_rocksdb_CompactionOptionsFIFO
|
|
* Method: newCompactionOptionsFIFO
|
|
* Signature: ()J
|
|
*/
|
|
jlong Java_org_rocksdb_CompactionOptionsFIFO_newCompactionOptionsFIFO(
|
|
JNIEnv*, jclass) {
|
|
const auto* opt = new rocksdb::CompactionOptionsFIFO();
|
|
return reinterpret_cast<jlong>(opt);
|
|
}
|
|
|
|
/*
|
|
* Class: org_rocksdb_CompactionOptionsFIFO
|
|
* Method: setMaxTableFilesSize
|
|
* Signature: (JJ)V
|
|
*/
|
|
void Java_org_rocksdb_CompactionOptionsFIFO_setMaxTableFilesSize(
|
|
JNIEnv*, jobject, jlong jhandle, jlong jmax_table_files_size) {
|
|
auto* opt = reinterpret_cast<rocksdb::CompactionOptionsFIFO*>(jhandle);
|
|
opt->max_table_files_size = static_cast<uint64_t>(jmax_table_files_size);
|
|
}
|
|
|
|
/*
|
|
* Class: org_rocksdb_CompactionOptionsFIFO
|
|
* Method: maxTableFilesSize
|
|
* Signature: (J)J
|
|
*/
|
|
jlong Java_org_rocksdb_CompactionOptionsFIFO_maxTableFilesSize(
|
|
JNIEnv*, jobject, jlong jhandle) {
|
|
auto* opt = reinterpret_cast<rocksdb::CompactionOptionsFIFO*>(jhandle);
|
|
return static_cast<jlong>(opt->max_table_files_size);
|
|
}
|
|
|
|
/*
|
|
* Class: org_rocksdb_CompactionOptionsFIFO
|
|
* Method: setAllowCompaction
|
|
* Signature: (JZ)V
|
|
*/
|
|
void Java_org_rocksdb_CompactionOptionsFIFO_setAllowCompaction(
|
|
JNIEnv*, jobject, jlong jhandle, jboolean allow_compaction) {
|
|
auto* opt = reinterpret_cast<rocksdb::CompactionOptionsFIFO*>(jhandle);
|
|
opt->allow_compaction = static_cast<bool>(allow_compaction);
|
|
}
|
|
|
|
/*
|
|
* Class: org_rocksdb_CompactionOptionsFIFO
|
|
* Method: allowCompaction
|
|
* Signature: (J)Z
|
|
*/
|
|
jboolean Java_org_rocksdb_CompactionOptionsFIFO_allowCompaction(
|
|
JNIEnv*, jobject, jlong jhandle) {
|
|
auto* opt = reinterpret_cast<rocksdb::CompactionOptionsFIFO*>(jhandle);
|
|
return static_cast<jboolean>(opt->allow_compaction);
|
|
}
|
|
|
|
/*
|
|
* Class: org_rocksdb_CompactionOptionsFIFO
|
|
* Method: disposeInternal
|
|
* Signature: (J)V
|
|
*/
|
|
void Java_org_rocksdb_CompactionOptionsFIFO_disposeInternal(
|
|
JNIEnv*, jobject, jlong jhandle) {
|
|
delete reinterpret_cast<rocksdb::CompactionOptionsFIFO*>(jhandle);
|
|
}
|