From c17d3dbbb733e545b4c52e5d9a082af85f03123c Mon Sep 17 00:00:00 2001 From: Marcus Boerger Date: Thu, 17 Feb 2005 21:05:04 +0000 Subject: [PATCH] - A little optimization to prevent problems when trying to reimplement an interface inherited from an interfaces that was just implemented...... --- Zend/zend_API.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/Zend/zend_API.c b/Zend/zend_API.c index 9d2f6ff7f4..a781e13f64 100644 --- a/Zend/zend_API.c +++ b/Zend/zend_API.c @@ -1631,7 +1631,7 @@ ZEND_API zend_class_entry *zend_register_internal_class_ex(zend_class_entry *cla ZEND_API void zend_class_implements(zend_class_entry *class_entry TSRMLS_DC, int num_interfaces, ...) { zend_class_entry *interface_entry; - int ce_num = class_entry->num_interfaces; + int ce_num = class_entry->num_interfaces, impl_num; va_list interface_list; va_start(interface_list, num_interfaces); @@ -1645,7 +1645,8 @@ ZEND_API void zend_class_implements(zend_class_entry *class_entry TSRMLS_DC, int interface_entry = va_arg(interface_list, zend_class_entry *); class_entry->interfaces[class_entry->num_interfaces++] = interface_entry; } - while(ce_num < class_entry->num_interfaces) { + impl_num = class_entry->num_interfaces; + while(ce_num < impl_num) { zend_do_implement_interface(class_entry, class_entry->interfaces[ce_num++] TSRMLS_CC); } va_end(interface_list); -- 2.40.0