diff options
author | Marcus Boerger <helly@php.net> | 2005-02-17 21:10:34 +0000 |
---|---|---|
committer | Marcus Boerger <helly@php.net> | 2005-02-17 21:10:34 +0000 |
commit | 10af23e6418d5a2cfd05da587f2bc736d99a42d4 (patch) | |
tree | 8a30a0d0e1ac7a38b97d7ce4e6b7b0fe55fcd2cc | |
parent | 2211aac68f0635cb5b50472d42c582972242bbbc (diff) | |
download | php-git-10af23e6418d5a2cfd05da587f2bc736d99a42d4.tar.gz |
- MFH
-rw-r--r-- | Zend/zend_API.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/Zend/zend_API.c b/Zend/zend_API.c index 08032604b1..cbc88eea99 100644 --- a/Zend/zend_API.c +++ b/Zend/zend_API.c @@ -1607,7 +1607,9 @@ 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, impl_num; va_list interface_list; + va_start(interface_list, 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)); @@ -1615,11 +1617,13 @@ ZEND_API void zend_class_implements(zend_class_entry *class_entry TSRMLS_DC, int class_entry->interfaces = erealloc(class_entry->interfaces, sizeof(zend_class_entry*) * (class_entry->num_interfaces+num_interfaces)); } - va_start(interface_list, num_interfaces); 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); + } + 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); } |