X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPackets%2FGenericTLV.cti;h=fb5c6bb55473bf1ef15ecf2db214aa41ecfaecf5;hb=a0b6f53e5c464c6b84fed30a67fcce32da81012d;hp=f66eec3f4fa4f4d30c41693763ba4b04139469c4;hpb=a79c5e98760ea8232c13d8266eb7ca0ac5cdefd3;p=senf.git diff --git a/senf/Packets/GenericTLV.cti b/senf/Packets/GenericTLV.cti index f66eec3..fb5c6bb 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,17 +61,33 @@ 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 *static_cast(this); +} + +template +prefix_ Base const & senf::GenericTLVParserBase::self() + const { - return this->type().value() == Parser::TYPEID; + return *static_cast(this); } +#ifndef DOXYGEN + template template prefix_ void senf::GenericTLVParserBase::value( ForwardReadableRange const & val, typename boost::disable_if >::type *) -{ - value_( val); +{ + value_( val); } template @@ -71,8 +95,8 @@ template prefix_ void senf::GenericTLVParserBase::value( std::pair const & val, typename boost::disable_if >::type *) -{ - value_( val); +{ + value_( val); } template @@ -80,11 +104,64 @@ 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 +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_