dont try to get frontend informations when the eDVBServicePlay is a pvr service
[enigma2.git] / lib / service / event.cpp
index 19df5fc6f7c32cd0b1b11095f643f19a0425012e..e76ea315968b3adbfa997f3837f8cb7eaa15d6c5 100644 (file)
@@ -1,9 +1,11 @@
 #include <lib/service/event.h>
 #include <lib/base/estring.h>
+#include <lib/base/encoding.h>
 #include <lib/dvb/dvbtime.h>
 #include <dvbsi++/event_information_section.h>
 #include <dvbsi++/short_event_descriptor.h>
 #include <dvbsi++/extended_event_descriptor.h>
+#include <dvbsi++/linkage_descriptor.h>
 #include <dvbsi++/descriptor_tag.h>
 
 DEFINE_REF(eServiceEvent);
@@ -52,20 +54,25 @@ std::string ISOtbl[MAX_LANG][2] =
 };
 
 /* search for the presence of language from given EIT event descriptors*/
-bool eServiceEvent::loadLanguage(Event *evt, std::string lang)
+bool eServiceEvent::loadLanguage(Event *evt, std::string lang, int tsidonid)
 {
        bool retval=0;
        for (DescriptorConstIterator desc = evt->getDescriptors()->begin(); desc != evt->getDescriptors()->end(); ++desc)
        {
                switch ((*desc)->getTag())
                {
+                       case LINKAGE_DESCRIPTOR:
+                               m_linkage_services.clear();
+                               break;
                        case SHORT_EVENT_DESCRIPTOR:
                        {
                                const ShortEventDescriptor *sed = (ShortEventDescriptor*)*desc;
-                               if (lang.empty() || sed->getIso639LanguageCode() == lang)
+                               const std::string &cc = sed->getIso639LanguageCode();
+                               int table=encodingHandler.getCountryCodeDefaultMapping(cc);
+                               if (lang.empty() || cc == lang)
                                {
-                                       m_event_name = convertDVBUTF8(sed->getEventName());
-                                       m_short_description = convertDVBUTF8(sed->getText());
+                                       m_event_name = convertDVBUTF8(sed->getEventName(), table, tsidonid);
+                                       m_short_description = convertDVBUTF8(sed->getText(), table, tsidonid);
                                        retval=1;
                                }
                                break;
@@ -73,26 +80,64 @@ bool eServiceEvent::loadLanguage(Event *evt, std::string lang)
                        case EXTENDED_EVENT_DESCRIPTOR:
                        {
                                const ExtendedEventDescriptor *eed = (ExtendedEventDescriptor*)*desc;
-                               if (lang.empty() || eed->getIso639LanguageCode() == lang)
+                               const std::string &cc = eed->getIso639LanguageCode();
+                               int table=encodingHandler.getCountryCodeDefaultMapping(cc);
+                               if (lang.empty() || cc == lang)
                                {
-                                       m_extended_description += convertDVBUTF8(eed->getText());
+                                       m_extended_description += convertDVBUTF8(eed->getText(), table, tsidonid);
                                        retval=1;
                                }
-                               // TODO handling for extended event items? ( producer... )
+#if 0
+                               const ExtendedEventList *itemlist = eed->getItems();
+                               for (ExtendedEventConstIterator it = itemlist->begin(); it != itemlist->end(); ++it)
+                               {
+                                       m_extended_description += '\n';
+                                       m_extended_description += convertDVBUTF8((*it)->getItemDescription());
+                                       m_extended_description += ' ';
+                                       m_extended_description += convertDVBUTF8((*it)->getItem());
+                               }
+#endif
                                break;
                        }
                        default:
                                break;
                }
        }
+       if ( retval == 1 )
+       {
+               for (DescriptorConstIterator desc = evt->getDescriptors()->begin(); desc != evt->getDescriptors()->end(); ++desc)
+               {
+                       switch ((*desc)->getTag())
+                       {
+                               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();
+                                               const PrivateDataByteVector *privateData =
+                                                       ld->getPrivateDataBytes();
+                                               s.description.assign((const char*)&((*privateData)[0]), privateData->size());
+                                               m_linkage_services.push_back(s);
+                                       }
+                                       break;
+                               }
+                       }
+               }
+       }
+       if ( m_extended_description.find(m_short_description) == 0 )
+               m_short_description="";
        return retval;
 }
 
-RESULT eServiceEvent::parseFrom(Event *evt)
+RESULT eServiceEvent::parseFrom(Event *evt, int tsidonid)
 {
        uint16_t stime_mjd = evt->getStartTimeMjd();
        uint32_t stime_bcd = evt->getStartTimeBcd();
-       uint16_t duration = evt->getDuration();
+       uint32_t duration = evt->getDuration();
        m_begin = parseDVBtime(
                stime_mjd >> 8,
                stime_mjd&0xFF,
@@ -100,17 +145,28 @@ RESULT eServiceEvent::parseFrom(Event *evt)
                (stime_bcd >> 8)&0xFF,
                stime_bcd & 0xFF
        );
-       m_duration = ((duration & 0xFF) + (duration >> 8) & 0xFF) * 24 * 60;
+       m_duration = fromBCD(duration>>16)*3600+fromBCD(duration>>8)*60+fromBCD(duration);
        std::string country="de_DE";  // TODO use local data here
        for (int i=0; i < MAX_LANG; i++)
                if (country==ISOtbl[i][0])
-                       if (loadLanguage(evt,ISOtbl[i][1]))
+                       if (loadLanguage(evt, ISOtbl[i][1], tsidonid))
                                return 0;
-       if (loadLanguage(evt,"eng"))
+       if (loadLanguage(evt, "eng", tsidonid))
                return 0;
-       if (loadLanguage(evt,std::string()))
+       if (loadLanguage(evt, std::string(), tsidonid))
                return 0;
        return 0;
 }
 
+std::string eServiceEvent::getBeginTimeString()
+{
+       tm t;
+       localtime_r(&m_begin, &t);
+       char tmp[13];
+       snprintf(tmp, 13, "%02d.%02d, %02d:%02d",
+               t.tm_mday, t.tm_mon+1,
+               t.tm_hour, t.tm_min);
+       return std::string(tmp, 12);
+}
+
 DEFINE_REF(eDebugClass);