X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FPacketType.cti;h=1b7e69369cdd9e42c1d0b01a5ca8023fbb442ece;hb=b8ca4a544cce3e6023bb56b712a03d6362f2bb79;hp=aa610d8c1afb388d42d8ce60673da5565d02dda0;hpb=47368f306a577d1e46df69a7f729bd3893cbe5e7;p=senf.git diff --git a/Packets/PacketType.cti b/Packets/PacketType.cti index aa610d8..1b7e693 100644 --- a/Packets/PacketType.cti +++ b/Packets/PacketType.cti @@ -1,6 +1,8 @@ -// Copyright (C) 2007 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) +// $Id$ +// +// Copyright (C) 2007 +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund // // This program is free software; you can redistribute it and/or modify @@ -44,7 +46,7 @@ prefix_ senf::PacketTypeBase::factory_t senf::PacketTypeBase::factory() template prefix_ senf::PacketInterpreterBase::optional_range -senf::PacketTypeMixin::nextPacketRange(Packet p) +senf::PacketTypeMixin::nextPacketRange(Packet const & p) { // Call the member defined in the specialization below return PacketTypeMixin::nextPacketRange(p); @@ -52,13 +54,11 @@ senf::PacketTypeMixin::nextPacketRange(Packet p) template prefix_ senf::PacketInterpreterBase::factory_t -senf::PacketTypeMixin::nextPacketType(Packet p) +senf::PacketTypeMixin::nextPacketType(Packet const & p) { if (p.data().size() < Self::initSize()) return Self::no_factory(); - PkReg_Entry const * e (PacketRegistry::lookup( - Self::nextPacketKey(p.as< ConcretePacket >()), nothrow)); - return e ? e->factory() : PacketTypeBase::no_factory(); + return lookup( Self::nextPacketKey(p.as< ConcretePacket >()) ); } template @@ -68,31 +68,28 @@ prefix_ senf::PacketInterpreterBase::size_type senf::PacketTypeMixin -prefix_ void senf::PacketTypeMixin::init(Packet p) +prefix_ void senf::PacketTypeMixin::init(Packet const & p) { p.as< ConcretePacket >()->init(); } -/////////////////////////////////////////////////////////////////////////// -// senf::PacketTypeMixin +template +prefix_ typename senf::PacketTypeMixin::optional_key_t +senf::PacketTypeMixin::key(Packet const & p) +{ + return p ? PacketRegistry::key(p, nothrow) : optional_key_t(); +} -template -prefix_ senf::PacketInterpreterBase::optional_range -senf::PacketTypeMixin::nextPacketRange(Packet p) +template +prefix_ senf::PacketTypeBase::factory_t senf::PacketTypeMixin::lookup(key_t key) { - if (p.data().size() < Self::initSize()) - return PacketTypeBase::no_range(); - typename Self::size_type sz (Self::initHeadSize()); - ///\idea This if condition could be replaced with a compile time switch by checking, wether - /// (the function address) Self::initHeadSize is different from PacketTypeBase::initHeadSize - if (sz == PacketTypeBase::size_type(-1)) - return PacketTypeBase::range(boost::next(p.data().begin(),Self::initSize()), - p.data().end()); - else - return PacketTypeBase::range(boost::next(p.data().begin(),sz), - boost::prior(p.data().end(),Self::initSize()-sz)); + PkReg_Entry const * entry (PacketRegistry::lookup( key, senf::nothrow )); + return entry ? entry->factory() : PacketTypeBase::no_factory(); } +/////////////////////////////////////////////////////////////////////////// +// senf::PacketTypeMixin + template prefix_ senf::PacketInterpreterBase::size_type senf::PacketTypeMixin::initSize() { @@ -100,7 +97,7 @@ prefix_ senf::PacketInterpreterBase::size_type senf::PacketTypeMixin: } template -prefix_ void senf::PacketTypeMixin::init(Packet p) +prefix_ void senf::PacketTypeMixin::init(Packet const & p) { p.as< ConcretePacket >()->init(); } @@ -115,4 +112,6 @@ prefix_ void senf::PacketTypeMixin::init(Packet p) // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: