mirror of
https://github.com/reactos/reactos.git
synced 2024-12-31 19:42:51 +00:00
[OLEAUT32_WINETEST] Sync with Wine Staging 4.18. CORE-16441
This commit is contained in:
parent
ae24453e12
commit
d3e07ed74a
4 changed files with 166 additions and 46 deletions
|
@ -410,7 +410,8 @@ static inline struct disp_obj *impl_from_ISomethingFromDispatch(ISomethingFromDi
|
||||||
static HRESULT WINAPI disp_obj_QueryInterface(ISomethingFromDispatch *iface, REFIID iid, void **out)
|
static HRESULT WINAPI disp_obj_QueryInterface(ISomethingFromDispatch *iface, REFIID iid, void **out)
|
||||||
{
|
{
|
||||||
if (IsEqualGUID(iid, &IID_IUnknown) || IsEqualGUID(iid, &IID_IDispatch)
|
if (IsEqualGUID(iid, &IID_IUnknown) || IsEqualGUID(iid, &IID_IDispatch)
|
||||||
|| IsEqualGUID(iid, &IID_ISomethingFromDispatch))
|
|| IsEqualGUID(iid, &IID_ISomethingFromDispatch)
|
||||||
|
|| IsEqualGUID(iid, &DIID_ItestIF4))
|
||||||
{
|
{
|
||||||
*out = iface;
|
*out = iface;
|
||||||
ISomethingFromDispatch_AddRef(iface);
|
ISomethingFromDispatch_AddRef(iface);
|
||||||
|
@ -1440,6 +1441,28 @@ static HRESULT WINAPI Widget_rect(IWidget *iface, RECT in, RECT *out, RECT *in_p
|
||||||
return S_OK;
|
return S_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI Widget_complex_struct(IWidget *iface, struct complex in)
|
||||||
|
{
|
||||||
|
HRESULT hr;
|
||||||
|
|
||||||
|
ok(in.c == 98, "Got char %d.\n", in.c);
|
||||||
|
ok(in.i == 76543, "Got int %d.\n", in.i);
|
||||||
|
ok(*in.pi == 2, "Got int pointer %d.\n", *in.pi);
|
||||||
|
ok(**in.ppi == 10, "Got int double pointer %d.\n", **in.ppi);
|
||||||
|
hr = ISomethingFromDispatch_anotherfn(in.iface);
|
||||||
|
ok(hr == 0x01234567, "Got wrong hr %#x.\n", hr);
|
||||||
|
hr = ISomethingFromDispatch_anotherfn(*in.iface_ptr);
|
||||||
|
ok(hr == 0x01234567, "Got wrong hr %#x.\n", hr);
|
||||||
|
ok(!lstrcmpW(in.bstr, test_bstr2), "Got string %s.\n", wine_dbgstr_w(in.bstr));
|
||||||
|
ok(V_VT(&in.var) == VT_I4, "Got wrong type %u.\n", V_VT(&in.var));
|
||||||
|
ok(V_I4(&in.var) == 123, "Got wrong value %d.\n", V_I4(&in.var));
|
||||||
|
ok(!memcmp(&in.mystruct, &test_mystruct1, sizeof(MYSTRUCT)), "Structs didn't match.\n");
|
||||||
|
ok(!memcmp(in.arr, test_array1, sizeof(array_t)), "Arrays didn't match.\n");
|
||||||
|
ok(in.myint == 456, "Got int %d.\n", in.myint);
|
||||||
|
|
||||||
|
return S_OK;
|
||||||
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI Widget_array(IWidget *iface, array_t in, array_t out, array_t in_out)
|
static HRESULT WINAPI Widget_array(IWidget *iface, array_t in, array_t out, array_t in_out)
|
||||||
{
|
{
|
||||||
static const array_t empty = {0};
|
static const array_t empty = {0};
|
||||||
|
@ -1458,21 +1481,21 @@ static HRESULT WINAPI Widget_variant_array(IWidget *iface, VARIANT in[2], VARIAN
|
||||||
{
|
{
|
||||||
ok(V_VT(&in[0]) == VT_I4, "Got wrong type %u.\n", V_VT(&in[0]));
|
ok(V_VT(&in[0]) == VT_I4, "Got wrong type %u.\n", V_VT(&in[0]));
|
||||||
ok(V_I4(&in[0]) == 1, "Got wrong value %d.\n", V_I4(&in[0]));
|
ok(V_I4(&in[0]) == 1, "Got wrong value %d.\n", V_I4(&in[0]));
|
||||||
ok(V_VT(&in[1]) == VT_I4, "Got wrong type %u.\n", V_VT(&in[1]));
|
ok(V_VT(&in[1]) == (VT_BYREF|VT_I4), "Got wrong type %u.\n", V_VT(&in[1]));
|
||||||
ok(V_I4(&in[1]) == 2, "Got wrong value %d.\n", V_I4(&in[1]));
|
ok(*V_I4REF(&in[1]) == 2, "Got wrong value %d.\n", *V_I4REF(&in[1]));
|
||||||
ok(V_VT(&out[0]) == VT_EMPTY, "Got wrong type %u.\n", V_VT(&out[0]));
|
ok(V_VT(&out[0]) == VT_EMPTY, "Got wrong type %u.\n", V_VT(&out[0]));
|
||||||
ok(V_VT(&out[1]) == VT_EMPTY, "Got wrong type %u.\n", V_VT(&out[1]));
|
ok(V_VT(&out[1]) == VT_EMPTY, "Got wrong type %u.\n", V_VT(&out[1]));
|
||||||
ok(V_VT(&in_out[0]) == VT_I4, "Got wrong type %u.\n", V_VT(&in_out[0]));
|
ok(V_VT(&in_out[0]) == VT_I4, "Got wrong type %u.\n", V_VT(&in_out[0]));
|
||||||
ok(V_I4(&in_out[0]) == 5, "Got wrong type %u.\n", V_VT(&in_out[0]));
|
ok(V_I4(&in_out[0]) == 5, "Got wrong type %u.\n", V_VT(&in_out[0]));
|
||||||
ok(V_VT(&in_out[1]) == VT_I4, "Got wrong type %u.\n", V_VT(&in_out[1]));
|
ok(V_VT(&in_out[1]) == VT_BSTR, "Got wrong type %u.\n", V_VT(&in_out[1]));
|
||||||
ok(V_I4(&in_out[1]) == 6, "Got wrong type %u.\n", V_VT(&in_out[1]));
|
ok(!lstrcmpW(V_BSTR(&in_out[1]), test_bstr1), "Got wrong value %s.\n", wine_dbgstr_w(V_BSTR(&in[1])));
|
||||||
|
|
||||||
V_VT(&in[0]) = VT_I1; V_I1(&in[0]) = 7;
|
V_VT(&in[0]) = VT_I1; V_I1(&in[0]) = 7;
|
||||||
V_VT(&in[1]) = VT_I1; V_I1(&in[1]) = 8;
|
V_VT(&in[1]) = VT_I1; V_I1(&in[1]) = 8;
|
||||||
V_VT(&out[0]) = VT_I1; V_I1(&out[0]) = 9;
|
V_VT(&out[0]) = VT_I1; V_I1(&out[0]) = 9;
|
||||||
V_VT(&out[1]) = VT_I1; V_I1(&out[1]) = 10;
|
V_VT(&out[1]) = VT_BSTR; V_BSTR(&out[1]) = SysAllocString(test_bstr2);
|
||||||
V_VT(&in_out[0]) = VT_I1; V_I1(&in_out[0]) = 11;
|
V_VT(&in_out[0]) = VT_I1; V_I1(&in_out[0]) = 11;
|
||||||
V_VT(&in_out[1]) = VT_I1; V_I1(&in_out[1]) = 12;
|
V_VT(&in_out[1]) = VT_UNKNOWN; V_UNKNOWN(&in_out[1]) = (IUnknown *)create_disp_obj();
|
||||||
|
|
||||||
return S_OK;
|
return S_OK;
|
||||||
}
|
}
|
||||||
|
@ -1599,6 +1622,7 @@ static const struct IWidgetVtbl Widget_VTable =
|
||||||
Widget_mystruct_ptr_ptr,
|
Widget_mystruct_ptr_ptr,
|
||||||
Widget_thin_struct,
|
Widget_thin_struct,
|
||||||
Widget_rect,
|
Widget_rect,
|
||||||
|
Widget_complex_struct,
|
||||||
Widget_array,
|
Widget_array,
|
||||||
Widget_variant_array,
|
Widget_variant_array,
|
||||||
Widget_mystruct_array,
|
Widget_mystruct_array,
|
||||||
|
@ -2499,6 +2523,9 @@ static void test_marshal_struct(IWidget *widget, IDispatch *disp)
|
||||||
{
|
{
|
||||||
MYSTRUCT out, in_ptr, in_out, *in_ptr_ptr;
|
MYSTRUCT out, in_ptr, in_out, *in_ptr_ptr;
|
||||||
RECT rect_out, rect_in_ptr, rect_in_out;
|
RECT rect_out, rect_in_ptr, rect_in_out;
|
||||||
|
ISomethingFromDispatch *sfd;
|
||||||
|
struct complex complex;
|
||||||
|
int i, i2, *pi = &i2;
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
|
|
||||||
memcpy(&out, &test_mystruct2, sizeof(MYSTRUCT));
|
memcpy(&out, &test_mystruct2, sizeof(MYSTRUCT));
|
||||||
|
@ -2530,14 +2557,35 @@ static void test_marshal_struct(IWidget *widget, IDispatch *disp)
|
||||||
ok(EqualRect(&rect_out, &test_rect5), "Rects didn't match.\n");
|
ok(EqualRect(&rect_out, &test_rect5), "Rects didn't match.\n");
|
||||||
ok(EqualRect(&rect_in_ptr, &test_rect3), "Rects didn't match.\n");
|
ok(EqualRect(&rect_in_ptr, &test_rect3), "Rects didn't match.\n");
|
||||||
ok(EqualRect(&rect_in_out, &test_rect7), "Rects didn't match.\n");
|
ok(EqualRect(&rect_in_out, &test_rect7), "Rects didn't match.\n");
|
||||||
|
|
||||||
|
/* Test complex structs. */
|
||||||
|
complex.c = 98;
|
||||||
|
complex.i = 76543;
|
||||||
|
i = 2;
|
||||||
|
complex.pi = &i;
|
||||||
|
i2 = 10;
|
||||||
|
complex.ppi = π
|
||||||
|
complex.iface = create_disp_obj();
|
||||||
|
sfd = create_disp_obj();
|
||||||
|
complex.iface_ptr = &sfd;
|
||||||
|
complex.bstr = SysAllocString(test_bstr2);
|
||||||
|
V_VT(&complex.var) = VT_I4;
|
||||||
|
V_I4(&complex.var) = 123;
|
||||||
|
memcpy(&complex.mystruct, &test_mystruct1, sizeof(MYSTRUCT));
|
||||||
|
memcpy(complex.arr, test_array1, sizeof(array_t));
|
||||||
|
complex.myint = 456;
|
||||||
|
hr = IWidget_complex_struct(widget, complex);
|
||||||
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_marshal_array(IWidget *widget, IDispatch *disp)
|
static void test_marshal_array(IWidget *widget, IDispatch *disp)
|
||||||
{
|
{
|
||||||
VARIANT var_in[2], var_out[2], var_in_out[2];
|
VARIANT var_in[2], var_out[2], var_in_out[2];
|
||||||
|
ISomethingFromDispatch *proxy_sfd;
|
||||||
array_t in, out, in_out;
|
array_t in, out, in_out;
|
||||||
MYSTRUCT struct_in[2];
|
MYSTRUCT struct_in[2];
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
|
int i = 2;
|
||||||
|
|
||||||
memcpy(in, test_array1, sizeof(array_t));
|
memcpy(in, test_array1, sizeof(array_t));
|
||||||
memcpy(out, test_array2, sizeof(array_t));
|
memcpy(out, test_array2, sizeof(array_t));
|
||||||
|
@ -2548,26 +2596,32 @@ static void test_marshal_array(IWidget *widget, IDispatch *disp)
|
||||||
ok(!memcmp(&out, &test_array5, sizeof(array_t)), "Arrays didn't match.\n");
|
ok(!memcmp(&out, &test_array5, sizeof(array_t)), "Arrays didn't match.\n");
|
||||||
ok(!memcmp(&in_out, &test_array6, sizeof(array_t)), "Arrays didn't match.\n");
|
ok(!memcmp(&in_out, &test_array6, sizeof(array_t)), "Arrays didn't match.\n");
|
||||||
|
|
||||||
V_VT(&var_in[0]) = VT_I4; V_I4(&var_in[0]) = 1;
|
V_VT(&var_in[0]) = VT_I4; V_I4(&var_in[0]) = 1;
|
||||||
V_VT(&var_in[1]) = VT_I4; V_I4(&var_in[1]) = 2;
|
V_VT(&var_in[1]) = VT_BYREF|VT_I4; V_I4REF(&var_in[1]) = &i;
|
||||||
V_VT(&var_out[0]) = VT_I4; V_I4(&var_out[0]) = 3;
|
V_VT(&var_out[0]) = VT_I4; V_I4(&var_out[0]) = 3;
|
||||||
V_VT(&var_out[1]) = VT_I4; V_I4(&var_out[1]) = 4;
|
V_VT(&var_out[1]) = VT_I4; V_I4(&var_out[1]) = 4;
|
||||||
V_VT(&var_in_out[0]) = VT_I4; V_I4(&var_in_out[0]) = 5;
|
V_VT(&var_in_out[0]) = VT_I4; V_I4(&var_in_out[0]) = 5;
|
||||||
V_VT(&var_in_out[1]) = VT_I4; V_I4(&var_in_out[1]) = 6;
|
V_VT(&var_in_out[1]) = VT_BSTR; V_BSTR(&var_in_out[1]) = SysAllocString(test_bstr1);
|
||||||
hr = IWidget_variant_array(widget, var_in, var_out, var_in_out);
|
hr = IWidget_variant_array(widget, var_in, var_out, var_in_out);
|
||||||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
ok(V_VT(&var_in[0]) == VT_I4, "Got wrong type %u.\n", V_VT(&var_in[0]));
|
ok(V_VT(&var_in[0]) == VT_I4, "Got wrong type %u.\n", V_VT(&var_in[0]));
|
||||||
ok(V_I4(&var_in[0]) == 1, "Got wrong value %d.\n", V_I4(&var_in[0]));
|
ok(V_I4(&var_in[0]) == 1, "Got wrong value %d.\n", V_I4(&var_in[0]));
|
||||||
ok(V_VT(&var_in[1]) == VT_I4, "Got wrong type %u.\n", V_VT(&var_in[1]));
|
ok(V_VT(&var_in[1]) == (VT_BYREF|VT_I4), "Got wrong type %u.\n", V_VT(&var_in[1]));
|
||||||
ok(V_I4(&var_in[1]) == 2, "Got wrong value %d.\n", V_I4(&var_in[1]));
|
ok(V_I4REF(&var_in[1]) == &i, "Got wrong value %p.\n", V_I4REF(&var_in[1]));
|
||||||
|
ok(i == 2, "Got wrong value %d.\n", i);
|
||||||
ok(V_VT(&var_out[0]) == VT_I1, "Got wrong type %u.\n", V_VT(&var_out[0]));
|
ok(V_VT(&var_out[0]) == VT_I1, "Got wrong type %u.\n", V_VT(&var_out[0]));
|
||||||
ok(V_I1(&var_out[0]) == 9, "Got wrong value %u.\n", V_VT(&var_out[0]));
|
ok(V_I1(&var_out[0]) == 9, "Got wrong value %u.\n", V_VT(&var_out[0]));
|
||||||
ok(V_VT(&var_out[1]) == VT_I1, "Got wrong type %u.\n", V_VT(&var_out[1]));
|
ok(V_VT(&var_out[1]) == VT_BSTR, "Got wrong type %u.\n", V_VT(&var_out[1]));
|
||||||
ok(V_I1(&var_out[1]) == 10, "Got wrong value %u.\n", V_VT(&var_out[1]));
|
ok(!lstrcmpW(V_BSTR(&var_out[1]), test_bstr2), "Got wrong value %s.\n", wine_dbgstr_w(V_BSTR(&var_out[1])));
|
||||||
ok(V_VT(&var_in_out[0]) == VT_I1, "Got wrong type %u.\n", V_VT(&var_in_out[0]));
|
ok(V_VT(&var_in_out[0]) == VT_I1, "Got wrong type %u.\n", V_VT(&var_in_out[0]));
|
||||||
ok(V_I1(&var_in_out[0]) == 11, "Got wrong value %u.\n", V_VT(&var_in_out[0]));
|
ok(V_I1(&var_in_out[0]) == 11, "Got wrong value %u.\n", V_VT(&var_in_out[0]));
|
||||||
ok(V_VT(&var_in_out[1]) == VT_I1, "Got wrong type %u.\n", V_VT(&var_in_out[1]));
|
ok(V_VT(&var_in_out[1]) == VT_UNKNOWN, "Got wrong type %u.\n", V_VT(&var_in_out[1]));
|
||||||
ok(V_I1(&var_in_out[1]) == 12, "Got wrong value %u.\n", V_VT(&var_in_out[1]));
|
hr = IUnknown_QueryInterface(V_UNKNOWN(&var_in_out[1]), &IID_ISomethingFromDispatch, (void **)&proxy_sfd);
|
||||||
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
|
hr = ISomethingFromDispatch_anotherfn(proxy_sfd);
|
||||||
|
ok(hr == 0x01234567, "Got hr %#x.\n", hr);
|
||||||
|
ISomethingFromDispatch_Release(proxy_sfd);
|
||||||
|
release_iface(V_UNKNOWN(&var_in_out[1]));
|
||||||
|
|
||||||
memcpy(&struct_in[0], &test_mystruct1, sizeof(MYSTRUCT));
|
memcpy(&struct_in[0], &test_mystruct1, sizeof(MYSTRUCT));
|
||||||
memcpy(&struct_in[1], &test_mystruct2, sizeof(MYSTRUCT));
|
memcpy(&struct_in[1], &test_mystruct2, sizeof(MYSTRUCT));
|
||||||
|
@ -3592,6 +3646,37 @@ static void test_external_connection(void)
|
||||||
IStream_Release(stream);
|
IStream_Release(stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void test_marshal_dispinterface(void)
|
||||||
|
{
|
||||||
|
static const LARGE_INTEGER zero;
|
||||||
|
|
||||||
|
ISomethingFromDispatch *disp_obj = create_disp_obj();
|
||||||
|
ITypeInfo *typeinfo = NULL;
|
||||||
|
IDispatch *proxy_disp;
|
||||||
|
IStream *stream;
|
||||||
|
HANDLE thread;
|
||||||
|
HRESULT hr;
|
||||||
|
ULONG ref;
|
||||||
|
DWORD tid;
|
||||||
|
|
||||||
|
CreateStreamOnHGlobal(NULL, TRUE, &stream);
|
||||||
|
tid = start_host_object(stream, &DIID_ItestIF4, (IUnknown *)disp_obj, MSHLFLAGS_NORMAL, &thread);
|
||||||
|
IStream_Seek(stream, zero, STREAM_SEEK_SET, NULL);
|
||||||
|
hr = CoUnmarshalInterface(stream, &DIID_ItestIF4, (void **)&proxy_disp);
|
||||||
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
|
|
||||||
|
hr = IDispatch_GetTypeInfo(proxy_disp, 0xdeadbeef, 0, &typeinfo);
|
||||||
|
ok(hr == 0xbeefdead, "Got hr %#x.\n", hr);
|
||||||
|
|
||||||
|
ref = IDispatch_Release(proxy_disp);
|
||||||
|
ok(!ref, "Got outstanding refcount %d.\n", ref);
|
||||||
|
ref = IStream_Release(stream);
|
||||||
|
ok(!ref, "Got outstanding refcount %d.\n", ref);
|
||||||
|
end_host_object(tid, thread);
|
||||||
|
ref = ISomethingFromDispatch_Release(disp_obj);
|
||||||
|
ok(!ref, "Got outstanding refcount %d.\n", ref);
|
||||||
|
}
|
||||||
|
|
||||||
START_TEST(tmarshal)
|
START_TEST(tmarshal)
|
||||||
{
|
{
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
|
@ -3613,6 +3698,7 @@ START_TEST(tmarshal)
|
||||||
test_StaticWidget();
|
test_StaticWidget();
|
||||||
test_libattr();
|
test_libattr();
|
||||||
test_external_connection();
|
test_external_connection();
|
||||||
|
test_marshal_dispinterface();
|
||||||
|
|
||||||
hr = UnRegisterTypeLib(&LIBID_TestTypelib, 2, 5, LOCALE_NEUTRAL,
|
hr = UnRegisterTypeLib(&LIBID_TestTypelib, 2, 5, LOCALE_NEUTRAL,
|
||||||
sizeof(void*) == 8 ? SYS_WIN64 : SYS_WIN32);
|
sizeof(void*) == 8 ? SYS_WIN64 : SYS_WIN32);
|
||||||
|
|
|
@ -65,6 +65,7 @@ enum IWidget_dispids
|
||||||
DISPID_TM_STRUCT_PTR_PTR,
|
DISPID_TM_STRUCT_PTR_PTR,
|
||||||
DISPID_TM_THIN_STRUCT,
|
DISPID_TM_THIN_STRUCT,
|
||||||
DISPID_TM_RECT,
|
DISPID_TM_RECT,
|
||||||
|
DISPID_TM_COMPLEX_STRUCT,
|
||||||
DISPID_TM_ARRAY,
|
DISPID_TM_ARRAY,
|
||||||
DISPID_TM_VARIANT_ARRAY,
|
DISPID_TM_VARIANT_ARRAY,
|
||||||
DISPID_TM_STRUCT_ARRAY,
|
DISPID_TM_STRUCT_ARRAY,
|
||||||
|
@ -105,6 +106,8 @@ library TestTypelib
|
||||||
|
|
||||||
typedef [public] int myint_t;
|
typedef [public] int myint_t;
|
||||||
|
|
||||||
|
typedef int array_t[4];
|
||||||
|
|
||||||
coclass ApplicationObject2;
|
coclass ApplicationObject2;
|
||||||
|
|
||||||
[
|
[
|
||||||
|
@ -335,7 +338,23 @@ library TestTypelib
|
||||||
[id(DISPID_TM_RECT)]
|
[id(DISPID_TM_RECT)]
|
||||||
HRESULT rect([in] RECT in, [out] RECT *out, [in] RECT *in_ptr, [in, out] RECT *in_out);
|
HRESULT rect([in] RECT in, [out] RECT *out, [in] RECT *in_ptr, [in, out] RECT *in_out);
|
||||||
|
|
||||||
typedef int array_t[4];
|
struct complex
|
||||||
|
{
|
||||||
|
char c;
|
||||||
|
int i;
|
||||||
|
int *pi;
|
||||||
|
int **ppi;
|
||||||
|
ISomethingFromDispatch *iface;
|
||||||
|
ISomethingFromDispatch **iface_ptr;
|
||||||
|
BSTR bstr;
|
||||||
|
VARIANT var;
|
||||||
|
MYSTRUCT mystruct;
|
||||||
|
array_t arr;
|
||||||
|
myint_t myint;
|
||||||
|
};
|
||||||
|
|
||||||
|
[id(DISPID_TM_COMPLEX_STRUCT)]
|
||||||
|
HRESULT complex_struct([in] struct complex in);
|
||||||
|
|
||||||
[id(DISPID_TM_ARRAY)]
|
[id(DISPID_TM_ARRAY)]
|
||||||
HRESULT array([in] array_t in, [out] array_t out, [in, out] array_t in_out);
|
HRESULT array([in] array_t in, [out] array_t out, [in, out] array_t in_out);
|
||||||
|
|
|
@ -1138,9 +1138,9 @@ static int WINAPI int_func( int a0, int a1, int a2, int a3, int a4 )
|
||||||
|
|
||||||
static double WINAPI double_func( double a0, float a1, double a2, int a3 )
|
static double WINAPI double_func( double a0, float a1, double a2, int a3 )
|
||||||
{
|
{
|
||||||
ok( a0 == 1.2, "wrong arg0 %f\n", (double)a0 );
|
ok( a0 == 1.2, "wrong arg0 %f\n", a0 );
|
||||||
ok( a1 == 3.25, "wrong arg1 %f\n", (double)a1 );
|
ok( a1 == 3.25, "wrong arg1 %f\n", (double)a1 );
|
||||||
ok( a2 == 1.2e12, "wrong arg2 %f\n", (double)a2);
|
ok( a2 == 1.2e12, "wrong arg2 %f\n", a2);
|
||||||
ok( a3 == -4433.0, "wrong arg3 %f\n", (double)a3 );
|
ok( a3 == -4433.0, "wrong arg3 %f\n", (double)a3 );
|
||||||
return 4321;
|
return 4321;
|
||||||
}
|
}
|
||||||
|
@ -4807,7 +4807,7 @@ static void test_dump_typelib(const char *name)
|
||||||
|
|
||||||
for (func = 0; func < typeattr->cFuncs; func++)
|
for (func = 0; func < typeattr->cFuncs; func++)
|
||||||
{
|
{
|
||||||
function_info *fn_info = (function_info *)&ti->funcs[func];
|
const function_info *fn_info = &ti->funcs[func];
|
||||||
FUNCDESC *desc;
|
FUNCDESC *desc;
|
||||||
BSTR namesTab[256];
|
BSTR namesTab[256];
|
||||||
UINT cNames;
|
UINT cNames;
|
||||||
|
@ -4963,6 +4963,7 @@ static void test_register_typelib(BOOL system_registration)
|
||||||
HKEY hkey;
|
HKEY hkey;
|
||||||
REGSAM opposite = (sizeof(void*) == 8 ? KEY_WOW64_32KEY : KEY_WOW64_64KEY);
|
REGSAM opposite = (sizeof(void*) == 8 ? KEY_WOW64_32KEY : KEY_WOW64_64KEY);
|
||||||
BOOL is_wow64 = FALSE;
|
BOOL is_wow64 = FALSE;
|
||||||
|
LONG size;
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
TYPEKIND kind;
|
TYPEKIND kind;
|
||||||
|
@ -5071,7 +5072,26 @@ static void test_register_typelib(BOOL system_registration)
|
||||||
|
|
||||||
ret = RegOpenKeyExA(HKEY_CLASSES_ROOT, key_name, 0, KEY_READ, &hkey);
|
ret = RegOpenKeyExA(HKEY_CLASSES_ROOT, key_name, 0, KEY_READ, &hkey);
|
||||||
ok(ret == expect_ret, "%d: got %d\n", i, ret);
|
ok(ret == expect_ret, "%d: got %d\n", i, ret);
|
||||||
if(ret == ERROR_SUCCESS) RegCloseKey(hkey);
|
if (ret == ERROR_SUCCESS)
|
||||||
|
{
|
||||||
|
size = sizeof(uuid);
|
||||||
|
ret = RegQueryValueA(hkey, "ProxyStubClsid32", uuid, &size);
|
||||||
|
ok(!ret, "Failed to get proxy GUID, error %u.\n", ret);
|
||||||
|
|
||||||
|
if (attrs[i].kind == TKIND_INTERFACE || (attrs[i].flags & TYPEFLAG_FDUAL))
|
||||||
|
{
|
||||||
|
ok(!strcasecmp(uuid, "{00020424-0000-0000-c000-000000000046}"),
|
||||||
|
"Got unexpected proxy CLSID %s.\n", uuid);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ok(!strcasecmp(uuid, "{00020420-0000-0000-c000-000000000046}"),
|
||||||
|
"Got unexpected proxy CLSID %s.\n", uuid);
|
||||||
|
}
|
||||||
|
|
||||||
|
RegCloseKey(hkey);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* 32-bit typelibs should be registered into both registry bit modes */
|
/* 32-bit typelibs should be registered into both registry bit modes */
|
||||||
if (is_win64 || is_wow64)
|
if (is_win64 || is_wow64)
|
||||||
|
|
|
@ -2715,15 +2715,13 @@ static void test_VarSub(void)
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_CY,
|
ok(hres == S_OK && V_VT(&result) == VT_CY,
|
||||||
"VarSub: expected coerced type VT_CY, got %s!\n", vtstr(V_VT(&result)));
|
"VarSub: expected coerced type VT_CY, got %s!\n", vtstr(V_VT(&result)));
|
||||||
hres = VarR8FromCy(V_CY(&result), &r);
|
hres = VarR8FromCy(V_CY(&result), &r);
|
||||||
ok(hres == S_OK && EQ_DOUBLE(r, 4702.0),
|
ok(hres == S_OK && EQ_DOUBLE(r, 4702.0), "VarSub: CY value %f, expected %f\n", r, 4720.0);
|
||||||
"VarSub: CY value %f, expected %f\n", r, (double)4720);
|
|
||||||
|
|
||||||
hres = pVarSub(&left, &dec, &result);
|
hres = pVarSub(&left, &dec, &result);
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL,
|
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL,
|
||||||
"VarSub: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
"VarSub: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
||||||
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
||||||
ok(hres == S_OK && EQ_DOUBLE(r, -6.8),
|
ok(hres == S_OK && EQ_DOUBLE(r, -6.8), "VarSub: DECIMAL value %f, expected %f\n", r, -6.8);
|
||||||
"VarSub: DECIMAL value %f, expected %f\n", r, (double)-15.2);
|
|
||||||
|
|
||||||
SysFreeString(lbstr);
|
SysFreeString(lbstr);
|
||||||
SysFreeString(rbstr);
|
SysFreeString(rbstr);
|
||||||
|
@ -5534,12 +5532,12 @@ static void test_VarMul(void)
|
||||||
hres = pVarMul(&cy, &right, &result);
|
hres = pVarMul(&cy, &right, &result);
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_CY, "VarMul: expected coerced type VT_CY, got %s!\n", vtstr(V_VT(&result)));
|
ok(hres == S_OK && V_VT(&result) == VT_CY, "VarMul: expected coerced type VT_CY, got %s!\n", vtstr(V_VT(&result)));
|
||||||
hres = VarR8FromCy(V_CY(&result), &r);
|
hres = VarR8FromCy(V_CY(&result), &r);
|
||||||
ok(hres == S_OK && EQ_DOUBLE(r, 42399.0), "VarMul: CY value %f, expected %f\n", r, (double)42399);
|
ok(hres == S_OK && EQ_DOUBLE(r, 42399.0), "VarMul: CY value %f, expected %f\n", r, 42399.0);
|
||||||
|
|
||||||
hres = pVarMul(&left, &dec, &result);
|
hres = pVarMul(&left, &dec, &result);
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL, "VarMul: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL, "VarMul: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
||||||
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
||||||
ok(hres == S_OK && EQ_DOUBLE(r, 46.2), "VarMul: DECIMAL value %f, expected %f\n", r, (double)46.2);
|
ok(hres == S_OK && EQ_DOUBLE(r, 46.2), "VarMul: DECIMAL value %f, expected %f\n", r, 46.2);
|
||||||
|
|
||||||
SysFreeString(lbstr);
|
SysFreeString(lbstr);
|
||||||
SysFreeString(rbstr);
|
SysFreeString(rbstr);
|
||||||
|
@ -5705,7 +5703,7 @@ static void test_VarAdd(void)
|
||||||
hres = pVarAdd(&left, &right, &result);
|
hres = pVarAdd(&left, &right, &result);
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_BSTR, "VarAdd: expected coerced type VT_BSTR, got %s!\n", vtstr(V_VT(&result)));
|
ok(hres == S_OK && V_VT(&result) == VT_BSTR, "VarAdd: expected coerced type VT_BSTR, got %s!\n", vtstr(V_VT(&result)));
|
||||||
hres = VarR8FromStr(V_BSTR(&result), 0, 0, &r);
|
hres = VarR8FromStr(V_BSTR(&result), 0, 0, &r);
|
||||||
ok(hres == S_OK && EQ_DOUBLE(r, 1212.0), "VarAdd: BSTR value %f, expected %f\n", r, (double)1212);
|
ok(hres == S_OK && EQ_DOUBLE(r, 1212.0), "VarAdd: BSTR value %f, expected %f\n", r, 1212.0);
|
||||||
VariantClear(&result);
|
VariantClear(&result);
|
||||||
|
|
||||||
/* Manuly test some VT_CY and VT_DECIMAL variants */
|
/* Manuly test some VT_CY and VT_DECIMAL variants */
|
||||||
|
@ -5725,12 +5723,12 @@ static void test_VarAdd(void)
|
||||||
hres = pVarAdd(&cy, &right, &result);
|
hres = pVarAdd(&cy, &right, &result);
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_CY, "VarAdd: expected coerced type VT_CY, got %s!\n", vtstr(V_VT(&result)));
|
ok(hres == S_OK && V_VT(&result) == VT_CY, "VarAdd: expected coerced type VT_CY, got %s!\n", vtstr(V_VT(&result)));
|
||||||
hres = VarR8FromCy(V_CY(&result), &r);
|
hres = VarR8FromCy(V_CY(&result), &r);
|
||||||
ok(hres == S_OK && EQ_DOUBLE(r, 4720.0), "VarAdd: CY value %f, expected %f\n", r, (double)4720);
|
ok(hres == S_OK && EQ_DOUBLE(r, 4720.0), "VarAdd: CY value %f, expected %f\n", r, 4720.0);
|
||||||
|
|
||||||
hres = pVarAdd(&left, &dec, &result);
|
hres = pVarAdd(&left, &dec, &result);
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL, "VarAdd: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL, "VarAdd: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
||||||
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
||||||
ok(hres == S_OK && EQ_DOUBLE(r, -15.2), "VarAdd: DECIMAL value %f, expected %f\n", r, (double)-15.2);
|
ok(hres == S_OK && EQ_DOUBLE(r, -15.2), "VarAdd: DECIMAL value %f, expected %f\n", r, -15.2);
|
||||||
VariantClear(&result);
|
VariantClear(&result);
|
||||||
|
|
||||||
SysFreeString(lbstr);
|
SysFreeString(lbstr);
|
||||||
|
@ -7995,40 +7993,37 @@ static void test_VarDiv(void)
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_R8,
|
ok(hres == S_OK && V_VT(&result) == VT_R8,
|
||||||
"VARDIV: expected coerced type VT_R8, got %s!\n", vtstr(V_VT(&result)));
|
"VARDIV: expected coerced type VT_R8, got %s!\n", vtstr(V_VT(&result)));
|
||||||
ok(hres == S_OK && EQ_DOUBLE(V_R8(&result), 1.0),
|
ok(hres == S_OK && EQ_DOUBLE(V_R8(&result), 1.0),
|
||||||
"VARDIV: CY value %f, expected %f\n", V_R8(&result), (double)1.0);
|
"VARDIV: CY value %f, expected %f\n", V_R8(&result), 1.0);
|
||||||
|
|
||||||
hres = pVarDiv(&cy, &right, &result);
|
hres = pVarDiv(&cy, &right, &result);
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_R8,
|
ok(hres == S_OK && V_VT(&result) == VT_R8,
|
||||||
"VARDIV: expected coerced type VT_R8, got %s!\n", vtstr(V_VT(&result)));
|
"VARDIV: expected coerced type VT_R8, got %s!\n", vtstr(V_VT(&result)));
|
||||||
ok(hres == S_OK && EQ_DOUBLE(V_R8(&result), 5000.0),
|
ok(hres == S_OK && EQ_DOUBLE(V_R8(&result), 5000.0),
|
||||||
"VARDIV: CY value %f, expected %f\n", V_R8(&result), (double)5000.0);
|
"VARDIV: CY value %f, expected %f\n", V_R8(&result), 5000.0);
|
||||||
|
|
||||||
hres = pVarDiv(&left, &cy, &result);
|
hres = pVarDiv(&left, &cy, &result);
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_R8,
|
ok(hres == S_OK && V_VT(&result) == VT_R8,
|
||||||
"VARDIV: expected coerced type VT_R8, got %s!\n", vtstr(V_VT(&result)));
|
"VARDIV: expected coerced type VT_R8, got %s!\n", vtstr(V_VT(&result)));
|
||||||
ok(hres == S_OK && EQ_DOUBLE(V_R8(&result), 0.01),
|
ok(hres == S_OK && EQ_DOUBLE(V_R8(&result), 0.01),
|
||||||
"VARDIV: CY value %f, expected %f\n", V_R8(&result), (double)0.01);
|
"VARDIV: CY value %f, expected %f\n", V_R8(&result), 0.01);
|
||||||
|
|
||||||
hres = pVarDiv(&left, &dec, &result);
|
hres = pVarDiv(&left, &dec, &result);
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL,
|
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL,
|
||||||
"VARDIV: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
"VARDIV: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
||||||
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
||||||
ok(hres == S_OK && EQ_DOUBLE(r, 50.0),
|
ok(hres == S_OK && EQ_DOUBLE(r, 50.0), "VARDIV: DECIMAL value %f, expected %f\n", r, 50.0);
|
||||||
"VARDIV: DECIMAL value %f, expected %f\n", r, (double)50.0);
|
|
||||||
|
|
||||||
hres = pVarDiv(&dec, &dec, &result);
|
hres = pVarDiv(&dec, &dec, &result);
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL,
|
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL,
|
||||||
"VARDIV: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
"VARDIV: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
||||||
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
||||||
ok(hres == S_OK && EQ_DOUBLE(r, 1.0),
|
ok(hres == S_OK && EQ_DOUBLE(r, 1.0), "VARDIV: DECIMAL value %f, expected %f\n", r, 1.0);
|
||||||
"VARDIV: DECIMAL value %f, expected %f\n", r, (double)1.0);
|
|
||||||
|
|
||||||
hres = pVarDiv(&dec, &right, &result);
|
hres = pVarDiv(&dec, &right, &result);
|
||||||
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL,
|
ok(hres == S_OK && V_VT(&result) == VT_DECIMAL,
|
||||||
"VARDIV: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
"VARDIV: expected coerced type VT_DECIMAL, got %s!\n", vtstr(V_VT(&result)));
|
||||||
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
hres = VarR8FromDec(&V_DECIMAL(&result), &r);
|
||||||
ok(hres == S_OK && EQ_DOUBLE(r, 1.0),
|
ok(hres == S_OK && EQ_DOUBLE(r, 1.0), "VARDIV: DECIMAL value %f, expected %f\n", r, 1.0);
|
||||||
"VARDIV: DECIMAL value %f, expected %f\n", r, (double)1.0);
|
|
||||||
|
|
||||||
/* Check for division by zero and overflow */
|
/* Check for division by zero and overflow */
|
||||||
V_VT(&left) = VT_R8;
|
V_VT(&left) = VT_R8;
|
||||||
|
|
Loading…
Reference in a new issue