4.5.1r9
[enigma2.git] / usr / include / enigma2 / lib / dvb / idemux.h
1 #ifndef __dvb_idemux_h
2 #define __dvb_idemux_h
3
4 #include <lib/dvb/idvb.h>
5
6 class iDVBSectionReader: public iObject
7 {
8 public:
9         virtual RESULT setBufferSize(int size)=0;
10         virtual RESULT start(const eDVBSectionFilterMask &mask)=0;
11         virtual RESULT startWithExternalBufferFunc(const eDVBSectionFilterMask &mask, const Slot0<__u8*> &buffer_func)=0;
12         virtual RESULT stop()=0;
13         virtual RESULT connectRead(const sigc::slot2<void,const __u8*, int> &read, ePtr<eConnection> &conn)=0;
14         virtual ~iDVBSectionReader() { };
15 };
16
17 class iDVBTSReader: public iObject
18 {
19 public:
20         enum {
21                 typeOther=0,
22                 typeVideo0=1,
23                 typeVideo1=2,
24                 typeVideo2=3,
25                 typeAudio0=4,
26                 typeAudio1=5,
27                 typeAudio2=6,
28         };
29         virtual RESULT setBufferSize(int size)=0;
30         virtual RESULT configure(int pid, int type) = 0;
31         virtual RESULT start()=0;
32         virtual RESULT start(int pid, int type)=0;
33         virtual RESULT stop()=0;
34         virtual RESULT addPID(int pid) = 0;
35         virtual RESULT removePID(int pid) = 0;
36
37         virtual bool paused()=0;
38         virtual void pause()=0;
39         virtual void resume()=0;
40
41         virtual bool active()=0;
42         virtual RESULT connectRead(const sigc::slot2<void,const __u8*, int> &read, ePtr<eConnection> &conn)=0;
43         virtual ~iDVBTSReader() { };
44
45         virtual void close() { }; // workaround to close a fd to interrupt a pending read for faster stop response... default a NOP
46         virtual bool closePending() { return false;  }
47
48         virtual ssize_t read(unsigned char *d, int bytes)=0;    /* for blocking reads.. on create context must be NULL */
49 };
50
51 class iDVBPESReader: public iObject
52 {
53 public:
54         virtual RESULT setBufferSize(int size)=0;
55         virtual RESULT start(int pid)=0;
56         virtual RESULT stop()=0;
57         virtual RESULT connectRead(const sigc::slot2<void,const __u8*, int> &read, ePtr<eConnection> &conn)=0;
58         virtual ~iDVBPESReader() { };
59 };
60
61         /* records a given set of pids into a file descriptor. */
62         /* the FD must not be modified between start() and stop() ! */
63 class iDVBTSRecorder: public iObject
64 {
65 public:
66         virtual RESULT setBufferSize(int size) = 0;
67         virtual RESULT start() = 0;
68         virtual RESULT addPID(int pid) = 0;
69         virtual RESULT removePID(int pid) = 0;
70         
71         virtual RESULT setTimingPID(int pid, int type) = 0;
72         
73         virtual RESULT setTargetFD(int fd) = 0;
74                 /* for saving additional meta data. */
75         virtual RESULT setTargetFilename(const char *filename) = 0;
76         virtual RESULT setAccessPoints(bool on) = 0;
77         
78         virtual RESULT stop() = 0;
79
80         virtual RESULT getCurrentPCR(pts_t &pcr) = 0;
81         
82         enum {
83                 eventWriteError,
84                                 /* a write error has occured. data won't get lost if fd is writable after return. */
85                                 /* you MUST respond with either stop() or fixing the problems, else you get the error */
86                                 /* again. */
87                 eventReachedBoundary,
88                                 /* the programmed boundary was reached. you might set a new target fd. you can close the */
89                                 /* old one. */
90         };
91         virtual RESULT connectEvent(const sigc::slot1<void,int> &event, ePtr<eConnection> &conn)=0;
92 };
93
94 class iDVBTSWriter: public iObject
95 {
96 public:
97         virtual ssize_t processData(const unsigned char *data, size_t bytes) = 0;
98         virtual void flush() = 0;
99         virtual int waitEOF() = 0;
100 };
101
102 #endif