X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/27ac653dea3ebb218d915604a8fce4b0d34d9278..f0c5ac102ddaf0bfbf86743a5aec0ea4accc605c:/lib/dvb_ci/dvbci_mmi.cpp diff --git a/lib/dvb_ci/dvbci_mmi.cpp b/lib/dvb_ci/dvbci_mmi.cpp index 29710660..f266e5da 100644 --- a/lib/dvb_ci/dvbci_mmi.cpp +++ b/lib/dvb_ci/dvbci_mmi.cpp @@ -2,7 +2,8 @@ #include #include -#include + +#include /* PyObject *list = PyList_New(len); @@ -30,119 +31,18 @@ eDVBCIMMISession::~eDVBCIMMISession() 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; iprocessMMIData(slot->getSlotID(), tag, data, len) == 1) { - unsigned char *d=(unsigned char*)data; - int timeout=0; - if (d[3] == 1) - { - if (len > 4) - timeout = d[4]; - else - { - eDebug("mmi close tag incorrect.. no timeout given.. assume 5 seconds"); - timeout = 5; - } - } - else if (timeout>1) - eDebug("mmi close tag incorrect.. byte 4 should be 0 or 1"); - eDVBCI_UI::getInstance()->mmiScreenClose(slot->getSlotID(), timeout); - break; - } - 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; } @@ -181,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}; @@ -192,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}; @@ -205,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 @@ -219,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