don't try to flush if there is nothing to flush

zlib reports Z_BUF_ERROR when a flush is attempted without any activity
since the previous flush (if any). while this is harmless as such,
discerning the condition from genuine errors would be much harder than
avoiding the pointless flush in the first place.

REFMAIL: eb5681612f17be777bc8d138d31dd6d6@mpcjanssen.nl
This commit is contained in:
Oswald Buddenhagen 2015-02-15 11:39:38 +01:00
parent f4240761f1
commit ef70bd4a40

View File

@ -812,7 +812,7 @@ socket_write( conn_t *conn, conn_iovec_t *iov, int iovcnt )
for (i = 0; i < iovcnt; i++)
total += iov[i].len;
if (total >= WRITE_CHUNK_SIZE) {
if (total >= WRITE_CHUNK_SIZE && pending_wakeup( &conn->fd_fake )) {
/* If the new data is too big, queue the pending buffer to avoid latency. */
do_flush( conn );
}