-// $Id$
+// $Id:TransportPacket.hh 560 2007-12-13 14:39:37Z tho $
//
// Copyright (C) 2007
-// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS)
-// Kompetenzzentrum fuer Satelitenkommunikation (SatCom)
-// Thorsten Horstmann <thorsten.horstmann@fokus.fraunhofer.de>
+// Fraunhofer Institute for Open Communication Systems (FOKUS)
+// Competence Center NETwork research (NET), St. Augustin, GERMANY
+// Thorsten Horstmann <tho@berlios.de>
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
\see TransportPacketType
*/
- struct Parse_TransportPacket : public PacketParserBase
+ struct TransportPacketParser : public PacketParserBase
{
# include SENF_FIXED_PARSER()
- SENF_PARSER_FIELD ( sync_byte , Parse_UInt8 );
-
- SENF_PARSER_BITFIELD ( transport_error_indicator , 1 , bool );
- SENF_PARSER_BITFIELD ( pusi , 1 , bool );
- SENF_PARSER_BITFIELD ( transport_priority , 1 , bool );
- SENF_PARSER_BITFIELD ( pid , 13 , unsigned );
- SENF_PARSER_BITFIELD ( transport_scrmbl_ctrl , 2 , unsigned );
- SENF_PARSER_BITFIELD ( adaptation_field_ctrl , 2 , unsigned );
- SENF_PARSER_BITFIELD ( continuity_counter , 4 , unsigned );
+ SENF_PARSER_FIELD ( sync_byte, UInt8Parser );
+
+ SENF_PARSER_BITFIELD ( transport_error_indicator, 1, bool );
+ SENF_PARSER_BITFIELD ( pusi, 1, bool );
+ SENF_PARSER_BITFIELD ( transport_priority, 1, bool );
+ SENF_PARSER_BITFIELD ( pid, 13, unsigned );
+ SENF_PARSER_BITFIELD ( transport_scrmbl_ctrl, 2, unsigned );
+ SENF_PARSER_BITFIELD ( adaptation_field_ctrl, 2, unsigned );
+ SENF_PARSER_BITFIELD ( continuity_counter, 4, unsigned );
- SENF_PARSER_FINALIZE( Parse_TransportPacket );
+ SENF_PARSER_FINALIZE( TransportPacketParser );
-// Parse_UInt8 payload_pointer() const {
-// return parse<Parse_UInt8>( Parse_TransportPacket::fixed_bytes );
+// UInt8Parser payload_pointer() const {
+// return parse<UInt8Parser>( TransportPacketParser::fixed_bytes );
// }
};
<td>transport_packet() {</td> <td></td>
</tr>
<tr>
- <td style="padding-left:2em">\ref Parse_TransportPacket::sync_byte() "sync_byte"</td>
+ <td style="padding-left:2em">\ref TransportPacketParser::sync_byte() "sync_byte"</td>
<td>8</td></tr>
<tr>
- <td style="padding-left:2em">\ref Parse_TransportPacket::transport_error_indicator() "transport_error_indicator"</td>
+ <td style="padding-left:2em">\ref TransportPacketParser::transport_error_indicator() "transport_error_indicator"</td>
<td>1</td></tr>
<tr>
- <td style="padding-left:2em">\ref Parse_TransportPacket::pusi() "payload_uni_start_indicator"</td>
+ <td style="padding-left:2em">\ref TransportPacketParser::pusi() "payload_uni_start_indicator"</td>
<td>1</td></tr>
<tr>
- <td style="padding-left:2em">\ref Parse_TransportPacket::transport_priority() "transport_priority"</td>
+ <td style="padding-left:2em">\ref TransportPacketParser::transport_priority() "transport_priority"</td>
<td>1</td></tr>
<tr>
- <td style="padding-left:2em">\ref Parse_TransportPacket::pid() "PID"</td>
+ <td style="padding-left:2em">\ref TransportPacketParser::pid() "PID"</td>
<td>13</td></tr>
<tr>
- <td style="padding-left:2em">\ref Parse_TransportPacket::transport_scrmbl_ctrl() "transport_scrambling_control"</td>
+ <td style="padding-left:2em">\ref TransportPacketParser::transport_scrmbl_ctrl() "transport_scrambling_control"</td>
<td>2</td></tr>
<tr>
- <td style="padding-left:2em">\ref Parse_TransportPacket::adaptation_field_ctrl() "adaptation_field_control"</td>
+ <td style="padding-left:2em">\ref TransportPacketParser::adaptation_field_ctrl() "adaptation_field_control"</td>
<td>2</td></tr>
<tr>
- <td style="padding-left:2em">\ref Parse_TransportPacket::continuity_counter() "continuity_counter"</td>
+ <td style="padding-left:2em">\ref TransportPacketParser::continuity_counter() "continuity_counter"</td>
<td>4</td></tr>
<tr>
<td>}</td> <td></td></tr>
\ref TransportPacket
\par Fields:
- \ref Parse_TransportPacket
+ \ref TransportPacketParser
\ingroup protocolbundle_mpegdvb
*/
{
typedef PacketTypeMixin<TransportPacketType> mixin;
typedef ConcretePacket<TransportPacketType> packet;
- typedef Parse_TransportPacket parser;
+ typedef TransportPacketParser parser;
using mixin::nextPacketRange;
using mixin::init;
using mixin::initSize;
static void dump(packet p, std::ostream & os);
+ static const byte SYNC_BYTE = 0x47;
};
/** \brief Transport packet typedef */
- typedef TransportPacketType::packet TransportPacket;
-
- #define TRANSPORT_PACKET_SYNC_BYTE 0x47
-
+ typedef ConcretePacket<TransportPacketType> TransportPacket;
}