aboutsummaryrefslogtreecommitdiff
path: root/lib/service/event.cpp
diff options
context:
space:
mode:
authorAndreas Monzner <andreas.monzner@multimedia-labs.de>2005-12-05 11:17:11 +0000
committerAndreas Monzner <andreas.monzner@multimedia-labs.de>2005-12-05 11:17:11 +0000
commit54e57557c7867d3d492ce9bd658ec2d672cd0168 (patch)
treeb75d3360ea29741219dd4522306a774bd04d9df6 /lib/service/event.cpp
parent91d875c1fe21ae2333475c74d46215b2ad3063cd (diff)
downloadenigma2-54e57557c7867d3d492ce9bd658ec2d672cd0168.tar.gz
enigma2-54e57557c7867d3d492ce9bd658ec2d672cd0168.zip
use eit component tags to get language info of audio streams (premiere)
Diffstat (limited to 'lib/service/event.cpp')
-rw-r--r--lib/service/event.cpp40
1 files changed, 35 insertions, 5 deletions
diff --git a/lib/service/event.cpp b/lib/service/event.cpp
index e76ea315..81a8d4bb 100644
--- a/lib/service/event.cpp
+++ b/lib/service/event.cpp
@@ -6,9 +6,11 @@
#include <dvbsi++/short_event_descriptor.h>
#include <dvbsi++/extended_event_descriptor.h>
#include <dvbsi++/linkage_descriptor.h>
+#include <dvbsi++/component_descriptor.h>
#include <dvbsi++/descriptor_tag.h>
DEFINE_REF(eServiceEvent);
+DEFINE_REF(eComponentData);
const char MAX_LANG = 37;
/* OSD language (see /share/locales/locales) to iso639 conversion table */
@@ -109,18 +111,30 @@ bool eServiceEvent::loadLanguage(Event *evt, std::string lang, int tsidonid)
{
switch ((*desc)->getTag())
{
+ case COMPONENT_DESCRIPTOR:
+ {
+ const ComponentDescriptor *cp = (ComponentDescriptor*)*desc;
+ eComponentData data;
+ data.m_streamContent = cp->getStreamContent();
+ data.m_componentType = cp->getComponentType();
+ data.m_componentTag = cp->getComponentTag();
+ data.m_iso639LanguageCode = cp->getIso639LanguageCode();
+ data.m_text = convertDVBUTF8(cp->getText());
+ m_component_data.push_back(data);
+ break;
+ }
case LINKAGE_DESCRIPTOR:
{
const LinkageDescriptor *ld = (LinkageDescriptor*)*desc;
if ( ld->getLinkageType() == 0xB0 )
{
linkage_service s;
- s.onid = ld->getOriginalNetworkId();
- s.tsid = ld->getTransportStreamId();
- s.sid = ld->getServiceId();
+ s.m_onid = ld->getOriginalNetworkId();
+ s.m_tsid = ld->getTransportStreamId();
+ s.m_sid = ld->getServiceId();
const PrivateDataByteVector *privateData =
ld->getPrivateDataBytes();
- s.description.assign((const char*)&((*privateData)[0]), privateData->size());
+ s.m_description.assign((const char*)&((*privateData)[0]), privateData->size());
m_linkage_services.push_back(s);
}
break;
@@ -158,7 +172,7 @@ RESULT eServiceEvent::parseFrom(Event *evt, int tsidonid)
return 0;
}
-std::string eServiceEvent::getBeginTimeString()
+std::string eServiceEvent::getBeginTimeString() const
{
tm t;
localtime_r(&m_begin, &t);
@@ -169,4 +183,20 @@ std::string eServiceEvent::getBeginTimeString()
return std::string(tmp, 12);
}
+RESULT eServiceEvent::getComponentData(ePtr<eComponentData> &dest, int tagnum) const
+{
+ std::list<eComponentData>::const_iterator it =
+ m_component_data.begin();
+ for(;it != m_component_data.end(); ++it)
+ {
+ if ( it->m_componentTag == tagnum )
+ {
+ dest=new eComponentData(*it);
+ return 0;
+ }
+ }
+ dest=0;
+ return -1;
+}
+
DEFINE_REF(eDebugClass);