default_logger_binding.cpp 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. //
  2. // logger_binding.cpp
  3. // logger
  4. //
  5. // Created by Sam Jaffe on 10/3/15.
  6. //
  7. //
  8. #include "default_logger_binding.hpp"
  9. #include <functional>
  10. #include <algorithm>
  11. namespace logging {
  12. namespace {
  13. void flush(appender & ptr) {
  14. ptr.flush();
  15. }
  16. void write(log_level level, std::string const& msg, appender & ptr) {
  17. ptr.write(level, msg);
  18. }
  19. }
  20. logger_impl& default_logger_impl::instance() {
  21. static default_logger_impl s;
  22. return s;
  23. }
  24. bool default_logger_impl::register_impl(const std::string &name, std::unique_ptr<logger_impl> (*factory)(const logging::properties &)) {
  25. return false; // TODO
  26. }
  27. void default_logger_impl::write(log_level level, std::string const& msg) {
  28. using namespace std::placeholders;
  29. std::for_each(streams_.begin(), streams_.end(),
  30. std::bind(logging::write, level, std::ref(msg), _1));
  31. }
  32. void default_logger_impl::flush() {
  33. std::for_each(streams_.begin(), streams_.end(), logging::flush);
  34. }
  35. _binding _default_logger_impl = &default_logger_impl::instance;
  36. }
  37. namespace logging {
  38. appender::appender(logger_impl* impl) : target_(impl) {}
  39. void appender::write(logging::log_level level, const std::string &msg) {
  40. target_->write(level, msg);
  41. }
  42. void appender::flush() {
  43. target_->flush();
  44. }
  45. }