From: Andreas Monzner Date: Thu, 8 Nov 2007 14:10:32 +0000 (+0000) Subject: show shutdown menu on long power button press X-Git-Tag: 2.6.0~1757 X-Git-Url: https://git.cweiske.de/enigma2.git/commitdiff_plain/ace3f764c4db999f9e63a904caf14282a7e3626f show shutdown menu on long power button press the old behavior (immediate shutdown) is choosable in usage config --- diff --git a/data/keymap.xml b/data/keymap.xml index 3b2185da..94e19e15 100644 --- a/data/keymap.xml +++ b/data/keymap.xml @@ -187,8 +187,9 @@ - - + + + diff --git a/data/setup.xml b/data/setup.xml index 3648420a..894a2b86 100644 --- a/data/setup.xml +++ b/data/setup.xml @@ -24,6 +24,7 @@ config.usage.multibouquet config.usage.quickzap_bouquet_change config.usage.e1like_radio_mode + config.usage.on_long_powerpress config.usage.infobar_timeout config.usage.output_12V config.usage.show_infobar_on_zap diff --git a/lib/python/Components/UsageConfig.py b/lib/python/Components/UsageConfig.py index 581e7cea..b3658018 100644 --- a/lib/python/Components/UsageConfig.py +++ b/lib/python/Components/UsageConfig.py @@ -34,6 +34,10 @@ def InitUsageConfig(): ("intermediate", _("Intermediate")), ("expert", _("Expert")) ]) + config.usage.on_long_powerpress = ConfigSelection(default = "show_menu", choices = [ + ("show_menu", _("show shutdown menu")), + ("shutdown", _("immediate shutdown")) ] ) + def setHDDStandby(configElement): os.system("hdparm -S" + configElement.value + " /dev/ide/host0/bus0/target0/lun0/disc") config.usage.hdd_standby.addNotifier(setHDDStandby) diff --git a/mytest.py b/mytest.py index 3a5ec3ec..79dd6277 100644 --- a/mytest.py +++ b/mytest.py @@ -393,36 +393,51 @@ class VolumeControl: self.volumeDialog.setValue(vol) import Screens.Standby +from Screens.Menu import MainMenu, mdom +import xml.dom.minidom class PowerKey: """ PowerKey stuff - handles the powerkey press and powerkey release actions""" def __init__(self, session): self.session = session - self.powerKeyTimer = eTimer() - self.powerKeyTimer.timeout.get().append(self.powertimer) - globalActionMap.actions["powerdown"]=self.powerdown - globalActionMap.actions["powerup"]=self.powerup + globalActionMap.actions["power_down"]=self.powerdown + globalActionMap.actions["power_up"]=self.powerup + globalActionMap.actions["power_long"]=self.powerlong self.standbyblocked = 1 -# self["PowerKeyActions"] = HelpableActionMap(self, "PowerKeyActions", - #{ - #"powerdown": self.powerdown, - #"powerup": self.powerup, - #"discreteStandby": (self.standby, "Go standby"), - #"discretePowerOff": (self.quit, "Go to deep standby"), - #}) - - def powertimer(self): - print "PowerOff - Now!" - if not Screens.Standby.inTryQuitMainloop: - self.session.open(Screens.Standby.TryQuitMainloop, 1) + + def MenuClosed(self, *val): + self.session.infobar = None + + def powerlong(self): + self.standbyblocked = 1 + action = config.usage.on_long_powerpress.value + if action == "shutdown": + print "PowerOff - Now!" + if not Screens.Standby.inTryQuitMainloop: + self.session.open(Screens.Standby.TryQuitMainloop, 1) + elif action == "show_menu": + print "Show shutdown Menu" + menu = mdom.childNodes[0] + for x in menu.childNodes: + if x.nodeType != xml.dom.minidom.Element.nodeType: + continue + elif x.tagName == 'menu': + for y in x.childNodes: + if y.nodeType != xml.dom.minidom.Element.nodeType: + continue + elif y.tagName == 'id': + id = y.getAttribute("val") + if id and id == "shutdown": + self.session.infobar = self + menu_screen = self.session.openWithCallback(self.MenuClosed, MainMenu, menu, x.childNodes) + menu_screen.setTitle(_("Standby Menu")) + return def powerdown(self): self.standbyblocked = 0 - self.powerKeyTimer.start(3000, True) def powerup(self): - self.powerKeyTimer.stop() if self.standbyblocked == 0: self.standbyblocked = 1 self.standby()