mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
614131ebe6
* implement make install set CMAKE_INSTALL_PREFIX e.g. to /opt to install to /opt/hyperion set ENABLE_SYSTEM_INSTALL to ON to activate installation after compiling use make install or make install/strip (for performance/size optimized binaries - compile in Release to get best performance) * cleanup cmake files use cmake -DINSTALL_PREFIX=/opt/hyperion .. to install all files to hyperion or cmake -DINSTALL_PREFIX=/usr/ to install to usr. install folders are linux standard. bin go to bin folder and additionals (effects) go to share/hyperion * add uninstall target - be patient with that, this will remove files from your system install service files to share/hyperion - if you want to use them you have to make a symlink to your location of service files * optimize build release script install service files into hyperion share folder (services not activated, this must be done by distribution package script) initial support of cmake option -DPLATFORM= option. This selects platform specific cmake flags. no need for -DENABLE_... options (unless you want some special things) automatic detect for apple build * update submodule * fix cmake error when no platform is given * initial support for deb,rpm and tgz packages - no usefull content atm! * make packeages contain usefull stuff * add license make packes more functional. package specific install missing yet * implement debian postinstall * disable rpm generation until it has a working state * add hypercon compat * add posibility for multiple config files. first one found is taken * remove hyperion comaptlayer services is not started automaticly * rework debian postinstall: - remove /opt compatibility complety. This makes more trouble as it is usefull - when hyperiond already started, restart it - cleanup * add deb package dependencies * wipe out last support for /opt installation * change default effect path in config to /usr * revert service files and config files * remove last occurences of ENABLE_PROTOBUF fix cmake warnings and make it ready for cmake 3 fix refactoring of hyperiond.cpp creates no objects for network services * all arguments via reference ... * fix xbmcchecker not working * add logger class * - profiler must be activated with ENABLE_PROFILER, otherwise an error will raise -> this should prevent profiler gets into release code * fix profiler * make logger compat with older/partial c++11 versions (r.g. debian wheezy) fix description of optionparser fix atmoorb not compile for qt4. now it should compile for qt5 and 4 * make logger compiles with qt5 too fix compiler warnings * remove debug code Former-commit-id: 6aa41351667caed712b1f28010dbedfca8a6a5a0
102 lines
2.4 KiB
C++
102 lines
2.4 KiB
C++
#include "utils/Logger.h"
|
|
|
|
#include <iostream>
|
|
#include <algorithm>
|
|
#include <syslog.h>
|
|
#include <map>
|
|
#include <QFileInfo>
|
|
#include <QString>
|
|
|
|
std::string getBaseName( std::string sourceFile)
|
|
{
|
|
QFileInfo fi( sourceFile.c_str() );
|
|
return fi.fileName().toStdString();
|
|
}
|
|
|
|
static const char * LogLevelStrings[] = { "DEBUG", "INFO", "WARNING", "ERROR" };
|
|
static const int LogLevelSysLog[] = { LOG_DEBUG, LOG_INFO, LOG_WARNING, LOG_ERR };
|
|
static unsigned int loggerCount = 0;
|
|
static unsigned int loggerId = 0;
|
|
std::map<std::string,Logger*> *Logger::LoggerMap = nullptr;
|
|
|
|
|
|
Logger* Logger::getInstance(std::string name, Logger::LogLevel minLevel)
|
|
{
|
|
if (Logger::LoggerMap == nullptr)
|
|
{
|
|
Logger::LoggerMap = new std::map<std::string,Logger*>;
|
|
}
|
|
|
|
if ( LoggerMap->find(name) == LoggerMap->end() )
|
|
{
|
|
Logger* log = new Logger(name,minLevel);
|
|
Logger::LoggerMap->insert(std::pair<std::string,Logger*>(name,log)); // compat version, replace it with following line if we have 100% c++11
|
|
//Logger::LoggerMap->emplace(name,log); // not compat with older linux distro's e.g. wheezy
|
|
return log;
|
|
}
|
|
|
|
return Logger::LoggerMap->at(name);
|
|
}
|
|
|
|
|
|
|
|
Logger::Logger ( std::string name, LogLevel minLevel ):
|
|
_name(name),
|
|
_minLevel(minLevel),
|
|
_syslogEnabled(true),
|
|
_loggerId(loggerId++)
|
|
{
|
|
_appname = std::string(program_invocation_short_name);
|
|
std::transform(_appname.begin(), _appname.end(),_appname.begin(), ::toupper);
|
|
|
|
loggerCount++;
|
|
|
|
// if (pLoggerMap == NULL)
|
|
// pLoggerMap = new std::map<unsigned int,Logger*>;
|
|
//
|
|
//
|
|
|
|
if (_syslogEnabled && loggerCount == 1 )
|
|
{
|
|
openlog (program_invocation_short_name, LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL0);
|
|
}
|
|
}
|
|
|
|
Logger::~Logger()
|
|
{
|
|
//LoggerMap.erase(_loggerId);
|
|
loggerCount--;
|
|
if ( loggerCount == 0 )
|
|
closelog();
|
|
}
|
|
|
|
|
|
void Logger::Message(LogLevel level, const char* sourceFile, const char* func, unsigned int line, const char* fmt, ...)
|
|
{
|
|
if ( level < _minLevel )
|
|
return;
|
|
|
|
char msg[512];
|
|
va_list args;
|
|
va_start (args, fmt);
|
|
vsprintf (msg,fmt, args);
|
|
va_end (args);
|
|
|
|
std::string location;
|
|
std::string function(func);
|
|
if ( level == Logger::DEBUG )
|
|
{
|
|
location = "<" + getBaseName(sourceFile) + ":" + QString::number(line).toStdString()+":"+ function + "()> ";
|
|
}
|
|
|
|
std::cout
|
|
<< "[" << _appname << " " << _name << "] <"
|
|
<< LogLevelStrings[level] << "> " << location << msg
|
|
<< std::endl;
|
|
|
|
if ( _syslogEnabled && level >= Logger::WARNING )
|
|
syslog (LogLevelSysLog[level], "%s", msg);
|
|
}
|
|
|
|
|