mirror of
https://github.com/facebook/rocksdb.git
synced 2024-11-28 05:43:50 +00:00
0d65315cb1
Summary: Make CompactionOptionsFIFO's ttl and allow_compaction options to be available in RocksJava. Pull Request resolved: https://github.com/facebook/rocksdb/pull/4609 Differential Revision: D12849503 Pulled By: sagar0 fbshipit-source-id: 47baa97918d252370f234c36c1af15ff2dad7658
106 lines
3.6 KiB
C++
106 lines
3.6 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* /*env*/, jclass /*jcls*/) {
|
|
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* /*env*/, jobject /*jobj*/, 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* /*env*/,
|
|
jobject /*jobj*/,
|
|
jlong jhandle) {
|
|
auto* opt = reinterpret_cast<rocksdb::CompactionOptionsFIFO*>(jhandle);
|
|
return static_cast<jlong>(opt->max_table_files_size);
|
|
}
|
|
|
|
/*
|
|
* Class: org_rocksdb_CompactionOptionsFIFO
|
|
* Method: setTtl
|
|
* Signature: (JJ)V
|
|
*/
|
|
void Java_org_rocksdb_CompactionOptionsFIFO_setTtl(JNIEnv* /*env*/,
|
|
jobject /*jobj*/,
|
|
jlong jhandle, jlong ttl) {
|
|
auto* opt = reinterpret_cast<rocksdb::CompactionOptionsFIFO*>(jhandle);
|
|
opt->ttl = static_cast<uint64_t>(ttl);
|
|
}
|
|
|
|
/*
|
|
* Class: org_rocksdb_CompactionOptionsFIFO
|
|
* Method: ttl
|
|
* Signature: (J)J
|
|
*/
|
|
jlong Java_org_rocksdb_CompactionOptionsFIFO_ttl(JNIEnv* /*env*/,
|
|
jobject /*jobj*/,
|
|
jlong jhandle) {
|
|
auto* opt = reinterpret_cast<rocksdb::CompactionOptionsFIFO*>(jhandle);
|
|
return static_cast<jlong>(opt->ttl);
|
|
}
|
|
|
|
/*
|
|
* Class: org_rocksdb_CompactionOptionsFIFO
|
|
* Method: setAllowCompaction
|
|
* Signature: (JZ)V
|
|
*/
|
|
void Java_org_rocksdb_CompactionOptionsFIFO_setAllowCompaction(
|
|
JNIEnv* /*env*/, jobject /*jobj*/, 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* /*env*/, jobject /*jobj*/, 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* /*env*/,
|
|
jobject /*jobj*/,
|
|
jlong jhandle) {
|
|
delete reinterpret_cast<rocksdb::CompactionOptionsFIFO*>(jhandle);
|
|
}
|