/*
-----------------------------------------------------------------------
Copyright: 2010-2016, iMinds-Vision Lab, University of Antwerp
2014-2016, CWI, Amsterdam
Contact: astra@uantwerpen.be
Website: http://www.astra-toolbox.com/
This file is part of the ASTRA Toolbox.
The ASTRA Toolbox 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.
The ASTRA Toolbox 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 the ASTRA Toolbox. If not, see .
-----------------------------------------------------------------------
*/
#define CLOG_MAIN
#include
#include
#include
using namespace astra;
void CLogger::enableScreen()
{
m_bEnabledScreen = true;
}
void CLogger::enableFile()
{
m_bEnabledFile = true;
}
void CLogger::enable()
{
enableScreen();
enableFile();
}
void CLogger::disableScreen()
{
m_bEnabledScreen = false;
}
void CLogger::disableFile()
{
m_bEnabledFile = false;
}
void CLogger::disable()
{
disableScreen();
disableFile();
}
void CLogger::debug(const char *sfile, int sline, const char *fmt, ...)
{
_assureIsInitialized();
va_list ap, apf;
if(m_bEnabledScreen){
va_start(ap, fmt);
clog_debug(sfile,sline,0,fmt,ap);
va_end(ap);
}
if(m_bEnabledFile && m_bFileProvided){
va_start(apf, fmt);
clog_debug(sfile,sline,1,fmt,apf);
va_end(apf);
}
}
void CLogger::info(const char *sfile, int sline, const char *fmt, ...)
{
_assureIsInitialized();
va_list ap, apf;
if(m_bEnabledScreen){
va_start(ap, fmt);
clog_info(sfile,sline,0,fmt,ap);
va_end(ap);
}
if(m_bEnabledFile && m_bFileProvided){
va_start(apf, fmt);
clog_info(sfile,sline,1,fmt,apf);
va_end(apf);
}
}
void CLogger::warn(const char *sfile, int sline, const char *fmt, ...)
{
_assureIsInitialized();
va_list ap, apf;
if(m_bEnabledScreen){
va_start(ap, fmt);
clog_warn(sfile,sline,0,fmt,ap);
va_end(ap);
}
if(m_bEnabledFile && m_bFileProvided){
va_start(apf, fmt);
clog_warn(sfile,sline,1,fmt,apf);
va_end(apf);
}
}
void CLogger::error(const char *sfile, int sline, const char *fmt, ...)
{
_assureIsInitialized();
va_list ap, apf;
if(m_bEnabledScreen){
va_start(ap, fmt);
clog_error(sfile,sline,0,fmt,ap);
va_end(ap);
}
if(m_bEnabledFile && m_bFileProvided){
va_start(apf, fmt);
clog_error(sfile,sline,1,fmt,apf);
va_end(apf);
}
}
void CLogger::_setLevel(int id, log_level m_eLevel)
{
switch(m_eLevel){
case LOG_DEBUG:
clog_set_level(id,CLOG_DEBUG);
break;
case LOG_INFO:
clog_set_level(id,CLOG_INFO);
break;
case LOG_WARN:
clog_set_level(id,CLOG_WARN);
break;
case LOG_ERROR:
clog_set_level(id,CLOG_ERROR);
break;
}
}
void CLogger::setOutputScreen(int fd, log_level m_eLevel)
{
_assureIsInitialized();
if(fd==1||fd==2){
clog_set_fd(0, fd);
}else{
error(__FILE__,__LINE__,"Invalid file descriptor");
}
_setLevel(0,m_eLevel);
}
void CLogger::setOutputFile(const char *filename, log_level m_eLevel)
{
if(m_bFileProvided){
clog_free(1);
m_bFileProvided=false;
}
if(!clog_init_path(1,filename)){
m_bFileProvided=true;
_setLevel(1,m_eLevel);
}
}
void CLogger::_assureIsInitialized()
{
if(!m_bInitialized)
{
clog_init_fd(0, 2);
clog_set_level(0, CLOG_INFO);
clog_set_fmt(0, "%l: %m\n");
m_bInitialized = true;
}
}
void CLogger::setFormatFile(const char *fmt)
{
if(m_bFileProvided){
clog_set_fmt(1,fmt);
}else{
error(__FILE__,__LINE__,"No log file specified");
}
}
void CLogger::setFormatScreen(const char *fmt)
{
clog_set_fmt(0,fmt);
}
CLogger::CLogger()
{
;
}
bool CLogger::setCallbackScreen(void (*cb)(const char *msg, size_t len)){
_assureIsInitialized();
return clog_set_cb(0,cb)==0;
}
bool CLogger::m_bEnabledScreen = true;
bool CLogger::m_bEnabledFile = true;
bool CLogger::m_bFileProvided = false;
bool CLogger::m_bInitialized = false;