add playlists
[enigma2.git] / main / enigma.cpp
index 4cc8eaf96c8c753453fe9ae18fd74dc79f94b939..7b30f6b2534263827a7cb42eae32d7d5de8425ba 100644 (file)
@@ -16,6 +16,8 @@
 #include <lib/service/iservice.h>
 #include <lib/nav/core.h>
 
+#include <main/cli.h>
+
 class eMain: public eApplication, public Object
 {
        eInit init;
@@ -27,6 +29,7 @@ class eMain: public eApplication, public Object
        ePtr<iPlayableService> m_playservice;
        ePtr<eNavigation> m_nav;
        ePtr<eConnection> m_conn_event;
+       ePtr<iServiceInformation> m_serviceInformation;
 public:
        eMain()
        {
@@ -38,8 +41,9 @@ public:
                ePtr<eServiceCenter> service_center;
                eServiceCenter::getInstance(service_center);
 
+               assert(service_center);
                m_nav = new eNavigation(service_center);
-#if 1
+#if 0
                if (service_center)
                {
                        eServiceReference ref("2:0:1:0:0:0:0:0:0:0:/");
@@ -77,8 +81,25 @@ public:
        
        void event(eNavigation *nav, int ev)
        {
+               assert(nav);
+               
+               ePtr<ePlaylist> playlist;
+               nav->getPlaylist(playlist);
+               if (playlist)
+               {
+                       eDebug("PLAYLIST:");
+                       ePlaylist::iterator i;
+                       for (i=playlist->begin(); i != playlist->end(); ++i)
+                               eDebug("%s %s", i == playlist->m_current ? "-->" : "   ", i->toString().c_str());
+               }
+               
                switch (ev)
                {
+               case eNavigation::evStopService:
+                               /* very important: the old service should be deallocated, so clear *all* references to it */
+                       m_serviceInformation = 0;
+                       eDebug("STOP service!");
+                       break;
                case eNavigation::evNewService:
                {
                        ePtr<iPlayableService> service;
@@ -88,14 +109,13 @@ public:
                                eDebug("no running service!");
                                break;
                        }
-                       ePtr<iServiceInformation> s;
-                       if (service->getIServiceInformation(s))
+                       if (service->getIServiceInformation(m_serviceInformation))
                        {
                                eDebug("failed to get iserviceinformation");
                                break;
                        }
                        eString name;
-                       s->getName(name);
+                       m_serviceInformation->getName(name);
                        eDebug("NEW running service: %s", name.c_str());
                        break;
                }
@@ -104,6 +124,7 @@ public:
                        break;
                case eNavigation::evPlaylistDone:
                        eDebug("playlist done");
+                       quit();
                        break;
                default:
                        eDebug("Navigation event %d", ev);
@@ -113,7 +134,6 @@ public:
        
        ~eMain()
        {
-               
        }
 };
 
@@ -127,10 +147,26 @@ void object_dump()
 #endif
 
 int main()
-{      
+{
 #ifdef OBJECT_DEBUG
        atexit(object_dump);
 #endif
+
+#if 0
+       eCLI cli;
+       eString res;
+       
+       while (1)
+       {
+               char line[1024];
+               if (!fgets(line, 1024, stdin))
+                       break;
+               line[strlen(line)-1]=0;
+               int rn = cli.doCommand(res, line);
+               eDebug("%s%d", res.c_str(), rn);
+       }
+#endif
        eMain app;
-       return app.exec();
+       int res = app.exec();
+       eDebug("after exec");
 }