aboutsummaryrefslogtreecommitdiff
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
parent91d875c1fe21ae2333475c74d46215b2ad3063cd (diff)
downloadenigma2-54e57557c7867d3d492ce9bd658ec2d672cd0168.tar.gz
enigma2-54e57557c7867d3d492ce9bd658ec2d672cd0168.zip
use eit component tags to get language info of audio streams (premiere)
-rw-r--r--lib/dvb/pmt.cpp7
-rw-r--r--lib/python/Screens/AudioSelection.py42
-rw-r--r--lib/service/event.cpp40
-rw-r--r--lib/service/event.h48
-rw-r--r--lib/service/servicedvb.cpp19
5 files changed, 89 insertions, 67 deletions
diff --git a/lib/dvb/pmt.cpp b/lib/dvb/pmt.cpp
index 19e6cf9c..fdee5b40 100644
--- a/lib/dvb/pmt.cpp
+++ b/lib/dvb/pmt.cpp
@@ -7,7 +7,7 @@
#include <dvbsi++/ca_program_map_section.h>
#include <dvbsi++/descriptor_tag.h>
#include <dvbsi++/iso639_language_descriptor.h>
-#include <dvbsi++/component_descriptor.h>
+#include <dvbsi++/stream_identifier_descriptor.h>
eDVBServicePMTHandler::eDVBServicePMTHandler(int record)
:m_ca_servicePtr(0)
@@ -143,6 +143,7 @@ int eDVBServicePMTHandler::getProgramInfo(struct program &program)
int isaudio = 0, isvideo = 0;
videoStream video;
audioStream audio;
+ audio.component_tag=-1;
video.pid = (*es)->getPid();
audio.pid = (*es)->getPid();
@@ -191,8 +192,8 @@ int eDVBServicePMTHandler::getProgramInfo(struct program &program)
break;
}
- case COMPONENT_DESCRIPTOR:
- audio.component_tag = ((ComponentDescriptor*)*desc)->getComponentTag();
+ case STREAM_IDENTIFIER_DESCRIPTOR:
+ audio.component_tag = ((StreamIdentifierDescriptor*)*desc)->getComponentTag();
break;
}
}
diff --git a/lib/python/Screens/AudioSelection.py b/lib/python/Screens/AudioSelection.py
index a3841747..e69de29b 100644
--- a/lib/python/Screens/AudioSelection.py
+++ b/lib/python/Screens/AudioSelection.py
@@ -1,42 +0,0 @@
-from Screen import Screen
-from Components.ActionMap import ActionMap
-from Components.MenuList import MenuList
-from Components.Label import Label
-from Tools.ISO639 import LanguageCodes
-
-class AudioSelection(Screen):
- def KeyOk(self):
- selection = self["tracks"].getCurrent()
- print "select track " + str(selection[1])
-
- self.audio.selectTrack(selection[1])
- self.close()
- def __init__(self, session, audio):
- Screen.__init__(self, session)
-
- self["actions"] = ActionMap(["OkCancelActions"],
- {
- "cancel": self.close,
- "ok": self.KeyOk,
- })
-
- self.audio = audio
-
- tlist = []
- n = audio.getNumberOfTracks()
- for x in range(n):
- i = audio.getTrackInfo(x)
- langCode = i.getLanguage()
-
- description = i.getDescription();
-
- if langCode in LanguageCodes:
- language = LanguageCodes[langCode][0]
- if len(description):
- description += " (" + language + ")"
- else:
- description = language
-
- tlist.append((description, x))
-
- self["tracks"] = MenuList(tlist)
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);
diff --git a/lib/service/event.h b/lib/service/event.h
index 3bbb322e..d224c183 100644
--- a/lib/service/event.h
+++ b/lib/service/event.h
@@ -9,21 +9,42 @@
class Event;
#endif
+struct eComponentData
+{
+DECLARE_REF(eComponentData);
+#ifndef SWIG
+ uint8_t m_streamContent;
+ uint8_t m_componentType;
+ uint8_t m_componentTag;
+ std::string m_iso639LanguageCode;
+ std::string m_text;
+#endif
+ int getStreamContent(void) const { return m_streamContent; }
+ int getComponentType(void) const { return m_componentType; }
+ int getComponentTag(void) const { return m_componentTag; }
+ std::string getIso639LanguageCode(void) const { return m_iso639LanguageCode; }
+ std::string getText(void) const { return m_text; }
+};
+
+TEMPLATE_TYPEDEF(ePtr<eComponentData>, eComponentDataPtr);
+
+struct linkage_service
+{
+ uint16_t m_sid;
+ uint16_t m_onid;
+ uint16_t m_tsid;
+ std::string m_description;
+};
+
class eServiceEvent: public iObject
{
DECLARE_REF(eServiceEvent);
#ifndef SWIG
bool loadLanguage(Event *event, std::string lang, int tsidonid);
+ std::list<eComponentData> m_component_data;
#endif
public:
#ifndef SWIG
- struct linkage_service
- {
- uint16_t sid;
- uint16_t onid;
- uint16_t tsid;
- std::string description;
- };
std::list<linkage_service> m_linkage_services;
time_t m_begin;
int m_duration;
@@ -31,12 +52,13 @@ public:
// .. additional info
RESULT parseFrom(Event *evt, int tsidonid=0);
#endif
- time_t getBeginTime() { return m_begin; }
- int getDuration() { return m_duration; }
- std::string getEventName() { return m_event_name; }
- std::string getShortDescription() { return m_short_description; }
- std::string getExtendedDescription() { return m_extended_description; }
- std::string getBeginTimeString();
+ time_t getBeginTime() const { return m_begin; }
+ int getDuration() const { return m_duration; }
+ std::string getEventName() const { return m_event_name; }
+ std::string getShortDescription() const { return m_short_description; }
+ std::string getExtendedDescription() const { return m_extended_description; }
+ std::string getBeginTimeString() const;
+ SWIG_VOID(RESULT) getComponentData(ePtr<eComponentData> &SWIG_OUTPUT, int tagnum) const;
};
TEMPLATE_TYPEDEF(ePtr<eServiceEvent>, eServiceEventPtr);
diff --git a/lib/service/servicedvb.cpp b/lib/service/servicedvb.cpp
index 271b94f0..3cb5387a 100644
--- a/lib/service/servicedvb.cpp
+++ b/lib/service/servicedvb.cpp
@@ -789,9 +789,20 @@ RESULT eDVBServicePlay::getTrackInfo(struct iAudioTrackInfo &info, unsigned int
info.m_description = "DTS";
else
info.m_description = "???";
-
- /* CHECK here for component tag override. */
- info.m_language = program.audioStreams[i].language_code;
+
+ if (program.audioStreams[i].component_tag != -1)
+ {
+ ePtr<eServiceEvent> evt;
+ if (!m_event_handler.getEvent(evt, 0))
+ {
+ ePtr<eComponentData> data;
+ if (!evt->getComponentData(data, program.audioStreams[i].component_tag))
+ info.m_language = data->getText();
+ }
+ }
+
+ if (info.m_language.empty())
+ info.m_language = program.audioStreams[i].language_code;
return 0;
}
@@ -803,7 +814,7 @@ int eDVBServicePlay::selectAudioStream(int i)
if (m_service_handler.getProgramInfo(program))
return -1;
- if (i >= program.audioStreams.size())
+ if ((unsigned int)i >= program.audioStreams.size())
return -2;
if (!m_decoder)