From: Andreas Monzner Date: Thu, 1 May 2008 15:24:37 +0000 (+0000) Subject: pass service events to old instance of InfoBarBase until a new service is X-Git-Tag: 2.6.0~1270 X-Git-Url: https://git.cweiske.de/enigma2.git/commitdiff_plain/3f0b490f6b5c5a4d83c1e2c1238d2eb33ff25a57 pass service events to old instance of InfoBarBase until a new service is running --- diff --git a/lib/python/Components/ServiceEventTracker.py b/lib/python/Components/ServiceEventTracker.py index 89c339f8..1c42ecc8 100644 --- a/lib/python/Components/ServiceEventTracker.py +++ b/lib/python/Components/ServiceEventTracker.py @@ -1,6 +1,10 @@ class InfoBarBase: - def __init__(self): - ServiceEventTracker.setActiveInfoBar(self) + def __init__(self, steal_current_service = False): + if steal_current_service: + ServiceEventTracker.setActiveInfoBar(self, None, None) + else: + nav = self.session.nav + ServiceEventTracker.setActiveInfoBar(self, not steal_current_service and nav.getCurrentService(), nav.getCurrentlyPlayingServiceReference()) self.onClose.append(self.__close) def __close(self): @@ -10,6 +14,7 @@ class ServiceEventTracker: """Tracks service events into a screen""" InfoBarStack = [ ] InfoBarStackSize = 0 + oldService = None def __init__(self, screen, eventmap): self.__eventmap = eventmap @@ -22,17 +27,29 @@ class ServiceEventTracker: def __event(self, ev): set = ServiceEventTracker - ssize = set.InfoBarStackSize - stack = set.InfoBarStack + screen = self.screen + nav = screen.session.nav + cur_ref = nav.getCurrentlyPlayingServiceReference() + old_service_running = set.oldRef and cur_ref and cur_ref == set.oldRef and set.oldService and set.oldService == str(nav.getCurrentService()) + if not old_service_running: + set.oldService = None + set.oldRef = None +# print "old_service_running", old_service_running if ev in self.__eventmap: - if not isinstance(self.screen, InfoBarBase) or (ssize and stack[ssize-1] == self.screen): + ssize = set.InfoBarStackSize + stack = set.InfoBarStack + if (not isinstance(screen, InfoBarBase) or # let pass all events to screens not derived from InfoBarBase + (not old_service_running and ssize and stack[ssize-1] == screen) or # let pass events from currently running service just to current active screen (derived from InfoBarBase) + (old_service_running and ssize > 1 and stack[ssize-2] == screen)): # let pass events from old running service just to previous active screen (derived from InfoBarBase) self.__eventmap[ev]() # else: # print "ignore event", ev, "for inactive infobar '" + str(self.screen) + "'" @staticmethod - def setActiveInfoBar(infobar): + def setActiveInfoBar(infobar, old_service, old_ref): set = ServiceEventTracker + set.oldRef = old_ref + set.oldService = old_service and str(old_service) assert infobar not in set.InfoBarStack, "FATAL: Infobar '" + str(infobar) + "' is already active!" set.InfoBarStack.append(infobar) set.InfoBarStackSize += 1 diff --git a/lib/python/Plugins/Extensions/CutListEditor/plugin.py b/lib/python/Plugins/Extensions/CutListEditor/plugin.py index 61acf042..7ebc42b5 100644 --- a/lib/python/Plugins/Extensions/CutListEditor/plugin.py +++ b/lib/python/Plugins/Extensions/CutListEditor/plugin.py @@ -171,7 +171,7 @@ class CutListEditor(Screen, InfoBarBase, InfoBarSeek, InfoBarCueSheetSupport, He Screen.__init__(self, session) InfoBarSeek.__init__(self, actionmap = "CutlistSeekActions") InfoBarCueSheetSupport.__init__(self) - InfoBarBase.__init__(self) + InfoBarBase.__init__(self, steal_current_service = True) HelpableScreen.__init__(self) self.old_service = session.nav.getCurrentlyPlayingServiceReference() session.nav.playService(service)