// Custom includes
#include <locale>
+#include <sstream>
#include <boost/algorithm/string/trim.hpp>
#include <boost/tokenizer.hpp>
///////////////////////////////////////////////////////////////////////////
// senf::log::IOStreamTarget
-const char * const senf::log::IOStreamTarget::LEVELNAMES_[8] = {
- "NONE", "VERBOSE", "NOTICE", "MESSAGE", "IMPORTANT", "CRITICAL", "FATAL", "DISABLED" };
-
-prefix_ senf::log::IOStreamTarget::IOStreamTarget(std::ostream & os)
- : stream_(os)
-{
- std::locale const & loc (stream_.getloc());
- if (!std::has_facet<boost::posix_time::time_facet>(loc))
- stream_.imbue( std::locale(
- loc, new boost::posix_time::time_facet("%Y-%m-%d %H:%M:%S.%f-0000")) );
-}
-
-////////////////////////////////////////
-// private members
-
-prefix_ void senf::log::IOStreamTarget::v_write(boost::posix_time::ptime timestamp,
+prefix_ void senf::log::IOStreamTarget::v_write(time_type timestamp,
std::string const & stream,
std::string const & area, unsigned level,
std::string const & message)
{
- std::string m (boost::trim_right_copy(message));
+ std::string m (message);
+ boost::trim_right(m);
+ detail::quoteNonPrintable(m);
- typedef boost::char_separator<char> Separator;
- typedef boost::tokenizer<Separator> Tokenizer;
- Separator separator ("\n");
- Tokenizer tokenizer (m, separator);
- Tokenizer::iterator i (tokenizer.begin());
- Tokenizer::iterator const i_end (tokenizer.end());
+ if (isPlainFormat())
+ stream_ << m << std::endl;
+ else {
+ std::string const & prf (prefix(timestamp, stream, area, level));
- char sep (' ');
+ typedef boost::char_separator<char> Separator;
+ typedef boost::tokenizer<Separator> Tokenizer;
+ Separator separator ("\n");
+ Tokenizer tokenizer (m, separator);
+ Tokenizer::iterator i (tokenizer.begin());
+ Tokenizer::iterator const i_end (tokenizer.end());
- for (; i != i_end; ++i) {
- stream_ << timestamp << sep;
- if (area != "senf::log::DefaultArea")
- stream_ << "[" << area << "]";
- stream_ << "[" << LEVELNAMES_[level] << "] ";
- stream_ << *i << "\n";
- sep = '-';
+ for (; i != i_end; ++i)
+ stream_ << prf << *i << "\n";
+ stream_ << std::flush;
}
- stream_ << std::flush;
}
///////////////////////////////cc.e////////////////////////////////////////