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_