#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "bsod.h" #include "version_info.h" #include #ifdef OBJECT_DEBUG int object_total_remaining; void object_dump() { printf("%d items left\n", object_total_remaining); } #endif static eWidgetDesktop *wdsk, *lcddsk; static int prev_ascii_code; int getPrevAsciiCode() { int ret = prev_ascii_code; prev_ascii_code = 0; return ret; } void keyEvent(const eRCKey &key) { static eRCKey last(0, 0, 0); static int num_repeat; ePtr ptr; eActionMap::getInstance(ptr); if ((key.code == last.code) && (key.producer == last.producer) && key.flags & eRCKey::flagRepeat) num_repeat++; else { num_repeat = 0; last = key; } if (num_repeat == 4) { ptr->keyPressed(key.producer->getIdentifier(), key.code, eRCKey::flagLong); num_repeat++; } if (key.flags & eRCKey::flagAscii) { prev_ascii_code = key.code; ptr->keyPressed(key.producer->getIdentifier(), 510 /* faked KEY_ASCII */, 0); } else ptr->keyPressed(key.producer->getIdentifier(), key.code, key.flags); } /************************************************/ #include #include #include #include #include #include #include class eMain: public eApplication, public Object { eInit init; ePtr m_dvbdb; ePtr m_mgr; ePtr m_locale_time_handler; ePtr m_epgcache; public: eMain() { init.setRunlevel(eAutoInitNumbers::main); /* TODO: put into init */ m_dvbdb = new eDVBDB(); m_mgr = new eDVBResourceManager(); m_locale_time_handler = new eDVBLocalTimeHandler(); m_epgcache = new eEPGCache(); m_mgr->setChannelList(m_dvbdb); } ~eMain() { m_dvbdb->saveServicelist(); m_mgr->releaseCachedChannel(); } }; int exit_code; int main(int argc, char **argv) { #ifdef MEMLEAK_CHECK atexit(DumpUnfreed); #endif #ifdef OBJECT_DEBUG atexit(object_dump); #endif gst_init(&argc, &argv); // set pythonpath if unset setenv("PYTHONPATH", eEnv::resolve("${libdir}/enigma2/python").c_str(), 0); printf("PYTHONPATH: %s\n", getenv("PYTHONPATH")); bsodLogInit(); ePython python; eMain main; #if 1 ePtr my_dc; gMainDC::getInstance(my_dc); //int double_buffer = my_dc->haveDoubleBuffering(); ePtr my_lcd_dc; gLCDDC::getInstance(my_lcd_dc); /* ok, this is currently hardcoded for arabic. */ /* some characters are wrong in the regular font, force them to use the replacement font */ for (int i = 0x60c; i <= 0x66d; ++i) eTextPara::forceReplacementGlyph(i); eTextPara::forceReplacementGlyph(0xfdf2); for (int i = 0xfe80; i < 0xff00; ++i) eTextPara::forceReplacementGlyph(i); eWidgetDesktop dsk(eSize(720, 576)); eWidgetDesktop dsk_lcd(my_lcd_dc->size()); dsk.setStyleID(0); dsk_lcd.setStyleID(my_lcd_dc->size().width() == 96 ? 2 : 1); /* if (double_buffer) { eDebug(" - double buffering found, enable buffered graphics mode."); dsk.setCompositionMode(eWidgetDesktop::cmBuffered); } */ wdsk = &dsk; lcddsk = &dsk_lcd; dsk.setDC(my_dc); dsk_lcd.setDC(my_lcd_dc); ePtr m_pm; loadPNG(m_pm, eEnv::resolve("${datadir}/enigma2/skin_default/pal.png").c_str()); if (!m_pm) { eFatal("pal.png not found!"); } else dsk.setPalette(*m_pm); dsk.setBackgroundColor(gRGB(0,0,0,0xFF)); #endif /* redrawing is done in an idle-timer, so we have to set the context */ dsk.setRedrawTask(main); dsk_lcd.setRedrawTask(main); eDebug("Loading spinners..."); { int i; #define MAX_SPINNER 64 ePtr wait[MAX_SPINNER]; for (i=0; isetSpinner(eRect(ePoint(100, 100), wait[0]->size()), wait, i); else my_dc->setSpinner(eRect(100, 100, 0, 0), wait, 1); } gRC::getInstance()->setSpinnerDC(my_dc); eRCInput::getInstance()->keyEvent.connect(slot(keyEvent)); printf("executing main\n"); bsodCatchSignals(); setIoPrio(IOPRIO_CLASS_BE, 3); // python.execute("mytest", "__main__"); python.execFile(eEnv::resolve("${libdir}/enigma2/python/mytest.py").c_str()); extern void setFullsize(); // definend in lib/gui/evideo.cpp setFullsize(); if (exit_code == 5) /* python crash */ { eDebug("(exit code 5)"); bsodFatal(0); } dsk.paint(); dsk_lcd.paint(); { gPainter p(my_lcd_dc); p.resetClip(eRect(0, 0, 132, 64)); p.clear(); } return exit_code; } eWidgetDesktop *getDesktop(int which) { return which ? lcddsk : wdsk; } eApplication *getApplication() { return eApp; } void runMainloop() { eApp->runLoop(); } void quitMainloop(int exitCode) { FILE *f = fopen("/proc/stb/fp/was_timer_wakeup", "w"); if (f) { fprintf(f, "%d", 0); fclose(f); } else { int fd = open("/dev/dbox/fp0", O_WRONLY); if (fd >= 0) { if (ioctl(fd, 10 /*FP_CLEAR_WAKEUP_TIMER*/) < 0) eDebug("FP_CLEAR_WAKEUP_TIMER failed (%m)"); close(fd); } else eDebug("open /dev/dbox/fp0 for wakeup timer clear failed!(%m)"); } exit_code = exitCode; eApp->quit(0); } const char *getEnigmaVersionString() { std::string date = enigma2_date; std::string branch = enigma2_branch; return std::string(date + '-' + branch).c_str(); } #include void dump_malloc_stats(void) { struct mallinfo mi = mallinfo(); eDebug("MALLOC: %d total", mi.uordblks); }