// Custom includes
#define prefix_ inline
-///////////////////////////////cti.p///////////////////////////////////////
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
-///////////////////////////////////////////////////////////////////////////
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
// senf::GenericTLVParserBase<Base>
template <class Base>
prefix_ senf::PacketParserBase::size_type senf::GenericTLVParserBase<Base>::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 <class Base>
prefix_ void senf::GenericTLVParserBase<Base>::value(
ForwardReadableRange const & val,
typename boost::disable_if<senf::is_pair<ForwardReadableRange> >::type *)
-{
- value_( val);
+{
+ value_( val);
}
template <class Base>
prefix_ void senf::GenericTLVParserBase<Base>::value(
std::pair<First, Second> const & val,
typename boost::disable_if<boost::is_convertible<First, typename Base::type_t::value_type> >::type *)
-{
- value_( val);
+{
+ value_( val);
}
template <class Base>
prefix_ void senf::GenericTLVParserBase<Base>::value(
std::pair<Type, ForwardReadableRange> const & val,
typename boost::enable_if<boost::is_convertible<Type, typename Base::type_t::value_type> >::type *)
-{
+{
this->type() = val.first;
- value_( val.second);
+ value_( val.second);
}
#endif
-///////////////////////////////////////////////////////////////////////////
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
// senf::detail:GenericTLVParserRegistry_Entry<BaseParser, Parser>
template <class BaseParser, class Parser>
(parser.template as<Parser>()).dump(os);
}
-///////////////////////////////////////////////////////////////////////////
+template <class BaseParser, class Parser>
+prefix_ senf::PacketParserBase::size_type
+senf::detail::GenericTLVParserRegistry_Entry<BaseParser, Parser>::bytes(
+ GenericTLVParserBase<BaseParser> const & parser)
+ const
+{
+ return senf::bytes( parser.template as<Parser>());
+}
+
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
// senf::GenericTLVParserRegistry<BaseParser,Keytype>
template <class BaseParser, class Keytype>
prefix_ bool senf::GenericTLVParserRegistry<BaseParser,Keytype>::isRegistered(
- GenericTLVParserBase<BaseParser> const & parser)
+ GenericTLVParser const & parser)
const
{
typename Map::const_iterator i (map_.find( parser.type()));
return i != map_.end();
}
-///////////////////////////////////////////////////////////////////////////
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
// senf::GenericTLVParserRegistry<BaseParser,Keytype>::RegistrationProxy<PacketParser>
template <class BaseParser, class Keytype>
GenericTLVParserRegistry<BaseParser,Keytype>::instance().registerParser<PacketParser>();
};
-///////////////////////////////cti.e///////////////////////////////////////
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
#undef prefix_
\f