]> granicus.if.org Git - php/commitdiff
Add oo support function zend_class_implements()
authorMarcus Boerger <helly@php.net>
Wed, 15 Oct 2003 06:24:17 +0000 (06:24 +0000)
committerMarcus Boerger <helly@php.net>
Wed, 15 Oct 2003 06:24:17 +0000 (06:24 +0000)
Zend/zend_API.c
Zend/zend_API.h

index edba59c2eb2c5d22d999131a7af66955773c98b1..d5d8676292dd08ffeabe0f444cbc9262ee9bbe66 100644 (file)
@@ -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));
index 186d3e62dce63140e5482fd0df29126f7ae6a355..256b83a723bbe7948c559fdd8bb56b05646c266f 100644 (file)
@@ -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);