You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
83 lines
2.1 KiB
83 lines
2.1 KiB
#include "Logger.hpp"
|
|
|
|
#include <time.h> //time
|
|
#include "Colors.hpp"
|
|
|
|
#include "Common.hpp"
|
|
|
|
|
|
void Logger::init(std::ostream& log_stream )
|
|
{
|
|
m_ostream = &log_stream;
|
|
}
|
|
|
|
|
|
void Logger::setLogLevel ( const LogLevel loglevel )
|
|
{
|
|
m_logLevel = loglevel;
|
|
}
|
|
|
|
|
|
void Logger::usePrefix( const bool use )
|
|
{
|
|
m_usePrefix = use;
|
|
}
|
|
|
|
|
|
void Logger::log_pointer( const void* pointer,
|
|
const char* file,
|
|
const int line,
|
|
const char* function)
|
|
{
|
|
if ( !m_usePrefix ) {
|
|
*m_ostream << pointer << std::endl;
|
|
return;
|
|
}
|
|
|
|
*m_ostream << getTime() << " "
|
|
<< COLOR( FG_GREEN ) << extractFilename(file)
|
|
<< COLOR_RESET << ":"
|
|
<< COLOR( FG_BROWN ) << line << COLOR_RESET << " "
|
|
<< COLOR( FG_CYAN ) << function << COLOR_RESET << " "
|
|
<< COLOR( FG_BLUE ) << pointer
|
|
<< COLOR_RESET << std::endl;
|
|
}
|
|
|
|
|
|
void Logger::log_string( const int level,
|
|
const void* pointer,
|
|
const char* msg,
|
|
const char* file,
|
|
const int line,
|
|
const char* function)
|
|
{
|
|
if ( !m_usePrefix ) {
|
|
*m_ostream << msg << std::endl;
|
|
return;
|
|
}
|
|
|
|
const char *color;
|
|
if ( level <= WARNING ) { color = COLOR_F_FG( F_BOLD, FG_RED ); }
|
|
else if ( level <= INFO ) { color = COLOR_F_FG( F_BOLD, FG_WHITE); }
|
|
else { color = COLOR_F_FG( F_BOLD, FG_BROWN); }
|
|
|
|
*m_ostream << getTime() << " "
|
|
<< COLOR( FG_GREEN ) << extractFilename(file)
|
|
<< COLOR_RESET << ":"
|
|
<< COLOR( FG_BROWN ) << line << COLOR_RESET << " "
|
|
<< COLOR( FG_CYAN ) << function << COLOR_RESET << " "
|
|
<< color << "\"" << msg << "\" "
|
|
<< COLOR( FG_BLUE ) << pointer
|
|
<< COLOR_RESET << std::endl;
|
|
}
|
|
|
|
void Logger::msg(const char* text)
|
|
{
|
|
*m_ostream << COLOR_F( F_BOLD) << text << COLOR_RESET << std::endl;
|
|
}
|
|
|
|
|
|
Logger::LogLevel Logger::m_logLevel = Logger::FINEST;
|
|
std::ostream* Logger::m_ostream = 0;
|
|
bool Logger::m_usePrefix = true;
|