better error/retry handling for recorder
[enigma2.git] / lib / service / servicedvb.h
index 6b93469dc837cbf15a0b77ea2fb51c11e775bf22..b1df4cb78169a60af637d39c2fcba9ea332c9080 100644 (file)
@@ -55,7 +55,7 @@ private:
 class eDVBServicePlay: public iPlayableService, public iPauseableService, 
                public iSeekableService, public Object, public iServiceInformation, 
                public iAudioTrackSelection, public iFrontendStatusInformation,
-               public iSubserviceList
+               public iSubserviceList, public iTimeshiftService
 {
 DECLARE_REF(eDVBServicePlay);
 public:
@@ -71,6 +71,7 @@ public:
        RESULT audioTracks(ePtr<iAudioTrackSelection> &ptr);
        RESULT frontendStatusInfo(ePtr<iFrontendStatusInformation> &ptr);
        RESULT subServices(ePtr<iSubserviceList> &ptr);
+       RESULT timeshift(ePtr<iTimeshiftService> &ptr);
 
                // iPauseableService
        RESULT pause();
@@ -83,6 +84,7 @@ public:
        RESULT seekTo(pts_t to);
        RESULT seekRelative(int direction, pts_t to);
        RESULT getPlayPosition(pts_t &pos);
+       RESULT setTrickmode(int trick=0);
 
                // iServiceInformation
        RESULT getName(std::string &name);
@@ -102,6 +104,10 @@ public:
        int getNumberOfSubservices();
        RESULT getSubservice(eServiceReference &subservice, unsigned int n);
 
+               // iTimeshiftService
+       RESULT startTimeshift();
+       RESULT stopTimeshift();
+
 private:
        friend class eServiceFactoryDVB;
        eServiceReference m_reference;
@@ -120,7 +126,7 @@ private:
        void serviceEvent(int event);
        Signal2<void,iPlayableService*,int> m_event;
        
-       int m_is_pvr, m_is_paused;
+       int m_is_pvr, m_is_paused, m_timeshift_enabled;
        
        int m_current_audio_stream;
        int selectAudioStream(int n);