summaryrefslogtreecommitdiff
path: root/Zend/zend_API.c
diff options
context:
space:
mode:
Diffstat (limited to 'Zend/zend_API.c')
-rw-r--r--Zend/zend_API.c14
1 files changed, 2 insertions, 12 deletions
diff --git a/Zend/zend_API.c b/Zend/zend_API.c
index b32b9eb47d..31faa25e7a 100644
--- a/Zend/zend_API.c
+++ b/Zend/zend_API.c
@@ -1970,24 +1970,14 @@ 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));
- } else {
- class_entry->interfaces = erealloc(class_entry->interfaces, sizeof(zend_class_entry*) * (class_entry->num_interfaces+num_interfaces));
- }
-
while (num_interfaces--) {
interface_entry = va_arg(interface_list, zend_class_entry *);
- class_entry->interfaces[class_entry->num_interfaces++] = interface_entry;
- }
- impl_num = class_entry->num_interfaces;
- while(ce_num < impl_num) {
- zend_do_implement_interface(class_entry, class_entry->interfaces[ce_num++] TSRMLS_CC);
+ zend_do_implement_interface(class_entry, interface_entry TSRMLS_CC);
}
+
va_end(interface_list);
}