aboutsummaryrefslogtreecommitdiff
path: root/lib/dvb_si/cell_list_descriptor.cpp
blob: c8588aebae0c3e5ca3076e0714fd67e3f2431379 (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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
/*
 * $Id: cell_list_descriptor.cpp,v 1.1 2003-10-17 15:36:37 tmbinc Exp $
 *
 * (C) 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.
 *
 */


#include <lib/dvb_si/cell_list_descriptor.h>

Subcell::Subcell(const uint8_t * const buffer)
{
	cellIdExtension = buffer[0];
	subcellLatitude = (buffer[1] << 8) | buffer[2];
	subcellLongitude = (buffer[3] << 8) | buffer[4];
	subcellExtendOfLatitude = (buffer[5] << 4) | ((buffer[6] >> 4) & 0x0f);
	subcellExtendOfLongitude = ((buffer[6] & 0x0f) << 8) | buffer[7];
}

uint8_t Subcell::getCellIdExtension(void) const
{
	return cellIdExtension;
}

uint16_t Subcell::getSubcellLatitude(void) const
{
	return subcellLatitude;
}

uint16_t Subcell::getSubcellLongtitude(void) const
{
	return subcellLongitude;
}

uint16_t Subcell::getSubcellExtendOfLatitude(void) const
{
	return subcellExtendOfLatitude;
}

uint16_t Subcell::getSubcellExtendOfLongtitude(void) const
{
	return subcellExtendOfLongitude;
}

Cell::Cell(const uint8_t * const buffer)
{
	cellId = (buffer[0] << 8) | buffer[1];
	cellLatitude = (buffer[2] << 8) | buffer[3];
	cellLongtitude = (buffer[4] << 8) | buffer[5];
	cellExtendOfLatitude = (buffer[6] << 4) | ((buffer[7] >> 4) & 0x0f);
	cellExtendOfLongtitude = ((buffer[7] & 0x0f) << 8) | buffer[8];
	subcellInfoLoopLength = buffer[9];

	for (uint16_t i = 0; i < subcellInfoLoopLength; i += 8)
		subcells.push_back(new Subcell(&buffer[i + 10]));
}

Cell::~Cell(void)
{
	for (SubcellIterator i = subcells.begin(); i != subcells.end(); ++i)
		delete *i;
}

uint16_t Cell::getCellId(void) const
{
	return cellId;
}

uint16_t Cell::getCellLatitude(void) const
{
	return cellLatitude;
}

uint16_t Cell::getCellLongtitude(void) const
{
	return cellLongtitude;
}

uint16_t Cell::getCellExtendOfLatitude(void) const
{
	return cellExtendOfLatitude;
}

uint16_t Cell::getCellExtendOfLongtitude(void) const
{
	return cellExtendOfLongtitude;
}

const SubcellVector *Cell::getSubcells(void) const
{
	return &subcells;
}

CellListDescriptor::CellListDescriptor(const uint8_t * const buffer) : Descriptor(buffer)
{
	for (uint16_t i = 0; i < descriptorLength; i += buffer[i + 11] + 10)
		cells.push_back(new Cell(&buffer[i + 2]));
}

CellListDescriptor::~CellListDescriptor(void)
{
	for (CellIterator i = cells.begin(); i != cells.end(); ++i)
		delete *i;
}

const CellVector *CellListDescriptor::getCells(void) const
{
	return &cells;
}