X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FPacketType.cti;h=75be1a788f1accbe591a2ce8002c6e1f7337eb4a;hb=6a0836b7f462d3d77b79b35638cdbf4c9d4202fc;hp=843e83aa25b9c0ebcfc59e523775200a67c8a73e;hpb=0990bd1c4f917855f3645e7329a84b00e54ccd7d;p=senf.git diff --git a/Packets/PacketType.cti b/Packets/PacketType.cti index 843e83a..75be1a7 100644 --- a/Packets/PacketType.cti +++ b/Packets/PacketType.cti @@ -1,8 +1,8 @@ // $Id$ // -// Copyright (C) 2007 -// Fraunhofer Institute for Open Communication Systems (FOKUS) -// Competence Center NETwork research (NET), St. Augustin, GERMANY +// 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 @@ -58,9 +58,7 @@ senf::PacketTypeMixin::nextPacketType(Packet 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 @@ -76,10 +74,17 @@ prefix_ void senf::PacketTypeMixin::init(Packet p) } template -prefix_ typename senf::PacketTypeMixin::optional_registry_key_t +prefix_ typename senf::PacketTypeMixin::optional_key_t senf::PacketTypeMixin::key(Packet p) { - return p ? PacketRegistry::key(p, nothrow) : optional_registry_key_t(); + return p ? PacketRegistry::key(p, nothrow) : optional_key_t(); +} + +template +prefix_ senf::PacketTypeBase::factory_t senf::PacketTypeMixin::lookup(key_t key) +{ + PkReg_Entry const * entry (PacketRegistry::lookup( key, senf::nothrow )); + return entry ? entry->factory() : PacketTypeBase::no_factory(); } ///////////////////////////////////////////////////////////////////////////