stdout_sinks.h 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. // Copyright(c) 2015-present, Gabi Melman & spdlog contributors.
  2. // Distributed under the MIT License (http://opensource.org/licenses/MIT)
  3. #pragma once
  4. #include <cstdio>
  5. #include <spdlog/details/console_globals.h>
  6. #include <spdlog/details/synchronous_factory.h>
  7. #include <spdlog/sinks/sink.h>
  8. #ifdef _WIN32
  9. #include <spdlog/details/windows_include.h>
  10. #endif
  11. namespace spdlog {
  12. namespace sinks {
  13. template <typename ConsoleMutex>
  14. class stdout_sink_base : public sink {
  15. public:
  16. using mutex_t = typename ConsoleMutex::mutex_t;
  17. explicit stdout_sink_base(FILE *file);
  18. ~stdout_sink_base() override = default;
  19. stdout_sink_base(const stdout_sink_base &other) = delete;
  20. stdout_sink_base(stdout_sink_base &&other) = delete;
  21. stdout_sink_base &operator=(const stdout_sink_base &other) = delete;
  22. stdout_sink_base &operator=(stdout_sink_base &&other) = delete;
  23. void log(const details::log_msg &msg) override;
  24. void flush() override;
  25. void set_pattern(const std::string &pattern) override;
  26. void set_formatter(std::unique_ptr<spdlog::formatter> sink_formatter) override;
  27. protected:
  28. mutex_t &mutex_;
  29. FILE *file_;
  30. std::unique_ptr<spdlog::formatter> formatter_;
  31. #ifdef _WIN32
  32. HANDLE handle_;
  33. #endif // WIN32
  34. };
  35. template <typename ConsoleMutex>
  36. class stdout_sink : public stdout_sink_base<ConsoleMutex> {
  37. public:
  38. stdout_sink();
  39. };
  40. template <typename ConsoleMutex>
  41. class stderr_sink : public stdout_sink_base<ConsoleMutex> {
  42. public:
  43. stderr_sink();
  44. };
  45. using stdout_sink_mt = stdout_sink<details::console_mutex>;
  46. using stdout_sink_st = stdout_sink<details::console_nullmutex>;
  47. using stderr_sink_mt = stderr_sink<details::console_mutex>;
  48. using stderr_sink_st = stderr_sink<details::console_nullmutex>;
  49. } // namespace sinks
  50. // factory methods
  51. template <typename Factory = spdlog::synchronous_factory>
  52. std::shared_ptr<logger> stdout_logger_mt(const std::string &logger_name);
  53. template <typename Factory = spdlog::synchronous_factory>
  54. std::shared_ptr<logger> stdout_logger_st(const std::string &logger_name);
  55. template <typename Factory = spdlog::synchronous_factory>
  56. std::shared_ptr<logger> stderr_logger_mt(const std::string &logger_name);
  57. template <typename Factory = spdlog::synchronous_factory>
  58. std::shared_ptr<logger> stderr_logger_st(const std::string &logger_name);
  59. } // namespace spdlog
  60. #ifdef SPDLOG_HEADER_ONLY
  61. #include "stdout_sinks-inl.h"
  62. #endif