X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/98652711568f9545526722e0090c05ae91b87e15..7265acc377e49beaed3f3c43f36267c9fced53e7:/lib/dvb_ci/dvbci_mmi.cpp diff --git a/lib/dvb_ci/dvbci_mmi.cpp b/lib/dvb_ci/dvbci_mmi.cpp index d3f564d9..b616ebce 100644 --- a/lib/dvb_ci/dvbci_mmi.cpp +++ b/lib/dvb_ci/dvbci_mmi.cpp @@ -25,23 +25,43 @@ 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 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: + eDebug("MMI display control"); if (((unsigned char*)data)[0] != 1) - printf("kann ich nicht. aber das sag ich dem modul nicht.\n"); + eDebug("kann ich nicht. aber das sag ich dem modul nicht."); state=stateDisplayReply; return 1; case 0x07: //Tmenu_enq @@ -50,7 +70,7 @@ int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, i unsigned char *max=((unsigned char*)d) + len; int textlen = len - 2; - printf("in enq\n"); + eDebug("in enq"); if ((d+2) > max) break; @@ -58,7 +78,7 @@ int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, i int blind = *d++ & 1; int alen = *d++; - printf("%d bytes text\n", textlen); + eDebug("%d bytes text", textlen); if ((d+textlen) > max) break; @@ -66,7 +86,7 @@ int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, i memcpy(str, ((char*)d), textlen); str[textlen] = '\0'; - printf("enq-text: %s\n",str); + eDebug("enq-text: %s",str); eDVBCI_UI::getInstance()->mmiScreenEnq(slot->getSlotID(), blind, alen, (char*)convertDVBUTF8(str).c_str()); @@ -78,7 +98,7 @@ 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"); + eDebug("Tmenu_last"); if (d > max) break; int n=*d++; @@ -92,16 +112,16 @@ int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, i n=0; else n++; - printf("%d texts\n", n); + eDebug("%d texts", 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]); + eDebug("text tag: %02x %02x %02x", d[0], d[1], d[2]); d+=3; d+=parseLengthField(d, textlen); - printf("%d bytes text\n", textlen); + eDebug("%d bytes text", textlen); if ((d+textlen) > max) break; @@ -112,14 +132,14 @@ int eDVBCIMMISession::receivedAPDU(const unsigned char *tag, const void *data, i eDVBCI_UI::getInstance()->mmiScreenAddText(slot->getSlotID(), pos++, (char*)convertDVBUTF8(str).c_str()); while (textlen--) - printf("%c", *d++); - printf("\n"); + eDebugNoNewLine("%c", *d++); + eDebug(""); } eDVBCI_UI::getInstance()->mmiScreenFinish(slot->getSlotID()); break; } default: - printf("unknown APDU tag 9F 88 %02x\n", tag[2]); + eDebug("unknown APDU tag 9F 88 %02x", tag[2]); break; } } @@ -161,7 +181,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 +192,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 +205,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 +219,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