switch to new MPL based Fraunhofer FOKUS Public License
[senf.git] / senf / Utils / StatisticsTargets.cc
1 // $Id$
2 //
3 // Copyright (C) 2009
4 // Fraunhofer Institute for Open Communication Systems (FOKUS)
5 //
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
10 //
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.
14 //
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.
18 //
19 // The Original Code is Fraunhofer FOKUS code.
20 //
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.
24 //
25 // Contributor(s):
26 //   Stefan Bund <g0dil@berlios.de>
27
28 /** \file
29     \brief StatisticsTargets non-inline non-template implementation */
30
31 #include "StatisticsTargets.hh"
32 #include "StatisticsTargets.ih"
33
34 // Custom includes
35 #include <boost/bind.hpp>
36 #include <senf/Utils/Console/ParsedCommand.hh>
37 #include "Statistics.hh"
38
39 //#include "StatisticsTargets.mpp"
40 #define prefix_
41 //-/////////////////////////////////////////////////////////////////////////////////////////////////
42
43 //-/////////////////////////////////////////////////////////////////////////////////////////////////
44 // senf::detail::StatisticsLoggerRegistry
45
46 prefix_ void
47 senf::detail::StatisticsLoggerRegistry::apply(StatisticsBase & stats,
48                                               unsigned rank, console::DirectoryNode & dir)
49 {
50     Adders::const_iterator i (adders_.begin());
51     Adders::const_iterator const i_end (adders_.end());
52     for (; i != i_end; ++i)
53         (*i)(stats, rank, dir);
54 }
55
56 //-/////////////////////////////////////////////////////////////////////////////////////////////////
57
58 namespace {
59
60     struct RegisterStatisticsLogger
61     {
62         RegisterStatisticsLogger();
63
64         static void adder(senf::StatisticsBase & stats,
65                           unsigned rank, senf::console::DirectoryNode & dir);
66
67         static void consoleCreate(senf::StatisticsBase & stats,
68                                   unsigned rank, std::string const & prefix);
69     };
70
71     RegisterStatisticsLogger registerStatisticsLogger;
72 }
73
74 prefix_ RegisterStatisticsLogger::RegisterStatisticsLogger()
75 {
76     senf::detail::StatisticsLoggerRegistry::instance().add(&adder);
77 }
78
79 prefix_ void RegisterStatisticsLogger::adder(senf::StatisticsBase & stats,
80                                              unsigned rank, senf::console::DirectoryNode & dir)
81 {
82     namespace kw = senf::console::kw;
83     namespace fty = senf::console::factory;
84     dir.add("logger", fty::Command<void (std::string const &)>(
85                 boost::bind(&consoleCreate, boost::ref(stats), rank, _1))
86             .arg("prefix","Optional prefix string to add to each log message",
87                  kw::default_value = "")
88             .doc("Send log messages to statistics log stream") );
89 }
90
91 prefix_ void RegisterStatisticsLogger::consoleCreate(senf::StatisticsBase & stats,
92                                                      unsigned rank, std::string const & prefix)
93 {
94     stats.output(rank).connect(senf::StatisticsLogger(prefix),
95                                "senf::StatisticsLogger(\"" + prefix + "\")");
96 }
97
98 //-/////////////////////////////////////////////////////////////////////////////////////////////////
99 #undef prefix_
100 //#include "StatisticsTargets.mpp"
101
102 \f
103 // Local Variables:
104 // mode: c++
105 // fill-column: 100
106 // comment-column: 40
107 // c-file-style: "senf"
108 // indent-tabs-mode: nil
109 // ispell-local-dictionary: "american"
110 // compile-command: "scons -u test"
111 // End: