summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarcus Boerger <helly@php.net>2005-02-17 21:10:34 +0000
committerMarcus Boerger <helly@php.net>2005-02-17 21:10:34 +0000
commit10af23e6418d5a2cfd05da587f2bc736d99a42d4 (patch)
tree8a30a0d0e1ac7a38b97d7ce4e6b7b0fe55fcd2cc
parent2211aac68f0635cb5b50472d42c582972242bbbc (diff)
downloadphp-git-10af23e6418d5a2cfd05da587f2bc736d99a42d4.tar.gz
- MFH
-rw-r--r--Zend/zend_API.c8
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);
}