2016-08-14 23:45:42 +00:00
|
|
|
//
|
|
|
|
// Created by koncord on 15.08.16.
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef OPENMW_LOG_HPP
|
|
|
|
#define OPENMW_LOG_HPP
|
|
|
|
|
|
|
|
#if defined(NOLOGS)
|
|
|
|
#define LOG_INIT(logLevel)
|
|
|
|
#define LOG_QUIT()
|
|
|
|
#define LOG_MESSAGE(level, msg, ...)
|
|
|
|
#define LOG_MESSAGE_SIMPLE(level, msg, ...)
|
|
|
|
#else
|
|
|
|
#define LOG_INIT(logLevel) Log::Create(logLevel)
|
|
|
|
#define LOG_QUIT() Log::Delete()
|
|
|
|
#define LOG_MESSAGE(level, msg, ...) Log::Get().print((level), (__FILE__), (__LINE__), (msg), __VA_ARGS__)
|
|
|
|
#define LOG_MESSAGE_SIMPLE(level, msg, ...) Log::Get().print((level), (0), (0), (msg), __VA_ARGS__)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
class Log
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
enum
|
|
|
|
{
|
2016-08-17 23:57:11 +00:00
|
|
|
LOG_VERBOSE = 0,
|
|
|
|
LOG_INFO,
|
2016-08-15 13:33:18 +00:00
|
|
|
LOG_WARN,
|
|
|
|
LOG_ERROR,
|
2016-08-17 23:57:11 +00:00
|
|
|
LOG_FATAL
|
2016-08-14 23:45:42 +00:00
|
|
|
};
|
|
|
|
static void Create(int logLevel);
|
|
|
|
static void Delete();
|
|
|
|
static const Log &Get();
|
2016-08-17 23:57:11 +00:00
|
|
|
static void SetLevel(int level);
|
2016-08-14 23:45:42 +00:00
|
|
|
void print(int level, const char *file, int line, const char *message, ...) const;
|
|
|
|
private:
|
|
|
|
Log(int logLevel);
|
2016-08-15 13:45:49 +00:00
|
|
|
/// Not implemented
|
|
|
|
Log( const Log& );
|
|
|
|
/// Not implemented
|
|
|
|
Log& operator=(Log& );
|
|
|
|
static Log *sLog;
|
2016-08-14 23:45:42 +00:00
|
|
|
int logLevel;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#endif //OPENMW_LOG_HPP
|