2 #include <libsig_comp.h>
3 #include <lib/base/ebase.h>
4 #include <lib/base/eerror.h>
5 #include <lib/base/init.h>
6 #include <lib/base/init_num.h>
8 #include <lib/dvb/dvb.h>
9 #include <lib/dvb/db.h>
10 #include <lib/dvb/isection.h>
11 #include <lib/dvb/esection.h>
12 #include <lib/dvb_si/pmt.h>
13 #include <lib/dvb/scan.h>
16 #include <lib/service/iservice.h>
17 #include <lib/nav/core.h>
21 class eMain: public eApplication, public Object
25 ePtr<eDVBResourceManager> m_mgr;
26 ePtr<iDVBChannel> m_channel;
29 ePtr<iPlayableService> m_playservice;
30 ePtr<eNavigation> m_nav;
31 ePtr<eConnection> m_conn_event;
32 ePtr<iServiceInformation> m_serviceInformation;
36 init.setRunlevel(eAutoInitNumbers::main);
37 m_dvbdb = new eDVBDB();
38 m_mgr = new eDVBResourceManager();
39 m_mgr->setChannelList(m_dvbdb);
41 ePtr<eServiceCenter> service_center;
42 eServiceCenter::getInstance(service_center);
44 assert(service_center);
45 m_nav = new eNavigation(service_center);
49 eServiceReference ref("2:0:1:0:0:0:0:0:0:0:/");
50 ePtr<iListableService> lst;
51 if (service_center->list(ref, lst))
52 eDebug("no list available!");
55 std::list<eServiceReference> list;
56 if (lst->getContent(list))
57 eDebug("list itself SUCKED AROUND!!!");
59 for (std::list<eServiceReference>::const_iterator i(list.begin());
61 eDebug("%s", i->toString().c_str());
65 m_nav->connectEvent(slot(*this, &eMain::event), m_conn_event);
67 // eServiceReference ref("1:0:1:6de2:44d:1:c00000:0:0:0:");
68 eServiceReference ref("4097:47:0:0:0:0:0:0:0:0:/sine_60s_100.mp3");
69 eServiceReference ref1("4097:47:0:0:0:0:0:0:0:0:/sine_60s_100.mp31");
70 eServiceReference ref2("4097:47:0:0:0:0:0:0:0:0:/sine_60s_100.mp32");
72 if (m_nav->enqueueService(ref))
73 eDebug("play sucked around!");
75 eDebug("play r00lz!");
77 m_nav->enqueueService(ref1);
78 m_nav->enqueueService(ref2);
79 m_nav->enqueueService(ref1);
82 void event(eNavigation *nav, int ev)
86 ePtr<ePlaylist> playlist;
87 nav->getPlaylist(playlist);
91 ePlaylist::iterator i;
92 for (i=playlist->begin(); i != playlist->end(); ++i)
93 eDebug("%s %s", i == playlist->m_current ? "-->" : " ", i->toString().c_str());
98 case eNavigation::evStopService:
99 /* very important: the old service should be deallocated, so clear *all* references to it */
100 m_serviceInformation = 0;
101 eDebug("STOP service!");
103 case eNavigation::evNewService:
105 ePtr<iPlayableService> service;
106 nav->getCurrentService(service);
109 eDebug("no running service!");
112 if (service->getIServiceInformation(m_serviceInformation))
114 eDebug("failed to get iserviceinformation");
118 m_serviceInformation->getName(name);
119 eDebug("NEW running service: %s", name.c_str());
122 case eNavigation::evPlayFailed:
123 eDebug("play failed!");
125 case eNavigation::evPlaylistDone:
126 eDebug("playlist done");
130 eDebug("Navigation event %d", ev);
141 int object_total_remaining;
145 printf("%d items left\n", object_total_remaining);
162 if (!fgets(line, 1024, stdin))
164 line[strlen(line)-1]=0;
165 int rn = cli.doCommand(res, line);
166 eDebug("%s%d", res.c_str(), rn);
170 int res = app.exec();
171 eDebug("after exec");