git.cweiske.de
/
enigma2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
update sv, hy, lt, pl, fr language
[enigma2.git]
/
lib
/
service
/
servicedvbrecord.h
diff --git
a/lib/service/servicedvbrecord.h
b/lib/service/servicedvbrecord.h
index 2b93b45aa3904bbf7950d6423f8bebc4cde458e0..17de033e190b18629f386538ea589d195fe799f0 100644
(file)
--- a/
lib/service/servicedvbrecord.h
+++ b/
lib/service/servicedvbrecord.h
@@
-11,32
+11,51
@@
#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 start();
+ RESULT prepareStreaming();
+ RESULT start(bool simulate=false);
RESULT stop();
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 };
private:
enum { stateIdle, statePrepared, stateRecording };
+ bool m_simulate;
int m_state, m_want_record;
friend class eServiceFactoryDVB;
eDVBServiceRecord(const eServiceReferenceDVB &ref);
eServiceReferenceDVB m_ref;
int m_state, m_want_record;
friend class eServiceFactoryDVB;
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