aboutsummaryrefslogtreecommitdiff
path: root/lib/python/Screens/Screen.py
diff options
context:
space:
mode:
authorAndreas Monzner <andreas.monzner@multimedia-labs.de>2006-12-30 15:07:29 +0000
committerAndreas Monzner <andreas.monzner@multimedia-labs.de>2006-12-30 15:07:29 +0000
commit7c8c2b339b747763eede225a0ca554a405e5ac7b (patch)
tree650d0706842e04353db797b8630deb15b38f9ee4 /lib/python/Screens/Screen.py
parent5cb2d3d4e46a40693cee0173425f8bc2ade2f09b (diff)
downloadenigma2-7c8c2b339b747763eede225a0ca554a405e5ac7b.tar.gz
enigma2-7c8c2b339b747763eede225a0ca554a405e5ac7b.zip
send evStart before tuneFailed Events..
fix evNoResources fix some bluescreens caused by notification handling
Diffstat (limited to 'lib/python/Screens/Screen.py')
-rw-r--r--lib/python/Screens/Screen.py46
1 files changed, 28 insertions, 18 deletions
diff --git a/lib/python/Screens/Screen.py b/lib/python/Screens/Screen.py
index 989f90a9..53492918 100644
--- a/lib/python/Screens/Screen.py
+++ b/lib/python/Screens/Screen.py
@@ -30,29 +30,36 @@ class Screen(dict, HTMLSkin, GUISkin):
# we need the list in every screen. how ironic.
self.helpList = [ ]
+ self.close_on_next_exec = None
+
def execBegin(self):
self.active_components = [ ]
+ if self.close_on_next_exec is not None:
+ tmp = self.close_on_next_exec
+ self.close_on_next_exec = None
+ self.execing = True
+ self.close(tmp)
+ else:
+ single = self.onFirstExecBegin
+ self.onFirstExecBegin = []
+ for x in self.onExecBegin + single:
+ x()
+ if self.session.current_dialog != self:
+ return
- single = self.onFirstExecBegin
- self.onFirstExecBegin = []
- for x in self.onExecBegin + single:
- x()
- if self.session.current_dialog != self:
- return
+# assert self.session == None, "a screen can only exec once per time"
+# self.session = session
-# assert self.session == None, "a screen can only exec once per time"
-# self.session = session
+ for val in self.values() + self.renderer:
+ val.execBegin()
+ if self.session.current_dialog != self:
+ return
+ self.active_components.append(val)
- for val in self.values() + self.renderer:
- val.execBegin()
- if self.session.current_dialog != self:
- return
- self.active_components.append(val)
-
- self.execing = True
+ self.execing = True
- for x in self.onShown:
- x()
+ for x in self.onShown:
+ x()
def execEnd(self):
# for (name, val) in self.items():
@@ -94,7 +101,10 @@ class Screen(dict, HTMLSkin, GUISkin):
self.__dict__.clear()
def close(self, *retval):
- self.session.close(self, *retval)
+ if not self.execing:
+ self.close_on_next_exec = retval
+ else:
+ self.session.close(self, *retval)
def setFocus(self, o):
self.instance.setFocus(o.instance)