scottmac Sat May 9 19:37:34 2009 UTC
Modified files:
/php-src/ext/spl spl_iterators.c
Log:
Fix bug #48206 - Iterating over an invalid data structure leads to a segfault
http://cvs.php.net/viewvc.cgi/php-src/ext/spl/spl_iterators.c?r1=1.188&r2=1.189&diff_format=u
Index: php-src/ext/spl/spl_iterators.c
diff -u php-src/ext/spl/spl_iterators.c:1.188
php-src/ext/spl/spl_iterators.c:1.189
--- php-src/ext/spl/spl_iterators.c:1.188 Thu Mar 26 20:02:12 2009
+++ php-src/ext/spl/spl_iterators.c Sat May 9 19:37:34 2009
@@ -16,7 +16,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: spl_iterators.c,v 1.188 2009/03/26 20:02:12 felipe Exp $ */
+/* $Id: spl_iterators.c,v 1.189 2009/05/09 19:37:34 scottmac Exp $ */
#ifdef HAVE_CONFIG_H
# include "config.h"
@@ -929,8 +929,9 @@
iterator->funcs->get_current_data(iterator, &data TSRMLS_CC);
zend_replace_error_handling(EH_THROW, spl_ce_UnexpectedValueException,
&error_handling TSRMLS_CC);
-
- RETVAL_ZVAL(*data, 1, 0);
+ if (data && *data) {
+ RETVAL_ZVAL(*data, 1, 0);
+ }
if (Z_TYPE_P(return_value) == IS_ARRAY) {
zval_dtor(return_value);
ZVAL_STRINGL(return_value, "Array", sizeof("Array")-1, 1);
@@ -1017,7 +1018,11 @@
zval **data;
iterator->funcs->get_current_data(iterator, &data TSRMLS_CC);
- RETURN_ZVAL(*data, 1, 0);
+ if (data && *data) {
+ RETURN_ZVAL(*data, 1, 0);
+ } else {
+ RETURN_NULL();
+ }
}
spl_recursive_tree_iterator_get_entry(object, &entry TSRMLS_CC);
@@ -2806,7 +2811,9 @@
intern = (spl_dual_it_object*)zend_object_store_get_object(getThis()
TSRMLS_CC);
intern->inner.iterator->funcs->get_current_data(intern->inner.iterator,
&data TSRMLS_CC);
- RETURN_ZVAL(*data, 1, 0);
+ if (data && *data) {
+ RETURN_ZVAL(*data, 1, 0);
+ }
} /* }}} */
/* {{{ proto void NoRewindIterator::next() U
@@ -3118,6 +3125,9 @@
if (EG(exception)) {
return ZEND_HASH_APPLY_STOP;
}
+ if (data == NULL || *data == NULL) {
+ return ZEND_HASH_APPLY_STOP;
+ }
if (iter->funcs->get_current_key) {
key_type = iter->funcs->get_current_key(iter, &str_key,
&str_key_len, &int_key TSRMLS_CC);
if (EG(exception)) {
@@ -3153,6 +3163,9 @@
if (EG(exception)) {
return ZEND_HASH_APPLY_STOP;
}
+ if (data == NULL || *data == NULL) {
+ return ZEND_HASH_APPLY_STOP;
+ }
Z_ADDREF_PP(data);
add_next_index_zval(return_value, *data);
return ZEND_HASH_APPLY_KEEP;
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php