X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/5cd11d2e469c17ebafb6b995076970f2a2ab82d0..ff840bdbd611fde4e94f80b733e9482dd95ac441:/lib/dvb/dvb.h diff --git a/lib/dvb/dvb.h b/lib/dvb/dvb.h index 5801dd6c..4ca986b1 100644 --- a/lib/dvb/dvb.h +++ b/lib/dvb/dvb.h @@ -23,6 +23,7 @@ class eDVBRegisteredFrontend: public iObject, public Object { DECLARE_REF(eDVBRegisteredFrontend); eTimer *disable; + Signal0 stateChanged; void closeFrontend() { if (!m_inuse && m_frontend->closeFrontend()) // frontend busy @@ -38,12 +39,18 @@ public: void dec_use() { if (!--m_inuse) + { + /* emit */ stateChanged(); disable->start(3000, true); + } } void inc_use() { if (++m_inuse == 1) + { m_frontend->openFrontend(); + /* emit */ stateChanged(); + } } iDVBAdapter *m_adapter; ePtr m_frontend; @@ -175,6 +182,7 @@ class eDVBResourceManager: public iObject, public Object eTimer m_releaseCachedChannelTimer; void DVBChannelStateChanged(iDVBChannel*); void releaseCachedChannel(); + void feStateChanged(); #ifndef SWIG public: #endif @@ -199,8 +207,9 @@ public: #ifdef SWIG public: #endif - RESULT allocateRawChannel(eUsePtr &SWIG_OUTPUT, int frontend_index); - static SWIG_VOID(RESULT) getInstance(ePtr &OUTPUT); + PSignal1 frontendUseMaskChanged; + RESULT allocateRawChannel(eUsePtr &, int frontend_index); + static RESULT getInstance(ePtr &); }; TEMPLATE_TYPEDEF(ePtr, eDVBResourceManagerPtr); #ifndef SWIG