X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2FGenericTLV.cti;h=b4ba16eed488223779e95a5dcbce391e47c5340a;hb=0f235de98cae838afb42244ebd307ce8cd1db409;hp=55005161e9e1bd0511fdc4191d953fb195904373;hpb=9ffdaae4804503c4f36a53747c852a87ee626b9e;p=senf.git diff --git a/senf/Packets/GenericTLV.cti b/senf/Packets/GenericTLV.cti index 5500516..b4ba16e 100644 --- a/senf/Packets/GenericTLV.cti +++ b/senf/Packets/GenericTLV.cti @@ -36,7 +36,10 @@ template prefix_ senf::PacketParserBase::size_type senf::GenericTLVParserBase::bytes() { - 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 @@ -75,13 +78,6 @@ prefix_ Base const & senf::GenericTLVParserBase::self() return *static_cast(this); } -template -prefix_ void senf::GenericTLVParserBase::dump(std::ostream & os) - const -{ - GenericTLVParserRegistry::instance().dump(*this, os); -} - #ifndef DOXYGEN template @@ -121,19 +117,48 @@ prefix_ void senf::GenericTLVParserBase::value( 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 +// senf::GenericTLVParserRegistry::RegistrationProxy -template +template template -prefix_ senf::GenericTLVParserRegistry::RegistrationProxy::RegistrationProxy() +prefix_ senf::GenericTLVParserRegistry::RegistrationProxy::RegistrationProxy() { - GenericTLVParserRegistry::instance().registerParser(); + GenericTLVParserRegistry::instance().registerParser(); }; ///////////////////////////////cti.e///////////////////////////////////////