X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2FGenericTLV.cti;h=b9a0960e41a837d43fa312f30b6d31c793126273;hb=8ce5d6817ae748496d7db06ff4b35ad496fa3d21;hp=f66eec3f4fa4f4d30c41693763ba4b04139469c4;hpb=a79c5e98760ea8232c13d8266eb7ca0ac5cdefd3;p=senf.git
diff --git a/senf/Packets/GenericTLV.cti b/senf/Packets/GenericTLV.cti
index f66eec3..b9a0960 100644
--- a/senf/Packets/GenericTLV.cti
+++ b/senf/Packets/GenericTLV.cti
@@ -30,10 +30,17 @@
#define prefix_ inline
///////////////////////////////cti.p///////////////////////////////////////
+///////////////////////////////////////////////////////////////////////////
+// senf::GenericTLVParserBase
+
template
prefix_ senf::PacketParserBase::size_type senf::GenericTLVParserBase::bytes()
+ const
{
- return senf::init_bytes::value + this->length();
+ if (Base::Registry::instance().isRegistered( *this))
+ return Base::Registry::instance().bytes( *this);
+ else
+ return senf::bytes(self()) + this->length();
}
template
@@ -46,6 +53,7 @@ prefix_ void senf::GenericTLVParserBase::init()
template
template
prefix_ Parser senf::GenericTLVParserBase::as()
+ const
{
return Parser(this->i(), this->state() );
}
@@ -53,11 +61,27 @@ prefix_ Parser senf::GenericTLVParserBase::as()
template
template
prefix_ bool senf::GenericTLVParserBase::is()
+ const
+{
+ return this->type().value() == Parser::typeId;
+}
+
+template
+prefix_ Base & senf::GenericTLVParserBase::self()
{
- return this->type().value() == Parser::TYPEID;
+ return *static_cast(this);
}
template
+prefix_ Base const & senf::GenericTLVParserBase::self()
+ const
+{
+ return *static_cast(this);
+}
+
+#ifndef DOXYGEN
+
+template
template
prefix_ void senf::GenericTLVParserBase::value(
ForwardReadableRange const & val,
@@ -85,6 +109,59 @@ prefix_ void senf::GenericTLVParserBase::value(
value_( val.second);
}
+#endif
+
+
+///////////////////////////////////////////////////////////////////////////
+// senf::detail:GenericTLVParserRegistry_Entry
+
+template
+prefix_ void senf::detail::GenericTLVParserRegistry_Entry::dump(
+ GenericTLVParserBase const & parser, std::ostream & os)
+ const
+{
+ (parser.template as()).dump(os);
+}
+
+template
+prefix_ senf::PacketParserBase::size_type
+senf::detail::GenericTLVParserRegistry_Entry::bytes(
+ GenericTLVParserBase const & parser)
+ const
+{
+ return senf::bytes( parser.template as());
+}
+
+///////////////////////////////////////////////////////////////////////////
+// senf::GenericTLVParserRegistry
+
+template
+prefix_ bool senf::GenericTLVParserRegistry::isRegistered(
+ GenericTLVParser const & parser)
+ const
+{
+ typename Map::const_iterator i (map_.find( parser.type()));
+ return i != map_.end();
+}
+
+template
+prefix_ bool senf::GenericTLVParserRegistry::isRegistered(Keytype const & key)
+ const
+{
+ typename Map::const_iterator i (map_.find( key));
+ return i != map_.end();
+}
+
+///////////////////////////////////////////////////////////////////////////
+// senf::GenericTLVParserRegistry::RegistrationProxy
+
+template
+template
+prefix_ senf::GenericTLVParserRegistry::RegistrationProxy::RegistrationProxy()
+{
+ GenericTLVParserRegistry::instance().registerParser();
+};
+
///////////////////////////////cti.e///////////////////////////////////////
#undef prefix_