X-Git-Url: http://code.vuplus.com/gitweb/?a=blobdiff_plain;f=lib%2Fnav%2Fcore.h;h=9f7be884dd15c3e1c6c26a2b16658393d03c09ef;hb=0ffeb4cf114a6706ba629112c070e3d94da98793;hp=99cf75ae35caaf7fd6c7484ae7285fb7ca98fe3c;hpb=02da1f586ef7945fef385e6d4743ef53441bc2fa;p=vuplus_dvbapp diff --git a/lib/nav/core.h b/lib/nav/core.h index 99cf75a..9f7be88 100644 --- a/lib/nav/core.h +++ b/lib/nav/core.h @@ -4,31 +4,36 @@ #include #include #include +#include +#include class eNavigation: public iObject, public Object { - DECLARE_REF; -private: - ePtr m_runningService; + DECLARE_REF(eNavigation); ePtr m_servicehandler; - Signal2 m_event; + + ePtr m_runningService; + Signal1 m_event; ePtr m_service_event_conn; void serviceEvent(iPlayableService* service, int event); - - std::list m_playlist; + + std::map, ePtr, std::less > m_recordings; + std::set, std::less > m_simulate_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, - evPlaylistDone - }; + 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 stopService(void); + + RESULT recordService(const eServiceReference &ref, ePtr &service, bool simulate=false); + RESULT stopRecordService(ePtr &service); + PyObject *getRecordings(bool simulate=false); RESULT pause(int p); eNavigation(iServiceHandler *serviceHandler);