git.cweiske.de
/
enigma2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fix dvd hotplug: stop assuming dvd for every other medium. in case of multiple ISO...
[enigma2.git]
/
lib
/
service
/
servicedvbrecord.h
diff --git
a/lib/service/servicedvbrecord.h
b/lib/service/servicedvbrecord.h
index 2b93b45aa3904bbf7950d6423f8bebc4cde458e0..b46a73ead40125342c52c1221389fcc78ced1f80 100644
(file)
--- a/
lib/service/servicedvbrecord.h
+++ b/
lib/service/servicedvbrecord.h
@@
-11,13
+11,24
@@
#include <lib/service/servicedvb.h>
class eDVBServiceRecord: public eDVBServiceBase,
#include <lib/service/servicedvb.h>
class eDVBServiceRecord: public eDVBServiceBase,
- public iRecordableService, public Object
+ public iRecordableService,
+ public iStreamableService,
+ public Object
{
{
-DECLARE_REF(eDVBServiceRecord);
+
DECLARE_REF(eDVBServiceRecord);
public:
public:
+ RESULT connectEvent(const Slot2<void,iRecordableService*,int> &event, ePtr<eConnection> &connection);
RESULT prepare(const char *filename, time_t begTime, time_t endTime, int eit_event_id);
RESULT prepare(const char *filename, time_t begTime, time_t endTime, int eit_event_id);
+ RESULT prepareStreaming();
RESULT start();
RESULT stop();
RESULT start();
RESULT stop();
+ RESULT stream(ePtr<iStreamableService> &ptr);
+ RESULT getError(int &error) { error = m_error; return 0; }
+ RESULT frontendInfo(ePtr<iFrontendInformation> &ptr);
+
+ /* streamable service */
+ PyObject *getStreamingData();
+
private:
enum { stateIdle, statePrepared, stateRecording };
int m_state, m_want_record;
private:
enum { stateIdle, statePrepared, stateRecording };
int m_state, m_want_record;
@@
-25,18
+36,25
@@
private:
eDVBServiceRecord(const eServiceReferenceDVB &ref);
eServiceReferenceDVB m_ref;
eDVBServiceRecord(const eServiceReferenceDVB &ref);
eServiceReferenceDVB m_ref;
- void serviceEvent(int event);
ePtr<iDVBTSRecorder> m_record;
ePtr<iDVBTSRecorder> m_record;
+ ePtr<eConnection> m_con_record_event;
- int m_recording, m_tuned;
+ int m_recording, m_tuned
, m_error
;
std::set<int> m_pids_active;
std::string m_filename;
int m_target_fd;
std::set<int> m_pids_active;
std::string m_filename;
int m_target_fd;
+ int m_streaming;
int doPrepare();
int doRecord();
int doPrepare();
int doRecord();
- RESULT frontendInfo(ePtr<iFrontendInformation> &ptr);
+
+ /* events */
+ void serviceEvent(int event);
+ Signal2<void,iRecordableService*,int> m_event;
+
+ /* recorder events */
+ void recordEvent(int event);
};
#endif
};
#endif