File: hyper_clock_cache.cc

package info (click to toggle)
rocksdb 9.10.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 46,052 kB
  • sloc: cpp: 500,768; java: 42,992; ansic: 9,789; python: 8,373; perl: 5,822; sh: 4,921; makefile: 2,386; asm: 550; xml: 342
file content (42 lines) | stat: -rw-r--r-- 1,578 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
// 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_NAMESPACE::HyperClockCache.

#include <jni.h>

#include "cache/clock_cache.h"
#include "include/org_rocksdb_HyperClockCache.h"
#include "rocksjni/cplusplus_to_java_convert.h"

/*
 * Class:     org_rocksdb_HyperClockCache
 * Method:    newHyperClockCache
 * Signature: (JJIZ)J
 */
jlong Java_org_rocksdb_HyperClockCache_newHyperClockCache(
    JNIEnv*, jclass, jlong capacity, jlong estimatedEntryCharge,
    jint numShardBits, jboolean strictCapacityLimit) {
  ROCKSDB_NAMESPACE::HyperClockCacheOptions cacheOptions =
      ROCKSDB_NAMESPACE::HyperClockCacheOptions(
          capacity, estimatedEntryCharge, numShardBits, strictCapacityLimit);

  auto* cache = new std::shared_ptr<ROCKSDB_NAMESPACE::Cache>(
      cacheOptions.MakeSharedCache());
  return GET_CPLUSPLUS_POINTER(cache);
}

/*
 * Class:     org_rocksdb_HyperClockCache
 * Method:    disposeInternalJni
 * Signature: (J)V
 */
void Java_org_rocksdb_HyperClockCache_disposeInternalJni(JNIEnv*, jclass,
                                                         jlong jhandle) {
  auto* hyper_clock_cache =
      reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::Cache>*>(jhandle);
  delete hyper_clock_cache;  // delete std::shared_ptr
}