+ }
+ if ( m_extended_description.find(m_short_description) == 0 )
+ m_short_description="";
+ return retval;
+}
+
+RESULT eServiceEvent::parseFrom(Event *evt, int tsidonid)
+{
+ uint16_t stime_mjd = evt->getStartTimeMjd();
+ uint32_t stime_bcd = evt->getStartTimeBcd();
+ uint32_t duration = evt->getDuration();
+ m_begin = parseDVBtime(
+ stime_mjd >> 8,
+ stime_mjd&0xFF,
+ stime_bcd >> 16,
+ (stime_bcd >> 8)&0xFF,
+ stime_bcd & 0xFF
+ );
+ m_event_id = evt->getEventId();
+ 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], tsidonid))
+ return 0;
+ if (loadLanguage(evt, "eng", tsidonid))
+ return 0;
+ if (loadLanguage(evt, std::string(), tsidonid))
+ return 0;
+ return 0;
+}
+
+std::string eServiceEvent::getBeginTimeString() const
+{
+ 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);
+}
+
+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;
+}
+
+RESULT eServiceEvent::getLinkageService(eServiceReference &service, eServiceReference &parent, 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;
+ eServiceReferenceDVB &subservice = (eServiceReferenceDVB&) service;
+ eServiceReferenceDVB ¤t = (eServiceReferenceDVB&) parent;
+ subservice.setDVBNamespace(current.getDVBNamespace());
+ if ( current.getParentTransportStreamID().get() )
+ {
+ subservice.setParentTransportStreamID( current.getParentTransportStreamID() );
+ subservice.setParentServiceID( current.getParentServiceID() );
+ }
+ else
+ {
+ subservice.setParentTransportStreamID( current.getTransportStreamID() );
+ subservice.setParentServiceID( current.getServiceID() );