4 // Fraunhofer Institute for Open Communication Systems (FOKUS)
6 // The contents of this file are subject to the Fraunhofer FOKUS Public License
7 // Version 1.0 (the "License"); you may not use this file except in compliance
8 // with the License. You may obtain a copy of the License at
9 // http://senf.berlios.de/license.html
11 // The Fraunhofer FOKUS Public License Version 1.0 is based on,
12 // but modifies the Mozilla Public License Version 1.1.
13 // See the full license text for the amendments.
15 // Software distributed under the License is distributed on an "AS IS" basis,
16 // WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
17 // for the specific language governing rights and limitations under the License.
19 // The Original Code is Fraunhofer FOKUS code.
21 // The Initial Developer of the Original Code is Fraunhofer-Gesellschaft e.V.
22 // (registered association), Hansastraße 27 c, 80686 Munich, Germany.
23 // All Rights Reserved.
26 // Stefan Bund <g0dil@berlios.de>
29 \brief IOStreamTarget non-inline non-template implementation */
31 #include "IOStreamTarget.hh"
32 //#include "IOStreamTarget.ih"
35 #include <boost/algorithm/string/trim.hpp>
36 #include <boost/tokenizer.hpp>
38 //#include "IOStreamTarget.mpp"
40 //-/////////////////////////////////////////////////////////////////////////////////////////////////
42 //-/////////////////////////////////////////////////////////////////////////////////////////////////
43 // senf::log::IOStreamTarget
45 prefix_ void senf::log::IOStreamTarget::v_write(time_type timestamp,
46 std::string const & stream,
47 std::string const & area, unsigned level,
48 std::string const & message)
50 std::string m (message);
52 detail::quoteNonPrintable(m);
55 stream_ << m << std::endl;
57 std::string const & prf (prefix(timestamp, stream, area, level));
59 typedef boost::char_separator<char> Separator;
60 typedef boost::tokenizer<Separator> Tokenizer;
61 Separator separator ("\n");
62 Tokenizer tokenizer (m, separator);
63 Tokenizer::iterator i (tokenizer.begin());
64 Tokenizer::iterator const i_end (tokenizer.end());
66 for (; i != i_end; ++i)
67 stream_ << prf << *i << "\n";
68 stream_ << std::flush;
72 //-/////////////////////////////////////////////////////////////////////////////////////////////////
74 //#include "IOStreamTarget.mpp"
81 // c-file-style: "senf"
82 // indent-tabs-mode: nil
83 // ispell-local-dictionary: "american"
84 // compile-command: "scons -u test"