///////////////////////////////////////////////////////////////////////////////
// MQ4CPP - Message queuing for C++
// Copyright (C) 2004-2007 Riccardo Pompeo (Italy)
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 2.1 of the License, or (at your option) any later version.
//
// This library 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
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
//
#ifndef __LOGGER__
#define __LOGGER__
#include <fstream>
using namespace std;
#include "Trace.h"
#include "MessageQueue.h"
class LogMessage : public Message
{
public:
enum LogLevel { INFO,WARNING,CRITICAL,DEBUG };
protected:
string itsLog; //v1.4
string itsFile; //v1.4
int itsLine;
enum LogLevel itsLevel;
string itsInstance;
public:
static const char* ClassName;
LogMessage(char* theLog);
LogMessage(const char* theLog);
LogMessage(char* theLog,const char* theFile,int theLine,enum LogLevel theLevel,const char* theInstance=NULL);
LogMessage(const char* theLog,const char* theFile,int theLine,enum LogLevel theLevel,const char* theInstance=NULL);
virtual ~LogMessage();
virtual const char* get() { return itsLog.c_str(); };
virtual const char* getFile() { return itsFile.c_str(); };
virtual int getLine() { return itsLine; };
virtual enum LogLevel getLevel() { return itsLevel; };
virtual void toStream(ostream& theStream);
};
class Logger : public MessageQueue
{
protected:
static Logger* itsDefaultLogger;
ofstream itsStream;
public:
Logger(const char* theLoggerName, const char* theFileName);
virtual ~Logger();
static void startDefaultLogger(const char* theFileName); // ++ v1.5
static void postToDefaultLogger(LogMessage* theMessage);
static void waitForCompletion();
static void bufferDump(char* theBuffer,int theLen,const char* theFile,int theLine);
protected:
Logger();
virtual void onMessage(Message* theMessage);
};
#ifndef SILENT
#define DEBUG(a) \
Logger::post(new LogMessage(a,__FILE__,__LINE__, LogMessage::DEBUG));
#else
#define DEBUG(a) ;
#endif
#define BUFFER(a,b) \
Logger::bufferDump(a,b,__FILE__,__LINE__);
#define LOG(a) \
Logger::postToDefaultLogger(new LogMessage(a,__FILE__,__LINE__, LogMessage::INFO));
#define WARNING(a) \
Logger::postToDefaultLogger(new LogMessage(a,__FILE__,__LINE__, LogMessage::WARNING,getName()));
#define CRITICAL(a) \
Logger::postToDefaultLogger(new LogMessage(a,__FILE__,__LINE__, LogMessage::CRITICAL,getName()));
#define STARTLOGGER(a) \
Logger::startDefaultLogger(a);
#define STOPLOGGER() \
Logger::waitForCompletion();
#endif
syntax highlighted by Code2HTML, v. 0.9.1