1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
/*!
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/.
*
* Copyright(c) 2009 Apogee Instruments, Inc.
* \class ApgLogger
* \brief Singleton logging class for the apg library.
*
*/
#include "ApgLogger.h"
#ifdef WIN_OS
#include "windozeHelpers.h"
#include "LoggerWin.h"
#else
#include "linux/LoggerSyslog.h"
#endif
////////////////////////////
// CTOR
ApgLogger::ApgLogger() : m_level( ApgLogger::LEVEL_RELEASE )
{
#ifdef WIN_OS
m_theLogger = std::shared_ptr<ILog>( new LoggerWin );
#else
m_theLogger = std::shared_ptr<ILog>( new LoggerSyslog );
#endif
//TODO figure out how to read ini or another file
//to set the logging level
}
////////////////////////////
// DTOR
ApgLogger::~ApgLogger()
{
}
////////////////////////////
// WRITE
void ApgLogger::Write(ApgLogger::Level level,
const std::string & type, const std::string & msg)
{
if( level <= m_level )
{
std::string libapgStr ( "libapogee:" );
if( 0 == msg.compare( 0, libapgStr.size(), libapgStr ) )
{
m_theLogger->Write(type,msg);
}
else
{
libapgStr.append( msg );
m_theLogger->Write(type,libapgStr);
}
}
}
////////////////////////////
// IsLevelVerbose
bool ApgLogger::IsLevelVerbose()
{
return ( ApgLogger::LEVEL_VERBOSE == m_level ? true : false) ;
}
|