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 no more working tuner resource handling
[enigma2.git]
/
lib
/
service
/
servicedvbrecord.h
diff --git
a/lib/service/servicedvbrecord.h
b/lib/service/servicedvbrecord.h
index 7d5a4fb3f7ebe7b8f3e8297d410424b8aef59c81..b46a73ead40125342c52c1221389fcc78ced1f80 100644
(file)
--- a/
lib/service/servicedvbrecord.h
+++ b/
lib/service/servicedvbrecord.h
@@
-10,13
+10,25
@@
#include <lib/service/servicedvb.h>
#include <lib/service/servicedvb.h>
-class eDVBServiceRecord: public iRecordableService, public Object
+class eDVBServiceRecord: public eDVBServiceBase,
+ public iRecordableService,
+ public iStreamableService,
+ public Object
{
{
-DECLARE_REF(eDVBServiceRecord);
+
DECLARE_REF(eDVBServiceRecord);
public:
public:
- RESULT prepare(const char *filename);
+ 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 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;
@@
-24,17
+36,25
@@
private:
eDVBServiceRecord(const eServiceReferenceDVB &ref);
eServiceReferenceDVB m_ref;
eDVBServiceRecord(const eServiceReferenceDVB &ref);
eServiceReferenceDVB m_ref;
- eDVBServicePMTHandler m_service_handler;
- void serviceEvent(int event);
ePtr<iDVBTSRecorder> m_record;
ePtr<iDVBTSRecorder> m_record;
+ ePtr<eConnection> m_con_record_event;
- int m_recording;
+ int m_recording
, m_tuned, m_error
;
std::set<int> m_pids_active;
std::string m_filename;
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();
+
+ /* events */
+ void serviceEvent(int event);
+ Signal2<void,iRecordableService*,int> m_event;
+
+ /* recorder events */
+ void recordEvent(int event);
};
#endif
};
#endif