From: Anatol Belski Date: Fri, 19 Jun 2015 12:23:32 +0000 (+0200) Subject: more precise way to destroy iterator object X-Git-Tag: php-7.0.0alpha2~2^2~64 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=1e65b65dd683612925d99202c45ed8ed410edbde;p=php more precise way to destroy iterator object which also fixes the iterator_to_array test --- diff --git a/ext/dom/dom_iterators.c b/ext/dom/dom_iterators.c index 7cef63bf9a..a96b6bfe9a 100644 --- a/ext/dom/dom_iterators.c +++ b/ext/dom/dom_iterators.c @@ -182,6 +182,7 @@ static void php_dom_iterator_move_forward(zend_object_iterator *iter) /* {{{ */ int previndex=0; HashTable *nodeht; zval *entry; + zend_bool do_curobj_undef = 1; php_dom_iterator *iterator = (php_dom_iterator *)iter; @@ -201,6 +202,7 @@ static void php_dom_iterator_move_forward(zend_object_iterator *iter) /* {{{ */ zval_ptr_dtor(&iterator->curobj); ZVAL_UNDEF(&iterator->curobj); ZVAL_COPY(&iterator->curobj, entry); + do_curobj_undef = 0; } } else { curnode = (xmlNodePtr)((php_libxml_node_ptr *)intern->ptr)->node; @@ -231,7 +233,7 @@ static void php_dom_iterator_move_forward(zend_object_iterator *iter) /* {{{ */ } } err: - if (IS_UNDEF != Z_TYPE(iterator->curobj)) { + if (do_curobj_undef) { zval_ptr_dtor(&iterator->curobj); ZVAL_UNDEF(&iterator->curobj); }