/* DVB CI MMI */ #include #include /* PyObject *list = PyList_New(len); for (i=0; immi_session = this; } eDVBCIMMISession::~eDVBCIMMISession() { slot->mmi_session = 0; } 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]); for (int i=0; i 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 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(0, pos++, str); while (textlen--) printf("%c", *d++); printf("\n"); } //FIXME: slotid eDVBCI_UI::getInstance()->mmiScreenFinish(0); break; } default: printf("unknown APDU tag 9F 88 %02x\n", tag[2]); break; } } return 0; } int eDVBCIMMISession::doAction() { switch (state) { case stateStarted: state=stateIdle; break; case stateDisplayReply: { unsigned char tag[]={0x9f, 0x88, 0x02}; unsigned char data[]={0x01, 0x01}; sendAPDU(tag, data, 2); state=stateFakeOK; return 1; break; } case stateFakeOK: { unsigned char tag[]={0x9f, 0x88, 0x0b}; unsigned char data[]={5}; sendAPDU(tag, data, 1); state=stateIdle; break; } case stateIdle: break; default: break; } 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); }