diff options
author | Gustavo André dos Santos Lopes <cataphract@php.net> | 2010-10-14 03:15:15 +0000 |
---|---|---|
committer | Gustavo André dos Santos Lopes <cataphract@php.net> | 2010-10-14 03:15:15 +0000 |
commit | 3943351e6a0a7d866ec2e74e32181eae340cf920 (patch) | |
tree | 978e2deeef7da83932dffd44b1b855468313a6ca | |
parent | fbd3eb6439de8c9dbf05b42449911f6206e10a50 (diff) | |
download | php-git-3943351e6a0a7d866ec2e74e32181eae340cf920.tar.gz |
- [DOC] Reverted rev #304382 and rev #304380, as I figured out a way to
fix the erratic behavior without breaking backwards compatibility. Namely,
$offset retains SEEK_SET behavior but actually SEEK_CUR is passed to
_php_stream_seek, if possible, by moving the offset stream->position bytes.
- Addresses bug #53006.
-rw-r--r-- | ext/standard/streamsfuncs.c | 21 | ||||
-rw-r--r-- | ext/standard/tests/streams/bug46426.phpt | 20 | ||||
-rw-r--r-- | ext/standard/tests/streams/stream_get_contents_001.phpt | 5 |
3 files changed, 23 insertions, 23 deletions
diff --git a/ext/standard/streamsfuncs.c b/ext/standard/streamsfuncs.c index a01c58c3fe..0ed8e10e6d 100644 --- a/ext/standard/streamsfuncs.c +++ b/ext/standard/streamsfuncs.c @@ -415,7 +415,7 @@ PHP_FUNCTION(stream_get_contents) { php_stream *stream; zval *zsrc; - long maxlen = PHP_STREAM_COPY_ALL, pos = 0; + long maxlen = PHP_STREAM_COPY_ALL, pos = -1L; int len, newlen; char *contents = NULL; @@ -425,12 +425,19 @@ PHP_FUNCTION(stream_get_contents) php_stream_from_zval(stream, &zsrc); - if ((pos > 0L) && php_stream_seek(stream, pos, SEEK_CUR) < 0) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "Failed to seek %ld bytes from current position in the stream", pos); - RETURN_FALSE; - } else if (pos < 0L) { - php_error_docref(NULL TSRMLS_CC, E_WARNING, "Number of bytes to seek must be non-negative, given %ld", pos); - RETURN_FALSE; + if (pos >= 0) { + int seek_res = 0; + if (pos > stream->position) { + /* use SEEK_CUR to allow emulation in streams that don't support seeking */ + seek_res = php_stream_seek(stream, pos - stream->position, SEEK_CUR); + } else if (pos < stream->position) { + seek_res = php_stream_seek(stream, pos, SEEK_SET); + } + + if (seek_res != 0) { + php_error_docref(NULL TSRMLS_CC, E_WARNING, "Failed to seek to position %ld in the stream", pos); + RETURN_FALSE; + } } len = php_stream_copy_to_mem(stream, &contents, maxlen, 0); diff --git a/ext/standard/tests/streams/bug46426.phpt b/ext/standard/tests/streams/bug46426.phpt index cd3c3254ef..80dbcded80 100644 --- a/ext/standard/tests/streams/bug46426.phpt +++ b/ext/standard/tests/streams/bug46426.phpt @@ -7,23 +7,19 @@ $tmp = tmpfile(); fwrite($tmp, b"12345"); -fseek($tmp, 0); -echo stream_get_contents($tmp, 2, 1); //23 +echo stream_get_contents($tmp, 2, 1); echo "\n"; -echo stream_get_contents($tmp, -1); //45 +echo stream_get_contents($tmp, -1); echo "\n"; -fseek($tmp, -1, SEEK_CUR); -echo stream_get_contents($tmp, -1, 0); //5 +echo stream_get_contents($tmp, -1, 0); echo "\n"; -fseek($tmp, 0); -echo stream_get_contents($tmp, -1, 2); //345 +echo stream_get_contents($tmp, -1, 2); echo "\n"; -fseek($tmp, 0); -echo stream_get_contents($tmp, 0, 0); //"" +echo stream_get_contents($tmp, 0, 0); echo "\n"; -echo stream_get_contents($tmp, 1, 0); //1 +echo stream_get_contents($tmp, 1, 0); echo "\n"; -echo stream_get_contents($tmp, -1); //2345 +echo stream_get_contents($tmp, -1); @unlink($tmp); @@ -31,7 +27,7 @@ echo stream_get_contents($tmp, -1); //2345 --EXPECT-- 23 45 -5 +12345 345 1 diff --git a/ext/standard/tests/streams/stream_get_contents_001.phpt b/ext/standard/tests/streams/stream_get_contents_001.phpt index 0b7db1fbcb..e8e1c3d26b 100644 --- a/ext/standard/tests/streams/stream_get_contents_001.phpt +++ b/ext/standard/tests/streams/stream_get_contents_001.phpt @@ -9,17 +9,14 @@ fwrite($tmp, b"12345"); echo stream_get_contents($tmp, 2, 5), "--\n"; echo stream_get_contents($tmp, 2), "--\n"; -fseek($tmp, 0); echo stream_get_contents($tmp, 2, 3), "--\n"; echo stream_get_contents($tmp, 2, -1), "--\n"; @unlink($tmp); ?> ---EXPECTF-- +--EXPECT-- -- -- 45-- - -Warning: stream_get_contents(): Number of bytes to seek must be non-negative, given -1 in %s on line %d -- |