LogFormat.h 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. /*
  2. * CLogFormat.h, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #pragma once
  11. namespace vstd
  12. {
  13. namespace detail
  14. {
  15. template <typename T>
  16. void makeFormat(boost::format & fmt, T t)
  17. {
  18. fmt % t;
  19. }
  20. template <typename T, typename ... Args>
  21. void makeFormat(boost::format & fmt, T t, Args ... args)
  22. {
  23. fmt % t;
  24. makeFormat(fmt, args...);
  25. }
  26. }
  27. template<typename Logger, typename ... Args>
  28. void logFormat(Logger * logger, ELogLevel::ELogLevel level, const std::string & format, Args ... args)
  29. {
  30. boost::format fmt(format);
  31. detail::makeFormat(fmt, args...);
  32. logger->log(level, fmt.str());
  33. }
  34. template<typename Logger, typename ... Args>
  35. void logErrorFormat(Logger * logger, const std::string & format, Args ... args)
  36. {
  37. logFormat(logger, ELogLevel::ERROR, format, args...);
  38. }
  39. template<typename Logger, typename ... Args>
  40. void logWarnFormat(Logger * logger, const std::string & format, Args ... args)
  41. {
  42. logFormat(logger, ELogLevel::WARN, format, args...);
  43. }
  44. template<typename Logger, typename ... Args>
  45. void logInfoFormat(Logger * logger, const std::string & format, Args ... args)
  46. {
  47. logFormat(logger, ELogLevel::INFO, format, args...);
  48. }
  49. template<typename Logger, typename ... Args>
  50. void logDebugFormat(Logger * logger, const std::string & format, Args ... args)
  51. {
  52. logFormat(logger, ELogLevel::DEBUG, format, args...);
  53. }
  54. template<typename Logger, typename ... Args>
  55. void logTraceFormat(Logger * logger, const std::string & format, Args ... args)
  56. {
  57. logFormat(logger, ELogLevel::TRACE, format, args...);
  58. }
  59. }