X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FLogger%2FIOStreamTarget.cc;fp=senf%2FUtils%2FLogger%2FIOStreamTarget.cc;h=b020e34b32344d66321aa94ecbe1ec3638e62f42;hb=601d1f509f5bb24df167a4dd5a20da67a0af9af8;hp=0000000000000000000000000000000000000000;hpb=164fe477094d42463722584e527a02379ab5d985;p=senf.git diff --git a/senf/Utils/Logger/IOStreamTarget.cc b/senf/Utils/Logger/IOStreamTarget.cc new file mode 100644 index 0000000..b020e34 --- /dev/null +++ b/senf/Utils/Logger/IOStreamTarget.cc @@ -0,0 +1,82 @@ +// $Id$ +// +// Copyright (C) 2007 +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY +// Stefan Bund +// +// This program 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 2 of the License, or +// (at your option) any later version. +// +// This program 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 this program; if not, write to the +// Free Software Foundation, Inc., +// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +/** \file + \brief IOStreamTarget non-inline non-template implementation */ + +#include "IOStreamTarget.hh" +//#include "IOStreamTarget.ih" + +// Custom includes +#include +#include +#include +#include + +//#include "IOStreamTarget.mpp" +#define prefix_ +///////////////////////////////cc.p//////////////////////////////////////// + +/////////////////////////////////////////////////////////////////////////// +// senf::log::IOStreamTarget + +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 (message); + boost::trim_right(m); + detail::quoteNonPrintable(m); + + if (isPlainFormat()) + stream_ << m << std::endl; + else { + std::string const & prf (prefix(timestamp, stream, area, level)); + + typedef boost::char_separator Separator; + typedef boost::tokenizer 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_ << prf << *i << "\n"; + stream_ << std::flush; + } +} + +///////////////////////////////cc.e//////////////////////////////////////// +#undef prefix_ +//#include "IOStreamTarget.mpp" + + +// Local Variables: +// mode: c++ +// fill-column: 100 +// comment-column: 40 +// c-file-style: "senf" +// indent-tabs-mode: nil +// ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// End: