oleaut32: Fix automatic value getting in ITypeInfo::Invoke.

Signed-off-by: Piotr Caban <piotr@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Piotr Caban 2017-11-07 13:30:14 +01:00 committed by Alexandre Julliard
parent baba9a8e48
commit 61c18632b8
3 changed files with 125 additions and 4 deletions

View file

@ -130,6 +130,15 @@ library register_test
interface Iole_from_disp; interface Iole_from_disp;
} }
[
uuid(fed318b2-c2ed-11e7-abc4-cec278b6b50a)
]
interface ICollection : IDispatch
{
[id(DISPID_VALUE)]
HRESULT Item([in] int i, [out, retval] int *p);
}
[ [
uuid(f1b68c3b-02a3-4110-bc4c-cf9bc7e7f177) uuid(f1b68c3b-02a3-4110-bc4c-cf9bc7e7f177)
] ]
@ -143,6 +152,8 @@ library register_test
LONG testprop2([in] IUnknown *i); LONG testprop2([in] IUnknown *i);
[id(3)] [id(3)]
HRESULT testfunc([in] int i, [out, retval] int *p); HRESULT testfunc([in] int i, [out, retval] int *p);
[propget, id(4)]
HRESULT testget([out, retval] ICollection **p);
} }
/* uuid is same as for test_struct2 in test_tlb.idl, fields are different */ /* uuid is same as for test_struct2 in test_tlb.idl, fields are different */

View file

@ -98,6 +98,91 @@ static const BOOL abi_supports_stdcall = TRUE;
static const BOOL abi_supports_stdcall = FALSE; static const BOOL abi_supports_stdcall = FALSE;
#endif #endif
static HRESULT WINAPI collection_QueryInterface(ICollection *iface, REFIID riid, void **ret)
{
if (IsEqualIID(riid, &IID_IUnknown) ||
IsEqualIID(riid, &IID_IDispatch) ||
IsEqualIID(riid, &IID_ICollection))
{
*ret = iface;
return S_OK;
}
return E_NOINTERFACE;
}
static ULONG WINAPI collection_AddRef(ICollection *iface)
{
return 2;
}
static ULONG WINAPI collection_Release(ICollection *iface)
{
return 1;
}
static HRESULT WINAPI collection_GetTypeInfoCount(ICollection *iface, UINT *cnt)
{
ok(0, "unexpected call\n");
*cnt = 0;
return E_NOTIMPL;
}
static HRESULT WINAPI collection_GetTypeInfo(ICollection *iface, UINT index, LCID lcid, ITypeInfo **ti)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI collection_GetIDsOfNames(ICollection *iface, REFIID riid, LPOLESTR *names,
UINT cnt, LCID lcid, DISPID *dispid)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI collection_Invoke(ICollection *iface, DISPID dispid, REFIID riid,
LCID lcid, WORD flags, DISPPARAMS *dispparams, VARIANT *res, EXCEPINFO *ei, UINT *argerr)
{
if(dispid != DISPID_VALUE) {
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
ok(flags == (DISPATCH_METHOD|DISPATCH_PROPERTYGET), "flags = %x\n", flags);
ok(dispparams != NULL, "dispparams == NULL\n");
ok(!dispparams->rgdispidNamedArgs, "dispparams->rgdispidNamedArgs != NULL\n");
ok(dispparams->cArgs == 1, "dispparams->cArgs = %d\n", dispparams->cArgs);
ok(!dispparams->cNamedArgs, "dispparams->cNamedArgs = %d\n", dispparams->cNamedArgs);
ok(V_VT(dispparams->rgvarg) == VT_I4, "V_VT(dispparams->rgvarg) = %d\n", V_VT(dispparams->rgvarg));
ok(V_I4(dispparams->rgvarg) == 7, "V_I4(dispparams->rgvarg) = %d\n", V_I4(dispparams->rgvarg));
ok(res != NULL, "res == NULL\n");
ok(V_VT(res) == VT_EMPTY, "V_VT(res) = %d\n", V_VT(res));
V_VT(res) = VT_I4;
V_I4(res) = 15;
return S_OK;
}
static HRESULT WINAPI collection_Item(ICollection *iface, int i, int *p)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static const ICollectionVtbl collectionvtbl = {
collection_QueryInterface,
collection_AddRef,
collection_Release,
collection_GetTypeInfoCount,
collection_GetTypeInfo,
collection_GetIDsOfNames,
collection_Invoke,
collection_Item
};
static ICollection collection = { &collectionvtbl };
static HRESULT WINAPI invoketest_QueryInterface(IInvokeTest *iface, REFIID riid, void **ret) static HRESULT WINAPI invoketest_QueryInterface(IInvokeTest *iface, REFIID riid, void **ret)
{ {
if (IsEqualIID(riid, &IID_IUnknown) || if (IsEqualIID(riid, &IID_IUnknown) ||
@ -169,6 +254,13 @@ static HRESULT WINAPI invoketest_testfunc(IInvokeTest *iface, int i, int *p)
return S_OK; return S_OK;
} }
static HRESULT WINAPI invoketest_testget(IInvokeTest *iface, ICollection **p)
{
*p = &collection;
ICollection_AddRef(&collection);
return S_OK;
}
static const IInvokeTestVtbl invoketestvtbl = { static const IInvokeTestVtbl invoketestvtbl = {
invoketest_QueryInterface, invoketest_QueryInterface,
invoketest_AddRef, invoketest_AddRef,
@ -180,7 +272,8 @@ static const IInvokeTestVtbl invoketestvtbl = {
invoketest_get_test, invoketest_get_test,
invoketest_putref_testprop, invoketest_putref_testprop,
invoketest_putref_testprop2, invoketest_putref_testprop2,
invoketest_testfunc invoketest_testfunc,
invoketest_testget
}; };
static IInvokeTest invoketest = { &invoketestvtbl }; static IInvokeTest invoketest = { &invoketestvtbl };
@ -968,6 +1061,22 @@ static void test_TypeInfo(void)
ok(V_VT(&res) == VT_I4, "got %d\n", V_VT(&res)); ok(V_VT(&res) == VT_I4, "got %d\n", V_VT(&res));
ok(V_I4(&res) == 1, "got %d\n", V_I4(&res)); ok(V_I4(&res) == 1, "got %d\n", V_I4(&res));
/* call propget with DISPATCH_METHOD|DISPATCH_PROPERTYGET flags */
V_VT(&args[0]) = VT_I4;
V_I4(&args[0]) = 7;
dispparams.cArgs = 1;
dispparams.rgvarg = args;
i = 0;
V_VT(&res) = VT_EMPTY;
V_I4(&res) = 0;
hr = ITypeInfo_Invoke(pTypeInfo, &invoketest, 4, DISPATCH_METHOD|DISPATCH_PROPERTYGET, &dispparams, &res, NULL, &i);
ok(hr == S_OK, "got 0x%08x, %d\n", hr, i);
ok(V_VT(&res) == VT_I4, "got %d\n", V_VT(&res));
ok(V_I4(&res) == 15, "got %d\n", V_I4(&res));
/* DISPATCH_PROPERTYPUTREF */ /* DISPATCH_PROPERTYPUTREF */
l = 1; l = 1;
V_VT(&args[0]) = VT_I4|VT_BYREF; V_VT(&args[0]) = VT_I4|VT_BYREF;
@ -4837,7 +4946,7 @@ static void test_register_typelib(BOOL system_registration)
{ {
TYPEKIND kind; TYPEKIND kind;
WORD flags; WORD flags;
} attrs[13] = } attrs[] =
{ {
{ TKIND_INTERFACE, 0 }, { TKIND_INTERFACE, 0 },
{ TKIND_INTERFACE, TYPEFLAG_FDISPATCHABLE }, { TKIND_INTERFACE, TYPEFLAG_FDISPATCHABLE },
@ -4851,6 +4960,7 @@ static void test_register_typelib(BOOL system_registration)
{ TKIND_DISPATCH, TYPEFLAG_FDISPATCHABLE }, { TKIND_DISPATCH, TYPEFLAG_FDISPATCHABLE },
{ TKIND_DISPATCH, TYPEFLAG_FDISPATCHABLE }, { TKIND_DISPATCH, TYPEFLAG_FDISPATCHABLE },
{ TKIND_INTERFACE, TYPEFLAG_FDISPATCHABLE }, { TKIND_INTERFACE, TYPEFLAG_FDISPATCHABLE },
{ TKIND_INTERFACE, TYPEFLAG_FDISPATCHABLE },
{ TKIND_RECORD, 0 } { TKIND_RECORD, 0 }
}; };
@ -4886,7 +4996,7 @@ static void test_register_typelib(BOOL system_registration)
ok(hr == S_OK, "got %08x\n", hr); ok(hr == S_OK, "got %08x\n", hr);
count = ITypeLib_GetTypeInfoCount(typelib); count = ITypeLib_GetTypeInfoCount(typelib);
ok(count == 13, "got %d\n", count); ok(count == 14, "got %d\n", count);
for(i = 0; i < count; i++) for(i = 0; i < count; i++)
{ {

View file

@ -7496,7 +7496,7 @@ static HRESULT WINAPI ITypeInfo_fnInvoke(
* pointer to be valid */ * pointer to be valid */
VariantInit(pVarResult); VariantInit(pVarResult);
hres = IDispatch_Invoke(pDispatch, DISPID_VALUE, &IID_NULL, hres = IDispatch_Invoke(pDispatch, DISPID_VALUE, &IID_NULL,
GetSystemDefaultLCID(), INVOKE_PROPERTYGET, GetSystemDefaultLCID(), wFlags,
pDispParams, pVarResult, pExcepInfo, pArgErr); pDispParams, pVarResult, pExcepInfo, pArgErr);
IDispatch_Release(pDispatch); IDispatch_Release(pDispatch);
} }