From: Andreas Monzner Date: Tue, 21 Nov 2006 22:37:43 +0000 (+0000) Subject: add infrastructure for record service events (not finished yet) X-Git-Tag: 2.6.0~2693 X-Git-Url: https://git.cweiske.de/enigma2.git/commitdiff_plain/9511adb1e0b28923cd05f5bcb74575d49e57f650?ds=sidebyside add infrastructure for record service events (not finished yet) --- diff --git a/lib/service/iservice.h b/lib/service/iservice.h index 71c82ab0..73a0f4ef 100644 --- a/lib/service/iservice.h +++ b/lib/service/iservice.h @@ -540,6 +540,28 @@ class iRecordableService: public iObject ~iRecordableService(); #endif public: + enum + { + evStart, + evStop, + evTunedIn, + evTuneFailed, + evRecordRunning, + evNewProgramInfo, + evRecordFailed +// evDiskFull + }; + enum + { + NoError=0, + errOpenRecordFile=-1, + errNoDemuxAvailable=-2, + errNoTsRecorderAvailable=-3, + errDiskFull=-4, + errTuneFailed=-255 + }; + virtual RESULT getError(int &)=0; + virtual RESULT connectEvent(const Slot2 &event, ePtr &connection)=0; virtual RESULT prepare(const char *filename, time_t begTime=-1, time_t endTime=-1, int eit_event_id=-1)=0; virtual RESULT start()=0; virtual RESULT stop()=0; diff --git a/lib/service/servicedvbrecord.cpp b/lib/service/servicedvbrecord.cpp index 0c5777a3..fb3ae2ba 100644 --- a/lib/service/servicedvbrecord.cpp +++ b/lib/service/servicedvbrecord.cpp @@ -13,6 +13,7 @@ eDVBServiceRecord::eDVBServiceRecord(const eServiceReferenceDVB &ref): m_ref(ref m_want_record = 0; m_tuned = 0; m_target_fd = -1; + m_error = 0; } void eDVBServiceRecord::serviceEvent(int event) @@ -26,6 +27,13 @@ void eDVBServiceRecord::serviceEvent(int event) m_tuned = 1; if (m_state == stateRecording && m_want_record) doRecord(); + m_event((iRecordableService*)this, evTunedIn); + break; + } + case eDVBServicePMTHandler::eventTuneFailed: + { + eDebug("record failed to tune"); + m_event((iRecordableService*)this, evTuneFailed); break; } case eDVBServicePMTHandler::eventNewProgramInfo: @@ -34,6 +42,7 @@ void eDVBServiceRecord::serviceEvent(int event) doPrepare(); else if (m_want_record) /* doRecord can be called from Prepared and Recording state */ doRecord(); + m_event((iRecordableService*)this, evNewProgramInfo); break; } } @@ -98,6 +107,7 @@ RESULT eDVBServiceRecord::start() { m_want_record = 1; /* when tune wasn't yet successfully, doRecord stays in "prepared"-state which is fine. */ + m_event((iRecordableService*)this, evStart); return doRecord(); } @@ -122,6 +132,7 @@ RESULT eDVBServiceRecord::stop() m_record = 0; m_state = stateIdle; } + m_event((iRecordableService*)this, evStop); return 0; } @@ -142,21 +153,26 @@ int eDVBServiceRecord::doRecord() { int err = doPrepare(); if (err) + { + m_error = errTuneFailed; + m_event((iRecordableService*)this, evRecordFailed); return err; + } if (!m_tuned) return 0; /* try it again when we are tuned in */ if (!m_record && m_tuned) { - eDebug("Recording to %s...", m_filename.c_str()); ::remove(m_filename.c_str()); int fd = ::open(m_filename.c_str(), O_WRONLY|O_CREAT|O_LARGEFILE, 0644); if (fd == -1) { eDebug("eDVBServiceRecord - can't open recording file!"); - return -1; + m_error = errOpenRecordFile; + m_event((iRecordableService*)this, evRecordFailed); + return errOpenRecordFile; } /* turn off kernel caching strategies */ @@ -166,13 +182,17 @@ int eDVBServiceRecord::doRecord() if (m_service_handler.getDataDemux(demux)) { eDebug("eDVBServiceRecord - NO DEMUX available!"); - return -2; + m_error = errNoDemuxAvailable; + m_event((iRecordableService*)this, evRecordFailed); + return errNoDemuxAvailable; } demux->createTSRecorder(m_record); if (!m_record) { eDebug("eDVBServiceRecord - no ts recorder available."); - return -3; + m_error = errNoTsRecorderAvailable; + m_event((iRecordableService*)this, evRecordFailed); + return errNoTsRecorderAvailable; } m_record->setTargetFD(fd); m_record->setTargetFilename(m_filename.c_str()); @@ -289,6 +309,8 @@ int eDVBServiceRecord::doRecord() m_state = stateRecording; } } + m_error = 0; + m_event((iRecordableService*)this, evRecordRunning); return 0; } @@ -297,3 +319,9 @@ RESULT eDVBServiceRecord::frontendInfo(ePtr &ptr) ptr = this; return 0; } + +RESULT eDVBServiceRecord::connectEvent(const Slot2 &event, ePtr &connection) +{ + connection = new eConnection((iRecordableService*)this, m_event.connect(event)); + return 0; +} diff --git a/lib/service/servicedvbrecord.h b/lib/service/servicedvbrecord.h index 2b93b45a..6a58fc84 100644 --- a/lib/service/servicedvbrecord.h +++ b/lib/service/servicedvbrecord.h @@ -15,9 +15,11 @@ class eDVBServiceRecord: public eDVBServiceBase, { DECLARE_REF(eDVBServiceRecord); public: + RESULT connectEvent(const Slot2 &event, ePtr &connection); RESULT prepare(const char *filename, time_t begTime, time_t endTime, int eit_event_id); RESULT start(); RESULT stop(); + RESULT getError(int &error) { error = m_error; m_error = 0; return 0; } private: enum { stateIdle, statePrepared, stateRecording }; int m_state, m_want_record; @@ -25,11 +27,10 @@ private: eDVBServiceRecord(const eServiceReferenceDVB &ref); eServiceReferenceDVB m_ref; - void serviceEvent(int event); ePtr m_record; - int m_recording, m_tuned; + int m_recording, m_tuned, m_error; std::set m_pids_active; std::string m_filename; int m_target_fd; @@ -37,6 +38,11 @@ private: int doPrepare(); int doRecord(); RESULT frontendInfo(ePtr &ptr); + + /* events */ + void serviceEvent(int event); + Signal2 m_event; + }; #endif