X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FMPEGDVBBundle%2FTLVPacket.hh;h=3954df923041105815cf82daa6f9a8b902772da0;hb=80c17af991e2f4690c7601e4408954322b176fe9;hp=2bbccb35ba18e2810b14d7c46371fa9e1525953a;hpb=63b12ae31810ee764d8a44c039056727da951bf8;p=senf.git diff --git a/Packets/MPEGDVBBundle/TLVPacket.hh b/Packets/MPEGDVBBundle/TLVPacket.hh index 2bbccb3..3954df9 100644 --- a/Packets/MPEGDVBBundle/TLVPacket.hh +++ b/Packets/MPEGDVBBundle/TLVPacket.hh @@ -28,15 +28,19 @@ // Custom includes #include -#include "../../Packets/PacketType.hh" -#include "../../Packets/ParseInt.hh" -#include "../../Packets/PacketParser.hh" +#include "../../Packets/Packets.hh" //#include "TLVPacket.mpp" ///////////////////////////////hh.p//////////////////////////////////////// namespace senf { + /** \brief xxx + + \todo document me + \todo add usefull exceptions strings + + */ struct UnsuportedTLVPacketException : public std::exception { virtual char const * what() const throw() { @@ -44,27 +48,26 @@ namespace senf { } }; + /** \brief xxx + \todo document me + */ class Parse_TLVPacketLength : public detail::packet::ParseIntOps, public PacketParserBase { public: -# ifndef DOXYGEN - - SENF_PACKET_PARSER_NO_INIT(Parse_TLVPacketLength); - -# endif + Parse_TLVPacketLength(data_iterator i, state_type s) : PacketParserBase(i,s) {} typedef boost::uint32_t value_type; - - value_type value() const; + static const size_type init_bytes = 1; + static value_type const min_value = 0; + static value_type const max_value = 4294967295u; + value_type value() const; void value(value_type const & v); Parse_TLVPacketLength const & operator= (value_type other); - - static const size_type init_bytes = 1; - + size_type bytes() const; void init() const; @@ -82,60 +85,59 @@ namespace senf { } void resize(size_type size); - }; /** \brief parse TLVPacket Packet - XXX - + \todo document me + \see TLVPacketType */ + template struct Parse_TLVPacket : public PacketParserBase { -# ifndef DOXYGEN +# include SENF_PARSER() - SENF_PACKET_PARSER_INIT(Parse_TLVPacket); + SENF_PARSER_FIELD( type, Parse_UInt32 ); + SENF_PARSER_FIELD( length, LengthParser ); - SENF_PACKET_PARSER_DEFINE_FIELDS( - ((Field)( type, Parse_UInt32 )) - ((Field)( length, Parse_TLVPacketLength )) - ); - -# endif + SENF_PARSER_FINALIZE(Parse_TLVPacket); }; - - /** \brief TLV Packet + + /** \brief generic TLV Packet type + + \todo document me - \par Packet type (typedef): - \ref TLVPacket - - \par Fields: - \ref Parse_TLVPacket - \ingroup protocolbundle_mpegdvb */ + template struct TLVPacketType : public PacketTypeBase { - typedef ConcretePacket packet; - typedef Parse_TLVPacket parser; - +#ifndef DOXYGEN + typedef ConcretePacket > packet; + typedef Parse_TLVPacket parser; +#endif static optional_range nextPacketRange(packet p); - static void init(packet p); static size_type initSize(); + static void finalize(packet p); + static void dump(packet p, std::ostream & os); }; - - typedef TLVPacketType::packet TLVPacket; + + typedef TLVPacketType::packet TLVPacket; + typedef ConcretePacket > TLVFix8Packet; + typedef ConcretePacket > TLVFix16Packet; + typedef ConcretePacket > TLVFix24Packet; + typedef ConcretePacket > TLVFix32Packet; } ///////////////////////////////hh.e//////////////////////////////////////// //#include "TLVPacket.cci" -//#include "TLVPacket.ct" +#include "TLVPacket.ct" //#include "TLVPacket.cti" #endif