Extend AudioSelection width, fix mediaplayer subtitle selection key
[enigma2.git] / lib / dvb_ci / dvbci_mmi.cpp
index d3f564d92faa2b53c03b8653534bb618aedd7b9a..f266e5dab2d1bba4ea45571456923f0b0cf40272 100644 (file)
@@ -2,7 +2,8 @@
 
 #include <lib/dvb_ci/dvbci_mmi.h>
 #include <lib/dvb_ci/dvbci_ui.h>
-#include <lib/base/estring.h>
+
+#include <string>
 
 /*
 PyObject *list = PyList_New(len);
@@ -25,104 +26,23 @@ eDVBCIMMISession::eDVBCIMMISession(eDVBCISlot *tslot)
 eDVBCIMMISession::~eDVBCIMMISession()
 {
        slot->setMMIManager(NULL);
+       eDVBCI_UI::getInstance()->mmiSessionDestroyed(slot->getSlotID());
 }
 
 int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, int len)
 {
-       printf("SESSION(%d)/MMI %02x %02x %02x: ", session_nb, tag[0], tag[1],tag[2]);
+       eDebugNoNewLine("SESSION(%d)/MMI %02x %02x %02x: ", session_nb, tag[0], tag[1],tag[2]);
        for (int i=0; i<len; i++)
-               printf("%02x ", ((const unsigned char*)data)[i]);
-       printf("\n");
+               eDebugNoNewLine("%02x ", ((const unsigned char*)data)[i]);
+       eDebug("");
 
        if ((tag[0]==0x9f) && (tag[1]==0x88))
-       {
-               switch (tag[2])
+               if (eDVBCI_UI::getInstance()->processMMIData(slot->getSlotID(), tag, data, len) == 1)
                {
-                       case 0x01:
-                       printf("MMI display control\n");
-                       if (((unsigned char*)data)[0] != 1)
-                               printf("kann ich nicht. aber das sag ich dem modul nicht.\n");
                        state=stateDisplayReply;
                        return 1;
-               case 0x07:              //Tmenu_enq
-               {
-                       unsigned char *d=(unsigned char*)data;
-                       unsigned char *max=((unsigned char*)d) + len;
-                       int textlen = len - 2;
-
-                       printf("in enq\n");
-                       
-                       if ((d+2) > max)
-                               break;
-                               
-                       int blind = *d++ & 1;
-                       int alen = *d++;
-
-                       printf("%d bytes text\n", textlen);
-                       if ((d+textlen) > max)
-                               break;
-                       
-                       char str[textlen + 1];
-                       memcpy(str, ((char*)d), textlen);
-                       str[textlen] = '\0';
-                       
-                       printf("enq-text: %s\n",str);
-                       
-                       eDVBCI_UI::getInstance()->mmiScreenEnq(slot->getSlotID(), blind, alen, (char*)convertDVBUTF8(str).c_str());
-
-                       break;          
-               }
-               case 0x09:              //Tmenu_last
-               case 0x0c:              //Tlist_last
-               {
-                       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++;
-                       
-                       if(tag[2] == 0x09)      //menu
-                               eDVBCI_UI::getInstance()->mmiScreenBegin(slot->getSlotID(), 0);
-                       else                                                            //list
-                               eDVBCI_UI::getInstance()->mmiScreenBegin(slot->getSlotID(), 1);
-                       
-                       if (n == 0xFF)
-                               n=0;
-                       else
-                               n++;
-                       printf("%d texts\n", n);
-                       for (int i=0; i < (n+3); ++i)
-                       {
-                               int textlen;
-                               if ((d+3) > max)
-                                       break;
-                               printf("text tag: %02x %02x %02x\n", d[0], d[1], d[2]);
-                               d+=3;
-                               d+=parseLengthField(d, textlen);
-                               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(slot->getSlotID(), pos++, (char*)convertDVBUTF8(str).c_str());
-                                       
-                               while (textlen--)
-                                       printf("%c", *d++);
-                               printf("\n");
-                       }
-                       eDVBCI_UI::getInstance()->mmiScreenFinish(slot->getSlotID());
-                       break;
-               }
-               default:
-                       printf("unknown APDU tag 9F 88 %02x\n", tag[2]);
-                       break;
                }
-       }
+
        return 0;
 }
 
@@ -161,7 +81,7 @@ int eDVBCIMMISession::doAction()
 
 int eDVBCIMMISession::stopMMI()
 {
-       printf("eDVBCIMMISession::stopMMI()\n");
+       eDebug("eDVBCIMMISession::stopMMI()");
 
        unsigned char tag[]={0x9f, 0x88, 0x00};
        unsigned char data[]={0x00};
@@ -172,7 +92,7 @@ int eDVBCIMMISession::stopMMI()
 
 int eDVBCIMMISession::answerText(int answer)
 {
-       printf("eDVBCIMMISession::answerText(%d)\n",answer);
+       eDebug("eDVBCIMMISession::answerText(%d)",answer);
 
        unsigned char tag[]={0x9f, 0x88, 0x0B};
        unsigned char data[]={0x00};
@@ -185,7 +105,7 @@ int eDVBCIMMISession::answerText(int answer)
 int eDVBCIMMISession::answerEnq(char *answer)
 {
        unsigned int len = strlen(answer);
-       printf("eDVBCIMMISession::answerEnq(%d bytes)\n", len);
+       eDebug("eDVBCIMMISession::answerEnq(%d bytes)", len);
 
        unsigned char data[len+1];
        data[0] = 0x01; // answer ok
@@ -199,7 +119,7 @@ int eDVBCIMMISession::answerEnq(char *answer)
 
 int eDVBCIMMISession::cancelEnq()
 {
-       printf("eDVBCIMMISession::cancelEnq()\n");
+       eDebug("eDVBCIMMISession::cancelEnq()");
 
        unsigned char tag[]={0x9f, 0x88, 0x08};
        unsigned char data[]={0x00}; // canceled