git.cweiske.de
/
enigma2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
don't kill if thread isn't alive
[enigma2.git]
/
lib
/
base
/
filepush.h
diff --git
a/lib/base/filepush.h
b/lib/base/filepush.h
index b8d9f22176ef0f613c31c8cee03ccbee95195556..f2bd98be3be46afc993da9eab3a9de7f792bfeff 100644
(file)
--- a/
lib/base/filepush.h
+++ b/
lib/base/filepush.h
@@
-2,19
+2,40
@@
#define __lib_base_filepush_h
#include <lib/base/thread.h>
#define __lib_base_filepush_h
#include <lib/base/thread.h>
+#include <libsig_comp.h>
+#include <lib/base/message.h>
+#include <sys/types.h>
-class eFilePushThread: public eThread
+class eFilePushThread: public eThread
, public Object
{
public:
eFilePushThread();
void thread();
void stop();
void start(int sourcefd, int destfd);
{
public:
eFilePushThread();
void thread();
void stop();
void start(int sourcefd, int destfd);
+
+ void pause();
+ void seek(int whence, off_t where);
+ void resume();
+
+ /* flushes the internal readbuffer */
+ void flush();
+ void enablePVRCommit(int);
+
+ enum { evtEOF, evtReadError, evtWriteError };
+ Signal1<void,int> m_event;
+
private:
int m_stop;
unsigned char m_buffer[65536];
int m_buf_start, m_buf_end;
int m_fd_source, m_fd_dest;
private:
int m_stop;
unsigned char m_buffer[65536];
int m_buf_start, m_buf_end;
int m_fd_source, m_fd_dest;
+ int m_send_pvr_commit;
+
+ eFixedMessagePump<int> m_messagepump;
+
+ void sendEvent(int evt);
+ void recvEvent(const int &evt);
};
#endif
};
#endif