aboutsummaryrefslogtreecommitdiff
path: root/lib/dvb_si/eit.h
blob: d065f4ec7d727d847915bd28a8aa6fae8fef1bb3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/*
 * $Id$
 *
 * (C) 2002-2003 Andreas Oberritter <obi@saftware.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
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 */

#ifndef __dvb_table_eit_h__
#define __dvb_table_eit_h__

#include <lib/dvb_si/container.h>
#include "long_crc_table.h"

class Event : public DescriptorContainer
{
	protected:
		unsigned eventId				: 16;
		unsigned startTimeMjd				: 16;
		unsigned startTimeBcd				: 24;
		unsigned duration				: 24;
		unsigned runningStatus				: 3;
		unsigned freeCaMode				: 1;
		unsigned descriptorsLoopLength			: 12;

	public:
		Event(const uint8_t * const buffer);

		uint16_t getEventId(void) const;
		uint16_t getStartTimeMjd(void) const;
		uint32_t getStartTimeBcd(void) const;
		uint32_t getDuration(void) const;
		uint8_t getRunningStatus(void) const;
		uint8_t getFreeCaMode(void) const;
};

typedef std::vector<Event *> EventVector;
typedef EventVector::iterator EventIterator;
typedef EventVector::const_iterator EventConstIterator;

class EventInformationTable : public LongCrcTable
{
	protected:
		unsigned transportStreamId			: 16;
		unsigned originalNetworkId			: 16;
		unsigned segmentLastSectionNumber		: 8;
		unsigned lastTableId				: 8;
		EventVector events;

	public:
		EventInformationTable(const uint8_t * const buffer);
		~EventInformationTable(void);

		static const uint16_t LENGTH = 4096;
		static const enum PacketId PID = PID_EIT;
		static const enum TableId TID = TID_EIT_ACTUAL;
		static const uint32_t TIMEOUT = 3000;

		uint16_t getTransportStreamId(void) const;
		uint16_t getOriginalNetworkId(void) const;
		uint8_t getLastSectionNumber(void) const;
		uint8_t getLastTableId(void) const;
		const EventVector *getEvents(void) const;
};

typedef std::vector<EventInformationTable *> EventInformationTableVector;
typedef EventInformationTableVector::iterator EventInformationTableIterator;
typedef EventInformationTableVector::const_iterator EventInformationTableConstIterator;

#endif /* __dvb_table_eit_h__ */