诸暨麻将添加redis
25개 이상의 토픽을 선택하실 수 없습니다. Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

375 lines
11 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. // Thread safe logger (except for set_error_handler())
  5. // Has name, log level, vector of std::shared sink pointers and formatter
  6. // Upon each log write the logger:
  7. // 1. Checks if its log level is enough to log the message and if yes:
  8. // 2. Call the underlying sinks to do the job.
  9. // 3. Each sink use its own private copy of a formatter to format the message
  10. // and send to its destination.
  11. //
  12. // The use of private formatter per sink provides the opportunity to cache some
  13. // formatted data, and support for different format per sink.
  14. #include <spdlog/common.h>
  15. #include <spdlog/details/log_msg.h>
  16. #include <spdlog/details/backtracer.h>
  17. #ifdef SPDLOG_WCHAR_TO_UTF8_SUPPORT
  18. #include <spdlog/details/os.h>
  19. #endif
  20. #include <vector>
  21. #ifndef SPDLOG_NO_EXCEPTIONS
  22. #define SPDLOG_LOGGER_CATCH() \
  23. catch (const std::exception &ex) \
  24. { \
  25. err_handler_(ex.what()); \
  26. } \
  27. catch (...) \
  28. { \
  29. err_handler_("Unknown exception in logger"); \
  30. }
  31. #else
  32. #define SPDLOG_LOGGER_CATCH()
  33. #endif
  34. namespace spdlog {
  35. class logger
  36. {
  37. public:
  38. // Empty logger
  39. explicit logger(std::string name)
  40. : name_(std::move(name))
  41. , sinks_()
  42. {}
  43. // Logger with range on sinks
  44. template<typename It>
  45. logger(std::string name, It begin, It end)
  46. : name_(std::move(name))
  47. , sinks_(begin, end)
  48. {}
  49. // Logger with single sink
  50. logger(std::string name, sink_ptr single_sink)
  51. : logger(std::move(name), {std::move(single_sink)})
  52. {}
  53. // Logger with sinks init list
  54. logger(std::string name, sinks_init_list sinks)
  55. : logger(std::move(name), sinks.begin(), sinks.end())
  56. {}
  57. virtual ~logger() = default;
  58. logger(const logger &other);
  59. logger(logger &&other) SPDLOG_NOEXCEPT;
  60. logger &operator=(logger other) SPDLOG_NOEXCEPT;
  61. void swap(spdlog::logger &other) SPDLOG_NOEXCEPT;
  62. template<typename... Args>
  63. void log(source_loc loc, level::level_enum lvl, string_view_t fmt, const Args &... args)
  64. {
  65. bool log_enabled = should_log(lvl);
  66. bool traceback_enabled = tracer_.enabled();
  67. if (!log_enabled && !traceback_enabled)
  68. {
  69. return;
  70. }
  71. SPDLOG_TRY
  72. {
  73. memory_buf_t buf;
  74. fmt::format_to(buf, fmt, args...);
  75. details::log_msg log_msg(loc, name_, lvl, string_view_t(buf.data(), buf.size()));
  76. log_it_(log_msg, log_enabled, traceback_enabled);
  77. }
  78. SPDLOG_LOGGER_CATCH()
  79. }
  80. template<typename... Args>
  81. void log(level::level_enum lvl, string_view_t fmt, const Args &... args)
  82. {
  83. log(source_loc{}, lvl, fmt, args...);
  84. }
  85. template<typename... Args>
  86. void trace(string_view_t fmt, const Args &... args)
  87. {
  88. log(level::trace, fmt, args...);
  89. }
  90. template<typename... Args>
  91. void debug(string_view_t fmt, const Args &... args)
  92. {
  93. log(level::debug, fmt, args...);
  94. }
  95. template<typename... Args>
  96. void info(string_view_t fmt, const Args &... args)
  97. {
  98. log(level::info, fmt, args...);
  99. }
  100. template<typename... Args>
  101. void warn(string_view_t fmt, const Args &... args)
  102. {
  103. log(level::warn, fmt, args...);
  104. }
  105. template<typename... Args>
  106. void error(string_view_t fmt, const Args &... args)
  107. {
  108. log(level::err, fmt, args...);
  109. }
  110. template<typename... Args>
  111. void critical(string_view_t fmt, const Args &... args)
  112. {
  113. log(level::critical, fmt, args...);
  114. }
  115. template<typename T>
  116. void log(level::level_enum lvl, const T &msg)
  117. {
  118. log(source_loc{}, lvl, msg);
  119. }
  120. // T can be statically converted to string_view
  121. template<class T, typename std::enable_if<std::is_convertible<const T &, spdlog::string_view_t>::value, T>::type * = nullptr>
  122. void log(source_loc loc, level::level_enum lvl, const T &msg)
  123. {
  124. bool log_enabled = should_log(lvl);
  125. bool traceback_enabled = tracer_.enabled();
  126. if (!log_enabled && !traceback_enabled)
  127. {
  128. return;
  129. }
  130. details::log_msg log_msg(loc, name_, lvl, msg);
  131. log_it_(log_msg, log_enabled, traceback_enabled);
  132. }
  133. void log(level::level_enum lvl, string_view_t msg)
  134. {
  135. log(source_loc{}, lvl, msg);
  136. }
  137. // T cannot be statically converted to string_view or wstring_view
  138. template<class T, typename std::enable_if<!std::is_convertible<const T &, spdlog::string_view_t>::value &&
  139. !is_convertible_to_wstring_view<const T &>::value,
  140. T>::type * = nullptr>
  141. void log(source_loc loc, level::level_enum lvl, const T &msg)
  142. {
  143. log(loc, lvl, "{}", msg);
  144. }
  145. template<typename T>
  146. void trace(const T &msg)
  147. {
  148. log(level::trace, msg);
  149. }
  150. template<typename T>
  151. void debug(const T &msg)
  152. {
  153. log(level::debug, msg);
  154. }
  155. template<typename T>
  156. void info(const T &msg)
  157. {
  158. log(level::info, msg);
  159. }
  160. template<typename T>
  161. void warn(const T &msg)
  162. {
  163. log(level::warn, msg);
  164. }
  165. template<typename T>
  166. void error(const T &msg)
  167. {
  168. log(level::err, msg);
  169. }
  170. template<typename T>
  171. void critical(const T &msg)
  172. {
  173. log(level::critical, msg);
  174. }
  175. #ifdef SPDLOG_WCHAR_TO_UTF8_SUPPORT
  176. #ifndef _WIN32
  177. #error SPDLOG_WCHAR_TO_UTF8_SUPPORT only supported on windows
  178. #else
  179. template<typename... Args>
  180. void log(source_loc loc, level::level_enum lvl, wstring_view_t fmt, const Args &... args)
  181. {
  182. bool log_enabled = should_log(lvl);
  183. bool traceback_enabled = tracer_.enabled();
  184. if (!log_enabled && !traceback_enabled)
  185. {
  186. return;
  187. }
  188. SPDLOG_TRY
  189. {
  190. // format to wmemory_buffer and convert to utf8
  191. fmt::wmemory_buffer wbuf;
  192. fmt::format_to(wbuf, fmt, args...);
  193. memory_buf_t buf;
  194. details::os::wstr_to_utf8buf(wstring_view_t(wbuf.data(), wbuf.size()), buf);
  195. details::log_msg log_msg(loc, name_, lvl, string_view_t(buf.data(), buf.size()));
  196. log_it_(log_msg, log_enabled, traceback_enabled);
  197. }
  198. SPDLOG_LOGGER_CATCH()
  199. }
  200. template<typename... Args>
  201. void log(level::level_enum lvl, wstring_view_t fmt, const Args &... args)
  202. {
  203. log(source_loc{}, lvl, fmt, args...);
  204. }
  205. template<typename... Args>
  206. void trace(wstring_view_t fmt, const Args &... args)
  207. {
  208. log(level::trace, fmt, args...);
  209. }
  210. template<typename... Args>
  211. void debug(wstring_view_t fmt, const Args &... args)
  212. {
  213. log(level::debug, fmt, args...);
  214. }
  215. template<typename... Args>
  216. void info(wstring_view_t fmt, const Args &... args)
  217. {
  218. log(level::info, fmt, args...);
  219. }
  220. template<typename... Args>
  221. void warn(wstring_view_t fmt, const Args &... args)
  222. {
  223. log(level::warn, fmt, args...);
  224. }
  225. template<typename... Args>
  226. void error(wstring_view_t fmt, const Args &... args)
  227. {
  228. log(level::err, fmt, args...);
  229. }
  230. template<typename... Args>
  231. void critical(wstring_view_t fmt, const Args &... args)
  232. {
  233. log(level::critical, fmt, args...);
  234. }
  235. // T can be statically converted to wstring_view
  236. template<class T, typename std::enable_if<is_convertible_to_wstring_view<const T &>::value, T>::type * = nullptr>
  237. void log(source_loc loc, level::level_enum lvl, const T &msg)
  238. {
  239. bool log_enabled = should_log(lvl);
  240. bool traceback_enabled = tracer_.enabled();
  241. if (!log_enabled && !traceback_enabled)
  242. {
  243. return;
  244. }
  245. SPDLOG_TRY
  246. {
  247. memory_buf_t buf;
  248. details::os::wstr_to_utf8buf(msg, buf);
  249. details::log_msg log_msg(loc, name_, lvl, string_view_t(buf.data(), buf.size()));
  250. log_it_(log_msg, log_enabled, traceback_enabled);
  251. }
  252. SPDLOG_LOGGER_CATCH()
  253. }
  254. #endif // _WIN32
  255. #endif // SPDLOG_WCHAR_TO_UTF8_SUPPORT
  256. // return true logging is enabled for the given level.
  257. bool should_log(level::level_enum msg_level) const
  258. {
  259. return msg_level >= level_.load(std::memory_order_relaxed);
  260. }
  261. // return true if backtrace logging is enabled.
  262. bool should_backtrace() const
  263. {
  264. return tracer_.enabled();
  265. }
  266. void set_level(level::level_enum log_level);
  267. level::level_enum level() const;
  268. const std::string &name() const;
  269. // set formatting for the sinks in this logger.
  270. // each sink will get a separate instance of the formatter object.
  271. void set_formatter(std::unique_ptr<formatter> f);
  272. void set_pattern(std::string pattern, pattern_time_type time_type = pattern_time_type::local);
  273. // backtrace support.
  274. // efficiently store all debug/trace messages in a circular buffer until needed for debugging.
  275. void enable_backtrace(size_t n_messages);
  276. void disable_backtrace();
  277. void dump_backtrace();
  278. // flush functions
  279. void flush();
  280. void flush_on(level::level_enum log_level);
  281. level::level_enum flush_level() const;
  282. // sinks
  283. const std::vector<sink_ptr> &sinks() const;
  284. std::vector<sink_ptr> &sinks();
  285. // error handler
  286. void set_error_handler(err_handler);
  287. // create new logger with same sinks and configuration.
  288. virtual std::shared_ptr<logger> clone(std::string logger_name);
  289. protected:
  290. std::string name_;
  291. std::vector<sink_ptr> sinks_;
  292. spdlog::level_t level_{level::info};
  293. spdlog::level_t flush_level_{level::off};
  294. err_handler custom_err_handler_{nullptr};
  295. details::backtracer tracer_;
  296. // log the given message (if the given log level is high enough),
  297. // and save backtrace (if backtrace is enabled).
  298. void log_it_(const details::log_msg &log_msg, bool log_enabled, bool traceback_enabled);
  299. virtual void sink_it_(const details::log_msg &msg);
  300. virtual void flush_();
  301. void dump_backtrace_();
  302. bool should_flush_(const details::log_msg &msg);
  303. // handle errors during logging.
  304. // default handler prints the error to stderr at max rate of 1 message/sec.
  305. void err_handler_(const std::string &msg);
  306. };
  307. void swap(logger &a, logger &b);
  308. } // namespace spdlog
  309. #ifdef SPDLOG_HEADER_ONLY
  310. #include "logger-inl.h"
  311. #endif