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 ca language
[enigma2.git]
/
lib
/
base
/
filepush.h
diff --git
a/lib/base/filepush.h
b/lib/base/filepush.h
index 7e16fa028aa9a8f5d90fbbc39e46ab1c90b78675..0749cd43d4b3f0c68b19c44e5afd37e7a06b088d 100644
(file)
--- a/
lib/base/filepush.h
+++ b/
lib/base/filepush.h
@@
-2,23
+2,28
@@
#define __lib_base_filepush_h
#include <lib/base/thread.h>
#define __lib_base_filepush_h
#include <lib/base/thread.h>
+#include <lib/base/ioprio.h>
#include <libsig_comp.h>
#include <lib/base/message.h>
#include <sys/types.h>
#include <libsig_comp.h>
#include <lib/base/message.h>
#include <sys/types.h>
+#include <lib/base/rawfile.h>
class iFilePushScatterGather
{
public:
class iFilePushScatterGather
{
public:
- virtual void getNextSourceSpan(size_t bytes_read, off_t &start, size_t &size)=0;
+ virtual void getNextSourceSpan(off_t current_offset, size_t bytes_read, off_t &start, size_t &size)=0;
+ virtual ~iFilePushScatterGather() {}
};
class eFilePushThread: public eThread, public Object
{
};
class eFilePushThread: public eThread, public Object
{
+ int prio_class, prio;
public:
public:
- eFilePushThread();
+ eFilePushThread(
int prio_class=IOPRIO_CLASS_BE, int prio_level=0
);
void thread();
void stop();
void start(int sourcefd, int destfd);
void thread();
void stop();
void start(int sourcefd, int destfd);
+ int start(const char *filename, int destfd);
void pause();
void seek(int whence, off_t where);
void pause();
void seek(int whence, off_t where);
@@
-28,22
+33,30
@@
public:
void flush();
void enablePVRCommit(int);
void flush();
void enablePVRCommit(int);
- void setS
G
(iFilePushScatterGather *);
+ void setS
catterGather
(iFilePushScatterGather *);
- enum { evtEOF, evtReadError, evtWriteError };
+ enum { evtEOF, evtReadError, evtWriteError
, evtUser
};
Signal1<void,int> m_event;
Signal1<void,int> m_event;
-
+
+ void installSigUSR1Handler();
+ void before_set_thread_alive();
+
+ /* you can send private events if you want */
+ void sendEvent(int evt);
+protected:
+ virtual void filterRecordData(const unsigned char *data, int len);
private:
iFilePushScatterGather *m_sg;
int m_stop;
unsigned char m_buffer[65536];
int m_buf_start, m_buf_end;
private:
iFilePushScatterGather *m_sg;
int m_stop;
unsigned char m_buffer[65536];
int m_buf_start, m_buf_end;
- int m_fd_
source, m_fd_
dest;
+ int m_fd_dest;
int m_send_pvr_commit;
int m_send_pvr_commit;
+ eRawFile m_raw_source;
+
eFixedMessagePump<int> m_messagepump;
eFixedMessagePump<int> m_messagepump;
- void sendEvent(int evt);
void recvEvent(const int &evt);
};
void recvEvent(const int &evt);
};