Utils/Logger: Fix 'senf::log::DefaultArea as empty-string' ambiguity
[senf.git] / Utils / Logger / IOStreamTarget.cc
index f70fdd7..f5e3a6f 100644 (file)
@@ -28,6 +28,8 @@
 
 // Custom includes
 #include <locale>
+#include <boost/algorithm/string/trim.hpp>
+#include <boost/tokenizer.hpp>
 
 //#include "IOStreamTarget.mpp"
 #define prefix_
@@ -41,7 +43,8 @@ prefix_ senf::log::IOStreamTarget::IOStreamTarget(std::ostream & 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")) );
+        stream_.imbue( std::locale(
+                           loc, new boost::posix_time::time_facet("%Y-%m-%d %H:%M:%S.%f-0000")) );
 }
 
 ////////////////////////////////////////
@@ -52,10 +55,25 @@ prefix_ void senf::log::IOStreamTarget::v_write(boost::posix_time::ptime timesta
                                                 std::string const & area, unsigned level,
                                                 std::string const & message)
 {
-    stream_ << timestamp << " ";
-    if (! area.empty())
-        stream_ << "[" << area << "] ";
-    stream_ << message << std::endl;
+    std::string m (boost::trim_right_copy(message));
+
+    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());
+
+    char sep (' ');
+
+    for (; i != i_end; ++i) {
+        stream_ << timestamp << sep;
+        if (area != "senf::log::DefaultArea")
+            stream_ << "[" << area << "] ";
+        stream_ << *i << "\n";
+        sep = '-';
+    }
+    stream_ << std::flush;
 }
 
 ///////////////////////////////cc.e////////////////////////////////////////