aboutsummaryrefslogtreecommitdiff
path: root/lib/python/Screens/Wizard.py
diff options
context:
space:
mode:
authorFelix Domke <tmbinc@elitedvb.net>2006-05-11 14:19:29 +0000
committerFelix Domke <tmbinc@elitedvb.net>2006-05-11 14:19:29 +0000
commit0e576bd17bd3f0e828179cdd7c07258373460fc3 (patch)
treebe322febaaa6770e7a99aa81aa2b403c7a34b230 /lib/python/Screens/Wizard.py
parent174f7b85cec9804931de3d432466e28b0da93fdb (diff)
downloadenigma2-0e576bd17bd3f0e828179cdd7c07258373460fc3.tar.gz
enigma2-0e576bd17bd3f0e828179cdd7c07258373460fc3.zip
'fix' orphan listboxes in wizard
Diffstat (limited to 'lib/python/Screens/Wizard.py')
-rw-r--r--lib/python/Screens/Wizard.py18
1 files changed, 14 insertions, 4 deletions
diff --git a/lib/python/Screens/Wizard.py b/lib/python/Screens/Wizard.py
index fc76bcd2..036c81de 100644
--- a/lib/python/Screens/Wizard.py
+++ b/lib/python/Screens/Wizard.py
@@ -72,6 +72,7 @@ class Wizard(Screen, HelpableScreen):
self.wizard[self.lastStep]["code"] = self.wizard[self.lastStep]["code"] + ch
elif self.currContent == "condition":
self.wizard[self.lastStep]["condition"] = self.wizard[self.lastStep]["condition"] + ch
+
def __init__(self, session, showSteps = True, showStepSlider = True, showList = True, showConfig = True):
Screen.__init__(self, session)
HelpableScreen.__init__(self)
@@ -109,6 +110,8 @@ class Wizard(Screen, HelpableScreen):
self["list"] = MenuList(self.list)
self.onShown.append(self.updateValues)
+
+ self.configInstance = None
self["actions"] = NumberActionMap(["WizardActions", "NumberActions"],
{
@@ -154,10 +157,11 @@ class Wizard(Screen, HelpableScreen):
currStep = self.currStep
if self.showConfig:
if (self.wizard[currStep]["config"]["screen"] != None):
- try: # don't die, if no run() is available
- self.configInstance.run()
- except:
- print "Failed to run configInstance"
+ # TODO: don't die, if no run() is available
+ # there was a try/except here, but i can't see a reason
+ # for this. If there is one, please do a more specific check
+ # and/or a comment in which situation there is no run()
+ self.configInstance.run()
if self.showList:
if (len(self.wizard[currStep]["list"]) > 0):
@@ -214,6 +218,11 @@ class Wizard(Screen, HelpableScreen):
self.stepHistory.append(self.currStep)
+ if self.configInstance is not None:
+ del self.configInstance["config"]
+ self.configInstance.doClose()
+ self.configInstance = None
+
self.condition = True
exec (self.wizard[self.currStep]["condition"])
if self.condition:
@@ -250,6 +259,7 @@ class Wizard(Screen, HelpableScreen):
else:
self.configInstance = self.session.instantiateDialog(self.wizard[self.currStep]["config"]["screen"], eval(self.wizard[self.currStep]["config"]["args"]))
self["config"].l.setList(self.configInstance["config"].list)
+ self.configInstance["config"].destroy()
self.configInstance["config"] = self["config"]
else:
self["config"].l.setList([])