git.cweiske.de
/
enigma2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add EOF event
[enigma2.git]
/
lib
/
service
/
servicedvb.h
diff --git
a/lib/service/servicedvb.h
b/lib/service/servicedvb.h
index 4b6ef3e14b724ff46701fa97ce902232f3be9162..c7c36e1c6936c461850caeba920996c14e9cdeeb 100644
(file)
--- a/
lib/service/servicedvb.h
+++ b/
lib/service/servicedvb.h
@@
-54,7
+54,8
@@
private:
class eDVBServicePlay: public iPlayableService, public iPauseableService,
public iSeekableService, public Object, public iServiceInformation,
class eDVBServicePlay: public iPlayableService, public iPauseableService,
public iSeekableService, public Object, public iServiceInformation,
- public iAudioTrackSelection, public iFrontendStatusInformation
+ public iAudioTrackSelection, public iFrontendStatusInformation,
+ public iSubserviceList, public iTimeshiftService
{
DECLARE_REF(eDVBServicePlay);
public:
{
DECLARE_REF(eDVBServicePlay);
public:
@@
-69,16
+70,21
@@
public:
RESULT info(ePtr<iServiceInformation> &ptr);
RESULT audioTracks(ePtr<iAudioTrackSelection> &ptr);
RESULT frontendStatusInfo(ePtr<iFrontendStatusInformation> &ptr);
RESULT info(ePtr<iServiceInformation> &ptr);
RESULT audioTracks(ePtr<iAudioTrackSelection> &ptr);
RESULT frontendStatusInfo(ePtr<iFrontendStatusInformation> &ptr);
-
+ RESULT subServices(ePtr<iSubserviceList> &ptr);
+ RESULT timeshift(ePtr<iTimeshiftService> &ptr);
+
// iPauseableService
RESULT pause();
RESULT unpause();
// iPauseableService
RESULT pause();
RESULT unpause();
-
+ RESULT setSlowMotion(int ratio);
+ RESULT setFastForward(int ratio);
+
// iSeekableService
RESULT getLength(pts_t &len);
RESULT seekTo(pts_t to);
RESULT seekRelative(int direction, pts_t to);
RESULT getPlayPosition(pts_t &pos);
// iSeekableService
RESULT getLength(pts_t &len);
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);
// iServiceInformation
RESULT getName(std::string &name);
@@
-94,6
+100,14
@@
public:
// iFrontendStatusInformation
int getFrontendInfo(int w);
// iFrontendStatusInformation
int getFrontendInfo(int w);
+ // iSubserviceList
+ int getNumberOfSubservices();
+ RESULT getSubservice(eServiceReference &subservice, unsigned int n);
+
+ // iTimeshiftService
+ RESULT startTimeshift();
+ RESULT stopTimeshift();
+
private:
friend class eServiceFactoryDVB;
eServiceReference m_reference;
private:
friend class eServiceFactoryDVB;
eServiceReference m_reference;
@@
-102,7
+116,8
@@
private:
ePtr<iTSMPEGDecoder> m_decoder;
ePtr<iTSMPEGDecoder> m_decoder;
- eDVBServicePMTHandler m_service_handler;
+ /* in timeshift mode, we essentially have two channels, and thus pmt handlers. */
+ eDVBServicePMTHandler m_service_handler, m_service_handler_timeshift;
eDVBServiceEITHandler m_event_handler;
eDVBServicePlay(const eServiceReference &ref, eDVBService *service);
eDVBServiceEITHandler m_event_handler;
eDVBServicePlay(const eServiceReference &ref, eDVBService *service);
@@
-110,12
+125,27
@@
private:
void gotNewEvent();
void serviceEvent(int event);
void gotNewEvent();
void serviceEvent(int event);
+ void serviceEventTimeshift(int event);
Signal2<void,iPlayableService*,int> m_event;
Signal2<void,iPlayableService*,int> m_event;
- int m_is_pvr, m_is_paused;
+ int m_is_pvr, m_is_paused, m_timeshift_enabled, m_timeshift_active;
+
+ std::string m_timeshift_file;
+ int m_timeshift_fd;
+
+ ePtr<iDVBDemux> m_decode_demux;
int m_current_audio_stream;
int selectAudioStream(int n);
int m_current_audio_stream;
int selectAudioStream(int n);
+
+ ePtr<iDVBTSRecorder> m_record;
+ std::set<int> m_pids_active;
+
+ void updateTimeshiftPids();
+ void switchToLive();
+ void switchToTimeshift();
+
+ void updateDecoder();
};
#endif
};
#endif