- fix initialisation
[enigma2.git] / lib / dvb_si / bat.cpp
1 /*
2  * $Id: bat.cpp,v 1.1 2003-10-17 15:36:37 tmbinc Exp $
3  *
4  * (C) 2002-2003 Andreas Oberritter <obi@saftware.de>
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19  *
20  */
21
22 #include <lib/dvb_si/bat.h>
23
24 BouquetAssociation::BouquetAssociation(const uint8_t * const buffer)
25 {
26         transportStreamId = (buffer[0] << 8) | buffer[1];
27         originalNetworkId = (buffer[2] << 8) | buffer[3];
28         reserved = (buffer[4] >> 4) & 0x0f;
29         transportStreamLoopLength = ((buffer[4] & 0x0f) << 8) | buffer[5];
30
31         for (uint16_t i = 6; i < transportStreamLoopLength + 6; i += buffer[i + 1] + 2)
32                 descriptor(&buffer[i]);
33 }
34
35 BouquetAssociationTable::BouquetAssociationTable(const uint8_t * const buffer) : LongCrcTable(buffer)
36 {
37         reserved4 = (buffer[8] >> 4) & 0x0f;
38         bouquetDescriptorsLength = ((buffer[8] & 0x0f) << 8) | buffer[9];
39
40         for (uint16_t i = 10; i < bouquetDescriptorsLength + 10; i += buffer[i + 1] + 2)
41                 descriptor(&buffer[i]);
42
43         reserved5 = (buffer[bouquetDescriptorsLength + 10] >> 4) & 0x0f;
44         transportStreamLoopLength = ((buffer[bouquetDescriptorsLength + 10] & 0x0f) << 8) | buffer[bouquetDescriptorsLength + 11];
45
46         for (uint16_t i = bouquetDescriptorsLength + 12; i < sectionLength - 1; i += ((buffer[i + 4] & 0x0f) | buffer[i + 5]) + 6)
47                 bouquet.push_back(new BouquetAssociation(&buffer[i]));
48 }
49
50 BouquetAssociationTable::~BouquetAssociationTable(void)
51 {
52         for (BouquetAssociationIterator b = bouquet.begin(); b != bouquet.end(); ++b)
53                 delete *b;
54 }
55