From bdac9ef10d90997f9576564dde693cbef6594142 Mon Sep 17 00:00:00 2001 From: twosee Date: Mon, 8 Apr 2019 12:58:46 +0200 Subject: Preserve keys in emulate_read_fd_set() Keys are already preserved in the non-emulated case. --- ext/standard/streamsfuncs.c | 12 +++++--- .../tests/streams/stream_select_preserve_keys.phpt | 35 ++++++++++++++++++++++ 2 files changed, 43 insertions(+), 4 deletions(-) create mode 100644 ext/standard/tests/streams/stream_select_preserve_keys.phpt diff --git a/ext/standard/streamsfuncs.c b/ext/standard/streamsfuncs.c index 2654382906..9d725db919 100644 --- a/ext/standard/streamsfuncs.c +++ b/ext/standard/streamsfuncs.c @@ -710,6 +710,8 @@ static int stream_array_emulate_read_fd_set(zval *stream_array) zval *elem, *dest_elem, new_array; php_stream *stream; int ret = 0; + zend_ulong num_ind; + zend_string *key; if (Z_TYPE_P(stream_array) != IS_ARRAY) { return 0; @@ -717,7 +719,7 @@ static int stream_array_emulate_read_fd_set(zval *stream_array) ZVAL_NEW_ARR(&new_array); zend_hash_init(Z_ARRVAL(new_array), zend_hash_num_elements(Z_ARRVAL_P(stream_array)), NULL, ZVAL_PTR_DTOR, 0); - ZEND_HASH_FOREACH_VAL(Z_ARRVAL_P(stream_array), elem) { + ZEND_HASH_FOREACH_KEY_VAL(Z_ARRVAL_P(stream_array), num_ind, key, elem) { ZVAL_DEREF(elem); php_stream_from_zval_no_verify(stream, elem); if (stream == NULL) { @@ -730,10 +732,12 @@ static int stream_array_emulate_read_fd_set(zval *stream_array) * This branch of code also allows blocking streams with buffered data to * operate correctly in stream_select. * */ - dest_elem = zend_hash_next_index_insert(Z_ARRVAL(new_array), elem); - if (dest_elem) { - zval_add_ref(dest_elem); + if (!key) { + dest_elem = zend_hash_index_update(Z_ARRVAL(new_array), num_ind, elem); + } else { + dest_elem = zend_hash_update(Z_ARRVAL(new_array), key, elem); } + zval_add_ref(dest_elem); ret++; continue; } diff --git a/ext/standard/tests/streams/stream_select_preserve_keys.phpt b/ext/standard/tests/streams/stream_select_preserve_keys.phpt new file mode 100644 index 0000000000..390709faf4 --- /dev/null +++ b/ext/standard/tests/streams/stream_select_preserve_keys.phpt @@ -0,0 +1,35 @@ +--TEST-- +Bug #53427 + emulate_read (stream_select does not preserve keys) +--FILE-- + +--EXPECTF-- +array(2) { + [1]=> + resource(%d) of type (stream) + ["myindex"]=> + resource(%d) of type (stream) +} +array(2) { + [1]=> + resource(%d) of type (stream) + ["myindex"]=> + resource(%d) of type (stream) +} +array(2) { + [1]=> + resource(%d) of type (stream) + ["myindex"]=> + resource(%d) of type (stream) +} -- cgit v1.2.1