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 languages: es, tr
[enigma2.git]
/
lib
/
base
/
filepush.cpp
diff --git
a/lib/base/filepush.cpp
b/lib/base/filepush.cpp
index 1e5685caed94448f29bc8d573c88d8315c51896f..1999707f537a9456a27b4a1ca18906b74caeee55 100644
(file)
--- a/
lib/base/filepush.cpp
+++ b/
lib/base/filepush.cpp
@@
-109,7
+109,7
@@
void eFilePushThread::thread()
// eDebug("wrote %d bytes", w);
if (w <= 0)
{
// eDebug("wrote %d bytes", w);
if (w <= 0)
{
- if (errno == EINTR)
+ if (errno == EINTR
|| errno == EAGAIN || errno == EBUSY
)
continue;
eDebug("eFilePushThread WRITE ERROR");
sendEvent(evtWriteError);
continue;
eDebug("eFilePushThread WRITE ERROR");
sendEvent(evtWriteError);
@@
-165,7
+165,7
@@
void eFilePushThread::thread()
if (m_buf_end < 0)
{
m_buf_end = 0;
if (m_buf_end < 0)
{
m_buf_end = 0;
- if (errno == EINTR)
+ if (errno == EINTR
|| errno == EBUSY || errno == EAGAIN
)
continue;
if (errno == EOVERFLOW)
{
continue;
if (errno == EOVERFLOW)
{
@@
-174,6
+174,15
@@
void eFilePushThread::thread()
}
eDebug("eFilePushThread *read error* (%m) - not yet handled");
}
}
eDebug("eFilePushThread *read error* (%m) - not yet handled");
}
+
+ /* a read might be mis-aligned in case of a short read. */
+ int d = m_buf_end % m_blocksize;
+ if (d)
+ {
+ m_raw_source.lseek(-d, SEEK_CUR);
+ m_buf_end -= d;
+ }
+
if (m_buf_end == 0)
{
/* on EOF, try COMMITting once. */
if (m_buf_end == 0)
{
/* on EOF, try COMMITting once. */