diff options
author | Marcus Boerger <helly@php.net> | 2006-01-01 19:51:17 +0000 |
---|---|---|
committer | Marcus Boerger <helly@php.net> | 2006-01-01 19:51:17 +0000 |
commit | e99fac3d016858f0614986f6a534059e18b4e3fd (patch) | |
tree | 06579b61cf672877ce36488de361e83d398ef42d | |
parent | d6ee7d1d9aa49bb52fb13ed05244478c800b932d (diff) | |
download | php-git-e99fac3d016858f0614986f6a534059e18b4e3fd.tar.gz |
- key() might be optional
-rwxr-xr-x | ext/spl/spl_iterators.c | 22 |
1 files changed, 13 insertions, 9 deletions
diff --git a/ext/spl/spl_iterators.c b/ext/spl/spl_iterators.c index 7f6d41dbaa..6baff4ff22 100755 --- a/ext/spl/spl_iterators.c +++ b/ext/spl/spl_iterators.c @@ -2049,17 +2049,21 @@ PHP_FUNCTION(iterator_to_array) iter->funcs->rewind(iter TSRMLS_CC); } while (iter->funcs->valid(iter TSRMLS_CC) == SUCCESS) { - key_type = iter->funcs->get_current_key(iter, &str_key, &str_key_len, &int_key TSRMLS_CC); iter->funcs->get_current_data(iter, &data TSRMLS_CC); (*data)->refcount++; - switch(key_type) { - case HASH_KEY_IS_STRING: - add_assoc_zval_ex(return_value, str_key, str_key_len, *data); - efree(str_key); - break; - case HASH_KEY_IS_LONG: - add_index_zval(return_value, int_key, *data); - break; + if (iter->funcs->get_current_key) { + key_type = iter->funcs->get_current_key(iter, &str_key, &str_key_len, &int_key TSRMLS_CC); + switch(key_type) { + case HASH_KEY_IS_STRING: + add_assoc_zval_ex(return_value, str_key, str_key_len, *data); + efree(str_key); + break; + case HASH_KEY_IS_LONG: + add_index_zval(return_value, int_key, *data); + break; + } + } else { + add_next_index_zval(return_value, *data); } iter->funcs->move_forward(iter TSRMLS_CC); } |