• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1  /*
2   *          Copyright Andrey Semashev 2007 - 2015.
3   * Distributed under the Boost Software License, Version 1.0.
4   *    (See accompanying file LICENSE_1_0.txt or copy at
5   *          http://www.boost.org/LICENSE_1_0.txt)
6   */
7  /*!
8   * \file   main.cpp
9   * \author Andrey Semashev
10   * \date   07.03.2009
11   *
12   * \brief  An example of logging to a syslog server (syslogd, for example).
13   *
14   * The example shows how to initialize logging to a local syslog server.
15   * The code creates a sink that will use native syslog API to emit messages.
16   */
17  
18  // #define BOOST_LOG_DYN_LINK 1
19  
20  #include <boost/config.hpp>
21  #if !defined(BOOST_WINDOWS)
22  #define BOOST_LOG_USE_NATIVE_SYSLOG
23  #endif
24  
25  #include <stdexcept>
26  #include <string>
27  #include <iostream>
28  #include <boost/smart_ptr/shared_ptr.hpp>
29  
30  #include <boost/log/common.hpp>
31  #include <boost/log/expressions.hpp>
32  #include <boost/log/attributes.hpp>
33  #include <boost/log/sinks/sync_frontend.hpp>
34  #include <boost/log/sinks/syslog_backend.hpp>
35  
36  #if defined(BOOST_LOG_USE_NATIVE_SYSLOG)
37  
38  namespace logging = boost::log;
39  namespace attrs = boost::log::attributes;
40  namespace src = boost::log::sources;
41  namespace sinks = boost::log::sinks;
42  namespace expr = boost::log::expressions;
43  namespace keywords = boost::log::keywords;
44  
45  using boost::shared_ptr;
46  
47  //! Define application-specific severity levels
48  enum severity_levels
49  {
50      normal,
51      warning,
52      error
53  };
54  
main(int argc,char * argv[])55  int main(int argc, char* argv[])
56  {
57      try
58      {
59          // Create a syslog sink
60          shared_ptr< sinks::synchronous_sink< sinks::syslog_backend > > sink(
61              new sinks::synchronous_sink< sinks::syslog_backend >(
62                  keywords::use_impl = sinks::syslog::native,
63                  keywords::facility = sinks::syslog::local7));
64  
65          sink->set_formatter
66          (
67              expr::format("native_syslog: %1%: %2%")
68                  % expr::attr< unsigned int >("RecordID")
69                  % expr::smessage
70          );
71  
72          // We'll have to map our custom levels to the syslog levels
73          sinks::syslog::custom_severity_mapping< severity_levels > mapping("Severity");
74          mapping[normal] = sinks::syslog::info;
75          mapping[warning] = sinks::syslog::warning;
76          mapping[error] = sinks::syslog::critical;
77  
78          sink->locked_backend()->set_severity_mapper(mapping);
79  
80          // Add the sink to the core
81          logging::core::get()->add_sink(sink);
82  
83          // Add some attributes too
84          logging::core::get()->add_global_attribute("RecordID", attrs::counter< unsigned int >());
85  
86          // Do some logging
87          src::severity_logger< severity_levels > lg(keywords::severity = normal);
88          BOOST_LOG_SEV(lg, normal) << "A syslog record with normal level";
89          BOOST_LOG_SEV(lg, warning) << "A syslog record with warning level";
90          BOOST_LOG_SEV(lg, error) << "A syslog record with error level";
91  
92          return 0;
93      }
94      catch (std::exception& e)
95      {
96          std::cout << "FAILURE: " << e.what() << std::endl;
97          return 1;
98      }
99  }
100  
101  #else // defined(BOOST_LOG_USE_NATIVE_SYSLOG)
102  
main(int,char * [])103  int main (int, char*[])
104  {
105      std::cout << "Native syslog API is not supported on this platform" << std::endl;
106      return 0;
107  }
108  
109  #endif // defined(BOOST_LOG_USE_NATIVE_SYSLOG)
110