show servicename in eventview
[enigma2.git] / lib / service / event.cpp
index 45a278793478908026418a06d8289314f581b689..36446797102ac5930b7a69602479e17e39fcfc4f 100644 (file)
@@ -52,7 +52,7 @@ std::string ISOtbl[MAX_LANG][2] =
 };
 
 /* search for the presence of language from given EIT event descriptors*/
-bool eServiceEvent::language_exists(Event *evt, std::string lang)
+bool eServiceEvent::loadLanguage(Event *evt, std::string lang)
 {
        bool retval=0;
        for (DescriptorConstIterator desc = evt->getDescriptors()->begin(); desc != evt->getDescriptors()->end(); ++desc)
@@ -78,7 +78,14 @@ bool eServiceEvent::language_exists(Event *evt, std::string lang)
                                        m_extended_description += convertDVBUTF8(eed->getText());
                                        retval=1;
                                }
-                               // TODO handling for extended event items? ( producer... )
+                               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());
+                               }
                                break;
                        }
                        default:
@@ -92,7 +99,7 @@ RESULT eServiceEvent::parseFrom(Event *evt)
 {
        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 +107,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 (language_exists(evt,ISOtbl[i][1]))
+                       if (loadLanguage(evt,ISOtbl[i][1]))
                                return 0;
-       if (language_exists(evt,"eng"))
+       if (loadLanguage(evt,"eng"))
                return 0;
-       if (language_exists(evt,std::string()))
+       if (loadLanguage(evt,std::string()))
                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);