诸暨麻将添加redis
25'ten fazla konu seçemezsiniz Konular bir harf veya rakamla başlamalı, kısa çizgiler ('-') içerebilir ve en fazla 35 karakter uzunluğunda olabilir.
 
 
 
 
 
 

119 satır
3.3 KiB

  1. // Copyright(c) 2015-present, Gabi Melman & spdlog contributors.
  2. // Distributed under the MIT License (http://opensource.org/licenses/MIT)
  3. #pragma once
  4. #ifdef __ANDROID__
  5. #include <spdlog/details/fmt_helper.h>
  6. #include <spdlog/details/null_mutex.h>
  7. #include <spdlog/details/os.h>
  8. #include <spdlog/sinks/base_sink.h>
  9. #include <spdlog/details/synchronous_factory.h>
  10. #include <android/log.h>
  11. #include <chrono>
  12. #include <mutex>
  13. #include <string>
  14. #include <thread>
  15. #if !defined(SPDLOG_ANDROID_RETRIES)
  16. #define SPDLOG_ANDROID_RETRIES 2
  17. #endif
  18. namespace spdlog {
  19. namespace sinks {
  20. /*
  21. * Android sink (logging using __android_log_write)
  22. */
  23. template<typename Mutex>
  24. class android_sink final : public base_sink<Mutex>
  25. {
  26. public:
  27. explicit android_sink(std::string tag = "spdlog", bool use_raw_msg = false)
  28. : tag_(std::move(tag))
  29. , use_raw_msg_(use_raw_msg)
  30. {}
  31. protected:
  32. void sink_it_(const details::log_msg &msg) override
  33. {
  34. const android_LogPriority priority = convert_to_android_(msg.level);
  35. memory_buf_t formatted;
  36. if (use_raw_msg_)
  37. {
  38. details::fmt_helper::append_string_view(msg.payload, formatted);
  39. }
  40. else
  41. {
  42. base_sink<Mutex>::formatter_->format(msg, formatted);
  43. }
  44. formatted.push_back('\0');
  45. const char *msg_output = formatted.data();
  46. // See system/core/liblog/logger_write.c for explanation of return value
  47. int ret = __android_log_write(priority, tag_.c_str(), msg_output);
  48. int retry_count = 0;
  49. while ((ret == -11 /*EAGAIN*/) && (retry_count < SPDLOG_ANDROID_RETRIES))
  50. {
  51. details::os::sleep_for_millis(5);
  52. ret = __android_log_write(priority, tag_.c_str(), msg_output);
  53. retry_count++;
  54. }
  55. if (ret < 0)
  56. {
  57. SPDLOG_THROW(spdlog_ex("__android_log_write() failed", ret));
  58. }
  59. }
  60. void flush_() override {}
  61. private:
  62. static android_LogPriority convert_to_android_(spdlog::level::level_enum level)
  63. {
  64. switch (level)
  65. {
  66. case spdlog::level::trace:
  67. return ANDROID_LOG_VERBOSE;
  68. case spdlog::level::debug:
  69. return ANDROID_LOG_DEBUG;
  70. case spdlog::level::info:
  71. return ANDROID_LOG_INFO;
  72. case spdlog::level::warn:
  73. return ANDROID_LOG_WARN;
  74. case spdlog::level::err:
  75. return ANDROID_LOG_ERROR;
  76. case spdlog::level::critical:
  77. return ANDROID_LOG_FATAL;
  78. default:
  79. return ANDROID_LOG_DEFAULT;
  80. }
  81. }
  82. std::string tag_;
  83. bool use_raw_msg_;
  84. };
  85. using android_sink_mt = android_sink<std::mutex>;
  86. using android_sink_st = android_sink<details::null_mutex>;
  87. } // namespace sinks
  88. // Create and register android syslog logger
  89. template<typename Factory = spdlog::synchronous_factory>
  90. inline std::shared_ptr<logger> android_logger_mt(const std::string &logger_name, const std::string &tag = "spdlog")
  91. {
  92. return Factory::template create<sinks::android_sink_mt>(logger_name, tag);
  93. }
  94. template<typename Factory = spdlog::synchronous_factory>
  95. inline std::shared_ptr<logger> android_logger_st(const std::string &logger_name, const std::string &tag = "spdlog")
  96. {
  97. return Factory::template create<sinks::android_sink_st>(logger_name, tag);
  98. }
  99. } // namespace spdlog
  100. #endif // __ANDROID__