2014-10-14 13:11:37 +00:00
|
|
|
|
/*
|
|
|
|
|
* This file is part of the Colobot: Gold Edition source code
|
|
|
|
|
* Copyright (C) 2001-2014, Daniel Roux, EPSITEC SA & TerranovaTeam
|
|
|
|
|
* http://epsiteс.ch; http://colobot.info; http://github.com/colobot
|
|
|
|
|
*
|
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
|
* (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
|
* See the GNU General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
|
* along with this program. If not, see http://gnu.org/licenses
|
|
|
|
|
*/
|
2012-07-04 16:04:34 +00:00
|
|
|
|
|
2012-09-09 15:51:10 +00:00
|
|
|
|
/**
|
|
|
|
|
* \file common/logger.h
|
|
|
|
|
* \brief Class for logging information to file or console
|
|
|
|
|
*/
|
2012-07-04 16:04:34 +00:00
|
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
2012-10-17 19:55:45 +00:00
|
|
|
|
|
2012-09-09 15:51:10 +00:00
|
|
|
|
#include "common/singleton.h"
|
|
|
|
|
|
2012-07-04 16:04:34 +00:00
|
|
|
|
#include <string>
|
|
|
|
|
#include <cstdarg>
|
2012-07-04 18:03:17 +00:00
|
|
|
|
#include <cstdio>
|
2012-07-04 16:04:34 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* \public
|
2013-03-10 14:44:21 +00:00
|
|
|
|
* \enum LogLevel common/logger.h
|
2012-07-04 16:04:34 +00:00
|
|
|
|
* \brief Enum representing log level
|
|
|
|
|
**/
|
2013-03-10 14:44:21 +00:00
|
|
|
|
enum LogLevel
|
2012-07-04 16:04:34 +00:00
|
|
|
|
{
|
2012-08-12 17:28:22 +00:00
|
|
|
|
LOG_TRACE = 1, /*!< lowest level, execution tracing */
|
|
|
|
|
LOG_DEBUG = 2, /*!< debugging messages */
|
|
|
|
|
LOG_INFO = 3, /*!< information */
|
|
|
|
|
LOG_WARN = 4, /*!< warning */
|
|
|
|
|
LOG_ERROR = 5, /*!< error */
|
|
|
|
|
LOG_NONE = 6 /*!< none level, used for custom messages */
|
2012-07-04 16:04:34 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @class CLogger
|
|
|
|
|
*
|
|
|
|
|
* @brief Class for loggin information to file or console
|
|
|
|
|
*
|
2012-07-27 16:44:43 +00:00
|
|
|
|
*/
|
2012-07-04 16:04:34 +00:00
|
|
|
|
class CLogger : public CSingleton<CLogger>
|
|
|
|
|
{
|
2013-03-10 14:44:21 +00:00
|
|
|
|
public:
|
|
|
|
|
CLogger();
|
|
|
|
|
~CLogger();
|
|
|
|
|
|
|
|
|
|
/** Write message to console or file
|
|
|
|
|
* \param str - message to write
|
|
|
|
|
* \param ... - additional arguments
|
|
|
|
|
*/
|
|
|
|
|
void Message(const char *str, ...);
|
|
|
|
|
|
|
|
|
|
/** Write message to console or file with LOG_TRACE level
|
|
|
|
|
* \param str - message to write
|
|
|
|
|
* \param ... - additional arguments
|
|
|
|
|
*/
|
|
|
|
|
void Trace(const char *str, ...);
|
|
|
|
|
|
|
|
|
|
/** Write message to console or file with LOG_DEBUG level
|
|
|
|
|
* \param str - message to write
|
|
|
|
|
* \param ... - additional arguments
|
|
|
|
|
*/
|
|
|
|
|
void Debug(const char *str, ...);
|
|
|
|
|
|
|
|
|
|
/** Write message to console or file with LOG_INFO level
|
|
|
|
|
* \param str - message to write
|
|
|
|
|
* \param ... - additional arguments
|
|
|
|
|
*/
|
|
|
|
|
void Info(const char *str, ...);
|
|
|
|
|
|
|
|
|
|
/** Write message to console or file with LOG_WARN level
|
|
|
|
|
* \param str - message to write
|
|
|
|
|
* \param ... - additional arguments
|
|
|
|
|
*/
|
|
|
|
|
void Warn(const char *str, ...);
|
|
|
|
|
|
|
|
|
|
/** Write message to console or file with LOG_ERROR level
|
|
|
|
|
* \param str - message to write
|
|
|
|
|
* \param ... - additional arguments
|
|
|
|
|
*/
|
|
|
|
|
void Error(const char *str, ...);
|
|
|
|
|
|
|
|
|
|
/** Set output file to write logs to
|
|
|
|
|
* \param filename - output file to write to
|
|
|
|
|
*/
|
|
|
|
|
void SetOutputFile(std::string filename);
|
|
|
|
|
|
|
|
|
|
/** Set log level. Logs with level below will not be shown
|
|
|
|
|
* \param level - minimum log level to write
|
|
|
|
|
*/
|
|
|
|
|
void SetLogLevel(LogLevel level);
|
|
|
|
|
|
|
|
|
|
/** Parses string as a log level
|
|
|
|
|
* \param str string to parse
|
|
|
|
|
* \param logLevel result log level
|
|
|
|
|
*
|
|
|
|
|
* Valid values are "trace", "debug", "info", "warn", "error" and "none".
|
|
|
|
|
* On invalid value, returns \c false.
|
|
|
|
|
*/
|
|
|
|
|
static bool ParseLogLevel(const std::string& str, LogLevel& logLevel);
|
|
|
|
|
|
|
|
|
|
private:
|
2013-05-26 17:34:05 +00:00
|
|
|
|
std::string m_filename;
|
|
|
|
|
FILE *m_file;
|
|
|
|
|
LogLevel m_logLevel;
|
2013-03-10 14:44:21 +00:00
|
|
|
|
|
|
|
|
|
void Open();
|
|
|
|
|
void Close();
|
|
|
|
|
bool IsOpened();
|
|
|
|
|
void Log(LogLevel type, const char* str, va_list args);
|
2012-07-04 16:04:34 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//! Global function to get Logger instance
|
2013-05-26 15:47:54 +00:00
|
|
|
|
inline CLogger* GetLogger()
|
|
|
|
|
{
|
2015-07-16 20:26:48 +00:00
|
|
|
|
return CLogger::GetInstancePointer();
|
2012-07-04 16:04:34 +00:00
|
|
|
|
}
|