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: