everything else
authorRonny Strutz <ronny.strutz@multimedia-labs.de>
Fri, 18 Nov 2005 03:28:24 +0000 (03:28 +0000)
committerRonny Strutz <ronny.strutz@multimedia-labs.de>
Fri, 18 Nov 2005 03:28:24 +0000 (03:28 +0000)
lib/dvb_ci/dvbci.cpp
lib/dvb_ci/dvbci.h
lib/dvb_ci/dvbci_appmgr.cpp
lib/dvb_ci/dvbci_appmgr.h

index 6fa8e2e..7199453 100644 (file)
@@ -10,6 +10,8 @@
 #include <lib/dvb_ci/dvbci_session.h>
 
 #include <lib/dvb_ci/dvbci_ui.h>
+#include <lib/dvb_ci/dvbci_appmgr.h>
+#include <lib/dvb_ci/dvbci_mmi.h>
 
 eDVBCIInterfaces *eDVBCIInterfaces::instance = 0;
 
@@ -91,6 +93,16 @@ int eDVBCIInterfaces::startMMI(int slotid)
        return slot->startMMI();
 }
 
+int eDVBCIInterfaces::stopMMI(int slotid)
+{
+       eDVBCISlot *slot;
+
+       if( (slot = getSlot(slotid)) == 0 )
+               return -1;
+       
+       return slot->stopMMI();
+}
+
 int eDVBCIInterfaces::answerMMI(int slotid, int answer, char *value)
 {
        eDVBCISlot *slot;
@@ -128,6 +140,9 @@ void eDVBCISlot::data(int what)
                        notifier->setRequested(eSocketNotifier::Read);
                        //HACK
                        eDVBCI_UI::getInstance()->setState(0,0);
+                       //FIXME; do in deconstructor of the appmgr class                        
+                       application_manager = 0;
+                       mmi_session = 0;
                }
                return;
        }
@@ -170,6 +185,9 @@ DEFINE_REF(eDVBCISlot);
 eDVBCISlot::eDVBCISlot(eMainloop *context, int nr)
 {
        char filename[128];
+       
+       application_manager = 0;
+       mmi_session = 0;
 
        slotid = nr;
 
@@ -218,6 +236,20 @@ int eDVBCISlot::initialize()
 int eDVBCISlot::startMMI()
 {
        printf("edvbcislot: startMMI()\n");
+       
+       if(application_manager)
+               application_manager->startMMI();
+       
+       return 0;
+}
+
+int eDVBCISlot::stopMMI()
+{
+       printf("edvbcislot: stopMMI()\n");
+
+       if(mmi_session)
+               mmi_session->stopMMI();
+       
        return 0;
 }
 
index c616655..e9de487 100644 (file)
@@ -6,6 +6,7 @@
 class eDVBCISession;
 class eDVBCIApplicationManagerSession;
 class eDVBCICAManagerSession;
+class eDVBCIMMISession;
 
 class eDVBCISlot: public iObject, public Object
 {
@@ -26,11 +27,13 @@ public:
        
        eDVBCIApplicationManagerSession *application_manager;
        eDVBCICAManagerSession *ca_manager;
+       eDVBCIMMISession *mmi_session;
        
        int getSlotID();
        int reset();
        int initialize();
        int startMMI();
+       int stopMMI();
        int answerMMI(int answer, char *value);
 };
 
@@ -50,6 +53,7 @@ public:
        int reset(int slot);
        int initialize(int slot);
        int startMMI(int slot);
+       int stopMMI(int slot);
        int answerMMI(int slot, int answer, char *value);
 };
 
index 5aad5b6..f07ea99 100644 (file)
@@ -75,3 +75,11 @@ int eDVBCIApplicationManagerSession::doAction()
     return 0;
   }
 }
+
+int eDVBCIApplicationManagerSession::startMMI()
+{
+       printf("in appmanager -> startmmi()\n");
+       const unsigned char tag[3]={0x9F, 0x80, 0x22};  // Tenter_menu
+       sendAPDU(tag);
+}
+
index b8ea87f..1d6e7b1 100644 (file)
@@ -13,6 +13,7 @@ class eDVBCIApplicationManagerSession: public eDVBCISession
        int doAction();
 public:
        int enterMenu();
+       int startMMI();
 };
 
 #endif