diff options
| author | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2006-05-23 12:29:43 +0000 |
|---|---|---|
| committer | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2006-05-23 12:29:43 +0000 |
| commit | 27ac653dea3ebb218d915604a8fce4b0d34d9278 (patch) | |
| tree | b5a2f64effe029c1b87f4f8f4b02d3f6ebabb82f /lib/python | |
| parent | b1f62dfee6033cb1074c0b1063e68ef365ce6a76 (diff) | |
| download | enigma2-27ac653dea3ebb218d915604a8fce4b0d34d9278.tar.gz enigma2-27ac653dea3ebb218d915604a8fce4b0d34d9278.zip | |
CI mmi is now working every time (for support alphacrypt parental control or other messages from CI)
Diffstat (limited to 'lib/python')
| -rw-r--r-- | lib/python/Screens/Ci.py | 205 | ||||
| -rw-r--r-- | lib/python/Screens/InfoBar.py | 3 | ||||
| -rw-r--r-- | lib/python/enigma_python.i | 2 |
3 files changed, 131 insertions, 79 deletions
diff --git a/lib/python/Screens/Ci.py b/lib/python/Screens/Ci.py index 9bf5b168..10e33cfe 100644 --- a/lib/python/Screens/Ci.py +++ b/lib/python/Screens/Ci.py @@ -24,9 +24,8 @@ class CiMmi(Screen): self.slotid = slotid - self.Timer = eTimer() - self.Timer.timeout.get().append(self.TimerCheck) - self.Timer.start(1000) + self.timer = eTimer() + self.timer.timeout.get().append(self.keyCancel) #else the skins fails self["title"] = Label("") @@ -56,12 +55,7 @@ class CiMmi(Screen): self.action = action - if action == 0: #reset - eDVBCI_UI.getInstance().setReset(self.slotid) - self.showWait() - elif action == 1: #init - eDVBCI_UI.getInstance().setInit(self.slotid) - elif action == 2: #start MMI + if action == 2: #start MMI eDVBCI_UI.getInstance().startMMI(self.slotid) self.showWait() elif action == 3: #mmi already there (called from infobar) @@ -84,7 +78,7 @@ class CiMmi(Screen): self["bottom"].setText(_("please press OK when ready")) def okbuttonClick(self): - print "ok" + self.timer.stop() if self.tag == "WAIT": print "do nothing - wait" elif self.tag == "MENU": @@ -109,11 +103,11 @@ class CiMmi(Screen): self.showWait() def closeMmi(self): - self.Timer.stop() - self.close() + self.timer.stop() + self.close(self.slotid) def keyCancel(self): - print "keyCancel" + self.timer.stop() if self.tag == "WAIT": eDVBCI_UI.getInstance().stopMMI(self.slotid) self.closeMmi() @@ -129,18 +123,22 @@ class CiMmi(Screen): print "give cancel action to ci" def keyConfigEntry(self, key): + self.timer.stop() try: self["entries"].handleKey(key) - except AttributeError: + except: pass def keyNumberGlobal(self, number): + self.timer.stop() self.keyConfigEntry(config.key[str(number)]) def keyLeft(self): + self.timer.stop() self.keyConfigEntry(config.key["prevElement"]) def keyRight(self): + self.timer.stop() self.keyConfigEntry(config.key["nextElement"]) def updateList(self, list): @@ -180,23 +178,30 @@ class CiMmi(Screen): list = [ ] - self.tag = screen[0][0] - - for entry in screen: - if entry[0] == "PIN": - self.addEntry(list, entry) + self.timer.stop() + if len(screen) > 0 and screen[0][0] == "CLOSE": + timeout = screen[0][1] + if timeout > 0: + self.timer.start(timeout*1000, True) else: - if entry[0] == "TITLE": - self["title"].setText(entry[1]) - elif entry[0] == "SUBTITLE": - self["subtitle"].setText(entry[1]) - elif entry[0] == "BOTTOM": - self["bottom"].setText(entry[1]) - elif entry[0] == "TEXT": + self.keyCancel() + else: + self.tag = screen[0][0] + for entry in screen: + if entry[0] == "PIN": self.addEntry(list, entry) - self.updateList(list) - - def TimerCheck(self): + else: + if entry[0] == "TITLE": + self["title"].setText(entry[1]) + elif entry[0] == "SUBTITLE": + self["subtitle"].setText(entry[1]) + elif entry[0] == "BOTTOM": + self["bottom"].setText(entry[1]) + elif entry[0] == "TEXT": + self.addEntry(list, entry) + self.updateList(list) + + def ciStateChanged(self): if self.action == 0: #reset self.closeMmi() if self.action == 1: #init @@ -210,73 +215,117 @@ class CiMmi(Screen): if eDVBCI_UI.getInstance().getMMIState(self.slotid) != 1: self.closeMmi() - if eDVBCI_UI.getInstance().availableMMI(self.slotid) == 1: + if self.action > 1 and eDVBCI_UI.getInstance().availableMMI(self.slotid) == 1: self.showScreen() #FIXME: check for mmi-session closed -class CiSelection(Screen): - def createMenu(self): - self.list = [ ] - self.list.append( (_("Reset"), 0) ) - self.list.append( (_("Init"), 1) ) - - self.state = eDVBCI_UI.getInstance().getState(0) - if self.state == 0: #no module - self.list.append( (_("no module found"), 2) ) - elif self.state == 1: #module in init - self.list.append( (_("init module"), 2) ) - elif self.state == 2: #module ready - #get appname - appname = eDVBCI_UI.getInstance().getAppName(0) - self.list.append( (appname, 2) ) +class CiMessageHandler: + def __init__(self): + self.session = None + self.ci = { } + self.dlgs = { } + eDVBCI_UI.getInstance().ciStateChanged.get().append(self.ciStateChanged) - self["entries"].list = self.list - self["entries"].l.setList(self.list) + def setSession(self, session): + self.session = session - def TimerCheck(self): - state = eDVBCI_UI.getInstance().getState(0) - if self.state != state: - #print "something happens" - self.state = state - self.createMenu() - - def okbuttonClick(self): - self.slot = 0 - - if self.state == 2: - self.session.open(CiMmi, 0, self["entries"].getCurrent()[1]) + def ciStateChanged(self, slot): + if slot in self.ci: + self.ci[slot](slot) + else: + if slot in self.dlgs: + self.dlgs[slot].ciStateChanged() + elif eDVBCI_UI.getInstance().availableMMI(slot) == 1: + if self.session: + self.dlgs[slot] = self.session.openWithCallback(self.dlgClosed, CiMmi, slot, 3) + else: + print "no session" - #generate menu / list - #list = [ ] - #list.append( ("TEXT", "CA-Info") ) - #list.append( ("TEXT", "Card Status") ) - #list.append( ("PIN", 6, "Card Pin", 1) ) - #self.session.open(CiMmi, 0, 0, "Wichtiges CI", "Mainmenu", "Footer", list) + def dlgClosed(self, slot): + del self.dlgs[slot] - def cancel(self): - self.Timer.stop() - self.close() + def registerCIMessageHandler(self, slot, func): + self.unregisterCIMessageHandler(slot) + self.ci[slot] = func - def mmiAvail(self, slot): - print "mmi avail slot", slot + def unregisterCIMessageHandler(self, slot): + if slot in self.ci: + del self.ci[slot] +CiHandler = CiMessageHandler() + +class CiSelection(Screen): def __init__(self, session): - #FIXME support for one ci only Screen.__init__(self, session) - - self["actions"] = ActionMap(["OkCancelActions"], + + self["actions"] = ActionMap(["OkCancelActions"], { "ok": self.okbuttonClick, "cancel": self.cancel }) + self.dlg = None + self.state = { } self.list = [ ] self["entries"] = MenuList(list) - self.createMenu() + self.clearMenu() + self.createMenu(0) # FIXME more than one CI + CiHandler.registerCIMessageHandler(0, self.ciStateChanged) + + def clearMenu(self): + self.list = [ ] + + def createMenu(self, slot): + self.list.append( (_("Reset"), 0, slot) ) + self.list.append( (_("Init"), 1, slot) ) + + self.state[slot] = eDVBCI_UI.getInstance().getState(slot) + if self.state[slot] == 0: #no module + self.list.append( (_("no module found"), 2, slot) ) + elif self.state[slot] == 1: #module in init + self.list.append( (_("init module"), 2, slot) ) + elif self.state[slot] == 2: #module ready + #get appname + appname = eDVBCI_UI.getInstance().getAppName(slot) + self.list.append( (appname, 2, slot) ) + + self["entries"].list = self.list + self["entries"].l.setList(self.list) + + def ciStateChanged(self, slot): + if self.dlg: + self.dlg.ciStateChanged() + else: + state = eDVBCI_UI.getInstance().getState(slot) + if self.state[slot] != state: + #print "something happens" + self.state[slot] = state + self.clearMenu() + self.createMenu(slot) - self.Timer = eTimer() - self.Timer.timeout.get().append(self.TimerCheck) - self.Timer.start(1000) + def dlgClosed(self, slot): + self.dlg = None - eDVBCI_UI.getInstance().mmiAvail.get().append(self.mmiAvail) + def okbuttonClick(self): + cur = self["entries"].getCurrent() + if cur: + action = cur[1] + slot = cur[2] + if action == 0: #reset + eDVBCI_UI.getInstance().setReset(slot) + elif action == 1: #init + eDVBCI_UI.getInstance().setInit(slot) + elif self.state[slot] == 2: + self.dlg = self.session.openWithCallback(self.dlgClosed, CiMmi, slot, action) + + #generate menu / list + #list = [ ] + #list.append( ("TEXT", "CA-Info") ) + #list.append( ("TEXT", "Card Status") ) + #list.append( ("PIN", 6, "Card Pin", 1) ) + #self.session.open(CiMmi, 0, 0, "Wichtiges CI", "Mainmenu", "Footer", list) + + def cancel(self): + CiHandler.unregisterCIMessageHandler(0) + self.close() diff --git a/lib/python/Screens/InfoBar.py b/lib/python/Screens/InfoBar.py index a35ff3a4..80ab0efb 100644 --- a/lib/python/Screens/InfoBar.py +++ b/lib/python/Screens/InfoBar.py @@ -3,6 +3,7 @@ from Screen import Screen from Screens.MovieSelection import MovieSelection from Screens.ChannelSelection import ChannelSelectionRadio from Screens.MessageBox import MessageBox +from Screens.Ci import CiHandler from ServiceReference import ServiceReference from Components.Clock import Clock @@ -35,6 +36,8 @@ class InfoBar(InfoBarShowHide, def __init__(self, session): Screen.__init__(self, session) + CiHandler.setSession(session) + self["actions"] = HelpableActionMap(self, "InfobarActions", { "showMovies": (self.showMovies, _("Play recorded movies...")), diff --git a/lib/python/enigma_python.i b/lib/python/enigma_python.i index 21f2b2ec..ce776320 100644 --- a/lib/python/enigma_python.i +++ b/lib/python/enigma_python.i @@ -152,7 +152,7 @@ typedef long time_t; %immutable eComponentScan::newService; %immutable pNavigation::m_event; %immutable eListbox::selectionChanged; -%immutable eDVBCI_UI::mmiAvail; +%immutable eDVBCI_UI::ciStateChanged; %include <lib/base/console.h> %include <lib/base/nconfig.h> |
