123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- /*
- * CLoggerBase.h, part of VCMI engine
- *
- * Authors: listed in file AUTHORS in main folder
- *
- * License: GNU General Public License v2.0 or later
- * Full text of license available in license.txt file, in main folder
- *
- */
- #pragma once
- namespace ELogLevel
- {
- enum ELogLevel
- {
- NOT_SET = 0,
- TRACE,
- DEBUG,
- INFO,
- WARN,
- ERROR
- };
- }
- namespace vstd
- {
- class DLL_LINKAGE CLoggerBase
- {
- public:
- virtual ~CLoggerBase(){};
- virtual void log(ELogLevel::ELogLevel level, const std::string & message) const = 0;
- template<typename T, typename ... Args>
- void log(ELogLevel::ELogLevel level, const std::string & format, T t, Args ... args)
- {
- boost::format fmt(format);
- makeFormat(fmt, t, args...);
- log(level, fmt.str());
- }
- /// Log methods for various log levels
- inline void error(const std::string & message) const
- {
- log(ELogLevel::ERROR, message);
- };
- template<typename T, typename ... Args>
- void error(const std::string & format, T t, Args ... args)
- {
- log(ELogLevel::ERROR, format, t, args...);
- }
- inline void warn(const std::string & message) const
- {
- log(ELogLevel::WARN, message);
- };
- template<typename T, typename ... Args>
- void warn(const std::string & format, T t, Args ... args)
- {
- log(ELogLevel::WARN, format, t, args...);
- }
- inline void info(const std::string & message) const
- {
- log(ELogLevel::INFO, message);
- };
- template<typename T, typename ... Args>
- void info(const std::string & format, T t, Args ... args)
- {
- log(ELogLevel::INFO, format, t, args...);
- }
- inline void debug(const std::string & message) const
- {
- log(ELogLevel::DEBUG, message);
- };
- template<typename T, typename ... Args>
- void debug(const std::string & format, T t, Args ... args)
- {
- log(ELogLevel::DEBUG, format, t, args...);
- }
- inline void trace(const std::string & message) const
- {
- log(ELogLevel::TRACE, message);
- };
- template<typename T, typename ... Args>
- void trace(const std::string & format, T t, Args ... args)
- {
- log(ELogLevel::TRACE, format, t, args...);
- }
- private:
- template <typename T>
- void makeFormat(boost::format & fmt, T t)
- {
- fmt % t;
- }
- template <typename T, typename ... Args>
- void makeFormat(boost::format & fmt, T t, Args ... args)
- {
- fmt % t;
- makeFormat(fmt, args...);
- }
- };
- }
|