d5d633c014bef8026c5882088568b0148ec33a0f
[senf.git] / senf / Utils / Logger / Log.ih
1 // $Id$
2 //
3 // Copyright (C) 2007
4 // Fraunhofer Institute for Open Communication Systems (FOKUS)
5 // Competence Center NETwork research (NET), St. Augustin, GERMANY
6 //     Stefan Bund <g0dil@berlios.de>
7 //
8 // This program is free software; you can redistribute it and/or modify
9 // it under the terms of the GNU General Public License as published by
10 // the Free Software Foundation; either version 2 of the License, or
11 // (at your option) any later version.
12 //
13 // This program is distributed in the hope that it will be useful,
14 // but WITHOUT ANY WARRANTY; without even the implied warranty of
15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 // GNU General Public License for more details.
17 //
18 // You should have received a copy of the GNU General Public License
19 // along with this program; if not, write to the
20 // Free Software Foundation, Inc.,
21 // 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22
23 /** \file
24     \brief Log internal header */
25
26 #ifndef IH_SENF_Utils_Logger_Log_
27 #define IH_SENF_Utils_Logger_Log_ 1
28
29 // Custom includes
30 #include <sstream>
31
32 ///////////////////////////////ih.p////////////////////////////////////////
33
34 #define SENF_LOG_BLOCK_(parameters, block)                                                        \
35     do {                                                                                          \
36         typedef parameters SENFLogParameters;                                                     \
37         if (SENFLogParameters::compileEnabled && SENFLogParameters::enabled()) {                  \
38             std::stringstream log;                                                                \
39             do block while(0);                                                                    \
40             senf::log::detail::write< SENFLogParameters::stream,                                  \
41                                       SENFLogParameters::area,                                    \
42                                       SENFLogParameters::level >(log.str());                      \
43         }                                                                                         \
44     } while(0)
45
46 #define SENF_LOG_BLOCK_TPL_(parameters, block)                                                    \
47     do {                                                                                          \
48         typedef parameters SENFLogParameters;                                                     \
49         if (SENFLogParameters::compileEnabled && SENFLogParameters::enabled()) {                  \
50             std::stringstream log;                                                                \
51             do block while(0);                                                                    \
52             senf::log::detail::write<typename SENFLogParameters::stream,                          \
53                              typename SENFLogParameters::area,                                    \
54                              typename SENFLogParameters::level>(log.str());                       \
55         }                                                                                         \
56     } while(0)
57
58 ///////////////////////////////ih.e////////////////////////////////////////
59 #endif
60
61 \f
62 // Local Variables:
63 // mode: c++
64 // fill-column: 100
65 // comment-column: 40
66 // c-file-style: "senf"
67 // indent-tabs-mode: nil
68 // ispell-local-dictionary: "american"
69 // compile-command: "scons -u test"
70 // End: