Search:

SENF Extensible Network Framework

  • Home
  • Download
  • Wiki
  • BerliOS
  • ChangeLog
  • Browse SVN
  • Bug Tracker
  • Overview
  • Examples
  • HowTos
  • Glossary
  • PPI
  • Packets
  • Scheduler
  • Socket
  • Utils
  • Console
  • Daemon
  • Logger
  • Termlib
  • Main Page
  • Related Pages
  • Modules
  • Namespaces
  • Classes
  • Files
  • Directories
  • File List
  • File Members

DebugModules.cti

Go to the documentation of this file.
00001 // $Id: DebugModules.cti 1742 2010-11-04 14:51:56Z g0dil $
00002 //
00003 // Copyright (C) 2007
00004 // Fraunhofer (FOKUS)
00005 // Competence Center NETwork research (NET), St. Augustin, GERMANY
00006 //     Stefan Bund <g0dil@berlios.de>
00007 //
00008 // This program is free software; you can redistribute it and/or modify
00009 // it under the terms of the GNU General Public License as published by
00010 // the Free Software Foundation; either version 2 of the License, or
00011 // (at your option) any later version.
00012 //
00013 // This program is distributed in the hope that it will be useful,
00014 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00015 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00016 // GNU General Public License for more details.
00017 //
00018 // You should have received a copy of the GNU General Public License
00019 // along with this program; if not, write to the
00020 // Free Software Foundation, Inc.,
00021 // 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
00022 
00026 //#include "DebugModules.ih"
00027 
00028 // Custom includes
00029 #include <senf/Utils/hexdump.hh>
00030 
00031 #define prefix_ inline
00032 //-/////////////////////////////////////////////////////////////////////////////////////////////////
00033 
00034 //-/////////////////////////////////////////////////////////////////////////////////////////////////
00035 // senf::ppi::module::debug::Logger<Stream,Area,level>
00036 
00037 template <class Stream, class Area, class Level>
00038 prefix_ senf::ppi::module::debug::Logger<Stream,Area,Level>::Logger()
00039 {}
00040 
00041 template <class Stream, class Area, class Level>
00042 prefix_ senf::ppi::module::debug::Logger<Stream,Area,Level>::Logger(std::string label)
00043     : label_ (label+"\n")
00044 {}
00045 
00046 //-/////////////////////////////////////////////////////////////////////////////////////////////////
00047 // private members
00048 
00049 template <class Stream, class Area, class Level>
00050 prefix_ void
00051 senf::ppi::module::debug::Logger<Stream,Area,Level>::v_handlePacket(Packet const & packet)
00052 {
00053     SENF_LOG_BLOCK_TPL((Stream)(Area)(Level)({
00054                 log << label_;
00055                 packet.dump(log);
00056                 hexdump(packet.last().data().begin(), packet.last().data().end(),log);
00057             }));
00058 }
00059 
00060 //-/////////////////////////////////////////////////////////////////////////////////////////////////
00061 #undef prefix_
00062 
00063 
00064 // Local Variables:
00065 // mode: c++
00066 // fill-column: 100
00067 // comment-column: 40
00068 // c-file-style: "senf"
00069 // indent-tabs-mode: nil
00070 // ispell-local-dictionary: "american"
00071 // compile-command: "scons -u test"
00072 // End:

Contact: senf-dev@lists.berlios.de | © 2006-2010 Fraunhofer Institute for Open Communication Systems, Network Research