X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2FGenericTLV.cti;h=f30cd9e9a295be8d9a2b38d8a25450ea400e2c77;hb=7ee689fe38d66aa3a0004d55e8708750d35adc0b;hp=55a4573d8f7eb1947022199df4b352270d9312e4;hpb=bea7cfcf3d02688ece159d76890acfe2d0051d71;p=senf.git
diff --git a/senf/Packets/GenericTLV.cti b/senf/Packets/GenericTLV.cti
index 55a4573..f30cd9e 100644
--- a/senf/Packets/GenericTLV.cti
+++ b/senf/Packets/GenericTLV.cti
@@ -28,15 +28,19 @@
// Custom includes
#define prefix_ inline
-///////////////////////////////cti.p///////////////////////////////////////
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
-///////////////////////////////////////////////////////////////////////////
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
// senf::GenericTLVParserBase
template
prefix_ senf::PacketParserBase::size_type senf::GenericTLVParserBase::bytes()
+ const
{
- return senf::bytes(self()) + this->length();
+ if (Base::Registry::instance().isRegistered( *this))
+ return Base::Registry::instance().bytes( *this);
+ else
+ return senf::bytes(self()) + this->length();
}
template
@@ -82,8 +86,8 @@ template
prefix_ void senf::GenericTLVParserBase::value(
ForwardReadableRange const & val,
typename boost::disable_if >::type *)
-{
- value_( val);
+{
+ value_( val);
}
template
@@ -91,8 +95,8 @@ template
prefix_ void senf::GenericTLVParserBase::value(
std::pair const & val,
typename boost::disable_if >::type *)
-{
- value_( val);
+{
+ value_( val);
}
template
@@ -100,15 +104,15 @@ template
prefix_ void senf::GenericTLVParserBase::value(
std::pair const & val,
typename boost::enable_if >::type *)
-{
+{
this->type() = val.first;
- value_( val.second);
+ value_( val.second);
}
#endif
-///////////////////////////////////////////////////////////////////////////
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
// senf::detail:GenericTLVParserRegistry_Entry
template
@@ -119,12 +123,21 @@ prefix_ void senf::detail::GenericTLVParserRegistry_Entry::d
(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(
- GenericTLVParserBase const & parser)
+ GenericTLVParser const & parser)
const
{
typename Map::const_iterator i (map_.find( parser.type()));
@@ -139,7 +152,7 @@ prefix_ bool senf::GenericTLVParserRegistry::isRegistered(Ke
return i != map_.end();
}
-///////////////////////////////////////////////////////////////////////////
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
// senf::GenericTLVParserRegistry::RegistrationProxy
template
@@ -149,7 +162,7 @@ prefix_ senf::GenericTLVParserRegistry::RegistrationProxy::instance().registerParser();
};
-///////////////////////////////cti.e///////////////////////////////////////
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
#undef prefix_