From a2ddfcd3b8c29e109fa46fc8a575644ff9aacad9 Mon Sep 17 00:00:00 2001 From: g0dil <g0dil@wiback.org> Date: Thu, 13 Nov 2008 15:25:01 +0000 Subject: [PATCH] Packets: Add descriptive dump() output to DataPacket Packets/DefaultBundle: Fix EthernetPacketType::finalize() (don't throw when no next packet) Scheduler/Console: Add some missing #undef's --- PPI/Doxyfile | 1 + Packets/DataPacket.cc | 53 +++++++++++++++++++++++++ Packets/DataPacket.hh | 5 ++- Packets/DefaultBundle/EthernetPacket.cc | 13 +++--- Scheduler/Console/ParsedCommand.mpp | 8 +++- 5 files changed, 73 insertions(+), 7 deletions(-) create mode 100644 Packets/DataPacket.cc diff --git a/PPI/Doxyfile b/PPI/Doxyfile index 276da6c5..e679a57c 100644 --- a/PPI/Doxyfile +++ b/PPI/Doxyfile @@ -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 index 00000000..3aba8ee4 --- /dev/null +++ b/Packets/DataPacket.cc @@ -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" + + +// 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: diff --git a/Packets/DataPacket.hh b/Packets/DataPacket.hh index 8469e9ed..ae2b39e7 100644 --- a/Packets/DataPacket.hh +++ b/Packets/DataPacket.hh @@ -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; diff --git a/Packets/DefaultBundle/EthernetPacket.cc b/Packets/DefaultBundle/EthernetPacket.cc index 15ca8f42..78fe56c3 100644 --- a/Packets/DefaultBundle/EthernetPacket.cc +++ b/Packets/DefaultBundle/EthernetPacket.cc @@ -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 } diff --git a/Scheduler/Console/ParsedCommand.mpp b/Scheduler/Console/ParsedCommand.mpp index f444a6b2..a8598faf 100644 --- a/Scheduler/Console/ParsedCommand.mpp +++ b/Scheduler/Console/ParsedCommand.mpp @@ -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 -- GitLab