DebugModules.cti
Go to the documentation of this file.
1 //
2 // Copyright (c) 2020 Fraunhofer Institute for Applied Information Technology (FIT)
3 // Network Research Group (NET)
4 // Schloss Birlinghoven, 53754 Sankt Augustin, GERMANY
5 // Contact: support@wiback.org
6 //
7 // This file is part of the SENF code tree.
8 // It is licensed under the 3-clause BSD License (aka New BSD License).
9 // See LICENSE.txt in the top level directory for details or visit
10 // https://opensource.org/licenses/BSD-3-Clause
11 //
12 
13 
14 /** \file
15  \brief DebugModules inline template implementation */
16 
17 //#include "DebugModules.ih"
18 
19 // Custom includes
20 #include <senf/Utils/hexdump.hh>
21 
22 #define prefix_ inline
23 //-/////////////////////////////////////////////////////////////////////////////////////////////////
24 
25 //-/////////////////////////////////////////////////////////////////////////////////////////////////
26 // senf::ppi::module::debug::Logger<Stream,Area,level>
27 
28 template <class Stream, class Area, class Level>
29 prefix_ senf::ppi::module::debug::Logger<Stream,Area,Level>::Logger()
30 {}
31 
32 template <class Stream, class Area, class Level>
33 prefix_ senf::ppi::module::debug::Logger<Stream,Area,Level>::Logger(std::string label)
34  : label_ (label+"\n")
35 {}
36 
37 //-/////////////////////////////////////////////////////////////////////////////////////////////////
38 // private members
39 
40 template <class Stream, class Area, class Level>
41 prefix_ void
42 senf::ppi::module::debug::Logger<Stream,Area,Level>::v_handlePacket(Packet const & packet)
43 {
44  SENF_LOG_BLOCK_TPL((Stream)(Area)(Level)({
45  log << label_;
46  packet.dump(log);
47  hexdump(packet.last().data().begin(), packet.last().data().end(),log);
48  }));
49 }
50 
51 //-/////////////////////////////////////////////////////////////////////////////////////////////////
52 #undef prefix_
53 
54 
55 // Local Variables:
56 // mode: c++
57 // fill-column: 100
58 // comment-column: 40
59 // c-file-style: "senf"
60 // indent-tabs-mode: nil
61 // ispell-local-dictionary: "american"
62 // compile-command: "scons -u test"
63 // End: