diff options
author | Arnaud Le Blanc <lbarnaud@php.net> | 2008-11-04 17:07:20 +0000 |
---|---|---|
committer | Arnaud Le Blanc <lbarnaud@php.net> | 2008-11-04 17:07:20 +0000 |
commit | 1ba7b093a6f2dd84204d275a4513f08e44486eef (patch) | |
tree | 8aaeeceff5960cd5c91d47626d331f48ae8e9a60 | |
parent | 930a8feb661db44a32546213a6a391b133fa39e5 (diff) | |
download | php-git-1ba7b093a6f2dd84204d275a4513f08e44486eef.tar.gz |
MFH: Fixed stream_get_line() to behave as documented on non-blocking
streams
-rw-r--r-- | NEWS | 2 | ||||
-rw-r--r-- | ext/standard/tests/streams/stream_get_line_nb.phpt | 66 | ||||
-rwxr-xr-x | main/streams/streams.c | 3 |
3 files changed, 71 insertions, 0 deletions
@@ -43,6 +43,8 @@ PHP NEWS filter). (Arnaud) - Fixed bug #42294 (Unified solution for round() based on C99 round). (Ilia) +- Fixed stream_get_line() to behave as documented on non-blocking streams. + (Arnaud) - Fixed endless loop in PDOStatement::debugDumpParams(). (jonah.harris at gmail dot com) - Fixed ability to use "internal" heaps in extensions. (Arnaud, Dmitry) diff --git a/ext/standard/tests/streams/stream_get_line_nb.phpt b/ext/standard/tests/streams/stream_get_line_nb.phpt new file mode 100644 index 0000000000..3e3848f54a --- /dev/null +++ b/ext/standard/tests/streams/stream_get_line_nb.phpt @@ -0,0 +1,66 @@ +--TEST-- +stream_get_line() on non-blocking stream +--SKIPIF-- +<?php +$sockets = @stream_socket_pair(STREAM_PF_UNIX, STREAM_SOCK_STREAM, 0); +if (!$sockets) die("skip"); +fclose($sockets[0]); +fclose($sockets[1]); +?> +--FILE-- +<?php +/** + * Tests that stream_get_line() behaves as documented on non-blocking streams: + * Never return incomplete lines, except on documented conditions: + * length bytes have been read, the string specified by ending is found, EOF. + */ + +$sockets = stream_socket_pair(STREAM_PF_UNIX, STREAM_SOCK_STREAM, 0); +var_dump($sockets); + +stream_set_blocking($sockets[1], 0); + +$eol = b'<EOL>'; + +fwrite($sockets[0], b"line start"); +var_dump(stream_get_line($sockets[1], 8192, $eol)); // Does not returns incomplete line (EOL not found) +var_dump(stream_get_line($sockets[1], 8192, $eol)); +fwrite($sockets[0], b", line end"); +fwrite($sockets[0], b", $eol"); +var_dump(stream_get_line($sockets[1], 8192, $eol)); // Returns full line (EOL found) +var_dump(stream_get_line($sockets[1], 8192, $eol)); // Nothing to read +var_dump(stream_get_line($sockets[1], 8192, $eol)); + +fwrite($sockets[0], b"incomplete line"); +var_dump(stream_get_line($sockets[1], strlen(b"incomplete line"), $eol)); // EOL not found but $length has been read, return incomplete line + +fwrite($sockets[0], b"incomplete line"); +var_dump(stream_get_line($sockets[1], 8192, $eol)); // Does not returns incomplete line (EOL not found) +var_dump(fread($sockets[1], strlen(b"incomplete line"))); // Returns buffer readden by stream_get_line + +fwrite($sockets[0], b"end of file"); +var_dump(stream_get_line($sockets[1], 8192, $eol)); // Does not returns incomplete line (EOL not found) + +fclose($sockets[0]); +var_dump(stream_get_line($sockets[1], 8192, $eol)); // Returns incomplete line (End of file) + +fclose($sockets[1]); + +?> +--EXPECTF-- +array(2) { + [0]=> + resource(%d) of type (stream) + [1]=> + resource(%d) of type (stream) +} +bool(false) +bool(false) +string(22) "line start, line end, " +bool(false) +bool(false) +string(15) "incomplete line" +bool(false) +string(15) "incomplete line" +bool(false) +string(11) "end of file" diff --git a/main/streams/streams.c b/main/streams/streams.c index a5f99791d8..4dd0f7442c 100755 --- a/main/streams/streams.c +++ b/main/streams/streams.c @@ -881,6 +881,9 @@ PHPAPI char *php_stream_get_record(php_stream *stream, size_t maxlen, size_t *re } if (!e) { + if (seek_len < maxlen && !stream->eof) { + return NULL; + } toread = maxlen; } else { toread = e - (char *) stream->readbuf - stream->readpos; |