helly Sun Mar 6 20:15:04 2005 EDT
Modified files: (Branch: PHP_5_0)
/php-src/ext/spl spl_iterators.c
Log:
- MFH avoid exception problems
http://cvs.php.net/diff.php/php-src/ext/spl/spl_iterators.c?r1=1.38.2.8&r2=1.38.2.9&ty=u
Index: php-src/ext/spl/spl_iterators.c
diff -u php-src/ext/spl/spl_iterators.c:1.38.2.8
php-src/ext/spl/spl_iterators.c:1.38.2.9
--- php-src/ext/spl/spl_iterators.c:1.38.2.8 Mon Jan 24 15:25:58 2005
+++ php-src/ext/spl/spl_iterators.c Sun Mar 6 20:15:03 2005
@@ -16,7 +16,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: spl_iterators.c,v 1.38.2.8 2005/01/24 20:25:58 helly Exp $ */
+/* $Id: spl_iterators.c,v 1.38.2.9 2005/03/07 01:15:03 helly Exp $ */
#ifdef HAVE_CONFIG_H
# include "config.h"
@@ -187,8 +187,9 @@
zend_class_entry *ce;
zval *retval, *child;
zend_object_iterator *sub_iter;
+ int has_children;
- while (1) {
+ while (!EG(exception)) {
next_step:
iterator = object->iterators[object->level].iterator;
switch (object->iterators[object->level].state) {
@@ -204,19 +205,21 @@
ce = object->iterators[object->level].ce;
zobject =
object->iterators[object->level].zobject;
zend_call_method_with_0_params(&zobject, ce,
NULL, "haschildren", &retval);
- if (zend_is_true(retval)) {
+ if (retval) {
+ has_children = zend_is_true(retval);
zval_ptr_dtor(&retval);
- switch (object->mode) {
- case RIT_LEAVES_ONLY:
- case RIT_CHILD_FIRST:
-
object->iterators[object->level].state = RS_CHILD;
- goto next_step;
- case RIT_SELF_FIRST:
-
object->iterators[object->level].state = RS_SELF;
- goto next_step;
+ if (has_children) {
+ switch (object->mode) {
+ case RIT_LEAVES_ONLY:
+ case RIT_CHILD_FIRST:
+
object->iterators[object->level].state = RS_CHILD;
+ goto next_step;
+ case RIT_SELF_FIRST:
+
object->iterators[object->level].state = RS_SELF;
+ goto next_step;
+ }
}
}
- zval_ptr_dtor(&retval);
object->iterators[object->level].state =
RS_NEXT;
return /* self */;
case RS_SELF:
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php