diff options
author | Wez Furlong <wez@php.net> | 2002-10-12 02:31:42 +0000 |
---|---|---|
committer | Wez Furlong <wez@php.net> | 2002-10-12 02:31:42 +0000 |
commit | 258aa4d239398226073d98100ba227343221c59a (patch) | |
tree | f9dc04c75bc8e42a082ff287f1235a7e5a39fe26 | |
parent | ba3730c2c8a499e3f673ca6a93dccc63e035d497 (diff) | |
download | php-git-258aa4d239398226073d98100ba227343221c59a.tar.gz |
Write in blocks of the current chunk_size for a stream.
Should resolve problems with network writes.
-rwxr-xr-x | main/streams.c | 25 |
1 files changed, 19 insertions, 6 deletions
diff --git a/main/streams.c b/main/streams.c index 475a4bbc2f..a39a6c0a89 100755 --- a/main/streams.c +++ b/main/streams.c @@ -759,18 +759,31 @@ PHPAPI int _php_stream_flush(php_stream *stream, int closing TSRMLS_DC) PHPAPI size_t _php_stream_write(php_stream *stream, const char *buf, size_t count TSRMLS_DC) { - size_t didwrite; + size_t didwrite = 0, towrite, justwrote; assert(stream); if (buf == NULL || count == 0 || stream->ops->write == NULL) return 0; - if (stream->filterhead) { - didwrite = stream->filterhead->fops->write(stream, stream->filterhead, buf, count TSRMLS_CC); - } else { - didwrite = stream->ops->write(stream, buf, count TSRMLS_CC); + while (count > 0) { + towrite = count; + if (towrite > stream->chunk_size) + towrite = stream->chunk_size; + + if (stream->filterhead) { + justwrote = stream->filterhead->fops->write(stream, stream->filterhead, buf, towrite TSRMLS_CC); + } else { + justwrote = stream->ops->write(stream, buf, towrite TSRMLS_CC); + } + if (justwrote > 0) { + stream->position += justwrote; + buf += justwrote; + count -= justwrote; + didwrite += justwrote; + } else { + break; + } } - stream->position += didwrite; return didwrite; } |