base_sink-inl.h 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. // Copyright(c) 2015-present, Gabi Melman & spdlog contributors.
  2. // Distributed under the MIT License (http://opensource.org/licenses/MIT)
  3. #pragma once
  4. #ifndef SPDLOG_HEADER_ONLY
  5. # include <spdlog/sinks/base_sink.h>
  6. #endif
  7. #include <spdlog/common.h>
  8. #include <spdlog/pattern_formatter.h>
  9. #include <memory>
  10. template<typename Mutex>
  11. SPDLOG_INLINE spdlog::sinks::base_sink<Mutex>::base_sink()
  12. : formatter_{details::make_unique<spdlog::pattern_formatter>()}
  13. {}
  14. template<typename Mutex>
  15. SPDLOG_INLINE spdlog::sinks::base_sink<Mutex>::base_sink(std::unique_ptr<spdlog::formatter> formatter)
  16. : formatter_{std::move(formatter)}
  17. {}
  18. template<typename Mutex>
  19. void SPDLOG_INLINE spdlog::sinks::base_sink<Mutex>::log(const details::log_msg &msg)
  20. {
  21. std::lock_guard<Mutex> lock(mutex_);
  22. sink_it_(msg);
  23. }
  24. template<typename Mutex>
  25. void SPDLOG_INLINE spdlog::sinks::base_sink<Mutex>::flush()
  26. {
  27. std::lock_guard<Mutex> lock(mutex_);
  28. flush_();
  29. }
  30. template<typename Mutex>
  31. void SPDLOG_INLINE spdlog::sinks::base_sink<Mutex>::set_pattern(const std::string &pattern)
  32. {
  33. std::lock_guard<Mutex> lock(mutex_);
  34. set_pattern_(pattern);
  35. }
  36. template<typename Mutex>
  37. void SPDLOG_INLINE spdlog::sinks::base_sink<Mutex>::set_formatter(std::unique_ptr<spdlog::formatter> sink_formatter)
  38. {
  39. std::lock_guard<Mutex> lock(mutex_);
  40. set_formatter_(std::move(sink_formatter));
  41. }
  42. template<typename Mutex>
  43. void SPDLOG_INLINE spdlog::sinks::base_sink<Mutex>::set_pattern_(const std::string &pattern)
  44. {
  45. set_formatter_(details::make_unique<spdlog::pattern_formatter>(pattern));
  46. }
  47. template<typename Mutex>
  48. void SPDLOG_INLINE spdlog::sinks::base_sink<Mutex>::set_formatter_(std::unique_ptr<spdlog::formatter> sink_formatter)
  49. {
  50. formatter_ = std::move(sink_formatter);
  51. }