]> granicus.if.org Git - php/commitdiff
- Allow to convert Traversable into Aggregate
authorMarcus Boerger <helly@php.net>
Wed, 23 Feb 2005 01:09:10 +0000 (01:09 +0000)
committerMarcus Boerger <helly@php.net>
Wed, 23 Feb 2005 01:09:10 +0000 (01:09 +0000)
Zend/zend_interfaces.c

index a6658133e416775c2ce16feba833e5d20f2a046a..75b6a2c26c825fa4964aa5811c7bbe314d388648 100755 (executable)
@@ -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;