X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2FGenericTLV.cti;h=55005161e9e1bd0511fdc4191d953fb195904373;hb=6c0332484574ed1cb571bbc0dc9f0a37d6653282;hp=a5d39b5dda1b1a95ae90bbfe162a07b399bf6f86;hpb=f723d7852a8195072eee387ea9ca77156b58438b;p=senf.git diff --git a/senf/Packets/GenericTLV.cti b/senf/Packets/GenericTLV.cti index a5d39b5..5500516 100644 --- a/senf/Packets/GenericTLV.cti +++ b/senf/Packets/GenericTLV.cti @@ -30,6 +30,9 @@ #define prefix_ inline ///////////////////////////////cti.p/////////////////////////////////////// +/////////////////////////////////////////////////////////////////////////// +// senf::GenericTLVParserBase + template prefix_ senf::PacketParserBase::size_type senf::GenericTLVParserBase::bytes() { @@ -56,7 +59,7 @@ template prefix_ bool senf::GenericTLVParserBase::is() const { - return this->type().value() == Parser::TYPEID; + return this->type().value() == Parser::typeId; } template @@ -72,6 +75,13 @@ 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 @@ -104,6 +114,28 @@ prefix_ void senf::GenericTLVParserBase::value( #endif + +/////////////////////////////////////////////////////////////////////////// +// senf::detail:GenericTLVParserRegistry_Entry + +template +prefix_ void senf::detail::GenericTLVParserRegistry_Entry::dump( + GenericTLVParserBase const & parser, std::ostream & os) +{ + (parser.template as()).dump(os); +} + + +/////////////////////////////////////////////////////////////////////////// +// senf::GenericTLVParserRegistry::RegistrationProxy + +template +template +prefix_ senf::GenericTLVParserRegistry::RegistrationProxy::RegistrationProxy() +{ + GenericTLVParserRegistry::instance().registerParser(); +}; + ///////////////////////////////cti.e/////////////////////////////////////// #undef prefix_