diff options
| author | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2005-12-05 19:24:42 +0000 |
|---|---|---|
| committer | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2005-12-05 19:24:42 +0000 |
| commit | 572caca1ba06dd8247724c9f5d6bcad515e2edf4 (patch) | |
| tree | 8525a3017c1d58b03b667cd8d77f942318256ddd /lib/service/event.cpp | |
| parent | 3c2c648735df18576453aa52f0d8441793619dc7 (diff) | |
| download | enigma2-572caca1ba06dd8247724c9f5d6bcad515e2edf4.tar.gz enigma2-572caca1ba06dd8247724c9f5d6bcad515e2edf4.zip | |
add support for Linkage services ( Premiere Subservices )
TODO: show/hide green point depending on avail subservices
Diffstat (limited to 'lib/service/event.cpp')
| -rw-r--r-- | lib/service/event.cpp | 37 |
1 files changed, 28 insertions, 9 deletions
diff --git a/lib/service/event.cpp b/lib/service/event.cpp index 81a8d4bb..40bc9b51 100644 --- a/lib/service/event.cpp +++ b/lib/service/event.cpp @@ -2,6 +2,7 @@ #include <lib/base/estring.h> #include <lib/base/encoding.h> #include <lib/dvb/dvbtime.h> +#include <lib/dvb/idvb.h> #include <dvbsi++/event_information_section.h> #include <dvbsi++/short_event_descriptor.h> #include <dvbsi++/extended_event_descriptor.h> @@ -119,7 +120,8 @@ bool eServiceEvent::loadLanguage(Event *evt, std::string lang, int tsidonid) data.m_componentType = cp->getComponentType(); data.m_componentTag = cp->getComponentTag(); data.m_iso639LanguageCode = cp->getIso639LanguageCode(); - data.m_text = convertDVBUTF8(cp->getText()); + int table=encodingHandler.getCountryCodeDefaultMapping(data.m_iso639LanguageCode); + data.m_text = convertDVBUTF8(cp->getText(),table,tsidonid); m_component_data.push_back(data); break; } @@ -128,14 +130,16 @@ bool eServiceEvent::loadLanguage(Event *evt, std::string lang, int tsidonid) const LinkageDescriptor *ld = (LinkageDescriptor*)*desc; if ( ld->getLinkageType() == 0xB0 ) { - linkage_service s; - s.m_onid = ld->getOriginalNetworkId(); - s.m_tsid = ld->getTransportStreamId(); - s.m_sid = ld->getServiceId(); - const PrivateDataByteVector *privateData = - ld->getPrivateDataBytes(); - s.m_description.assign((const char*)&((*privateData)[0]), privateData->size()); - m_linkage_services.push_back(s); + eServiceReference ref; + ref.type = eServiceReference::idDVB; + eServiceReferenceDVB &dvb_ref = (eServiceReferenceDVB&) ref; + dvb_ref.setServiceType(1); + dvb_ref.setTransportStreamID(ld->getTransportStreamId()); + dvb_ref.setOriginalNetworkID(ld->getOriginalNetworkId()); + dvb_ref.setServiceID(ld->getServiceId()); + const PrivateDataByteVector *privateData = ld->getPrivateDataBytes(); + dvb_ref.name = convertDVBUTF8((const char*)&((*privateData)[0]), privateData->size(), 0, tsidonid); + m_linkage_services.push_back(ref); } break; } @@ -199,4 +203,19 @@ RESULT eServiceEvent::getComponentData(ePtr<eComponentData> &dest, int tagnum) c return -1; } +RESULT eServiceEvent::getLinkageService(eServiceReference &service, int num) const +{ + std::list<eServiceReference>::const_iterator it = + m_linkage_services.begin(); + while( it != m_linkage_services.end() && num-- ) + ++it; + if ( it != m_linkage_services.end() ) + { + service = *it; + return 0; + } + service.type = eServiceReference::idInvalid; + return -1; +} + DEFINE_REF(eDebugClass); |
