X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/cb0260fc843d3d7386dd79ae977081d0ad082e04..cab018779de4f2f01e0fe651e71112754ebd0ef8:/lib/dvb_ci/dvbci_ui.cpp diff --git a/lib/dvb_ci/dvbci_ui.cpp b/lib/dvb_ci/dvbci_ui.cpp index 191d6ca4..af613c43 100644 --- a/lib/dvb_ci/dvbci_ui.cpp +++ b/lib/dvb_ci/dvbci_ui.cpp @@ -5,29 +5,20 @@ #include #include -#include - #include #include -#include #include +#include + +#define MAX_SLOTS 4 -eDVBCI_UI *eDVBCI_UI::instance = 0; +eDVBCI_UI *eDVBCI_UI::instance; eDVBCI_UI::eDVBCI_UI() + :eMMI_UI(MAX_SLOTS) { - int i; - - for(i=0;ienableTS(slot, 1); -} - -std::string eDVBCI_UI::getAppName(int slot) -{ - return appName; -} - -void eDVBCI_UI::setAppName(int slot, const char *name) +void eDVBCI_UI::setInit(int slot) { - //printf("set name to -%c-\n", name); - appName = name; + eDVBCIInterfaces::getInstance()->initialize(slot); } void eDVBCI_UI::setReset(int slot) @@ -67,117 +39,30 @@ void eDVBCI_UI::setReset(int slot) int eDVBCI_UI::startMMI(int slot) { eDVBCIInterfaces::getInstance()->startMMI(slot); + return 0; } int eDVBCI_UI::stopMMI(int slot) { eDVBCIInterfaces::getInstance()->stopMMI(slot); -} - -int eDVBCI_UI::initialize(int slot) -{ - eDVBCIInterfaces::getInstance()->initialize(slot); + return 0; } int eDVBCI_UI::answerMenu(int slot, int answer) { eDVBCIInterfaces::getInstance()->answerText(slot, answer); + return 0; } int eDVBCI_UI::answerEnq(int slot, char *value) { eDVBCIInterfaces::getInstance()->answerEnq(slot, value); + return 0; } int eDVBCI_UI::cancelEnq(int slot) { eDVBCIInterfaces::getInstance()->cancelEnq(slot); -} - -int eDVBCI_UI::availableMMI(int slot) -{ - return mmiScreenReady; -} - -int eDVBCI_UI::mmiScreenEnq(int slot, int blind, int answerLen, char *text) -{ - mmiScreenReady = 0; - - mmiScreen = PyList_New(2); - - PyObject *tuple = PyTuple_New(1); - PyTuple_SetItem(tuple, 0, PyString_FromString("ENQ")); - PyList_SetItem(mmiScreen, 0, tuple); - - tuple = PyTuple_New(4); - - PyTuple_SetItem(tuple, 0, PyString_FromString("PIN")); - PyTuple_SetItem(tuple, 1, PyInt_FromLong(answerLen)); - PyTuple_SetItem(tuple, 2, PyString_FromString(text)); - PyTuple_SetItem(tuple, 3, PyInt_FromLong(blind)); - PyList_SetItem(mmiScreen, 1, tuple); - - mmiScreenReady = 1; - - return 0; -} - -int eDVBCI_UI::mmiScreenBegin(int slot, int listmenu) -{ - printf("eDVBCI_UI::mmiScreenBegin\n"); - - mmiScreenReady = 0; - - mmiScreen = PyList_New(1); - - PyObject *tuple = PyTuple_New(1); - if(listmenu == 0) //menu - PyTuple_SetItem(tuple, 0, PyString_FromString("MENU")); - else //list - PyTuple_SetItem(tuple, 0, PyString_FromString("LIST")); - - PyList_SetItem(mmiScreen, 0, tuple); - - mmiTuplePos = 1; - - return 0; -} - -int eDVBCI_UI::mmiScreenAddText(int slot, int type, char *value) -{ - printf("eDVBCI_UI::mmiScreenAddText(%s)\n",value); - - PyObject *tuple = PyTuple_New(3); - - if(type == 0) //title - PyTuple_SetItem(tuple, 0, PyString_FromString("TITLE")); - else if(type == 1) //subtitle - PyTuple_SetItem(tuple, 0, PyString_FromString("SUBTITLE")); - else if(type == 2) //bottom - PyTuple_SetItem(tuple, 0, PyString_FromString("BOTTOM")); - else - PyTuple_SetItem(tuple, 0, PyString_FromString("TEXT")); - - printf("addText %s with id %d\n", value, type); - - PyTuple_SetItem(tuple, 1, PyString_FromString(value)); - - if(type > 2) - PyTuple_SetItem(tuple, 2, PyInt_FromLong(type-2)); - else - PyTuple_SetItem(tuple, 2, PyInt_FromLong(-1)); - - PyList_Append(mmiScreen, tuple); - - return 0; -} - -int eDVBCI_UI::mmiScreenFinish(int slot) -{ - printf("eDVBCI_UI::mmiScreenFinish\n"); - - mmiScreenReady = 1; - return 0; } @@ -186,15 +71,5 @@ int eDVBCI_UI::getMMIState(int slot) return eDVBCIInterfaces::getInstance()->getMMIState(slot); } -PyObject *eDVBCI_UI::getMMIScreen(int slot) -{ - if(mmiScreenReady != 1) - return Py_None; - - mmiScreenReady = 0; - - return mmiScreen; -} - //FIXME: correct "run/startlevel" eAutoInitP0 init_dvbciui(eAutoInitNumbers::rc, "DVB-CI UI");