removed some useless spaces; not very important, I know :)
[senf.git] / Packets / PacketRegistry.cti
index 72e503a..2f7ffd1 100644 (file)
@@ -1,9 +1,9 @@
 // $Id$
 //
 // Copyright (C) 2006
-// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS)
-// Kompetenzzentrum fuer Satelitenkommunikation (SatCom)
-//     Stefan Bund <stefan.bund@fokus.fraunhofer.de>
+// 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
 // Free Software Foundation, Inc.,
 // 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 
-// Definition of inline template funPacketRegistry.ons
+/** \file
+    \brief PacketRegistry inline template implementation */
 
 #include "PacketRegistry.ih"
 
 // Custom includes
-#include "Packet.hh"
 
 #define prefix_ inline
 ///////////////////////////////PacketRegistry..p///////////////////////////////////////
 
 template <class Tag>
-template <class OtherPacket>
-prefix_ void senf::PacketRegistry<Tag>::registerPacket(typename Tag::key_t key)
+template <class PacketType>
+prefix_ senf::PacketRegistry<Tag>::RegistrationProxy<PacketType>::
+RegistrationProxy(typename Tag::key_t key)
 {
-    registry().registerPacket<OtherPacket>(key);
+    PacketRegistry<Tag>::template registerPacket<PacketType>(key);
 }
 
 template <class Tag>
-template <class OtherPacket>
-prefix_ senf::PacketRegistry<Tag>::RegistrationProxy<OtherPacket>::
-RegistrationProxy(typename Tag::key_t key)
+template <class PacketType>
+prefix_ void senf::PacketRegistry<Tag>::registerPacket(typename Tag::key_t key)
 {
-    PacketRegistry<Tag>::template registerPacket<OtherPacket>(key);
+    registry().registerPacket<PacketType>(key);
 }
 
 template <class Tag>
-template <class OtherPacket>
+template <class PacketType>
 prefix_ typename Tag::key_t senf::PacketRegistry<Tag>::key()
 {
-    return registry().key(senf::typeIdValue<OtherPacket>());
+    return registry().key(senf::typeIdValue<PacketType>());
+}
+
+template <class Tag>
+template <class PacketType>
+prefix_ typename boost::optional<typename Tag::key_t> senf::PacketRegistry<Tag>::key(NoThrow_t)
+{
+    return registry().key(senf::typeIdValue<PacketType>(),true);
+}
+
+template <class Tag>
+prefix_ typename Tag::key_t senf::PacketRegistry<Tag>::key(Packet packet)
+{
+    return registry().key(packet.typeId());
 }
 
-template <class KeyType>
-template <class OtherPacket>
-prefix_ void
-senf::impl::PacketRegistryImpl<KeyType>::registerInterpreter(Packet * p,
-                                                                    Packet::iterator b,
-                                                                    Packet::iterator e)
+template <class Tag>
+prefix_ typename boost::optional<typename Tag::key_t>
+senf::PacketRegistry<Tag>::key(Packet packet, NoThrow_t)
 {
-    p->registerInterpreter<OtherPacket>(b,e);
+    return registry().key(packet.typeId(),true);
 }
 
-template <class Tag, class Derived>
-prefix_ void
-senf::PacketRegistryMixin<Tag,Derived>::registerInterpreter(typename Tag::key_t key,
-                                                                   Packet::iterator b,
-                                                                   Packet::iterator e)
-    const
+template <class Tag>
+prefix_ senf::PkReg_Entry const & senf::PacketRegistry<Tag>::lookup(typename Tag::key_t key)
+{
+    return registry().lookup(key);
+}
+
+template <class Tag>
+prefix_ senf::PkReg_Entry const * senf::PacketRegistry<Tag>::lookup(typename Tag::key_t key,
+                                                                    NoThrow_t)
 {
-    PacketRegistry<Tag>::registry().lookup(key)->registerInterpreter(
-        static_cast<Derived const * const>(this),b,e);
+    return registry().lookup(key,true);
 }
 
 ///////////////////////////////PacketRegistry..e///////////////////////////////////////