Packets: Add descriptive dump() output to DataPacket
g0dil [Thu, 13 Nov 2008 15:25:01 +0000 (15:25 +0000)]
Packets/DefaultBundle: Fix EthernetPacketType::finalize() (don't throw when no next packet)
Scheduler/Console: Add some missing #undef's

git-svn-id: https://svn.berlios.de/svnroot/repos/senf/trunk@959 270642c3-0616-0410-b53a-bc976706d245

PPI/Doxyfile
Packets/DataPacket.cc [new file with mode: 0644]
Packets/DataPacket.hh
Packets/DefaultBundle/EthernetPacket.cc
Scheduler/Console/ParsedCommand.mpp

index 276da6c..e679a57 100644 (file)
@@ -4,6 +4,7 @@ PROJECT_NAME = libPPI
 GENERATE_TAGFILE = doc/PPI.tag
 RECURSIVE = Yes
 SHOW_DIRECTORIES = Yes
+EXCLUDE = NetEmu
 
 TAGFILES = \
     "$(TOPDIR)/Scheduler/doc/Scheduler.tag" \
diff --git a/Packets/DataPacket.cc b/Packets/DataPacket.cc
new file mode 100644 (file)
index 0000000..3aba8ee
--- /dev/null
@@ -0,0 +1,53 @@
+// $Id$
+//
+// Copyright (C) 2008 
+// Fraunhofer Institute for Open Communication Systems (FOKUS)
+// Competence Center NETwork research (NET), St. Augustin, GERMANY
+//     Stefan Bund <g0dil@berlios.de>
+//
+// This program is free software; you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation; either version 2 of the License, or
+// (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program; if not, write to the
+// Free Software Foundation, Inc.,
+// 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+
+/** \file
+    \brief DataPacket non-inline non-template implementation */
+
+#include "Packets.hh"
+//#include "DataPacket.ih"
+
+// Custom includes
+
+//#include "DataPacket.mpp"
+#define prefix_
+///////////////////////////////cc.p////////////////////////////////////////
+
+prefix_ void senf::DataPacketType::dump(packet p, std::ostream & os)
+{
+    os << "Payload data (" << p.size() << " bytes)\n";
+}
+
+///////////////////////////////cc.e////////////////////////////////////////
+#undef prefix_
+//#include "DataPacket.mpp"
+
+\f
+// Local Variables:
+// mode: c++
+// fill-column: 100
+// comment-column: 40
+// c-file-style: "senf"
+// indent-tabs-mode: nil
+// ispell-local-dictionary: "american"
+// compile-command: "scons -u test"
+// End:
index 8469e9e..ae2b39e 100644 (file)
@@ -47,7 +47,10 @@ namespace senf {
         \ingroup packet_module
      */
     struct DataPacketType : public PacketTypeBase
-    {};
+    {
+        typedef ConcretePacket<DataPacketType> packet;
+        static void dump(packet p, std::ostream & os);
+    };
 
     /** \brief Generic payload-only packet typedef */
     typedef ConcretePacket<DataPacketType> DataPacket;
index 15ca8f4..78fe56c 100644 (file)
@@ -67,11 +67,14 @@ prefix_ senf::PacketInterpreterBase::factory_t senf::EthernetPacketType::nextPac
 
 prefix_ void senf::EthernetPacketType::finalize(packet p)
 {
-    optional_key_t k (key(p.next(nothrow)));
-    if (k)
-        p->type_length() << k;
-    else if (p.next().is<LlcSnapPacket>())
-        p->type_length() << p.next().data().size();
+    Packet n (p.next(nothrow));
+    if (n) {
+        optional_key_t k (key(n));
+        if (k)
+            p->type_length() << k;
+        else if (n.is<LlcSnapPacket>())
+            p->type_length() << n.data().size();
+    }
     // Do NOT reset type_length if the type is not known ... doing this will destroy read packets
 }
 
index f444a6b..a8598fa 100644 (file)
@@ -361,12 +361,18 @@ next_type arg ( BOOST_PP_ENUM_BINARY_PARAMS( BOOST_PP_ITERATION(), A, const & a
 // ////////////////////////////////////////////////////////////////////////
 // Undefine local Macros
 
+#undef mpp_TrailingBindArgs
+#undef mpp_BindArgs_
+
 #undef mpp_TrailingArgs
 #undef mpp_Args_
 
-#undef mpp_TrailingArgTypes
+#undef mpp_ArgTypes
 #undef mpp_ArgTypes_
 
+#undef mpp_TrailingArgTypes
+#undef mpp_TrailingArgTypes_
+
 #undef mpp_ArgN
 #undef mpp_ArgTypeN