fix-fix configlist assertion (add #188)
[enigma2.git] / lib / dvb_ci / dvbci_ui.cpp
index 8dfb87e39408bcd2684bb43ccf04f336957d8a16..b1bfdc25acc9ecb30c40536c1af19fcac289d998 100644 (file)
@@ -1,4 +1,5 @@
 #include <lib/dvb_ci/dvbci_ui.h>
+#include <lib/dvb_ci/dvbci.h>
 
 #include <unistd.h>
 #include <fcntl.h>
@@ -6,34 +7,73 @@
 
 #include <lib/base/init.h>
 #include <lib/base/init_num.h>
-#include <lib/base/econfig.h>
 #include <lib/base/eerror.h>
+#include <lib/base/estring.h>
 
-eDVBCI_UI *eDVBCI_UI::instance = 0;
+#define MAX_SLOTS 4
+
+eDVBCI_UI *eDVBCI_UI::instance;
 
 eDVBCI_UI::eDVBCI_UI()
+       :eMMI_UI(MAX_SLOTS)
 {
-       int i;
-       
-       for(i=0;i<MAX_SLOTS;i++)
-               state[i] = 0;           //no module
-
        ASSERT(!instance);
        instance = this;
 }
 
-eDVBCI_UI::~eDVBCI_UI()
+eDVBCI_UI *eDVBCI_UI::getInstance()
 {
+       return instance;
 }
 
-eDVBCI_UI *eDVBCI_UI::getInstance()
+void eDVBCI_UI::setInit(int slot)
 {
-       return instance;
+       eDVBCIInterfaces::getInstance()->initialize(slot);
+}
+
+void eDVBCI_UI::setReset(int slot)
+{
+       eDVBCIInterfaces::getInstance()->reset(slot);
+}
+
+int eDVBCI_UI::startMMI(int slot)
+{
+       eDVBCIInterfaces::getInstance()->startMMI(slot);
+       return 0;
+}
+
+int eDVBCI_UI::stopMMI(int slot)
+{
+       eDVBCIInterfaces::getInstance()->stopMMI(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);
+       return 0;
+}
+
+int eDVBCI_UI::getMMIState(int slot)
+{
+       return eDVBCIInterfaces::getInstance()->getMMIState(slot);
 }
 
-int eDVBCI_UI::getState(int slot)
+int eDVBCI_UI::setClockRate(int slot, int rate)
 {
-       return state[slot];     //exploit me ;)
+       return eDVBCIInterfaces::getInstance()->setCIClockRate(slot, rate);
 }
 
 //FIXME: correct "run/startlevel"