stderr_logger.cc 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. // Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
  2. // This source code is licensed under both the GPLv2 (found in the
  3. // COPYING file in the root directory) and Apache 2.0 License
  4. // (found in the LICENSE.Apache file in the root directory).
  5. #include "util/stderr_logger.h"
  6. #include <jni.h>
  7. #include <memory>
  8. #include "include/org_rocksdb_util_StdErrLogger.h"
  9. #include "rocksjni/cplusplus_to_java_convert.h"
  10. #include "rocksjni/portal.h"
  11. /*
  12. * Class: org_rocksdb_util_StdErrLogger
  13. * Method: newStdErrLogger
  14. * Signature: (BLjava/lang/String;)J
  15. */
  16. jlong Java_org_rocksdb_util_StdErrLogger_newStdErrLogger(JNIEnv* env,
  17. jclass /*jcls*/,
  18. jbyte jlog_level,
  19. jstring jlog_prefix) {
  20. auto log_level = static_cast<ROCKSDB_NAMESPACE::InfoLogLevel>(jlog_level);
  21. std::shared_ptr<ROCKSDB_NAMESPACE::StderrLogger>* sptr_logger = nullptr;
  22. if (jlog_prefix == nullptr) {
  23. sptr_logger = new std::shared_ptr<ROCKSDB_NAMESPACE::StderrLogger>(
  24. new ROCKSDB_NAMESPACE::StderrLogger(log_level));
  25. } else {
  26. jboolean has_exception = JNI_FALSE;
  27. auto log_prefix = ROCKSDB_NAMESPACE::JniUtil::copyStdString(
  28. env, jlog_prefix, &has_exception); // also releases jlog_prefix
  29. if (has_exception == JNI_TRUE) {
  30. return 0;
  31. }
  32. sptr_logger = new std::shared_ptr<ROCKSDB_NAMESPACE::StderrLogger>(
  33. new ROCKSDB_NAMESPACE::StderrLogger(log_level, log_prefix));
  34. }
  35. return GET_CPLUSPLUS_POINTER(sptr_logger);
  36. }
  37. /*
  38. * Class: org_rocksdb_util_StdErrLogger
  39. * Method: setInfoLogLevel
  40. * Signature: (JB)V
  41. */
  42. void Java_org_rocksdb_util_StdErrLogger_setInfoLogLevel(JNIEnv* /*env*/,
  43. jclass /*jcls*/,
  44. jlong jhandle,
  45. jbyte jlog_level) {
  46. auto* handle =
  47. reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::StderrLogger>*>(
  48. jhandle);
  49. handle->get()->SetInfoLogLevel(
  50. static_cast<ROCKSDB_NAMESPACE::InfoLogLevel>(jlog_level));
  51. }
  52. /*
  53. * Class: org_rocksdb_util_StdErrLogger
  54. * Method: infoLogLevel
  55. * Signature: (J)B
  56. */
  57. jbyte Java_org_rocksdb_util_StdErrLogger_infoLogLevel(JNIEnv* /*env*/,
  58. jclass /*jcls*/,
  59. jlong jhandle) {
  60. auto* handle =
  61. reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::StderrLogger>*>(
  62. jhandle);
  63. return static_cast<jbyte>(handle->get()->GetInfoLogLevel());
  64. }
  65. /*
  66. * Class: org_rocksdb_util_StdErrLogger
  67. * Method: disposeInternal
  68. * Signature: (J)V
  69. */
  70. void Java_org_rocksdb_util_StdErrLogger_disposeInternal(JNIEnv* /*env*/,
  71. jobject /*jobj*/,
  72. jlong jhandle) {
  73. auto* handle =
  74. reinterpret_cast<std::shared_ptr<ROCKSDB_NAMESPACE::StderrLogger>*>(
  75. jhandle);
  76. delete handle; // delete std::shared_ptr
  77. }