git.cweiske.de
/
enigma2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
filepush: do not loop anymore on eof, but signal an event
[enigma2.git]
/
lib
/
base
/
filepush.cpp
diff --git
a/lib/base/filepush.cpp
b/lib/base/filepush.cpp
index cb22ea1b0999abb266f1600a2d8eea51eb90ff4e..7ab8c0d375856166b6e904b9bd10b349acb8e597 100644
(file)
--- a/
lib/base/filepush.cpp
+++ b/
lib/base/filepush.cpp
@@
-4,10
+4,11
@@
#include <errno.h>
#include <fcntl.h>
#include <errno.h>
#include <fcntl.h>
-eFilePushThread::eFilePushThread()
+eFilePushThread::eFilePushThread()
: m_messagepump(eApp, 0)
{
m_stop = 0;
flush();
{
m_stop = 0;
flush();
+ CONNECT(m_messagepump.recv_msg, eFilePushThread::recvEvent);
}
static void signal_handler(int x)
}
static void signal_handler(int x)
@@
-65,12
+66,16
@@
void eFilePushThread::thread()
}
if (m_buf_end == 0)
{
}
if (m_buf_end == 0)
{
+ sendEvent(evtEOF);
+
+#if 0
eDebug("FILEPUSH: end-of-file! (currently unhandled)");
if (!lseek(m_fd_source, 0, SEEK_SET))
{
eDebug("(looping)");
continue;
}
eDebug("FILEPUSH: end-of-file! (currently unhandled)");
if (!lseek(m_fd_source, 0, SEEK_SET))
{
eDebug("(looping)");
continue;
}
+#endif
break;
}
// printf("FILEPUSH: read %d bytes\n", m_buf_end);
break;
}
// printf("FILEPUSH: read %d bytes\n", m_buf_end);
@@
-114,3
+119,13
@@
void eFilePushThread::flush()
m_buf_start = m_buf_end = 0;
}
m_buf_start = m_buf_end = 0;
}
+
+void eFilePushThread::sendEvent(int evt)
+{
+ m_messagepump.send(evt);
+}
+
+void eFilePushThread::recvEvent(const int &evt)
+{
+ m_event(evt);
+}