diff options
author | Harald Radi <phanto@php.net> | 2001-05-03 11:20:29 +0000 |
---|---|---|
committer | Harald Radi <phanto@php.net> | 2001-05-03 11:20:29 +0000 |
commit | 172a9c93031a21c19ad035df210c2b76e517bb88 (patch) | |
tree | a5ba001ca87a6383e6e3eefad95f782a96e7e095 /ext/rpc/com/com_wrapper.c | |
parent | e337f07ecd4e53d394f07b631f6ec536e9c8c81f (diff) | |
download | php-git-172a9c93031a21c19ad035df210c2b76e517bb88.tar.gz |
fixed leaky code
#cleaned up dirty hack from yesterday
Diffstat (limited to 'ext/rpc/com/com_wrapper.c')
-rw-r--r-- | ext/rpc/com/com_wrapper.c | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/ext/rpc/com/com_wrapper.c b/ext/rpc/com/com_wrapper.c index ca26a5c66c..70906964ad 100644 --- a/ext/rpc/com/com_wrapper.c +++ b/ext/rpc/com/com_wrapper.c @@ -672,7 +672,8 @@ VARIANT *_php_COM_get_property_handler(zend_property_reference *property_referen obj_prop = (i_dispatch *) emalloc(sizeof(i_dispatch)); php_COM_clone(obj_prop, obj, FALSE); - + + //leak !!! var_result = (VARIANT *) emalloc(sizeof(VARIANT)); var_result->vt = VT_DISPATCH; var_result->pdispVal = obj_prop->i.dispatch; @@ -705,7 +706,6 @@ VARIANT *_php_COM_get_property_handler(zend_property_reference *property_referen break; case OE_IS_METHOD: -// var_result->pdispVal = obj_prop->i.dispatch; efree(obj_prop); return var_result; break; @@ -832,25 +832,28 @@ PHPAPI void php_COM_call_function_handler(INTERNAL_FUNCTION_PARAMETERS, zend_pro i_dispatch *obj; pval **arguments; int arg_count = ZEND_NUM_ARGS(); - VARIANTARG var_result; - - var_result.vt = VT_EMPTY; + VARIANT *var_result; obj = (i_dispatch *) emalloc(sizeof(i_dispatch)); - php_COM_set(obj, _php_COM_get_property_handler(property_reference)->pdispVal, TRUE); + + var_result = _php_COM_get_property_handler(property_reference); + php_COM_set(obj, var_result->pdispVal, TRUE); + + var_result->vt = VT_EMPTY; arguments = (pval **) emalloc(sizeof(pval *)*arg_count); getParametersArray(ht, arg_count, arguments); - - if (do_COM_invoke(obj , &function_name->element, &var_result, arguments, arg_count)==FAILURE) { + + if (do_COM_invoke(obj , &function_name->element, var_result, arguments, arg_count)==FAILURE) { RETVAL_FALSE; } pval_destructor(&function_name->element); php_COM_release(obj); + php_variant_to_pval(var_result, return_value, 0, codepage); efree(obj); + efree(var_result); efree(arguments); - php_variant_to_pval(&var_result, return_value, 0, codepage); } for (overloaded_property = (zend_overloaded_element *) zend_llist_get_first(property_reference->elements_list); |