summaryrefslogtreecommitdiff
path: root/ext/win32ole/win32ole.c
diff options
context:
space:
mode:
authorsuke <suke@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-10-19 11:40:33 +0000
committersuke <suke@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-10-19 11:40:33 +0000
commit05a43e2367ca8961e733d5434b474da14126d68b (patch)
treef78063330c94a6e9ff3c0f088f051f982b0f7c59 /ext/win32ole/win32ole.c
parent1057902ac7bc51a9d6c852e6cd778498acbed869 (diff)
* ext/win32ole.c(ole_invoke): retrieve the result value when
retrying the IDispatch::invoke. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@7072 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/win32ole/win32ole.c')
-rw-r--r--ext/win32ole/win32ole.c14
1 files changed, 8 insertions, 6 deletions
diff --git a/ext/win32ole/win32ole.c b/ext/win32ole/win32ole.c
index 66a00ddee7..0d977100d8 100644
--- a/ext/win32ole/win32ole.c
+++ b/ext/win32ole/win32ole.c
@@ -78,7 +78,7 @@
#define WC2VSTR(x) ole_wc2vstr((x), TRUE)
-#define WIN32OLE_VERSION "0.5.8"
+#define WIN32OLE_VERSION "0.5.9"
typedef HRESULT (STDAPICALLTYPE FNCOCREATEINSTANCEEX)
(REFCLSID, IUnknown*, DWORD, COSERVERINFO*, DWORD, MULTI_QI*);
@@ -1994,9 +1994,10 @@ ole_invoke(argc, argv, self, wFlags)
ole_val2variant(param, &op.dp.rgvarg[n]);
}
memset(&excepinfo, 0, sizeof(EXCEPINFO));
+ VariantInit(&result);
hr = pole->pDispatch->lpVtbl->Invoke(pole->pDispatch, DispID,
&IID_NULL, lcid, wFlags,
- &op.dp, NULL,
+ &op.dp, &result,
&excepinfo, &argErr);
for(i = cNamedArgs; i < op.dp.cArgs; i++) {
n = op.dp.cArgs - i + cNamedArgs - 1;
@@ -2008,10 +2009,11 @@ ole_invoke(argc, argv, self, wFlags)
* hResult == DISP_E_EXCEPTION. this only happens on
* functions whose DISPID > 0x8000 */
if (hr == DISP_E_EXCEPTION && DispID > 0x8000) {
+ VariantInit(&result);
memset(&excepinfo, 0, sizeof(EXCEPINFO));
hr = pole->pDispatch->lpVtbl->Invoke(pole->pDispatch, DispID,
&IID_NULL, lcid, wFlags,
- &op.dp, NULL,
+ &op.dp, &result,
&excepinfo, &argErr);
}
@@ -2758,7 +2760,7 @@ static VALUE
fole_get_methods( self )
VALUE self;
{
- return ole_methods(self, INVOKE_PROPERTYGET);
+ return ole_methods( self, INVOKE_PROPERTYGET);
}
/*
@@ -2770,7 +2772,7 @@ static VALUE
fole_put_methods( self )
VALUE self;
{
- return ole_methods(self, INVOKE_PROPERTYPUT);
+ return ole_methods( self, INVOKE_PROPERTYPUT);
}
/*
@@ -2782,7 +2784,7 @@ static VALUE
fole_func_methods( self )
VALUE self;
{
- return ole_methods(self, INVOKE_FUNC);
+ return ole_methods( self, INVOKE_FUNC);
}
/*