aboutsummaryrefslogtreecommitdiff
path: root/lib/dvb_si/mosaic_descriptor.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'lib/dvb_si/mosaic_descriptor.cpp')
-rw-r--r--lib/dvb_si/mosaic_descriptor.cpp171
1 files changed, 171 insertions, 0 deletions
diff --git a/lib/dvb_si/mosaic_descriptor.cpp b/lib/dvb_si/mosaic_descriptor.cpp
new file mode 100644
index 00000000..f13bccff
--- /dev/null
+++ b/lib/dvb_si/mosaic_descriptor.cpp
@@ -0,0 +1,171 @@
+/*
+ * $Id: mosaic_descriptor.cpp,v 1.1 2003-10-17 15:36:37 tmbinc Exp $
+ *
+ * (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.
+ *
+ */
+
+#include <lib/dvb_si/mosaic_descriptor.h>
+
+ElementaryCellField::ElementaryCellField (const uint8_t * const buffer)
+{
+ reserved = (buffer[0] >> 6) & 0x03;
+ elementaryCellId = buffer[0] & 0x3F;
+}
+
+uint8_t ElementaryCellField::getElementaryCellId(void) const
+{
+ return elementaryCellId;
+}
+
+MosaicCell::MosaicCell (const uint8_t * const buffer)
+{
+ logicalCellId = (buffer[0] >> 2) & 0x3F;
+ reserved = (((buffer[0] & 0x03) << 8) | (buffer[1] & 0xF1)) >> 3;
+ logicalCellPresentationInfo = buffer[1] & 0x07;
+ elementaryCellFieldLength = buffer[2];
+
+ for (uint16_t i = 0; i < elementaryCellFieldLength; ++i)
+ elementaryCellFields.push_back(new ElementaryCellField(&buffer[i + 3]));
+
+ cellLinkageInfo = buffer[elementaryCellFieldLength + 3];
+
+ switch (cellLinkageInfo) {
+ case 0x01:
+ bouquetId = (buffer[elementaryCellFieldLength + 4] << 8) | buffer[elementaryCellFieldLength + 5];
+ break;
+ case 0x02:
+ case 0x03:
+ case 0x04:
+ originalNetworkId = (buffer[elementaryCellFieldLength + 4] << 8) | buffer[elementaryCellFieldLength + 5];
+ transportStreamId = (buffer[elementaryCellFieldLength + 6] << 8) | buffer[elementaryCellFieldLength + 7];
+ serviceId = (buffer[elementaryCellFieldLength + 8] << 8) | buffer[elementaryCellFieldLength + 9];
+ break;
+ default:
+ break;
+ }
+
+ if (cellLinkageInfo == 0x04)
+ eventId = (buffer[elementaryCellFieldLength + 10] << 8) | buffer[elementaryCellFieldLength + 11];
+}
+
+MosaicCell::~MosaicCell(void)
+{
+ for (ElementaryCellFieldIterator i = elementaryCellFields.begin(); i != elementaryCellFields.end(); ++i)
+ delete *i;
+}
+
+uint8_t MosaicCell::getLogicalCellId(void) const
+{
+ return logicalCellId;
+}
+
+uint8_t MosaicCell::getLogicalCellPresentationInfo(void) const
+{
+ return logicalCellPresentationInfo;
+}
+
+const ElementaryCellFieldVector *MosaicCell::getElementaryCellFields(void) const
+{
+ return &elementaryCellFields;
+}
+
+uint8_t MosaicCell::getCellLinkageInfo(void) const
+{
+ return cellLinkageInfo;
+}
+
+uint16_t MosaicCell::getBouquetId(void) const
+{
+ return bouquetId;
+}
+
+uint16_t MosaicCell::getOriginalNetworkId(void) const
+{
+ return originalNetworkId;
+}
+
+uint16_t MosaicCell::getTransportStreamId(void) const
+{
+ return transportStreamId;
+}
+
+uint16_t MosaicCell::getServiceId(void) const
+{
+ return serviceId;
+}
+
+uint16_t MosaicCell::getEventId(void) const
+{
+ return eventId;
+}
+
+MosaicDescriptor::MosaicDescriptor(const uint8_t * const buffer) : Descriptor(buffer)
+{
+ if (descriptorLength < 1)
+ return;
+
+ mosaicEntryPoint = (buffer[2] >> 7) & 0x01;
+ numberOfHorizontalElementaryCells = (buffer[2] >> 4) & 0x07;
+ reserved = (buffer[2] >> 3) & 0x01;
+ numberOfVerticalElementaryCells = buffer[2] & 0x07;
+
+ for (uint16_t i = 0; i < descriptorLength - 1; i += buffer[i + 6] + 2) {
+ mosaicCells.push_back(new MosaicCell(&buffer[i + 1]));
+ switch (buffer[i + 6 + buffer[i + 6] + 1]) {
+ case 0x01:
+ i += 2;
+ break;
+ case 0x02:
+ case 0x03:
+ i += 6;
+ break;
+ case 0x04:
+ i += 8;
+ break;
+ default:
+ break;
+ }
+ }
+}
+
+MosaicDescriptor::~MosaicDescriptor(void)
+{
+ for (MosaicCellIterator i = mosaicCells.begin(); i != mosaicCells.end(); ++i)
+ delete *i;
+}
+
+uint8_t MosaicDescriptor::getMosaicEntryPoint(void) const
+{
+ return mosaicEntryPoint;
+}
+
+uint8_t MosaicDescriptor::getNumberOfHorizontalElementaryCells(void) const
+{
+ return numberOfHorizontalElementaryCells;
+}
+
+uint8_t MosaicDescriptor::getNumberOfVerticalElementaryCells(void) const
+{
+ return numberOfVerticalElementaryCells;
+}
+
+const MosaicCellVector *MosaicDescriptor::getMosaicCells(void) const
+{
+ return &mosaicCells;
+}
+