X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/67b53c1cb06988394c35a6e965c99b72b67fe1be..55125a070ce39f188225a32c664a97d8271fdcfc:/lib/python/Components/Sources/EventInfo.py diff --git a/lib/python/Components/Sources/EventInfo.py b/lib/python/Components/Sources/EventInfo.py index a4bc874f..5af0bf97 100644 --- a/lib/python/Components/Sources/EventInfo.py +++ b/lib/python/Components/Sources/EventInfo.py @@ -1,9 +1,8 @@ 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 - class EventInfo(PerServiceBase, Source, object): NOW = 0 NEXT = 1 @@ -16,19 +15,28 @@ class EventInfo(PerServiceBase, Source, object): iPlayableService.evUpdatedEventInfo: self.gotEvent, iPlayableService.evEnd: self.gotEvent }, with_event=True) - 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() - 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): - if what in [iPlayableService.evStart, iPlayableService.evEnd]: + if what == iPlayableService.evEnd: self.changed((self.CHANGED_CLEAR,)) else: self.changed((self.CHANGED_ALL,)) + + def destroy(self): + PerServiceBase.destroy(self) + Source.destroy(self) +