X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/4c54cecb6020cde399b564f17dacb048b937018a..fc0d94d9a917be5979e4c2fcd910bd441a35843e:/lib/nav/core.h diff --git a/lib/nav/core.h b/lib/nav/core.h index db438412..b82d2fbd 100644 --- a/lib/nav/core.h +++ b/lib/nav/core.h @@ -3,35 +3,35 @@ #include #include -#include #include +#include class eNavigation: public iObject, public Object { - DECLARE_REF; + DECLARE_REF(eNavigation); private: - ePtr m_runningService; ePtr m_servicehandler; - Signal2 m_event; + + ePtr m_runningService; + Signal1 m_event; ePtr m_service_event_conn; void serviceEvent(iPlayableService* service, int event); - - ePtr m_playlist; + + std::map, ePtr, std::less > m_recordings; + Signal2,int> m_record_event; + void recordEvent(iRecordableService* service, int event); public: - enum - { - evStopService, /** the "current" service was just stopped and likes to be deallocated (clear refs!) */ - evNewService, /** a new "current" service was just started */ - evPlayFailed, /** the next service (in playlist) or the one given in playService failed to play */ - evPlaylistDone /** the last service in the playlist was just played */ - }; RESULT playService(const eServiceReference &service); - RESULT enqueueService(const eServiceReference &service); - RESULT connectEvent(const Slot2 &event, ePtr &connection); + RESULT connectEvent(const Slot1 &event, ePtr &connection); + RESULT connectRecordEvent(const Slot2,int> &event, ePtr &connection); /* int connectServiceEvent(const Slot1 &event, ePtr &connection); */ RESULT getCurrentService(ePtr &service); - RESULT getPlaylist(ePtr &playlist); + RESULT stopService(void); + + RESULT recordService(const eServiceReference &ref, ePtr &service); + RESULT stopRecordService(ePtr &service); + PyObject *getRecordings(void); RESULT pause(int p); eNavigation(iServiceHandler *serviceHandler);