fork of https://github.com/rust-rocksdb/rust-rocksdb for nextgraph
				
			
			
		
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							268 lines
						
					
					
						
							8.8 KiB
						
					
					
				
			
		
		
	
	
							268 lines
						
					
					
						
							8.8 KiB
						
					
					
				| // 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::Statistics methods from Java side.
 | |
| 
 | |
| #include "rocksdb/statistics.h"
 | |
| 
 | |
| #include <jni.h>
 | |
| 
 | |
| #include <memory>
 | |
| #include <set>
 | |
| 
 | |
| #include "include/org_rocksdb_Statistics.h"
 | |
| #include "rocksjni/cplusplus_to_java_convert.h"
 | |
| #include "rocksjni/portal.h"
 | |
| #include "rocksjni/statisticsjni.h"
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    newStatistics
 | |
|  * Signature: ()J
 | |
|  */
 | |
| jlong Java_org_rocksdb_Statistics_newStatistics__(JNIEnv* env, jclass jcls) {
 | |
|   return Java_org_rocksdb_Statistics_newStatistics___3BJ(env, jcls, nullptr, 0);
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    newStatistics
 | |
|  * Signature: (J)J
 | |
|  */
 | |
| jlong Java_org_rocksdb_Statistics_newStatistics__J(
 | |
|     JNIEnv* env, jclass jcls, jlong jother_statistics_handle) {
 | |
|   return Java_org_rocksdb_Statistics_newStatistics___3BJ(
 | |
|       env, jcls, nullptr, jother_statistics_handle);
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    newStatistics
 | |
|  * Signature: ([B)J
 | |
|  */
 | |
| jlong Java_org_rocksdb_Statistics_newStatistics___3B(JNIEnv* env, jclass jcls,
 | |
|                                                      jbyteArray jhistograms) {
 | |
|   return Java_org_rocksdb_Statistics_newStatistics___3BJ(env, jcls, jhistograms,
 | |
|                                                          0);
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    newStatistics
 | |
|  * Signature: ([BJ)J
 | |
|  */
 | |
| jlong Java_org_rocksdb_Statistics_newStatistics___3BJ(
 | |
|     JNIEnv* env, jclass, jbyteArray jhistograms,
 | |
|     jlong jother_statistics_handle) {
 | |
|   std::shared_ptr<ROCKSDB_NAMESPACE::Statistics>* pSptr_other_statistics =
 | |
|       nullptr;
 | |
|   if (jother_statistics_handle > 0) {
 | |
|     pSptr_other_statistics =
 | |
|         reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::Statistics>*>(
 | |
|             jother_statistics_handle);
 | |
|   }
 | |
| 
 | |
|   std::set<uint32_t> histograms;
 | |
|   if (jhistograms != nullptr) {
 | |
|     const jsize len = env->GetArrayLength(jhistograms);
 | |
|     if (len > 0) {
 | |
|       jbyte* jhistogram = env->GetByteArrayElements(jhistograms, nullptr);
 | |
|       if (jhistogram == nullptr) {
 | |
|         // exception thrown: OutOfMemoryError
 | |
|         return 0;
 | |
|       }
 | |
| 
 | |
|       for (jsize i = 0; i < len; i++) {
 | |
|         const ROCKSDB_NAMESPACE::Histograms histogram =
 | |
|             ROCKSDB_NAMESPACE::HistogramTypeJni::toCppHistograms(jhistogram[i]);
 | |
|         histograms.emplace(histogram);
 | |
|       }
 | |
| 
 | |
|       env->ReleaseByteArrayElements(jhistograms, jhistogram, JNI_ABORT);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   std::shared_ptr<ROCKSDB_NAMESPACE::Statistics> sptr_other_statistics =
 | |
|       nullptr;
 | |
|   if (pSptr_other_statistics != nullptr) {
 | |
|     sptr_other_statistics = *pSptr_other_statistics;
 | |
|   }
 | |
| 
 | |
|   auto* pSptr_statistics =
 | |
|       new std::shared_ptr<ROCKSDB_NAMESPACE::StatisticsJni>(
 | |
|           new ROCKSDB_NAMESPACE::StatisticsJni(sptr_other_statistics,
 | |
|                                                histograms));
 | |
| 
 | |
|   return GET_CPLUSPLUS_POINTER(pSptr_statistics);
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    disposeInternal
 | |
|  * Signature: (J)V
 | |
|  */
 | |
| void Java_org_rocksdb_Statistics_disposeInternal(JNIEnv*, jobject,
 | |
|                                                  jlong jhandle) {
 | |
|   if (jhandle > 0) {
 | |
|     auto* pSptr_statistics =
 | |
|         reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::Statistics>*>(
 | |
|             jhandle);
 | |
|     delete pSptr_statistics;
 | |
|   }
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    statsLevel
 | |
|  * Signature: (J)B
 | |
|  */
 | |
| jbyte Java_org_rocksdb_Statistics_statsLevel(JNIEnv*, jobject, jlong jhandle) {
 | |
|   auto* pSptr_statistics =
 | |
|       reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::Statistics>*>(
 | |
|           jhandle);
 | |
|   assert(pSptr_statistics != nullptr);
 | |
|   return ROCKSDB_NAMESPACE::StatsLevelJni::toJavaStatsLevel(
 | |
|       pSptr_statistics->get()->get_stats_level());
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    setStatsLevel
 | |
|  * Signature: (JB)V
 | |
|  */
 | |
| void Java_org_rocksdb_Statistics_setStatsLevel(JNIEnv*, jobject, jlong jhandle,
 | |
|                                                jbyte jstats_level) {
 | |
|   auto* pSptr_statistics =
 | |
|       reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::Statistics>*>(
 | |
|           jhandle);
 | |
|   assert(pSptr_statistics != nullptr);
 | |
|   auto stats_level =
 | |
|       ROCKSDB_NAMESPACE::StatsLevelJni::toCppStatsLevel(jstats_level);
 | |
|   pSptr_statistics->get()->set_stats_level(stats_level);
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    getTickerCount
 | |
|  * Signature: (JB)J
 | |
|  */
 | |
| jlong Java_org_rocksdb_Statistics_getTickerCount(JNIEnv*, jobject,
 | |
|                                                  jlong jhandle,
 | |
|                                                  jbyte jticker_type) {
 | |
|   auto* pSptr_statistics =
 | |
|       reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::Statistics>*>(
 | |
|           jhandle);
 | |
|   assert(pSptr_statistics != nullptr);
 | |
|   auto ticker = ROCKSDB_NAMESPACE::TickerTypeJni::toCppTickers(jticker_type);
 | |
|   uint64_t count = pSptr_statistics->get()->getTickerCount(ticker);
 | |
|   return static_cast<jlong>(count);
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    getAndResetTickerCount
 | |
|  * Signature: (JB)J
 | |
|  */
 | |
| jlong Java_org_rocksdb_Statistics_getAndResetTickerCount(JNIEnv*, jobject,
 | |
|                                                          jlong jhandle,
 | |
|                                                          jbyte jticker_type) {
 | |
|   auto* pSptr_statistics =
 | |
|       reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::Statistics>*>(
 | |
|           jhandle);
 | |
|   assert(pSptr_statistics != nullptr);
 | |
|   auto ticker = ROCKSDB_NAMESPACE::TickerTypeJni::toCppTickers(jticker_type);
 | |
|   return pSptr_statistics->get()->getAndResetTickerCount(ticker);
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    getHistogramData
 | |
|  * Signature: (JB)Lorg/rocksdb/HistogramData;
 | |
|  */
 | |
| jobject Java_org_rocksdb_Statistics_getHistogramData(JNIEnv* env, jobject,
 | |
|                                                      jlong jhandle,
 | |
|                                                      jbyte jhistogram_type) {
 | |
|   auto* pSptr_statistics =
 | |
|       reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::Statistics>*>(
 | |
|           jhandle);
 | |
|   assert(pSptr_statistics != nullptr);
 | |
| 
 | |
|   // TODO(AR) perhaps better to construct a Java Object Wrapper that
 | |
|   //    uses ptr to C++ `new HistogramData`
 | |
|   ROCKSDB_NAMESPACE::HistogramData data;
 | |
| 
 | |
|   auto histogram =
 | |
|       ROCKSDB_NAMESPACE::HistogramTypeJni::toCppHistograms(jhistogram_type);
 | |
|   pSptr_statistics->get()->histogramData(
 | |
|       static_cast<ROCKSDB_NAMESPACE::Histograms>(histogram), &data);
 | |
| 
 | |
|   jclass jclazz = ROCKSDB_NAMESPACE::HistogramDataJni::getJClass(env);
 | |
|   if (jclazz == nullptr) {
 | |
|     // exception occurred accessing class
 | |
|     return nullptr;
 | |
|   }
 | |
| 
 | |
|   jmethodID mid =
 | |
|       ROCKSDB_NAMESPACE::HistogramDataJni::getConstructorMethodId(env);
 | |
|   if (mid == nullptr) {
 | |
|     // exception occurred accessing method
 | |
|     return nullptr;
 | |
|   }
 | |
| 
 | |
|   return env->NewObject(jclazz, mid, data.median, data.percentile95,
 | |
|                         data.percentile99, data.average,
 | |
|                         data.standard_deviation, data.max, data.count, data.sum,
 | |
|                         data.min);
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    getHistogramString
 | |
|  * Signature: (JB)Ljava/lang/String;
 | |
|  */
 | |
| jstring Java_org_rocksdb_Statistics_getHistogramString(JNIEnv* env, jobject,
 | |
|                                                        jlong jhandle,
 | |
|                                                        jbyte jhistogram_type) {
 | |
|   auto* pSptr_statistics =
 | |
|       reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::Statistics>*>(
 | |
|           jhandle);
 | |
|   assert(pSptr_statistics != nullptr);
 | |
|   auto histogram =
 | |
|       ROCKSDB_NAMESPACE::HistogramTypeJni::toCppHistograms(jhistogram_type);
 | |
|   auto str = pSptr_statistics->get()->getHistogramString(histogram);
 | |
|   return env->NewStringUTF(str.c_str());
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    reset
 | |
|  * Signature: (J)V
 | |
|  */
 | |
| void Java_org_rocksdb_Statistics_reset(JNIEnv* env, jobject, jlong jhandle) {
 | |
|   auto* pSptr_statistics =
 | |
|       reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::Statistics>*>(
 | |
|           jhandle);
 | |
|   assert(pSptr_statistics != nullptr);
 | |
|   ROCKSDB_NAMESPACE::Status s = pSptr_statistics->get()->Reset();
 | |
|   if (!s.ok()) {
 | |
|     ROCKSDB_NAMESPACE::RocksDBExceptionJni::ThrowNew(env, s);
 | |
|   }
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Class:     org_rocksdb_Statistics
 | |
|  * Method:    toString
 | |
|  * Signature: (J)Ljava/lang/String;
 | |
|  */
 | |
| jstring Java_org_rocksdb_Statistics_toString(JNIEnv* env, jobject,
 | |
|                                              jlong jhandle) {
 | |
|   auto* pSptr_statistics =
 | |
|       reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::Statistics>*>(
 | |
|           jhandle);
 | |
|   assert(pSptr_statistics != nullptr);
 | |
|   auto str = pSptr_statistics->get()->ToString();
 | |
|   return env->NewStringUTF(str.c_str());
 | |
| }
 | |
| 
 |