From: Marcus Boerger Date: Thu, 17 Feb 2005 20:49:56 +0000 (+0000) Subject: - Actually we must do this in two steps: 1st resize the table and set all X-Git-Tag: RELEASE_0_2_4~12 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=82ccc2511353f496df4606e0761019f63a0c1c09;p=php - Actually we must do this in two steps: 1st resize the table and set all interfaces, 2nd implement the interfaces --- diff --git a/Zend/zend_API.c b/Zend/zend_API.c index 81ef11665a..4452f4dff9 100644 --- a/Zend/zend_API.c +++ b/Zend/zend_API.c @@ -1633,6 +1633,7 @@ ZEND_API void zend_class_implements(zend_class_entry *class_entry TSRMLS_DC, int zend_class_entry *interface_entry; va_list interface_list; va_start(interface_list, num_interfaces); + int ce_num = class_entry->num_interfaces; if (class_entry->type & ZEND_INTERNAL_CLASS) { class_entry->interfaces = realloc(class_entry->interfaces, sizeof(zend_class_entry*) * (class_entry->num_interfaces+num_interfaces)); @@ -1642,8 +1643,10 @@ ZEND_API void zend_class_implements(zend_class_entry *class_entry TSRMLS_DC, int while (num_interfaces--) { interface_entry = va_arg(interface_list, zend_class_entry *); - class_entry->interfaces[class_entry->num_interfaces] = interface_entry; - zend_do_implement_interface(class_entry, interface_entry TSRMLS_CC); + class_entry->interfaces[class_entry->num_interfaces++] = interface_entry; + } + while(ce_num < class_entry->num_interfaces) { + zend_do_implement_interface(class_entry, class_entry->interfaces[ce_num++] TSRMLS_CC); } va_end(interface_list); }