From 4073a08488e6a99e6438d9c15d72084c6b078c9d Mon Sep 17 00:00:00 2001 From: Marcus Boerger Date: Wed, 15 Oct 2003 06:24:17 +0000 Subject: [PATCH] Add oo support function zend_class_implements() --- Zend/zend_API.c | 20 ++++++++++++++++++++ Zend/zend_API.h | 1 + 2 files changed, 21 insertions(+) diff --git a/Zend/zend_API.c b/Zend/zend_API.c index edba59c2eb..d5d8676292 100644 --- a/Zend/zend_API.c +++ b/Zend/zend_API.c @@ -1445,6 +1445,26 @@ ZEND_API zend_class_entry *zend_register_internal_class_ex(zend_class_entry *cla return register_class; } +ZEND_API void zend_class_implements(zend_class_entry *class_entry TSRMLS_DC, int num_interfaces, ...) +{ + zend_class_entry *interface_entry; + va_list interface_list; + + 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)); + } + + 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); + } + va_end(interface_list); +} + ZEND_API zend_class_entry *zend_register_internal_class(zend_class_entry *orig_class_entry TSRMLS_DC) { zend_class_entry *class_entry = malloc(sizeof(zend_class_entry)); diff --git a/Zend/zend_API.h b/Zend/zend_API.h index 186d3e62dc..256b83a723 100644 --- a/Zend/zend_API.h +++ b/Zend/zend_API.h @@ -158,6 +158,7 @@ ZEND_API int zend_register_module(zend_module_entry *module_entry); ZEND_API zend_class_entry *zend_register_internal_class(zend_class_entry *class_entry TSRMLS_DC); ZEND_API zend_class_entry *zend_register_internal_class_ex(zend_class_entry *class_entry, zend_class_entry *parent_ce, char *parent_name TSRMLS_DC); +ZEND_API void zend_class_implements(zend_class_entry *class_entry TSRMLS_DC, int num_interfaces, ...); ZEND_API int zend_disable_function(char *function_name, uint function_name_length TSRMLS_DC); ZEND_API int zend_disable_class(char *class_name, uint class_name_length TSRMLS_DC); -- 2.40.0