Add 'unflatten' to doxygen/dot processing
[senf.git] / Packets / PacketRegistry.cti
index 41a9127..fa4096d 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
@@ -20,7 +20,8 @@
 // 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"
 
@@ -29,6 +30,9 @@
 #define prefix_ inline
 ///////////////////////////////PacketRegistry..p///////////////////////////////////////
 
+///////////////////////////////////////////////////////////////////////////
+// senf::PacketRegistry<Tag>::RegistrationProxy<PacketType>
+
 template <class Tag>
 template <class PacketType>
 prefix_ senf::PacketRegistry<Tag>::RegistrationProxy<PacketType>::
@@ -37,6 +41,9 @@ RegistrationProxy(typename Tag::key_t key)
     PacketRegistry<Tag>::template registerPacket<PacketType>(key);
 }
 
+///////////////////////////////////////////////////////////////////////////
+// senf::PacketRegistry<Tag>
+
 template <class Tag>
 template <class PacketType>
 prefix_ void senf::PacketRegistry<Tag>::registerPacket(typename Tag::key_t key)
@@ -59,13 +66,14 @@ prefix_ typename boost::optional<typename Tag::key_t> senf::PacketRegistry<Tag>:
 }
 
 template <class Tag>
-prefix_ typename Tag::key_t senf::PacketRegistry<Tag>::key(Packet packet)
+prefix_ typename Tag::key_t senf::PacketRegistry<Tag>::key(Packet const & packet)
 {
     return registry().key(packet.typeId());
 }
 
 template <class Tag>
-prefix_ typename Tag::key_t senf::PacketRegistry<Tag>::key(Packet packet, NoThrow_t)
+prefix_ typename boost::optional<typename Tag::key_t>
+senf::PacketRegistry<Tag>::key(Packet const & packet, NoThrow_t)
 {
     return registry().key(packet.typeId(),true);
 }
@@ -83,10 +91,49 @@ prefix_ senf::PkReg_Entry const * senf::PacketRegistry<Tag>::lookup(typename Tag
     return registry().lookup(key,true);
 }
 
+template <class Tag>
+prefix_ typename senf::PacketRegistry<Tag>::iterator senf::PacketRegistry<Tag>::begin()
+{
+    return registry().begin();
+}
+
+template <class Tag>
+prefix_ typename senf::PacketRegistry<Tag>::iterator senf::PacketRegistry<Tag>::end()
+{
+    return registry().end();
+}
+
+///////////////////////////////////////////////////////////////////////////
+// senf::detail::PacketRegistryImpl<KeyType>
+
+template <class KeyType>
+prefix_ senf::detail::PacketRegistryImpl<KeyType>::PacketRegistryImpl(std::string const & name)
+{
+    registries()[name] = this;
+}
+
+template <class KeyType>
+prefix_ typename senf::detail::PacketRegistryImpl<KeyType>::iterator
+senf::detail::PacketRegistryImpl<KeyType>::begin()
+    const
+{
+    return boost::make_transform_iterator(
+        registry_.begin(), ::__gnu_cxx::select1st<typename PacketMap::value_type>());
+}
+
+template <class KeyType>
+prefix_ typename senf::detail::PacketRegistryImpl<KeyType>::iterator
+senf::detail::PacketRegistryImpl<KeyType>::end()
+    const
+{
+    return boost::make_transform_iterator(
+        registry_.end(), ::__gnu_cxx::select1st<typename PacketMap::value_type>());
+}
+
 ///////////////////////////////PacketRegistry..e///////////////////////////////////////
 #undef prefix_
 
-\f
+
 // Local Variables:
 // mode: c++
 // fill-column: 100