LogFormat.h 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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. //TODO: Put into CLogger after log api extract
  28. template<typename Logger>
  29. void log(Logger * logger, ELogLevel::ELogLevel level, const std::string & message)
  30. {
  31. logger->log(level, message);
  32. }
  33. template<typename Logger, typename T, typename ... Args>
  34. void log(Logger * logger, ELogLevel::ELogLevel level, const std::string & format, T t, Args ... args)
  35. {
  36. boost::format fmt(format);
  37. detail::makeFormat(fmt, t, args...);
  38. logger->log(level, fmt.str());
  39. }
  40. template<typename Logger, typename T, typename ... Args>
  41. void logError(Logger * logger, const std::string & format, T t, Args ... args)
  42. {
  43. log(logger, ELogLevel::ERROR, format, t, args...);
  44. }
  45. template<typename Logger, typename T, typename ... Args>
  46. void logWarn(Logger * logger, const std::string & format, T t, Args ... args)
  47. {
  48. log(logger, ELogLevel::WARN, format, t, args...);
  49. }
  50. template<typename Logger, typename T, typename ... Args>
  51. void logInfo(Logger * logger, const std::string & format, T t, Args ... args)
  52. {
  53. log(logger, ELogLevel::INFO, format, t, args...);
  54. }
  55. template<typename Logger, typename T, typename ... Args>
  56. void logDebug(Logger * logger, const std::string & format, T t, Args ... args)
  57. {
  58. log(logger, ELogLevel::DEBUG, format, t, args...);
  59. }
  60. template<typename Logger, typename T, typename ... Args>
  61. void logTrace(Logger * logger, const std::string & format, T t, Args ... args)
  62. {
  63. log(logger, ELogLevel::TRACE, format, t, args...);
  64. }
  65. }