]> granicus.if.org Git - php/commitdiff
Give some freedon to c iterators but not in userspace.
authorMarcus Boerger <helly@php.net>
Tue, 28 Oct 2003 18:46:37 +0000 (18:46 +0000)
committerMarcus Boerger <helly@php.net>
Tue, 28 Oct 2003 18:46:37 +0000 (18:46 +0000)
Zend/zend_interfaces.c

index 04cc74ea41da84bc9c5acc4a6c702191eba4c059..082653fedf548839bcad1bd128fb330148c9076b 100755 (executable)
@@ -302,8 +302,14 @@ 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)
 {
-       if (class_type->get_iterator && class_type->get_iterator != zend_user_get_new_iterator) {
-               return FAILURE;
+       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_get_new_iterator) {
+                       /* c-level get_iterator cannot be changed */
+                       return FAILURE;
+               }
        }
        class_type->iterator_funcs.zf_new_iterator = NULL;
        class_type->get_iterator = zend_user_get_new_iterator;
@@ -315,7 +321,13 @@ static int zend_implement_aggregate(zend_class_entry *interface, zend_class_entr
 static int zend_implement_iterator(zend_class_entry *interface, zend_class_entry *class_type TSRMLS_DC)
 {
        if (class_type->get_iterator && class_type->get_iterator != zend_user_get_iterator) {
-               return FAILURE;
+               if (class_type->type == ZEND_INTERNAL_CLASS) {
+                       /* inheritance ensures the class has the necessary userland methods */
+                       return SUCCESS;
+               } else if (class_type->get_iterator != zend_user_get_new_iterator) {
+                       /* c-level get_iterator cannot be changed */
+                       return FAILURE;
+               }
        }
        class_type->get_iterator = zend_user_get_iterator;
        class_type->iterator_funcs.zf_has_more = NULL;