summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
2a4e5e2)
now/next table is received
from Components.PerServiceDisplay import PerServiceBase
from Components.Element import cached
from Components.PerServiceDisplay import PerServiceBase
from Components.Element import cached
-from enigma import iPlayableService
+from enigma import iPlayableService, iServiceInformation, eServiceReference, eEPGCache
from Source import Source
from Source import Source
class EventInfo(PerServiceBase, Source, object):
NOW = 0
NEXT = 1
class EventInfo(PerServiceBase, Source, object):
NOW = 0
NEXT = 1
iPlayableService.evUpdatedEventInfo: self.gotEvent,
iPlayableService.evEnd: self.gotEvent
}, with_event=True)
iPlayableService.evUpdatedEventInfo: self.gotEvent,
iPlayableService.evEnd: self.gotEvent
}, with_event=True)
self.now_or_next = now_or_next
self.now_or_next = now_or_next
+ self.epgQuery = eEPGCache.getInstance().lookupEventTime
@cached
def getEvent(self):
service = self.navcore.getCurrentService()
info = service and service.info()
@cached
def getEvent(self):
service = self.navcore.getCurrentService()
info = service and service.info()
- return info and info.getEvent(self.now_or_next)
+ ret = info and info.getEvent(self.now_or_next)
+ if not ret and info:
+ refstr = info.getInfoString(iServiceInformation.sServiceref)
+ ret = self.epgQuery(eServiceReference(refstr), -1, self.now_or_next and 1 or 0)
+ return ret
event = property(getEvent)
def gotEvent(self, what):
event = property(getEvent)
def gotEvent(self, what):
- if what in [iPlayableService.evStart, iPlayableService.evEnd]:
+ if what == iPlayableService.evEnd:
self.changed((self.CHANGED_CLEAR,))
else:
self.changed((self.CHANGED_ALL,))
self.changed((self.CHANGED_CLEAR,))
else:
self.changed((self.CHANGED_ALL,))