diff options
Diffstat (limited to 'ext/com_dotnet/php_com_dotnet_internal.h')
-rw-r--r-- | ext/com_dotnet/php_com_dotnet_internal.h | 37 |
1 files changed, 30 insertions, 7 deletions
diff --git a/ext/com_dotnet/php_com_dotnet_internal.h b/ext/com_dotnet/php_com_dotnet_internal.h index 7aae5b3538..37fbf94bcb 100644 --- a/ext/com_dotnet/php_com_dotnet_internal.h +++ b/ext/com_dotnet/php_com_dotnet_internal.h @@ -1,6 +1,6 @@ /* +----------------------------------------------------------------------+ - | PHP Version 4 | + | PHP Version 5 | +----------------------------------------------------------------------+ | Copyright (c) 1997-2003 The PHP Group | +----------------------------------------------------------------------+ @@ -41,6 +41,11 @@ typedef struct _php_com_dotnet_object { zend_class_entry *ce; DISPID default_bind; /* default property for array accesses */ + + /* associated event sink */ + IDispatch *sink_dispatch; + GUID sink_id; + DWORD sink_cookie; } php_com_dotnet_object; static inline int php_com_is_valid_object(zval *zv TSRMLS_DC) @@ -54,7 +59,7 @@ static inline int php_com_is_valid_object(zval *zv TSRMLS_DC) #define CDNO_FETCH(zv) (php_com_dotnet_object*)zend_object_store_get_object(zv TSRMLS_CC) #define CDNO_FETCH_VERIFY(obj, zv) do { \ if (!php_com_is_valid_object(zv TSRMLS_CC)) { \ - php_com_throw_exception("expected a variant object" TSRMLS_CC); \ + php_com_throw_exception(E_UNEXPECTED, "expected a variant object" TSRMLS_CC); \ return; \ } \ obj = (php_com_dotnet_object*)zend_object_store_get_object(zv TSRMLS_CC); \ @@ -62,13 +67,18 @@ static inline int php_com_is_valid_object(zval *zv TSRMLS_DC) /* com_extension.c */ TsHashTable php_com_typelibraries; -zend_class_entry *php_com_variant_class_entry; +zend_class_entry *php_com_variant_class_entry, *php_com_exception_class_entry, *php_com_saproxy_class_entry; /* com_handlers.c */ zend_object_value php_com_object_new(zend_class_entry *ce TSRMLS_DC); void php_com_object_clone(void *object, void **clone_ptr TSRMLS_DC); void php_com_object_dtor(void *object, zend_object_handle handle TSRMLS_DC); zend_object_handlers php_com_object_handlers; +void php_com_object_enable_event_sink(php_com_dotnet_object *obj, int enable TSRMLS_DC); + +/* com_saproxy.c */ +zend_object_iterator *php_com_saproxy_iter_get(zend_class_entry *ce, zval *object TSRMLS_DC); +int php_com_saproxy_create(zval *com_object, zval *proxy_out, long index TSRMLS_DC); /* com_olechar.c */ PHPAPI char *php_com_olestring_to_string(OLECHAR *olestring, @@ -79,6 +89,12 @@ PHPAPI OLECHAR *php_com_string_to_olestring(char *string, /* com_com.c */ PHP_FUNCTION(com_create_instance); +PHP_FUNCTION(com_event_sink); +PHP_FUNCTION(com_create_guid); +PHP_FUNCTION(com_print_typeinfo); +PHP_FUNCTION(com_message_pump); +PHP_FUNCTION(com_load_typelib); + HRESULT php_com_invoke_helper(php_com_dotnet_object *obj, DISPID id_member, WORD flags, DISPPARAMS *disp_params, VARIANT *v TSRMLS_DC); HRESULT php_com_get_id_of_name(php_com_dotnet_object *obj, char *name, @@ -88,6 +104,11 @@ int php_com_do_invoke_by_id(php_com_dotnet_object *obj, DISPID dispid, int php_com_do_invoke(php_com_dotnet_object *obj, char *name, int namelen, WORD flags, VARIANT *v, int nargs, zval **args TSRMLS_DC); +/* com_wrapper.c */ +int php_com_wrapper_minit(INIT_FUNC_ARGS); +PHPAPI IDispatch *php_com_wrapper_export_as_sink(zval *val, GUID *sinkid, HashTable *id_to_name TSRMLS_DC); +PHPAPI IDispatch *php_com_wrapper_export(zval *val TSRMLS_DC); + /* com_variant.c */ PHP_FUNCTION(com_variant_create_instance); PHP_FUNCTION(variant_set); @@ -127,20 +148,22 @@ void php_com_dotnet_rshutdown(TSRMLS_D); void php_com_dotnet_mshutdown(TSRMLS_D); /* com_misc.c */ -zval *php_com_throw_exception(char *message TSRMLS_DC); +void php_com_throw_exception(HRESULT code, char *message TSRMLS_DC); PHPAPI void php_com_wrap_dispatch(zval *z, IDispatch *disp, int codepage TSRMLS_DC); PHPAPI void php_com_wrap_variant(zval *z, VARIANT *v, int codepage TSRMLS_DC); +PHPAPI int php_com_safearray_get_elem(VARIANT *array, VARIANT *dest, LONG dim1 TSRMLS_DC); /* com_typeinfo.c */ PHPAPI ITypeLib *php_com_load_typelib_via_cache(char *search_string, - int mode, int codepage, int *cached TSRMLS_DC); -PHPAPI ITypeLib *php_com_load_typelib(char *search_string, int mode, - int codepage TSRMLS_DC); + int codepage, int *cached TSRMLS_DC); +PHPAPI ITypeLib *php_com_load_typelib(char *search_string, int codepage TSRMLS_DC); PHPAPI int php_com_import_typelib(ITypeLib *TL, int mode, int codepage TSRMLS_DC); void php_com_typelibrary_dtor(void *pDest); +ITypeInfo *php_com_locate_typeinfo(char *typelibname, php_com_dotnet_object *obj, char *dispname, int sink TSRMLS_DC); +int php_com_process_typeinfo(ITypeInfo *typeinfo, HashTable *id_to_name, int printdef, GUID *guid, int codepage TSRMLS_DC); /* com_iterator.c */ zend_object_iterator *php_com_iter_get(zend_class_entry *ce, zval *object TSRMLS_DC); |