From: Harald Radi Date: Mon, 10 Sep 2001 09:22:40 +0000 (+0000) Subject: IDispatchs got released if they were passed to another component X-Git-Tag: PRE_SUBST_Z_MACROS~136 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=d1a2dbfd9dc005bb8b07ab63c7086978f71fd7c7;p=php IDispatchs got released if they were passed to another component --- diff --git a/ext/com/COM.c b/ext/com/COM.c index fda0b948da..b4d855242e 100644 --- a/ext/com/COM.c +++ b/ext/com/COM.c @@ -511,6 +511,12 @@ PHP_FUNCTION(com_load) /* @todo if (server_name) */ if (!server_name) { + /* @todo shouldn't the bind context be fetched on module startup and kept as a global shared instance ? + * all calls to BindToObject would deliver the same instance then (as desired) + * IBindCtx::RegisterObjectBound() should be called then after mkparsedisplayname() + * + * @todo use mkparsedisplaynameex() ? + */ if (SUCCEEDED(hr = CreateBindCtx(0, &pBindCtx))) { if (SUCCEEDED(hr = MkParseDisplayName(pBindCtx, ProgID, &ulEaten, &pMoniker))) { hr = pMoniker->lpVtbl->BindToObject(pMoniker, pBindCtx, NULL, &IID_IDispatch, (LPVOID *) &C_DISPATCH(obj)); @@ -742,7 +748,11 @@ int do_COM_invoke(comval *obj, pval *function_name, VARIANT *var_result, pval ** efree(funcname); for (current_arg=0;current_argIDispatch */ + VariantClear(&variant_args[current_arg]); + } } efree(variant_args); diff --git a/ext/rpc/com/com_wrapper.c b/ext/rpc/com/com_wrapper.c index fda0b948da..b4d855242e 100644 --- a/ext/rpc/com/com_wrapper.c +++ b/ext/rpc/com/com_wrapper.c @@ -511,6 +511,12 @@ PHP_FUNCTION(com_load) /* @todo if (server_name) */ if (!server_name) { + /* @todo shouldn't the bind context be fetched on module startup and kept as a global shared instance ? + * all calls to BindToObject would deliver the same instance then (as desired) + * IBindCtx::RegisterObjectBound() should be called then after mkparsedisplayname() + * + * @todo use mkparsedisplaynameex() ? + */ if (SUCCEEDED(hr = CreateBindCtx(0, &pBindCtx))) { if (SUCCEEDED(hr = MkParseDisplayName(pBindCtx, ProgID, &ulEaten, &pMoniker))) { hr = pMoniker->lpVtbl->BindToObject(pMoniker, pBindCtx, NULL, &IID_IDispatch, (LPVOID *) &C_DISPATCH(obj)); @@ -742,7 +748,11 @@ int do_COM_invoke(comval *obj, pval *function_name, VARIANT *var_result, pval ** efree(funcname); for (current_arg=0;current_argIDispatch */ + VariantClear(&variant_args[current_arg]); + } } efree(variant_args);