X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/1ecf38f50b87d055d3b0b6e9ae959093378d10e0..0bbd93ba1e8f12d5cf1756e6a80e7513af51fe79:/lib/python/Screens/HarddiskSetup.py diff --git a/lib/python/Screens/HarddiskSetup.py b/lib/python/Screens/HarddiskSetup.py index 3d605924..1f936010 100644 --- a/lib/python/Screens/HarddiskSetup.py +++ b/lib/python/Screens/HarddiskSetup.py @@ -4,16 +4,31 @@ from Components.Harddisk import harddiskmanager #global harddiskmanager from Components.MenuList import MenuList from Components.Label import Label from Screens.MessageBox import MessageBox +from enigma import eTimer + +class HarddiskWait(Screen): + def doInit(self): + self.timer.stop() + result = self.hdd.initialize() + self.close(result) + + def __init__(self, session, hdd): + Screen.__init__(self, session) + self.hdd = hdd + self["wait"] = Label(_("Initializing Harddisk...")); + self.timer = eTimer() + self.timer.timeout.get().append(self.doInit) + self.timer.start(100) class HarddiskSetup(Screen): def __init__(self, session, hdd): Screen.__init__(self, session) self.hdd = hdd - self["model"] = Label("Model: " + hdd.model()) - self["capacity"] = Label("Capacity: " + hdd.capacity()) - self["bus"] = Label("Bus: " + hdd.bus()) - self["initialize"] = Label("Initialize") + self["model"] = Label(_("Model: ") + hdd.model()) + self["capacity"] = Label(_("Capacity: ") + hdd.capacity()) + self["bus"] = Label(_("Bus: ") + hdd.bus()) + self["initialize"] = Label(_("Initialize")) self["actions"] = ActionMap(["OkCancelActions"], { @@ -26,20 +41,27 @@ class HarddiskSetup(Screen): "red": self.hddInitialize }) + def hddReady(self, result): + print "Result: " + str(result) + if (result != 0): + self.session.open(MessageBox, _("Unable to initialize harddisk.\nPlease refer to the user-manual.\nError: ") + str(self.hdd.errorList[0 - result])) + else: + self.close() + def hddInitialize(self): - #some protection for the exhibition (IFA 2005) - #if self.hdd.getIndex() == 2: #CF - # print "not a good idea!" - # self.session.open(MessageBox, "not a good idea - this will kill our rootfs!") - #else: print "this will start the initialize now!" - self.hdd.initialize() + self.session.openWithCallback(self.hddReady, HarddiskWait, self.hdd) class HarddiskSelection(Screen): def __init__(self, session): Screen.__init__(self, session) - - self["hddlist"] = MenuList(harddiskmanager.HDDList()) + + if harddiskmanager.HDDCount() == 0: + tlist = [] + tlist.append((_("no HDD found"), 0)) + self["hddlist"] = MenuList(tlist) + else: + self["hddlist"] = MenuList(harddiskmanager.HDDList()) self["actions"] = ActionMap(["OkCancelActions"], { @@ -49,4 +71,5 @@ class HarddiskSelection(Screen): def okbuttonClick(self): selection = self["hddlist"].getCurrent() - self.session.open(HarddiskSetup, selection[1]) + if selection[1] != 0: + self.session.open(HarddiskSetup, selection[1])