From 72c1baa9d8491ffa89095f109437be471b89dfa9 Mon Sep 17 00:00:00 2001 From: Marcus Boerger Date: Wed, 23 Feb 2005 01:09:10 +0000 Subject: [PATCH] - Allow to convert Traversable into Aggregate --- Zend/zend_interfaces.c | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/Zend/zend_interfaces.c b/Zend/zend_interfaces.c index a6658133e4..75b6a2c26c 100755 --- a/Zend/zend_interfaces.c +++ b/Zend/zend_interfaces.c @@ -316,13 +316,27 @@ static int zend_implement_traversable(zend_class_entry *interface, zend_class_en /* {{{ zend_implement_aggregate */ static int zend_implement_aggregate(zend_class_entry *interface, zend_class_entry *class_type TSRMLS_DC) { + int i, t = -1; + if (class_type->get_iterator) { if (class_type->type == ZEND_INTERNAL_CLASS) { /* inheritance ensures the class has necessary userland methods */ return SUCCESS; } else if (class_type->get_iterator != zend_user_it_get_new_iterator) { - /* c-level get_iterator cannot be changed */ - return FAILURE; + /* c-level get_iterator cannot be changed (exception being only Traversable is implmented) */ + if (class_type->num_interfaces) { + for (i = 0; i < class_type->num_interfaces; i++) { + if (class_type->interfaces[i] == zend_ce_iterator) { + return FAILURE; + } + if (class_type->interfaces[i] == zend_ce_traversable) { + t = i; + } + } + } + if (t == -1) { + return FAILURE; + } } } class_type->iterator_funcs.zf_new_iterator = NULL; -- 2.40.0