2005-01-27 03:35:23 +00:00
|
|
|
//This file is part of Photon (http://photon.sourceforge.net)
|
|
|
|
//Copyright (C) 2004-2005 James Turk
|
|
|
|
//
|
|
|
|
// Author:
|
|
|
|
// James Turk (jpt2433@rit.edu)
|
|
|
|
//
|
|
|
|
// Version:
|
2005-07-19 01:31:37 +00:00
|
|
|
// $Id: Log.cpp,v 1.9 2005/07/19 01:31:38 cozman Exp $
|
2005-01-27 03:35:23 +00:00
|
|
|
|
2005-02-13 22:12:02 +00:00
|
|
|
#include "Log.hpp"
|
2005-01-27 03:35:23 +00:00
|
|
|
|
|
|
|
#include <algorithm>
|
2005-02-13 22:12:02 +00:00
|
|
|
#include "exceptions.hpp"
|
2005-01-27 03:35:23 +00:00
|
|
|
|
|
|
|
namespace photon
|
|
|
|
{
|
|
|
|
|
|
|
|
Log::Log()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
Log::~Log()
|
|
|
|
{
|
2005-07-19 01:31:37 +00:00
|
|
|
removeSinks(); // drop all sinks (also flushes output)
|
2005-01-27 03:35:23 +00:00
|
|
|
}
|
|
|
|
|
2005-02-04 08:11:54 +00:00
|
|
|
void Log::addSink(LogSinkPtr sink)
|
2005-01-27 03:35:23 +00:00
|
|
|
{
|
2005-02-04 08:11:54 +00:00
|
|
|
flush();
|
|
|
|
|
2005-07-19 01:31:37 +00:00
|
|
|
// search through list of sinks to avoid adding same sink twice
|
2005-02-04 08:11:54 +00:00
|
|
|
for(std::list<LogSinkPtr>::iterator it = sinks_.begin();
|
2005-01-27 03:35:23 +00:00
|
|
|
it != sinks_.end();
|
|
|
|
++it)
|
|
|
|
{
|
|
|
|
if(sink == *it || sink->getName() == (*it)->getName())
|
|
|
|
{
|
2005-02-04 08:11:54 +00:00
|
|
|
throw PreconditionException("Log already contains sink: " +
|
|
|
|
sink->getName());
|
2005-01-27 03:35:23 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-07-19 01:31:37 +00:00
|
|
|
sinks_.push_back(sink); // add sink if unique
|
2005-01-27 03:35:23 +00:00
|
|
|
}
|
|
|
|
|
2005-02-07 01:48:25 +00:00
|
|
|
void Log::removeSink(const std::string& sinkName)
|
2005-01-27 03:35:23 +00:00
|
|
|
{
|
2005-02-04 08:11:54 +00:00
|
|
|
flush();
|
|
|
|
|
2005-07-19 01:31:37 +00:00
|
|
|
// find sink and erase it
|
2005-02-04 08:11:54 +00:00
|
|
|
for(std::list<LogSinkPtr>::iterator it = sinks_.begin();
|
2005-01-27 03:35:23 +00:00
|
|
|
it != sinks_.end();
|
|
|
|
++it)
|
|
|
|
{
|
|
|
|
if((*it)->getName() == sinkName)
|
|
|
|
{
|
|
|
|
sinks_.erase(it);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-02-04 08:11:54 +00:00
|
|
|
void Log::removeSink(LogSinkPtr sink)
|
2005-01-27 03:35:23 +00:00
|
|
|
{
|
2005-02-04 08:11:54 +00:00
|
|
|
flush();
|
|
|
|
|
2005-07-19 01:31:37 +00:00
|
|
|
// search for sink
|
2005-02-04 08:11:54 +00:00
|
|
|
std::list<LogSinkPtr>::iterator it =
|
2005-01-27 03:35:23 +00:00
|
|
|
std::find(sinks_.begin(),sinks_.end(),sink);
|
|
|
|
|
2005-07-19 01:31:37 +00:00
|
|
|
// remove sink if it exists
|
2005-01-27 03:35:23 +00:00
|
|
|
if(it != sinks_.end())
|
|
|
|
{
|
|
|
|
sinks_.erase(it);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void Log::removeSinks()
|
|
|
|
{
|
2005-07-19 01:31:37 +00:00
|
|
|
flush(); // make sure last message gets flushed to sinks
|
2005-02-04 08:11:54 +00:00
|
|
|
|
2005-07-19 01:31:37 +00:00
|
|
|
sinks_.clear(); // empty entire sink list
|
2005-01-27 03:35:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void Log::flush()
|
|
|
|
{
|
2005-07-19 01:31:37 +00:00
|
|
|
std::string str = buffer_.str(); // get string from buffer
|
|
|
|
if(str.length()) // if a message exists, write it to all sinks
|
2005-01-27 03:35:23 +00:00
|
|
|
{
|
2005-02-04 08:11:54 +00:00
|
|
|
for(std::list<LogSinkPtr>::iterator it = sinks_.begin();
|
2005-01-27 03:35:23 +00:00
|
|
|
it != sinks_.end();
|
|
|
|
++it)
|
|
|
|
{
|
|
|
|
(*it)->writeMessage(lastLevel_,str);
|
|
|
|
}
|
2005-07-19 01:31:37 +00:00
|
|
|
buffer_.str(""); // clear message
|
2005-01-27 03:35:23 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-07-19 01:31:37 +00:00
|
|
|
// note, verbose, warning, error, critical all flush the existing buffer
|
|
|
|
// set the level and return the stringstream for writing
|
2005-01-27 03:35:23 +00:00
|
|
|
std::ostream& Log::note()
|
|
|
|
{
|
|
|
|
flush();
|
|
|
|
lastLevel_ = LOG_NOTE;
|
|
|
|
return buffer_;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::ostream& Log::verbose()
|
|
|
|
{
|
|
|
|
flush();
|
|
|
|
lastLevel_ = LOG_VERBOSE;
|
|
|
|
return buffer_;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::ostream& Log::warning()
|
|
|
|
{
|
|
|
|
flush();
|
|
|
|
lastLevel_ = LOG_WARNING;
|
|
|
|
return buffer_;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::ostream& Log::error()
|
|
|
|
{
|
|
|
|
flush();
|
|
|
|
lastLevel_ = LOG_ERROR;
|
|
|
|
return buffer_;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::ostream& Log::critical()
|
|
|
|
{
|
|
|
|
flush();
|
|
|
|
lastLevel_ = LOG_CRITICAL;
|
|
|
|
return buffer_;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|