MoviePlayer: offer "help"
[enigma2.git] / lib / dvb_ci / dvbci_mmi.cpp
index 463c91bd1b90c9b1e311d2608497619be00d342a..b652da89fafddd005a87beb70ae6916cfe09a08d 100644 (file)
@@ -1,6 +1,30 @@
 /* DVB CI MMI */
 
 #include <lib/dvb_ci/dvbci_mmi.h>
+#include <lib/dvb_ci/dvbci_ui.h>
+
+/*
+PyObject *list = PyList_New(len);
+for (i=0; i<len; ++i) {
+       PyObject *tuple = PyTuple_New(3); // 3 eintrge im tuple
+       PyTuple_SetItem(tuple, 0, PyString_FromString("eintrag 1"))
+       PyTuple_SetItem(tuple, 1, PyInt_FromLong(31337));
+       PyTuple_SetItem(tuple, 2, PyString_FromString("eintrag 3"))
+       PyList_SetItem(list, i, tuple);
+}
+return list;
+*/
+
+eDVBCIMMISession::eDVBCIMMISession(eDVBCISlot *tslot)
+{
+       slot = tslot;
+       slot->mmi_session = this;
+}
+
+eDVBCIMMISession::~eDVBCIMMISession()
+{
+       slot->mmi_session = 0;
+}
 
 int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, int len)
 {
@@ -24,10 +48,18 @@ int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, i
                {
                        unsigned char *d=(unsigned char*)data;
                        unsigned char *max=((unsigned char*)d) + len;
+                       int pos = 0;
                        printf("Tmenu_last\n");
                        if (d > max)
                                break;
                        int n=*d++;
+                       
+                       //FIXME: slotid
+                       if(tag[2] == 0x09)
+                               eDVBCI_UI::getInstance()->mmiScreenBegin(0, 0);
+                       else
+                               eDVBCI_UI::getInstance()->mmiScreenBegin(0, 1);
+                       
                        if (n == 0xFF)
                                n=0;
                        else
@@ -44,10 +76,19 @@ int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, i
                                printf("%d bytes text\n", textlen);
                                if ((d+textlen) > max)
                                        break;
+                                       
+                               char str[textlen + 1];
+                               memcpy(str, ((char*)d), textlen);
+                               str[textlen] = '\0';
+                               
+                               eDVBCI_UI::getInstance()->mmiScreenAddText(0, pos++, str);
+                                       
                                while (textlen--)
                                        printf("%c", *d++);
                                printf("\n");
                        }
+                       //FIXME: slotid
+                       eDVBCI_UI::getInstance()->mmiScreenFinish(0);
                        break;
                }
                default:
@@ -90,3 +131,22 @@ int eDVBCIMMISession::doAction()
        return 0;
 }
 
+int eDVBCIMMISession::stopMMI()
+{
+       printf("eDVBCIMMISession::stopMMI()\n");
+
+       unsigned char tag[]={0x9f, 0x88, 0x00};
+       unsigned char data[]={0x00};
+       sendAPDU(tag, data, 1);
+}
+
+int eDVBCIMMISession::answerText(int answer)
+{
+       printf("eDVBCIMMISession::answerText(%d)\n",answer);
+
+       unsigned char tag[]={0x9f, 0x88, 0x0B};
+       unsigned char data[]={0x00};
+       data[0] = answer & 0xff;
+       sendAPDU(tag, data, 1);
+}
+