X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/9202d4248dd7df2f6e5eb53b4154c8297ec9b1d1..54bd4123728628a6f77bad2584b70d1353a91666:/main/enigma.cpp diff --git a/main/enigma.cpp b/main/enigma.cpp index faff4d89..b055619e 100644 --- a/main/enigma.cpp +++ b/main/enigma.cpp @@ -21,6 +21,10 @@ #include #include +#include + +#include + #ifdef OBJECT_DEBUG int object_total_remaining; @@ -49,25 +53,68 @@ void dumpRegion(const gRegion ®ion) } } +eWidgetDesktop *wdsk; + +// typedef struct _object PyObject; + +void print(int i) +{ + printf("C++ says: it's a %d!!!\n", i); +} + +PSignal1 keyPressed; + +PSignal1 &keyPressedSignal() +{ + return keyPressed; +} + +void keyEvent(const eRCKey &key) +{ + if (!key.flags) + keyPressed(key.code); +} + +/************************************************/ +#include +#include +#include +#include +#include class eMain: public eApplication, public Object { eInit init; + + ePtr m_mgr; + ePtr m_dvbdb; + + ePtr m_scan; + public: eMain() { init.setRunlevel(eAutoInitNumbers::main); + + /* TODO: put into init */ + m_dvbdb = new eDVBDB(); + m_mgr = new eDVBResourceManager(); + + m_mgr->setChannelList(m_dvbdb); + +// m_scan = new eComponentScan(); +// m_scan->start(); + + } + + ~eMain() + { + m_scan = 0; } }; -eWidgetDesktop *wdsk; +/************************************************/ -// typedef struct _object PyObject; - -void print(int i) -{ - printf("C++ says: it's a %d!!!\n", i); -} int main(int argc, char **argv) { @@ -76,9 +123,10 @@ int main(int argc, char **argv) #endif -#if 1 + ePython python; eMain main; +#if 1 ePtr my_dc; gFBDC::getInstance(my_dc); @@ -105,17 +153,20 @@ int main(int argc, char **argv) eWidgetDesktop dsk(eSize(720, 576)); wdsk = &dsk; + dsk.setBackgroundColor(gColor(0)); dsk.setDC(my_dc); #endif /* redrawing is done in an idle-timer, so we have to set the context */ dsk.setRedrawTask(main); - ePython python; + eRCInput::getInstance()->keyEvent.connect(slot(keyEvent)); printf("executing main\n"); python.execute("mytest", "__main__"); +// eApp->exec(); + return 0; } @@ -128,3 +179,8 @@ void runMainloop() { eApp->exec(); } + +void quitMainloop() +{ + eApp->quit(0); +}