X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/2e2cf81de863a180f7d27dca89e5122e1eb0acaa..2d01fd232419dbb9edaf7eb42f587dc635d21d42:/lib/service/servicedvb.h diff --git a/lib/service/servicedvb.h b/lib/service/servicedvb.h index 165703dd..4b6ef3e1 100644 --- a/lib/service/servicedvb.h +++ b/lib/service/servicedvb.h @@ -37,6 +37,7 @@ public: int compareLessEqual(const eServiceReference &a, const eServiceReference &b); RESULT startEdit(ePtr &); + RESULT flushChanges(); RESULT addService(eServiceReference &ref); RESULT removeService(eServiceReference &ref); RESULT moveService(eServiceReference &ref, int pos); @@ -51,7 +52,9 @@ private: eBouquet *m_bouquet; }; -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 { DECLARE_REF(eDVBServicePlay); public: @@ -64,6 +67,8 @@ public: RESULT seek(ePtr &ptr); RESULT pause(ePtr &ptr); RESULT info(ePtr &ptr); + RESULT audioTracks(ePtr &ptr); + RESULT frontendStatusInfo(ePtr &ptr); // iPauseableService RESULT pause(); @@ -78,6 +83,16 @@ public: // iServiceInformation RESULT getName(std::string &name); RESULT getEvent(ePtr &evt, int nownext); + int getInfo(int w); + std::string getInfoString(int w); + + // iAudioTrackSelection + int getNumberOfTracks(); + RESULT selectTrack(unsigned int i); + RESULT getTrackInfo(struct iAudioTrackInfo &, unsigned int n); + + // iFrontendStatusInformation + int getFrontendInfo(int w); private: friend class eServiceFactoryDVB; @@ -98,6 +113,9 @@ private: Signal2 m_event; int m_is_pvr, m_is_paused; + + int m_current_audio_stream; + int selectAudioStream(int n); }; #endif