2 * Low level variant tests
4 * Copyright 2003 Jon Griffiths
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
21 #include "wine/test.h"
25 /* Some Visual C++ versions choke on __uint64 to float conversions.
26 * To fix this you need either VC++ 6.0 plus the processor pack
27 * or Visual C++ >=7.0.
30 # define HAS_UINT64_TO_FLOAT
33 # define HAS_UINT64_TO_FLOAT
36 # if defined(_mm_free)
37 /* _mm_free is defined if the Processor Pack has been installed */
38 # define HAS_UINT64_TO_FLOAT
44 static HMODULE hOleaut32
;
46 /* Get a conversion function ptr, return if function not available */
47 #define CHECKPTR(func) p##func = (void*)GetProcAddress(hOleaut32, #func); \
49 skip("function " # func " not available, not testing it\n"); return; }
51 /* Is a given function exported from oleaut32? */
52 #define HAVE_FUNC(func) ((void*)GetProcAddress(hOleaut32, #func) != NULL)
54 /* Have IRecordInfo data type? */
55 #define HAVE_OLEAUT32_RECORD HAVE_FUNC(SafeArraySetRecordInfo)
56 /* Have DECIMAL data type with new error checking? */
57 #define HAVE_OLEAUT32_DECIMAL HAVE_FUNC(VarDecAdd)
58 /* Have CY data type? */
59 #define HAVE_OLEAUT32_CY HAVE_FUNC(VarCyAdd)
60 /* Have I8/UI8 data type? */
61 #define HAVE_OLEAUT32_I8 HAVE_FUNC(VarI8FromI1)
62 /* Have proper locale conversions? */
63 #define HAVE_OLEAUT32_LOCALES (HAVE_FUNC(GetVarConversionLocaleSetting) && HAVE_OLEAUT32_I8)
64 /* Is this an ancient version with support for only I2/I4/R4/R8/DATE? */
65 #define IS_ANCIENT (!HAVE_FUNC(VarI1FromI2))
66 /* Is vt a type unavailable to ancient versions? */
67 #define IS_MODERN_VTYPE(vt) (vt==VT_VARIANT||vt==VT_DECIMAL|| \
68 vt==VT_I1||vt==VT_UI2||vt==VT_UI4||vt == VT_INT||vt == VT_UINT)
70 /* Macros for converting and testing results */
71 #define CONVVARS(typ) HRESULT hres; CONV_TYPE out; typ in
73 #define _EXPECTRES(res, x, fs) \
74 ok((hres == S_OK && out == (CONV_TYPE)(x)) || ((HRESULT)res != S_OK && hres == (HRESULT)res), \
75 "expected " #x ", got " fs "; hres=0x%08x\n", out, hres)
76 #define EXPECT(x) EXPECTRES(S_OK, (x))
77 #define EXPECT_OVERFLOW EXPECTRES(DISP_E_OVERFLOW, DISP_E_OVERFLOW)
78 #define EXPECT_MISMATCH EXPECTRES(DISP_E_TYPEMISMATCH,DISP_E_TYPEMISMATCH)
79 #define EXPECT_BADVAR EXPECTRES(DISP_E_BADVARTYPE, DISP_E_BADVARTYPE)
80 #define EXPECT_INVALID EXPECTRES(E_INVALIDARG, E_INVALIDARG)
81 #define EXPECT_LT EXPECTRES(VARCMP_LT, VARCMP_LT)
82 #define EXPECT_GT EXPECTRES(VARCMP_GT, VARCMP_GT)
83 #define EXPECT_EQ EXPECTRES(VARCMP_EQ, VARCMP_EQ)
84 #define EXPECT_DBL(x) \
85 ok(hres == S_OK && fabs(out-(x))<=1e-14*(x), "expected %16.16g, got %16.16g; hres=0x%08x\n", (x), out, hres)
87 #define CONVERT(func, val) in = val; hres = p##func(in, &out)
88 #define CONVERTRANGE(func,start,end) for (i = start; i < end; i+=1) { CONVERT(func, i); EXPECT(i); };
89 #define OVERFLOWRANGE(func,start,end) for (i = start; i < end; i+=1) { CONVERT(func, i); EXPECT_OVERFLOW; };
91 #define CY_MULTIPLIER 10000
93 #define DATE_MIN -657434
94 #define DATE_MAX 2958465
96 #define CONVERT_I8(func,hi,lo) in = hi; in = (in << 32) | lo; hres = p##func(in, &out)
98 #define CONVERT_CY(func,val) in.int64 = (LONGLONG)(val * CY_MULTIPLIER); hres = p##func(in, &out)
100 #define CONVERT_CY64(func,hi,lo) S(in).Hi = hi; S(in).Lo = lo; in.int64 *= CY_MULTIPLIER; hres = p##func(in, &out)
102 #define SETDEC(dec, scl, sgn, hi, lo) S(U(dec)).scale = (BYTE)scl; S(U(dec)).sign = (BYTE)sgn; \
103 dec.Hi32 = (ULONG)hi; U1(dec).Lo64 = (ULONG64)lo
105 #define SETDEC64(dec, scl, sgn, hi, mid, lo) S(U(dec)).scale = (BYTE)scl; S(U(dec)).sign = (BYTE)sgn; \
106 dec.Hi32 = (ULONG)hi; S1(U1(dec)).Mid32 = mid; S1(U1(dec)).Lo32 = lo;
108 #define CONVERT_DEC(func,scl,sgn,hi,lo) SETDEC(in,scl,sgn,hi,lo); hres = p##func(&in, &out)
110 #define CONVERT_DEC64(func,scl,sgn,hi,mid,lo) SETDEC64(in,scl,sgn,hi,mid,lo); hres = p##func(&in, &out)
112 #define CONVERT_BADDEC(func) \
113 if (HAVE_OLEAUT32_DECIMAL) \
115 CONVERT_DEC(func,29,0,0,0); EXPECT_INVALID; \
116 CONVERT_DEC(func,0,0x1,0,0); EXPECT_INVALID; \
117 CONVERT_DEC(func,0,0x40,0,0); EXPECT_INVALID; \
118 CONVERT_DEC(func,0,0x7f,0,0); EXPECT_INVALID; \
121 #define CONVERT_STR(func,str,flags) \
123 if (str) MultiByteToWideChar(CP_ACP,0,str,-1,buff,sizeof(buff)/sizeof(WCHAR)); \
124 hres = p##func(str ? buff : NULL,in,flags,&out)
126 #define COPYTEST(val, vt, srcval, dstval, srcref, dstref, fs) do { \
127 HRESULT hres; VARIANTARG vSrc, vDst; CONV_TYPE in = val; \
128 VariantInit(&vSrc); VariantInit(&vDst); \
129 V_VT(&vSrc) = vt; srcval = in; \
130 hres = VariantCopy(&vDst, &vSrc); \
131 ok(hres == S_OK && V_VT(&vDst) == vt && dstval == in, \
132 "copy hres 0x%X, type %d, value (" fs ") " fs "\n", hres, V_VT(&vDst), val, dstval); \
133 V_VT(&vSrc) = vt|VT_BYREF; srcref = ∈ \
134 hres = VariantCopy(&vDst, &vSrc); \
135 ok(hres == S_OK && V_VT(&vDst) == (vt|VT_BYREF) && dstref == &in, \
136 "ref hres 0x%X, type %d, ref (%p) %p\n", hres, V_VT(&vDst), &in, dstref); \
137 hres = VariantCopyInd(&vDst, &vSrc); \
138 ok(hres == S_OK && V_VT(&vDst) == vt && dstval == in, \
139 "ind hres 0x%X, type %d, value (" fs ") " fs "\n", hres, V_VT(&vDst), val, dstval); \
142 #define CHANGETYPEEX(typ) hres = VariantChangeTypeEx(&vDst, &vSrc, 0, 0, typ)
144 #define TYPETEST(typ,res,fs) CHANGETYPEEX(typ); \
145 ok(hres == S_OK && V_VT(&vDst) == typ && (CONV_TYPE)res == in, \
146 "hres=0x%X, type=%d (should be %d(" #typ ")), value=" fs " (should be " fs ")\n", \
147 hres, V_VT(&vDst), typ, (CONV_TYPE)res, in);
148 #define TYPETESTI8(typ,res) CHANGETYPEEX(typ); \
149 ok(hres == S_OK && V_VT(&vDst) == typ && (CONV_TYPE)res == in, \
150 "hres=0x%X, type=%d (should be %d(" #typ ")), value=%d (should be 1)\n", \
151 hres, V_VT(&vDst), typ, (int)res);
152 #define BADVAR(typ) CHANGETYPEEX(typ); out = (CONV_TYPE)hres; EXPECT_BADVAR
153 #define MISMATCH(typ) CHANGETYPEEX(typ); out = (CONV_TYPE)hres; EXPECT_MISMATCH
155 #define INITIAL_TYPETEST(vt, val, fs) \
156 VariantInit(&vSrc); \
157 VariantInit(&vDst); \
161 TYPETEST(VT_I1, V_I1(&vDst), fs); \
162 TYPETEST(VT_UI2, V_UI2(&vDst), fs); \
163 TYPETEST(VT_UI4, V_UI4(&vDst), fs); \
164 TYPETEST(VT_INT, V_INT(&vDst), fs); \
165 TYPETEST(VT_UINT, V_UINT(&vDst), fs); \
167 BADVAR(VT_I1); BADVAR(VT_UI2); BADVAR(VT_UI4); \
168 BADVAR(VT_INT); BADVAR(VT_UINT); \
170 TYPETEST(VT_UI1, V_UI1(&vDst), fs); \
171 TYPETEST(VT_I2, V_I2(&vDst), fs); \
172 TYPETEST(VT_I4, V_I4(&vDst), fs); \
173 TYPETEST(VT_R4, V_R4(&vDst), fs); \
174 TYPETEST(VT_R8, V_R8(&vDst), fs); \
175 TYPETEST(VT_DATE, V_DATE(&vDst), fs); \
176 if (HAVE_OLEAUT32_I8) \
178 TYPETEST(VT_I8, V_I8(&vDst), fs); \
179 TYPETEST(VT_UI8, V_UI8(&vDst), fs); \
181 #define NEGATIVE_TYPETEST(vt, val, fs, vtneg, valneg) \
183 VariantInit(&vSrc); \
184 VariantInit(&vDst); \
188 TYPETEST(vtneg, valneg(&vDst), fs); \
191 #define INITIAL_TYPETESTI8(vt, val) \
192 VariantInit(&vSrc); \
193 VariantInit(&vDst); \
196 TYPETESTI8(VT_I1, V_I1(&vDst)); \
197 TYPETESTI8(VT_UI1, V_UI1(&vDst)); \
198 TYPETESTI8(VT_I2, V_I2(&vDst)); \
199 TYPETESTI8(VT_UI2, V_UI2(&vDst)); \
200 TYPETESTI8(VT_I4, V_I4(&vDst)); \
201 TYPETESTI8(VT_UI4, V_UI4(&vDst)); \
202 TYPETESTI8(VT_INT, V_INT(&vDst)); \
203 TYPETESTI8(VT_UINT, V_UINT(&vDst)); \
204 TYPETESTI8(VT_R4, V_R4(&vDst)); \
205 TYPETESTI8(VT_R8, V_R8(&vDst)); \
206 TYPETESTI8(VT_DATE, V_DATE(&vDst)); \
207 TYPETESTI8(VT_I8, V_I8(&vDst)); \
208 TYPETESTI8(VT_UI8, V_UI8(&vDst))
210 #define COMMON_TYPETEST \
211 hres = VariantChangeTypeEx(&vDst, &vSrc, 0, 0, VT_BOOL); \
212 ok(hres == S_OK && V_VT(&vDst) == VT_BOOL && \
213 (V_BOOL(&vDst) == VARIANT_TRUE || (V_VT(&vSrc) == VT_BOOL && V_BOOL(&vDst) == 1)), \
214 "->VT_BOOL hres=0x%X, type=%d (should be VT_BOOL), value %d (should be VARIANT_TRUE)\n", \
215 hres, V_VT(&vDst), V_BOOL(&vDst)); \
216 if (HAVE_OLEAUT32_CY) \
218 hres = VariantChangeTypeEx(&vDst, &vSrc, 0, 0, VT_CY); \
219 ok(hres == S_OK && V_VT(&vDst) == VT_CY && V_CY(&vDst).int64 == CY_MULTIPLIER, \
220 "->VT_CY hres=0x%X, type=%d (should be VT_CY), value (%08x,%08x) (should be CY_MULTIPLIER)\n", \
221 hres, V_VT(&vDst), S(V_CY(&vDst)).Hi, S(V_CY(&vDst)).Lo); \
223 if (V_VT(&vSrc) != VT_DATE) \
225 hres = VariantChangeTypeEx(&vDst, &vSrc, 0, 0, VT_BSTR); \
226 ok(hres == S_OK && V_VT(&vDst) == VT_BSTR && \
227 V_BSTR(&vDst) && V_BSTR(&vDst)[0] == '1' && V_BSTR(&vDst)[1] == '\0', \
228 "->VT_BSTR hres=0x%X, type=%d (should be VT_BSTR), *bstr='%c'\n", \
229 hres, V_VT(&vDst), V_BSTR(&vDst) ? *V_BSTR(&vDst) : '?'); \
231 if (HAVE_OLEAUT32_DECIMAL) \
233 hres = VariantChangeTypeEx(&vDst, &vSrc, 0, 0, VT_DECIMAL); \
234 ok(hres == S_OK && V_VT(&vDst) == VT_DECIMAL && \
235 S(U(V_DECIMAL(&vDst))).sign == 0 && S(U(V_DECIMAL(&vDst))).scale == 0 && \
236 V_DECIMAL(&vDst).Hi32 == 0 && U1(V_DECIMAL(&vDst)).Lo64 == (ULONGLONG)in, \
237 "->VT_DECIMAL hres=0x%X, type=%d (should be VT_DECIMAL), sign=%d, scale=%d, hi=%u, lo=(%8x %8x),\n", \
238 hres, V_VT(&vDst), S(U(V_DECIMAL(&vDst))).sign, S(U(V_DECIMAL(&vDst))).scale, \
239 V_DECIMAL(&vDst).Hi32, S1(U1(V_DECIMAL(&vDst))).Mid32, S1(U1(V_DECIMAL(&vDst))).Lo32); \
241 hres = VariantChangeTypeEx(&vDst, &vSrc, 0, 0, VT_EMPTY); \
242 ok(hres == S_OK && V_VT(&vDst) == VT_EMPTY, "->VT_EMPTY hres=0x%X, type=%d (should be VT_EMPTY)\n", hres, V_VT(&vDst)); \
243 hres = VariantChangeTypeEx(&vDst, &vSrc, 0, 0, VT_NULL); \
244 ok(hres == S_OK && V_VT(&vDst) == VT_NULL, "->VT_NULL hres=0x%X, type=%d (should be VT_NULL)\n", hres, V_VT(&vDst)); \
245 MISMATCH(VT_DISPATCH); \
246 MISMATCH(VT_ERROR); \
247 MISMATCH(VT_UNKNOWN); \
248 if (!IS_ANCIENT) { MISMATCH(VT_VARIANT); } else { BADVAR(VT_VARIANT); } \
249 if (HAVE_OLEAUT32_RECORD) \
251 MISMATCH(VT_RECORD); \
254 BADVAR(VT_HRESULT); \
255 BADVAR(VT_SAFEARRAY); \
257 BADVAR(VT_USERDEFINED); \
261 BADVAR(VT_INT_PTR); \
262 BADVAR(VT_UINT_PTR); \
263 BADVAR(VT_FILETIME); \
266 BADVAR(VT_STORAGE); \
267 BADVAR(VT_STREAMED_OBJECT); \
268 BADVAR(VT_STORED_OBJECT); \
269 BADVAR(VT_BLOB_OBJECT); \
274 /* Early versions of oleaut32 are missing many functions */
275 static HRESULT (WINAPI
*pVarI1FromUI1
)(BYTE
,signed char*);
276 static HRESULT (WINAPI
*pVarI1FromI2
)(SHORT
,signed char*);
277 static HRESULT (WINAPI
*pVarI1FromI4
)(LONG
,signed char*);
278 static HRESULT (WINAPI
*pVarI1FromR4
)(FLOAT
,signed char*);
279 static HRESULT (WINAPI
*pVarI1FromR8
)(double,signed char*);
280 static HRESULT (WINAPI
*pVarI1FromDate
)(DATE
,signed char*);
281 static HRESULT (WINAPI
*pVarI1FromCy
)(CY
,signed char*);
282 static HRESULT (WINAPI
*pVarI1FromStr
)(OLECHAR
*,LCID
,ULONG
,signed char*);
283 static HRESULT (WINAPI
*pVarI1FromBool
)(VARIANT_BOOL
,signed char*);
284 static HRESULT (WINAPI
*pVarI1FromUI2
)(USHORT
,signed char*);
285 static HRESULT (WINAPI
*pVarI1FromUI4
)(ULONG
,signed char*);
286 static HRESULT (WINAPI
*pVarI1FromDec
)(DECIMAL
*,signed char*);
287 static HRESULT (WINAPI
*pVarI1FromI8
)(LONG64
,signed char*);
288 static HRESULT (WINAPI
*pVarI1FromUI8
)(ULONG64
,signed char*);
289 static HRESULT (WINAPI
*pVarUI1FromI2
)(SHORT
,BYTE
*);
290 static HRESULT (WINAPI
*pVarUI1FromI4
)(LONG
,BYTE
*);
291 static HRESULT (WINAPI
*pVarUI1FromR4
)(FLOAT
,BYTE
*);
292 static HRESULT (WINAPI
*pVarUI1FromR8
)(double,BYTE
*);
293 static HRESULT (WINAPI
*pVarUI1FromCy
)(CY
,BYTE
*);
294 static HRESULT (WINAPI
*pVarUI1FromDate
)(DATE
,BYTE
*);
295 static HRESULT (WINAPI
*pVarUI1FromStr
)(OLECHAR
*,LCID
,ULONG
,BYTE
*);
296 static HRESULT (WINAPI
*pVarUI1FromBool
)(VARIANT_BOOL
,BYTE
*);
297 static HRESULT (WINAPI
*pVarUI1FromI1
)(signed char,BYTE
*);
298 static HRESULT (WINAPI
*pVarUI1FromUI2
)(USHORT
,BYTE
*);
299 static HRESULT (WINAPI
*pVarUI1FromUI4
)(ULONG
,BYTE
*);
300 static HRESULT (WINAPI
*pVarUI1FromDec
)(DECIMAL
*,BYTE
*);
301 static HRESULT (WINAPI
*pVarUI1FromI8
)(LONG64
,BYTE
*);
302 static HRESULT (WINAPI
*pVarUI1FromUI8
)(ULONG64
,BYTE
*);
303 static HRESULT (WINAPI
*pVarUI1FromDisp
)(IDispatch
*,LCID
,BYTE
*);
305 static HRESULT (WINAPI
*pVarI2FromUI1
)(BYTE
,SHORT
*);
306 static HRESULT (WINAPI
*pVarI2FromI4
)(LONG
,SHORT
*);
307 static HRESULT (WINAPI
*pVarI2FromR4
)(FLOAT
,SHORT
*);
308 static HRESULT (WINAPI
*pVarI2FromR8
)(double,SHORT
*);
309 static HRESULT (WINAPI
*pVarI2FromCy
)(CY
,SHORT
*);
310 static HRESULT (WINAPI
*pVarI2FromDate
)(DATE
,SHORT
*);
311 static HRESULT (WINAPI
*pVarI2FromStr
)(OLECHAR
*,LCID
,ULONG
,SHORT
*);
312 static HRESULT (WINAPI
*pVarI2FromBool
)(VARIANT_BOOL
,SHORT
*);
313 static HRESULT (WINAPI
*pVarI2FromI1
)(signed char,SHORT
*);
314 static HRESULT (WINAPI
*pVarI2FromUI2
)(USHORT
,SHORT
*);
315 static HRESULT (WINAPI
*pVarI2FromUI4
)(ULONG
,SHORT
*);
316 static HRESULT (WINAPI
*pVarI2FromDec
)(DECIMAL
*,SHORT
*);
317 static HRESULT (WINAPI
*pVarI2FromI8
)(LONG64
,SHORT
*);
318 static HRESULT (WINAPI
*pVarI2FromUI8
)(ULONG64
,SHORT
*);
319 static HRESULT (WINAPI
*pVarUI2FromUI1
)(BYTE
,USHORT
*);
320 static HRESULT (WINAPI
*pVarUI2FromI2
)(SHORT
,USHORT
*);
321 static HRESULT (WINAPI
*pVarUI2FromI4
)(LONG
,USHORT
*);
322 static HRESULT (WINAPI
*pVarUI2FromR4
)(FLOAT
,USHORT
*);
323 static HRESULT (WINAPI
*pVarUI2FromR8
)(double,USHORT
*);
324 static HRESULT (WINAPI
*pVarUI2FromDate
)(DATE
,USHORT
*);
325 static HRESULT (WINAPI
*pVarUI2FromCy
)(CY
,USHORT
*);
326 static HRESULT (WINAPI
*pVarUI2FromStr
)(OLECHAR
*,LCID
,ULONG
,USHORT
*);
327 static HRESULT (WINAPI
*pVarUI2FromBool
)(VARIANT_BOOL
,USHORT
*);
328 static HRESULT (WINAPI
*pVarUI2FromI1
)(signed char,USHORT
*);
329 static HRESULT (WINAPI
*pVarUI2FromUI4
)(ULONG
,USHORT
*);
330 static HRESULT (WINAPI
*pVarUI2FromDec
)(DECIMAL
*,USHORT
*);
331 static HRESULT (WINAPI
*pVarUI2FromI8
)(LONG64
,USHORT
*);
332 static HRESULT (WINAPI
*pVarUI2FromUI8
)(ULONG64
,USHORT
*);
334 static HRESULT (WINAPI
*pVarI4FromUI1
)(BYTE
,LONG
*);
335 static HRESULT (WINAPI
*pVarI4FromI2
)(SHORT
,LONG
*);
336 static HRESULT (WINAPI
*pVarI4FromR4
)(FLOAT
,LONG
*);
337 static HRESULT (WINAPI
*pVarI4FromR8
)(DOUBLE
,LONG
*);
338 static HRESULT (WINAPI
*pVarI4FromCy
)(CY
,LONG
*);
339 static HRESULT (WINAPI
*pVarI4FromDate
)(DATE
,LONG
*);
340 static HRESULT (WINAPI
*pVarI4FromStr
)(OLECHAR
*,LCID
,ULONG
,LONG
*);
341 static HRESULT (WINAPI
*pVarI4FromBool
)(VARIANT_BOOL
,LONG
*);
342 static HRESULT (WINAPI
*pVarI4FromI1
)(signed char,LONG
*);
343 static HRESULT (WINAPI
*pVarI4FromUI2
)(USHORT
,LONG
*);
344 static HRESULT (WINAPI
*pVarI4FromUI4
)(ULONG
,LONG
*);
345 static HRESULT (WINAPI
*pVarI4FromDec
)(DECIMAL
*,LONG
*);
346 static HRESULT (WINAPI
*pVarI4FromI8
)(LONG64
,LONG
*);
347 static HRESULT (WINAPI
*pVarI4FromUI8
)(ULONG64
,LONG
*);
348 static HRESULT (WINAPI
*pVarUI4FromUI1
)(BYTE
,ULONG
*);
349 static HRESULT (WINAPI
*pVarUI4FromI2
)(SHORT
,ULONG
*);
350 static HRESULT (WINAPI
*pVarUI4FromI4
)(LONG
,ULONG
*);
351 static HRESULT (WINAPI
*pVarUI4FromR4
)(FLOAT
,ULONG
*);
352 static HRESULT (WINAPI
*pVarUI4FromR8
)(DOUBLE
,ULONG
*);
353 static HRESULT (WINAPI
*pVarUI4FromDate
)(DATE
,ULONG
*);
354 static HRESULT (WINAPI
*pVarUI4FromCy
)(CY
,ULONG
*);
355 static HRESULT (WINAPI
*pVarUI4FromStr
)(OLECHAR
*,LCID
,ULONG
,ULONG
*);
356 static HRESULT (WINAPI
*pVarUI4FromBool
)(VARIANT_BOOL
,ULONG
*);
357 static HRESULT (WINAPI
*pVarUI4FromI1
)(signed char,ULONG
*);
358 static HRESULT (WINAPI
*pVarUI4FromUI2
)(USHORT
,ULONG
*);
359 static HRESULT (WINAPI
*pVarUI4FromDec
)(DECIMAL
*,ULONG
*);
360 static HRESULT (WINAPI
*pVarUI4FromI8
)(LONG64
,ULONG
*);
361 static HRESULT (WINAPI
*pVarUI4FromUI8
)(ULONG64
,ULONG
*);
363 static HRESULT (WINAPI
*pVarI8FromUI1
)(BYTE
,LONG64
*);
364 static HRESULT (WINAPI
*pVarI8FromI2
)(SHORT
,LONG64
*);
365 static HRESULT (WINAPI
*pVarI8FromR4
)(FLOAT
,LONG64
*);
366 static HRESULT (WINAPI
*pVarI8FromR8
)(double,LONG64
*);
367 static HRESULT (WINAPI
*pVarI8FromCy
)(CY
,LONG64
*);
368 static HRESULT (WINAPI
*pVarI8FromDate
)(DATE
,LONG64
*);
369 static HRESULT (WINAPI
*pVarI8FromStr
)(OLECHAR
*,LCID
,ULONG
,LONG64
*);
370 static HRESULT (WINAPI
*pVarI8FromBool
)(VARIANT_BOOL
,LONG64
*);
371 static HRESULT (WINAPI
*pVarI8FromI1
)(signed char,LONG64
*);
372 static HRESULT (WINAPI
*pVarI8FromUI2
)(USHORT
,LONG64
*);
373 static HRESULT (WINAPI
*pVarI8FromUI4
)(ULONG
,LONG64
*);
374 static HRESULT (WINAPI
*pVarI8FromDec
)(DECIMAL
*,LONG64
*);
375 static HRESULT (WINAPI
*pVarI8FromUI8
)(ULONG64
,LONG64
*);
376 static HRESULT (WINAPI
*pVarUI8FromI8
)(LONG64
,ULONG64
*);
377 static HRESULT (WINAPI
*pVarUI8FromUI1
)(BYTE
,ULONG64
*);
378 static HRESULT (WINAPI
*pVarUI8FromI2
)(SHORT
,ULONG64
*);
379 static HRESULT (WINAPI
*pVarUI8FromR4
)(FLOAT
,ULONG64
*);
380 static HRESULT (WINAPI
*pVarUI8FromR8
)(double,ULONG64
*);
381 static HRESULT (WINAPI
*pVarUI8FromCy
)(CY
,ULONG64
*);
382 static HRESULT (WINAPI
*pVarUI8FromDate
)(DATE
,ULONG64
*);
383 static HRESULT (WINAPI
*pVarUI8FromStr
)(OLECHAR
*,LCID
,ULONG
,ULONG64
*);
384 static HRESULT (WINAPI
*pVarUI8FromBool
)(VARIANT_BOOL
,ULONG64
*);
385 static HRESULT (WINAPI
*pVarUI8FromI1
)(signed char,ULONG64
*);
386 static HRESULT (WINAPI
*pVarUI8FromUI2
)(USHORT
,ULONG64
*);
387 static HRESULT (WINAPI
*pVarUI8FromUI4
)(ULONG
,ULONG64
*);
388 static HRESULT (WINAPI
*pVarUI8FromDec
)(DECIMAL
*,ULONG64
*);
390 static HRESULT (WINAPI
*pVarR4FromUI1
)(BYTE
,float*);
391 static HRESULT (WINAPI
*pVarR4FromI2
)(SHORT
,float*);
392 static HRESULT (WINAPI
*pVarR4FromI4
)(LONG
,float*);
393 static HRESULT (WINAPI
*pVarR4FromR8
)(double,float*);
394 static HRESULT (WINAPI
*pVarR4FromCy
)(CY
,float*);
395 static HRESULT (WINAPI
*pVarR4FromDate
)(DATE
,float*);
396 static HRESULT (WINAPI
*pVarR4FromStr
)(OLECHAR
*,LCID
,ULONG
,float*);
397 static HRESULT (WINAPI
*pVarR4FromBool
)(VARIANT_BOOL
,float*);
398 static HRESULT (WINAPI
*pVarR4FromI1
)(signed char,float*);
399 static HRESULT (WINAPI
*pVarR4FromUI2
)(USHORT
,float*);
400 static HRESULT (WINAPI
*pVarR4FromUI4
)(ULONG
,float*);
401 static HRESULT (WINAPI
*pVarR4FromDec
)(DECIMAL
*,float*);
402 static HRESULT (WINAPI
*pVarR4FromI8
)(LONG64
,float*);
403 static HRESULT (WINAPI
*pVarR4FromUI8
)(ULONG64
,float*);
405 static HRESULT (WINAPI
*pVarR8FromUI1
)(BYTE
,double*);
406 static HRESULT (WINAPI
*pVarR8FromI2
)(SHORT
,double*);
407 static HRESULT (WINAPI
*pVarR8FromI4
)(LONG
,double*);
408 static HRESULT (WINAPI
*pVarR8FromR4
)(FLOAT
,double*);
409 static HRESULT (WINAPI
*pVarR8FromCy
)(CY
,double*);
410 static HRESULT (WINAPI
*pVarR8FromDate
)(DATE
,double*);
411 static HRESULT (WINAPI
*pVarR8FromStr
)(OLECHAR
*,LCID
,ULONG
,double*);
412 static HRESULT (WINAPI
*pVarR8FromBool
)(VARIANT_BOOL
,double*);
413 static HRESULT (WINAPI
*pVarR8FromI1
)(signed char,double*);
414 static HRESULT (WINAPI
*pVarR8FromUI2
)(USHORT
,double*);
415 static HRESULT (WINAPI
*pVarR8FromUI4
)(ULONG
,double*);
416 static HRESULT (WINAPI
*pVarR8FromDec
)(DECIMAL
*,double*);
417 static HRESULT (WINAPI
*pVarR8FromI8
)(LONG64
,double*);
418 static HRESULT (WINAPI
*pVarR8FromUI8
)(ULONG64
,double*);
419 static HRESULT (WINAPI
*pVarR8Round
)(double,int,double*);
421 static HRESULT (WINAPI
*pVarDateFromUI1
)(BYTE
,DATE
*);
422 static HRESULT (WINAPI
*pVarDateFromI2
)(SHORT
,DATE
*);
423 static HRESULT (WINAPI
*pVarDateFromI4
)(LONG
,DATE
*);
424 static HRESULT (WINAPI
*pVarDateFromR4
)(FLOAT
,DATE
*);
425 static HRESULT (WINAPI
*pVarDateFromCy
)(CY
,DATE
*);
426 static HRESULT (WINAPI
*pVarDateFromR8
)(double,DATE
*);
427 static HRESULT (WINAPI
*pVarDateFromStr
)(OLECHAR
*,LCID
,ULONG
,DATE
*);
428 static HRESULT (WINAPI
*pVarDateFromBool
)(VARIANT_BOOL
,DATE
*);
429 static HRESULT (WINAPI
*pVarDateFromI1
)(signed char,DATE
*);
430 static HRESULT (WINAPI
*pVarDateFromUI2
)(USHORT
,DATE
*);
431 static HRESULT (WINAPI
*pVarDateFromUI4
)(ULONG
,DATE
*);
432 static HRESULT (WINAPI
*pVarDateFromDec
)(DECIMAL
*,DATE
*);
433 static HRESULT (WINAPI
*pVarDateFromI8
)(LONG64
,DATE
*);
434 static HRESULT (WINAPI
*pVarDateFromUI8
)(ULONG64
,DATE
*);
436 static HRESULT (WINAPI
*pVarCyFromUI1
)(BYTE
,CY
*);
437 static HRESULT (WINAPI
*pVarCyFromI2
)(SHORT
,CY
*);
438 static HRESULT (WINAPI
*pVarCyFromI4
)(LONG
,CY
*);
439 static HRESULT (WINAPI
*pVarCyFromR4
)(FLOAT
,CY
*);
440 static HRESULT (WINAPI
*pVarCyFromR8
)(double,CY
*);
441 static HRESULT (WINAPI
*pVarCyFromDate
)(DATE
,CY
*);
442 static HRESULT (WINAPI
*pVarCyFromBool
)(VARIANT_BOOL
,CY
*);
443 static HRESULT (WINAPI
*pVarCyFromI1
)(signed char,CY
*);
444 static HRESULT (WINAPI
*pVarCyFromUI2
)(USHORT
,CY
*);
445 static HRESULT (WINAPI
*pVarCyFromUI4
)(ULONG
,CY
*);
446 static HRESULT (WINAPI
*pVarCyFromDec
)(DECIMAL
*,CY
*);
447 static HRESULT (WINAPI
*pVarCyFromI8
)(LONG64
,CY
*);
448 static HRESULT (WINAPI
*pVarCyFromUI8
)(ULONG64
,CY
*);
449 static HRESULT (WINAPI
*pVarCyAdd
)(const CY
,const CY
,CY
*);
450 static HRESULT (WINAPI
*pVarCyMul
)(const CY
,const CY
,CY
*);
451 static HRESULT (WINAPI
*pVarCyMulI4
)(const CY
,LONG
,CY
*);
452 static HRESULT (WINAPI
*pVarCySub
)(const CY
,const CY
,CY
*);
453 static HRESULT (WINAPI
*pVarCyAbs
)(const CY
,CY
*);
454 static HRESULT (WINAPI
*pVarCyFix
)(const CY
,CY
*);
455 static HRESULT (WINAPI
*pVarCyInt
)(const CY
,CY
*);
456 static HRESULT (WINAPI
*pVarCyNeg
)(const CY
,CY
*);
457 static HRESULT (WINAPI
*pVarCyRound
)(const CY
,int,CY
*);
458 static HRESULT (WINAPI
*pVarCyCmp
)(const CY
,const CY
);
459 static HRESULT (WINAPI
*pVarCyCmpR8
)(const CY
,double);
460 static HRESULT (WINAPI
*pVarCyMulI8
)(const CY
,LONG64
,CY
*);
462 static HRESULT (WINAPI
*pVarDecFromUI1
)(BYTE
,DECIMAL
*);
463 static HRESULT (WINAPI
*pVarDecFromI2
)(SHORT
,DECIMAL
*);
464 static HRESULT (WINAPI
*pVarDecFromI4
)(LONG
,DECIMAL
*);
465 static HRESULT (WINAPI
*pVarDecFromI8
)(LONG64
,DECIMAL
*);
466 static HRESULT (WINAPI
*pVarDecFromR4
)(FLOAT
,DECIMAL
*);
467 static HRESULT (WINAPI
*pVarDecFromR8
)(DOUBLE
,DECIMAL
*);
468 static HRESULT (WINAPI
*pVarDecFromDate
)(DATE
,DECIMAL
*);
469 static HRESULT (WINAPI
*pVarDecFromStr
)(OLECHAR
*,LCID
,ULONG
,DECIMAL
*);
470 static HRESULT (WINAPI
*pVarDecFromBool
)(VARIANT_BOOL
,DECIMAL
*);
471 static HRESULT (WINAPI
*pVarDecFromI1
)(signed char,DECIMAL
*);
472 static HRESULT (WINAPI
*pVarDecFromUI2
)(USHORT
,DECIMAL
*);
473 static HRESULT (WINAPI
*pVarDecFromUI4
)(ULONG
,DECIMAL
*);
474 static HRESULT (WINAPI
*pVarDecFromUI8
)(ULONG64
,DECIMAL
*);
475 static HRESULT (WINAPI
*pVarDecFromCy
)(CY
,DECIMAL
*);
476 static HRESULT (WINAPI
*pVarDecAbs
)(const DECIMAL
*,DECIMAL
*);
477 static HRESULT (WINAPI
*pVarDecAdd
)(const DECIMAL
*,const DECIMAL
*,DECIMAL
*);
478 static HRESULT (WINAPI
*pVarDecSub
)(const DECIMAL
*,const DECIMAL
*,DECIMAL
*);
479 static HRESULT (WINAPI
*pVarDecMul
)(const DECIMAL
*,const DECIMAL
*,DECIMAL
*);
480 static HRESULT (WINAPI
*pVarDecDiv
)(const DECIMAL
*,const DECIMAL
*,DECIMAL
*);
481 static HRESULT (WINAPI
*pVarDecCmp
)(const DECIMAL
*,const DECIMAL
*);
482 static HRESULT (WINAPI
*pVarDecNeg
)(const DECIMAL
*,DECIMAL
*);
484 static HRESULT (WINAPI
*pVarBoolFromUI1
)(BYTE
,VARIANT_BOOL
*);
485 static HRESULT (WINAPI
*pVarBoolFromI2
)(SHORT
,VARIANT_BOOL
*);
486 static HRESULT (WINAPI
*pVarBoolFromI4
)(LONG
,VARIANT_BOOL
*);
487 static HRESULT (WINAPI
*pVarBoolFromR4
)(FLOAT
,VARIANT_BOOL
*);
488 static HRESULT (WINAPI
*pVarBoolFromR8
)(DOUBLE
,VARIANT_BOOL
*);
489 static HRESULT (WINAPI
*pVarBoolFromDate
)(DATE
,VARIANT_BOOL
*);
490 static HRESULT (WINAPI
*pVarBoolFromCy
)(CY
,VARIANT_BOOL
*);
491 static HRESULT (WINAPI
*pVarBoolFromStr
)(OLECHAR
*,LCID
,ULONG
,VARIANT_BOOL
*);
492 static HRESULT (WINAPI
*pVarBoolFromI1
)(signed char,VARIANT_BOOL
*);
493 static HRESULT (WINAPI
*pVarBoolFromUI2
)(USHORT
,VARIANT_BOOL
*);
494 static HRESULT (WINAPI
*pVarBoolFromUI4
)(ULONG
,VARIANT_BOOL
*);
495 static HRESULT (WINAPI
*pVarBoolFromDec
)(DECIMAL
*,VARIANT_BOOL
*);
496 static HRESULT (WINAPI
*pVarBoolFromI8
)(LONG64
,VARIANT_BOOL
*);
497 static HRESULT (WINAPI
*pVarBoolFromUI8
)(ULONG64
,VARIANT_BOOL
*);
499 static HRESULT (WINAPI
*pVarBstrFromR4
)(FLOAT
,LCID
,ULONG
,BSTR
*);
500 static HRESULT (WINAPI
*pVarBstrFromDate
)(DATE
,LCID
,ULONG
,BSTR
*);
501 static HRESULT (WINAPI
*pVarBstrFromDec
)(DECIMAL
*,LCID
,ULONG
,BSTR
*);
502 static HRESULT (WINAPI
*pVarBstrCmp
)(BSTR
,BSTR
,LCID
,ULONG
);
504 static INT (WINAPI
*pSystemTimeToVariantTime
)(LPSYSTEMTIME
,double*);
505 static void (WINAPI
*pClearCustData
)(LPCUSTDATA
);
507 /* Internal representation of a BSTR */
508 typedef struct tagINTERNAL_BSTR
512 } INTERNAL_BSTR
, *LPINTERNAL_BSTR
;
516 const IDispatchVtbl
*lpVtbl
;
522 static DummyDispatch dispatch
;
524 static ULONG WINAPI
DummyDispatch_AddRef(LPDISPATCH iface
)
526 trace("AddRef(%p)\n", iface
);
527 return InterlockedIncrement(&((DummyDispatch
*)iface
)->ref
);
530 static ULONG WINAPI
DummyDispatch_Release(LPDISPATCH iface
)
532 trace("Release(%p)\n", iface
);
533 return InterlockedDecrement(&((DummyDispatch
*)iface
)->ref
);
536 static HRESULT WINAPI
DummyDispatch_QueryInterface(LPDISPATCH iface
,
540 trace("QueryInterface(%p)\n", iface
);
544 if (IsEqualIID(riid
, &IID_IDispatch
))
546 trace("Asked for IID_IDispatch\n");
549 else if (IsEqualIID(riid
, &IID_IUnknown
))
551 trace("Asked for IID_IUnknown\n");
556 DummyDispatch_AddRef((IDispatch
*)*ppvObject
);
560 return E_NOINTERFACE
;
563 static HRESULT WINAPI
DummyDispatch_Invoke(LPDISPATCH iface
,
564 DISPID dispIdMember
, REFIID riid
,
565 LCID lcid
, WORD wFlags
,
566 DISPPARAMS
*pDispParams
,
568 EXCEPINFO
*pExcepInfo
,
571 trace("Invoke(%p)\n", iface
);
572 ok(wFlags
== DISPATCH_PROPERTYGET
, "Flags wrong\n");
573 ok(pDispParams
->cArgs
== 0, "Property get has args\n");
575 if (dispatch
.bFailInvoke
)
576 return E_OUTOFMEMORY
;
578 memset(pVarResult
, 0, sizeof(*pVarResult
));
579 V_VT(pVarResult
) = dispatch
.vt
;
583 static const IDispatchVtbl DummyDispatch_VTable
=
585 DummyDispatch_QueryInterface
,
586 DummyDispatch_AddRef
,
587 DummyDispatch_Release
,
594 static DummyDispatch dispatch
= { &DummyDispatch_VTable
, 1, 0, 0 };
601 #define CONV_TYPE signed char
603 #define EXPECTRES(res, x) _EXPECTRES(res, x, "%d")
605 static void test_VarI1FromI2(void)
610 CHECKPTR(VarI1FromI2
);
611 OVERFLOWRANGE(VarI1FromI2
, -32768, -128);
612 CONVERTRANGE(VarI1FromI2
, -128, 128);
613 OVERFLOWRANGE(VarI1FromI2
, 129, 32768);
616 static void test_VarI1FromI4(void)
621 CHECKPTR(VarI1FromI4
);
622 CONVERT(VarI1FromI4
, -129); EXPECT_OVERFLOW
;
623 CONVERTRANGE(VarI1FromI4
, -128, 128);
624 CONVERT(VarI1FromI4
, 128); EXPECT_OVERFLOW
;
627 static void test_VarI1FromI8(void)
632 CHECKPTR(VarI1FromI8
);
633 CONVERT(VarI1FromI8
, -129); EXPECT_OVERFLOW
;
634 CONVERTRANGE(VarI1FromI8
, -127, 128);
635 CONVERT(VarI1FromI8
, 128); EXPECT_OVERFLOW
;
638 static void test_VarI1FromUI1(void)
643 CHECKPTR(VarI1FromUI1
);
644 CONVERTRANGE(VarI1FromUI1
, 0, 127);
645 OVERFLOWRANGE(VarI1FromUI1
, 128, 255);
648 static void test_VarI1FromUI2(void)
653 CHECKPTR(VarI1FromUI2
);
654 CONVERTRANGE(VarI1FromUI2
, 0, 127);
655 OVERFLOWRANGE(VarI1FromUI2
, 128, 32768);
658 static void test_VarI1FromUI4(void)
663 CHECKPTR(VarI1FromUI4
);
664 CONVERTRANGE(VarI1FromUI4
, 0, 127);
665 CONVERT(VarI1FromUI4
, 128); EXPECT_OVERFLOW
;
668 static void test_VarI1FromUI8(void)
673 CHECKPTR(VarI1FromUI8
);
674 CONVERTRANGE(VarI1FromUI8
, 0, 127);
675 CONVERT(VarI1FromUI8
, 128); EXPECT_OVERFLOW
;
678 static void test_VarI1FromBool(void)
680 CONVVARS(VARIANT_BOOL
);
683 CHECKPTR(VarI1FromBool
);
684 /* Note that conversions from bool wrap around! */
685 CONVERT(VarI1FromBool
, -129); EXPECT(127);
686 CONVERTRANGE(VarI1FromBool
, -128, 128);
687 CONVERT(VarI1FromBool
, 128); EXPECT(-128);
690 static void test_VarI1FromR4(void)
694 CHECKPTR(VarI1FromR4
);
695 CONVERT(VarI1FromR4
, -129.0f
); EXPECT_OVERFLOW
;
696 CONVERT(VarI1FromR4
, -128.0f
); EXPECT(-128);
697 CONVERT(VarI1FromR4
, -1.0f
); EXPECT(-1);
698 CONVERT(VarI1FromR4
, 0.0f
); EXPECT(0);
699 CONVERT(VarI1FromR4
, 1.0f
); EXPECT(1);
700 CONVERT(VarI1FromR4
, 127.0f
); EXPECT(127);
701 CONVERT(VarI1FromR4
, 128.0f
); EXPECT_OVERFLOW
;
703 CONVERT(VarI1FromR4
, -1.5f
); EXPECT(-2);
704 CONVERT(VarI1FromR4
, -0.6f
); EXPECT(-1);
705 CONVERT(VarI1FromR4
, -0.5f
); EXPECT(0);
706 CONVERT(VarI1FromR4
, -0.4f
); EXPECT(0);
707 CONVERT(VarI1FromR4
, 0.4f
); EXPECT(0);
708 CONVERT(VarI1FromR4
, 0.5f
); EXPECT(0);
709 CONVERT(VarI1FromR4
, 0.6f
); EXPECT(1);
710 CONVERT(VarI1FromR4
, 1.5f
); EXPECT(2);
713 static void test_VarI1FromR8(void)
717 CHECKPTR(VarI1FromR8
);
718 CONVERT(VarI1FromR8
, -129.0); EXPECT_OVERFLOW
;
719 CONVERT(VarI1FromR8
, -128.0); EXPECT(-128);
720 CONVERT(VarI1FromR8
, -1.0); EXPECT(-1);
721 CONVERT(VarI1FromR8
, 0.0); EXPECT(0);
722 CONVERT(VarI1FromR8
, 1.0); EXPECT(1);
723 CONVERT(VarI1FromR8
, 127.0); EXPECT(127);
724 CONVERT(VarI1FromR8
, 128.0); EXPECT_OVERFLOW
;
726 CONVERT(VarI1FromR8
, -1.5); EXPECT(-2);
727 CONVERT(VarI1FromR8
, -0.6); EXPECT(-1);
728 CONVERT(VarI1FromR8
, -0.5); EXPECT(0);
729 CONVERT(VarI1FromR8
, -0.4); EXPECT(0);
730 CONVERT(VarI1FromR8
, 0.4); EXPECT(0);
731 CONVERT(VarI1FromR8
, 0.5); EXPECT(0);
732 CONVERT(VarI1FromR8
, 0.6); EXPECT(1);
733 CONVERT(VarI1FromR8
, 1.5); EXPECT(2);
736 static void test_VarI1FromDate(void)
740 CHECKPTR(VarI1FromDate
);
741 CONVERT(VarI1FromDate
, -129.0); EXPECT_OVERFLOW
;
742 CONVERT(VarI1FromDate
, -128.0); EXPECT(-128);
743 CONVERT(VarI1FromDate
, -1.0); EXPECT(-1);
744 CONVERT(VarI1FromDate
, 0.0); EXPECT(0);
745 CONVERT(VarI1FromDate
, 1.0); EXPECT(1);
746 CONVERT(VarI1FromDate
, 127.0); EXPECT(127);
747 CONVERT(VarI1FromDate
, 128.0); EXPECT_OVERFLOW
;
749 CONVERT(VarI1FromDate
, -1.5); EXPECT(-2);
750 CONVERT(VarI1FromDate
, -0.6); EXPECT(-1);
751 CONVERT(VarI1FromDate
, -0.5); EXPECT(0);
752 CONVERT(VarI1FromDate
, -0.4); EXPECT(0);
753 CONVERT(VarI1FromDate
, 0.4); EXPECT(0);
754 CONVERT(VarI1FromDate
, 0.5); EXPECT(0);
755 CONVERT(VarI1FromDate
, 0.6); EXPECT(1);
756 CONVERT(VarI1FromDate
, 1.5); EXPECT(2);
759 static void test_VarI1FromCy(void)
763 CHECKPTR(VarI1FromCy
);
764 CONVERT_CY(VarI1FromCy
,-129); EXPECT_OVERFLOW
;
765 CONVERT_CY(VarI1FromCy
,-128); EXPECT(128);
766 CONVERT_CY(VarI1FromCy
,-1); EXPECT(-1);
767 CONVERT_CY(VarI1FromCy
,0); EXPECT(0);
768 CONVERT_CY(VarI1FromCy
,1); EXPECT(1);
769 CONVERT_CY(VarI1FromCy
,127); EXPECT(127);
770 CONVERT_CY(VarI1FromCy
,128); EXPECT_OVERFLOW
;
772 CONVERT_CY(VarI1FromCy
,-1.5); EXPECT(-2);
773 CONVERT_CY(VarI1FromCy
,-0.6); EXPECT(-1);
774 CONVERT_CY(VarI1FromCy
,-0.5); EXPECT(0);
775 CONVERT_CY(VarI1FromCy
,-0.4); EXPECT(0);
776 CONVERT_CY(VarI1FromCy
,0.4); EXPECT(0);
777 CONVERT_CY(VarI1FromCy
,0.5); EXPECT(0);
778 CONVERT_CY(VarI1FromCy
,0.6); EXPECT(1);
779 CONVERT_CY(VarI1FromCy
,1.5); EXPECT(2);
782 static void test_VarI1FromDec(void)
786 CHECKPTR(VarI1FromDec
);
788 CONVERT_BADDEC(VarI1FromDec
);
790 CONVERT_DEC(VarI1FromDec
,0,0x80,0,129); EXPECT_OVERFLOW
;
791 CONVERT_DEC(VarI1FromDec
,0,0x80,0,128); EXPECT(-128);
792 CONVERT_DEC(VarI1FromDec
,0,0x80,0,1); EXPECT(-1);
793 CONVERT_DEC(VarI1FromDec
,0,0,0,0); EXPECT(0);
794 CONVERT_DEC(VarI1FromDec
,0,0,0,1); EXPECT(1);
795 CONVERT_DEC(VarI1FromDec
,0,0,0,127); EXPECT(127);
796 CONVERT_DEC(VarI1FromDec
,0,0,0,128); EXPECT_OVERFLOW
;
798 CONVERT_DEC(VarI1FromDec
,2,0x80,0,12800); EXPECT(-128);
799 CONVERT_DEC(VarI1FromDec
,2,0,0,12700); EXPECT(127);
802 static void test_VarI1FromStr(void)
807 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
809 CHECKPTR(VarI1FromStr
);
811 CONVERT_STR(VarI1FromStr
,NULL
, 0); EXPECT_MISMATCH
;
812 CONVERT_STR(VarI1FromStr
,"0", 0); EXPECT(0);
813 CONVERT_STR(VarI1FromStr
,"-129", 0); EXPECT_OVERFLOW
;
814 CONVERT_STR(VarI1FromStr
,"-128", 0); EXPECT(-128);
815 CONVERT_STR(VarI1FromStr
,"127", 0); EXPECT(127);
816 CONVERT_STR(VarI1FromStr
,"128", 0); EXPECT_OVERFLOW
;
818 CONVERT_STR(VarI1FromStr
,"-1.5", LOCALE_NOUSEROVERRIDE
); EXPECT(-2);
819 CONVERT_STR(VarI1FromStr
,"-0.6", LOCALE_NOUSEROVERRIDE
); EXPECT(-1);
820 CONVERT_STR(VarI1FromStr
,"-0.5", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
821 CONVERT_STR(VarI1FromStr
,"-0.4", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
822 CONVERT_STR(VarI1FromStr
,"0.4", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
823 CONVERT_STR(VarI1FromStr
,"0.5", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
824 CONVERT_STR(VarI1FromStr
,"0.6", LOCALE_NOUSEROVERRIDE
); EXPECT(1);
825 CONVERT_STR(VarI1FromStr
,"1.5", LOCALE_NOUSEROVERRIDE
); EXPECT(2);
828 static void test_VarI1Copy(void)
832 COPYTEST(1, VT_I1
, V_I1(&vSrc
), V_I1(&vDst
), V_I1REF(&vSrc
), V_I1REF(&vDst
), "%d");
836 static void test_VarI1ChangeTypeEx(void)
839 VARIANTARG vSrc
, vDst
;
845 INITIAL_TYPETEST(VT_I1
, V_I1
, "%d");
847 NEGATIVE_TYPETEST(VT_I1
, V_I1
, "%d", VT_UI1
, V_UI1
);
852 #define CONV_TYPE BYTE
854 static void test_VarUI1FromI1(void)
856 CONVVARS(signed char);
859 CHECKPTR(VarUI1FromI1
);
860 OVERFLOWRANGE(VarUI1FromI1
, -128, 0);
861 CONVERTRANGE(VarUI1FromI1
, 0, 128);
864 static void test_VarUI1FromI2(void)
869 CHECKPTR(VarUI1FromI2
);
870 OVERFLOWRANGE(VarUI1FromI2
, -32768, 0);
871 CONVERTRANGE(VarUI1FromI2
, 0, 256);
872 OVERFLOWRANGE(VarUI1FromI2
, 256, 32768);
875 static void test_VarUI1FromI4(void)
880 CHECKPTR(VarUI1FromI4
);
881 CONVERT(VarUI1FromI4
, -1); EXPECT_OVERFLOW
;
882 CONVERTRANGE(VarUI1FromI4
, 0, 256);
883 CONVERT(VarUI1FromI4
, 256); EXPECT_OVERFLOW
;
886 static void test_VarUI1FromI8(void)
891 CHECKPTR(VarUI1FromI8
);
892 CONVERT(VarUI1FromI8
, -1); EXPECT_OVERFLOW
;
893 CONVERTRANGE(VarUI1FromI8
, 0, 256);
894 CONVERT(VarUI1FromI8
, 256); EXPECT_OVERFLOW
;
897 static void test_VarUI1FromUI2(void)
902 CHECKPTR(VarUI1FromUI2
);
903 CONVERTRANGE(VarUI1FromUI2
, 0, 256);
904 OVERFLOWRANGE(VarUI1FromUI2
, 256, 65536);
907 static void test_VarUI1FromUI4(void)
912 CHECKPTR(VarUI1FromUI4
);
913 CONVERTRANGE(VarUI1FromUI4
, 0, 256);
914 CONVERT(VarUI1FromUI4
, 256); EXPECT_OVERFLOW
;
917 static void test_VarUI1FromUI8(void)
922 CHECKPTR(VarUI1FromUI8
);
923 CONVERTRANGE(VarUI1FromUI8
, 0, 256);
924 CONVERT(VarUI1FromUI8
, 256); EXPECT_OVERFLOW
;
927 static void test_VarUI1FromBool(void)
929 CONVVARS(VARIANT_BOOL
);
932 CHECKPTR(VarUI1FromBool
);
933 /* Note that conversions from bool overflow! */
934 CONVERT(VarUI1FromBool
, -1); EXPECT(255);
935 CONVERTRANGE(VarUI1FromBool
, 0, 256);
936 CONVERT(VarUI1FromBool
, 256); EXPECT(0);
939 static void test_VarUI1FromR4(void)
943 CHECKPTR(VarUI1FromR4
);
944 CONVERT(VarUI1FromR4
, -1.0f
); EXPECT_OVERFLOW
;
945 CONVERT(VarUI1FromR4
, 0.0f
); EXPECT(0);
946 CONVERT(VarUI1FromR4
, 1.0f
); EXPECT(1);
947 CONVERT(VarUI1FromR4
, 255.0f
); EXPECT(255);
948 CONVERT(VarUI1FromR4
, 256.0f
); EXPECT_OVERFLOW
;
951 CONVERT(VarUI1FromR4
, -1.5f
); EXPECT_OVERFLOW
;
952 CONVERT(VarUI1FromR4
, -0.6f
); EXPECT_OVERFLOW
;
953 CONVERT(VarUI1FromR4
, -0.5f
); EXPECT(0);
954 CONVERT(VarUI1FromR4
, -0.4f
); EXPECT(0);
955 CONVERT(VarUI1FromR4
, 0.4f
); EXPECT(0);
956 CONVERT(VarUI1FromR4
, 0.5f
); EXPECT(0);
957 CONVERT(VarUI1FromR4
, 0.6f
); EXPECT(1);
958 CONVERT(VarUI1FromR4
, 1.5f
); EXPECT(2);
961 static void test_VarUI1FromR8(void)
965 CHECKPTR(VarUI1FromR8
);
966 CONVERT(VarUI1FromR8
, -1.0); EXPECT_OVERFLOW
;
967 CONVERT(VarUI1FromR8
, 0.0); EXPECT(0);
968 CONVERT(VarUI1FromR8
, 1.0); EXPECT(1);
969 CONVERT(VarUI1FromR8
, 255.0); EXPECT(255);
970 CONVERT(VarUI1FromR8
, 256.0); EXPECT_OVERFLOW
;
973 CONVERT(VarUI1FromR8
, -1.5); EXPECT_OVERFLOW
;
974 CONVERT(VarUI1FromR8
, -0.6); EXPECT_OVERFLOW
;
975 CONVERT(VarUI1FromR8
, -0.5); EXPECT(0);
976 CONVERT(VarUI1FromR8
, -0.4); EXPECT(0);
977 CONVERT(VarUI1FromR8
, 0.4); EXPECT(0);
978 CONVERT(VarUI1FromR8
, 0.5); EXPECT(0);
979 CONVERT(VarUI1FromR8
, 0.6); EXPECT(1);
980 CONVERT(VarUI1FromR8
, 1.5); EXPECT(2);
983 static void test_VarUI1FromDate(void)
987 CHECKPTR(VarUI1FromDate
);
988 CONVERT(VarUI1FromDate
, -1.0); EXPECT_OVERFLOW
;
989 CONVERT(VarUI1FromDate
, 0.0); EXPECT(0);
990 CONVERT(VarUI1FromDate
, 1.0); EXPECT(1);
991 CONVERT(VarUI1FromDate
, 255.0); EXPECT(255);
992 CONVERT(VarUI1FromDate
, 256.0); EXPECT_OVERFLOW
;
995 CONVERT(VarUI1FromDate
, -1.5); EXPECT_OVERFLOW
;
996 CONVERT(VarUI1FromDate
, -0.6); EXPECT_OVERFLOW
;
997 CONVERT(VarUI1FromDate
, -0.5); EXPECT(0);
998 CONVERT(VarUI1FromDate
, -0.4); EXPECT(0);
999 CONVERT(VarUI1FromDate
, 0.4); EXPECT(0);
1000 CONVERT(VarUI1FromDate
, 0.5); EXPECT(0);
1001 CONVERT(VarUI1FromDate
, 0.6); EXPECT(1);
1002 CONVERT(VarUI1FromDate
, 1.5); EXPECT(2);
1005 static void test_VarUI1FromCy(void)
1009 CHECKPTR(VarUI1FromCy
);
1010 CONVERT_CY(VarUI1FromCy
,-1); EXPECT_OVERFLOW
;
1011 CONVERT_CY(VarUI1FromCy
,0); EXPECT(0);
1012 CONVERT_CY(VarUI1FromCy
,1); EXPECT(1);
1013 CONVERT_CY(VarUI1FromCy
,255); EXPECT(255);
1014 CONVERT_CY(VarUI1FromCy
,256); EXPECT_OVERFLOW
;
1017 CONVERT_CY(VarUI1FromCy
,-1.5); EXPECT_OVERFLOW
;
1018 CONVERT_CY(VarUI1FromCy
,-0.6); EXPECT_OVERFLOW
;
1019 CONVERT_CY(VarUI1FromCy
,-0.5); EXPECT(0);
1020 CONVERT_CY(VarUI1FromCy
,-0.4); EXPECT(0);
1021 CONVERT_CY(VarUI1FromCy
,0.4); EXPECT(0);
1022 CONVERT_CY(VarUI1FromCy
,0.5); EXPECT(0);
1023 CONVERT_CY(VarUI1FromCy
,0.6); EXPECT(1);
1024 CONVERT_CY(VarUI1FromCy
,1.5); EXPECT(2);
1027 static void test_VarUI1FromDec(void)
1031 CHECKPTR(VarUI1FromDec
);
1033 CONVERT_BADDEC(VarUI1FromDec
);
1035 CONVERT_DEC(VarUI1FromDec
,0,0x80,0,1); EXPECT_OVERFLOW
;
1036 CONVERT_DEC(VarUI1FromDec
,0,0,0,0); EXPECT(0);
1037 CONVERT_DEC(VarUI1FromDec
,0,0,0,1); EXPECT(1);
1038 CONVERT_DEC(VarUI1FromDec
,0,0,0,255); EXPECT(255);
1039 CONVERT_DEC(VarUI1FromDec
,0,0,0,256); EXPECT_OVERFLOW
;
1041 CONVERT_DEC(VarUI1FromDec
,2,0x80,0,100); EXPECT_OVERFLOW
;
1042 CONVERT_DEC(VarUI1FromDec
,2,0,0,25500); EXPECT(255);
1045 static void test_VarUI1FromStr(void)
1050 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
1052 CHECKPTR(VarUI1FromStr
);
1054 CONVERT_STR(VarUI1FromStr
,NULL
, 0); EXPECT_MISMATCH
;
1055 CONVERT_STR(VarUI1FromStr
,"0", 0); EXPECT(0);
1056 CONVERT_STR(VarUI1FromStr
,"-1", 0); EXPECT_OVERFLOW
;
1057 CONVERT_STR(VarUI1FromStr
,"255", 0); EXPECT(255);
1058 CONVERT_STR(VarUI1FromStr
,"256", 0); EXPECT_OVERFLOW
;
1061 CONVERT_STR(VarUI1FromStr
,"-1.5", LOCALE_NOUSEROVERRIDE
); EXPECT_OVERFLOW
;
1062 CONVERT_STR(VarUI1FromStr
,"-0.6", LOCALE_NOUSEROVERRIDE
); EXPECT_OVERFLOW
;
1063 CONVERT_STR(VarUI1FromStr
,"-0.5", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1064 CONVERT_STR(VarUI1FromStr
,"-0.4", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1065 CONVERT_STR(VarUI1FromStr
,"0.4", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1066 CONVERT_STR(VarUI1FromStr
,"0.5", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1067 CONVERT_STR(VarUI1FromStr
,"0.6", LOCALE_NOUSEROVERRIDE
); EXPECT(1);
1068 CONVERT_STR(VarUI1FromStr
,"1.5", LOCALE_NOUSEROVERRIDE
); EXPECT(2);
1071 static void test_VarUI1FromDisp(void)
1074 VARIANTARG vSrc
, vDst
;
1076 CHECKPTR(VarUI1FromDisp
);
1079 * Conversions from IDispatch should get the default 'value' property
1080 * from the IDispatch pointer and return it. The following tests this.
1081 * However, I can't get these tests to return a valid value under native
1082 * oleaut32, regardless of the value returned in response to the Invoke()
1083 * call (early versions of oleaut32 call AddRef/Release, but not Invoke.
1084 * I'm obviously missing something, as these conversions work fine
1085 * when called through VBA on an object to get its default value property.
1087 * Should this test be corrected so that it works under native it should be
1088 * generalised and the remaining types checked as well.
1090 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
1095 V_VT(&vSrc
) = VT_DISPATCH
;
1096 V_DISPATCH(&vSrc
) = (IDispatch
*)&dispatch
;
1097 dispatch
.vt
= VT_UI1
;
1098 dispatch
.bFailInvoke
= FALSE
;
1100 hres
= VarUI1FromDisp((IDispatch
*)&dispatch
, in
, &out
);
1101 trace("0x%08x\n", hres
);
1103 hres
= VariantChangeTypeEx(&vDst
, &vSrc
, in
, 0, VT_UI1
);
1104 trace("0x%08x\n", hres
);
1106 dispatch
.bFailInvoke
= TRUE
;
1108 hres
= VarUI1FromDisp((IDispatch
*)&dispatch
, in
, &out
);
1109 trace("0x%08x\n", hres
);
1111 hres
= VariantChangeTypeEx(&vDst
, &vSrc
, in
, 0, VT_UI1
);
1112 trace("0x%08x\n", hres
);
1115 static void test_VarUI1Copy(void)
1117 COPYTEST(1, VT_UI1
, V_UI1(&vSrc
), V_UI1(&vDst
), V_UI1REF(&vSrc
), V_UI1REF(&vDst
), "%d");
1120 static void test_VarUI1ChangeTypeEx(void)
1122 CONVVARS(CONV_TYPE
);
1123 VARIANTARG vSrc
, vDst
;
1127 INITIAL_TYPETEST(VT_UI1
, V_UI1
, "%d");
1129 NEGATIVE_TYPETEST(VT_UI1
, V_UI1
, "%d", VT_I1
, V_I1
);
1137 #define CONV_TYPE SHORT
1139 #define EXPECTRES(res, x) _EXPECTRES(res, x, "%d")
1141 static void test_VarI2FromI1(void)
1143 CONVVARS(signed char);
1146 CHECKPTR(VarI2FromI1
);
1147 CONVERTRANGE(VarI2FromI1
, -128, 128);
1150 static void test_VarI2FromI4(void)
1155 CHECKPTR(VarI2FromI4
);
1156 CONVERT(VarI2FromI4
, -32769); EXPECT_OVERFLOW
;
1157 CONVERTRANGE(VarI2FromI4
, -32768, 32768);
1158 CONVERT(VarI2FromI4
, 32768); EXPECT_OVERFLOW
;
1161 static void test_VarI2FromI8(void)
1165 CHECKPTR(VarI2FromI8
);
1166 CONVERT(VarI2FromI8
, -32769); EXPECT_OVERFLOW
;
1167 CONVERT(VarI2FromI8
, -32768); EXPECT(-32768);
1168 CONVERT(VarI2FromI8
, 32767); EXPECT(32767);
1169 CONVERT(VarI2FromI8
, 32768); EXPECT_OVERFLOW
;
1172 static void test_VarI2FromUI1(void)
1177 CHECKPTR(VarI2FromUI1
);
1178 CONVERTRANGE(VarI2FromUI1
, 0, 256);
1181 static void test_VarI2FromUI2(void)
1186 CHECKPTR(VarI2FromUI2
);
1187 CONVERTRANGE(VarI2FromUI2
, 0, 32768);
1188 CONVERT(VarI2FromUI2
, 32768); EXPECT_OVERFLOW
;
1191 static void test_VarI2FromUI4(void)
1196 CHECKPTR(VarI2FromUI4
);
1197 CONVERTRANGE(VarI2FromUI4
, 0, 32768);
1198 CONVERT(VarI2FromUI4
, 32768); EXPECT_OVERFLOW
;
1201 static void test_VarI2FromUI8(void)
1206 CHECKPTR(VarI2FromUI8
);
1207 CONVERTRANGE(VarI2FromUI8
, 0, 32768);
1208 CONVERT(VarI2FromUI8
, 32768); EXPECT_OVERFLOW
;
1211 static void test_VarI2FromBool(void)
1213 CONVVARS(VARIANT_BOOL
);
1216 CHECKPTR(VarI2FromBool
);
1217 CONVERTRANGE(VarI2FromBool
, -32768, 32768);
1220 static void test_VarI2FromR4(void)
1224 CHECKPTR(VarI2FromR4
);
1225 CONVERT(VarI2FromR4
, -32769.0f
); EXPECT_OVERFLOW
;
1226 CONVERT(VarI2FromR4
, -32768.0f
); EXPECT(-32768);
1227 CONVERT(VarI2FromR4
, -1.0f
); EXPECT(-1);
1228 CONVERT(VarI2FromR4
, 0.0f
); EXPECT(0);
1229 CONVERT(VarI2FromR4
, 1.0f
); EXPECT(1);
1230 CONVERT(VarI2FromR4
, 32767.0f
); EXPECT(32767);
1231 CONVERT(VarI2FromR4
, 32768.0f
); EXPECT_OVERFLOW
;
1234 CONVERT(VarI2FromR4
, -1.5f
); EXPECT(-2);
1235 CONVERT(VarI2FromR4
, -0.6f
); EXPECT(-1);
1236 CONVERT(VarI2FromR4
, -0.5f
); EXPECT(0);
1237 CONVERT(VarI2FromR4
, -0.4f
); EXPECT(0);
1238 CONVERT(VarI2FromR4
, 0.4f
); EXPECT(0);
1239 CONVERT(VarI2FromR4
, 0.5f
); EXPECT(0);
1240 CONVERT(VarI2FromR4
, 0.6f
); EXPECT(1);
1241 CONVERT(VarI2FromR4
, 1.5f
); EXPECT(2);
1244 static void test_VarI2FromR8(void)
1248 CHECKPTR(VarI2FromR8
);
1249 CONVERT(VarI2FromR8
, -32769.0); EXPECT_OVERFLOW
;
1250 CONVERT(VarI2FromR8
, -32768.0); EXPECT(-32768);
1251 CONVERT(VarI2FromR8
, -1.0); EXPECT(-1);
1252 CONVERT(VarI2FromR8
, 0.0); EXPECT(0);
1253 CONVERT(VarI2FromR8
, 1.0); EXPECT(1);
1254 CONVERT(VarI2FromR8
, 32767.0); EXPECT(32767);
1255 CONVERT(VarI2FromR8
, 32768.0); EXPECT_OVERFLOW
;
1258 CONVERT(VarI2FromR8
, -1.5); EXPECT(-2);
1259 CONVERT(VarI2FromR8
, -0.6); EXPECT(-1);
1260 CONVERT(VarI2FromR8
, -0.5); EXPECT(0);
1261 CONVERT(VarI2FromR8
, -0.4); EXPECT(0);
1262 CONVERT(VarI2FromR8
, 0.4); EXPECT(0);
1263 CONVERT(VarI2FromR8
, 0.5); EXPECT(0);
1264 CONVERT(VarI2FromR8
, 0.6); EXPECT(1);
1265 CONVERT(VarI2FromR8
, 1.5); EXPECT(2);
1268 static void test_VarI2FromDate(void)
1272 CHECKPTR(VarI2FromDate
);
1273 CONVERT(VarI2FromDate
, -32769.0); EXPECT_OVERFLOW
;
1274 CONVERT(VarI2FromDate
, -32768.0); EXPECT(-32768);
1275 CONVERT(VarI2FromDate
, -1.0); EXPECT(-1);
1276 CONVERT(VarI2FromDate
, 0.0); EXPECT(0);
1277 CONVERT(VarI2FromDate
, 1.0); EXPECT(1);
1278 CONVERT(VarI2FromDate
, 32767.0); EXPECT(32767);
1279 CONVERT(VarI2FromDate
, 32768.0); EXPECT_OVERFLOW
;
1282 CONVERT(VarI2FromDate
, -1.5); EXPECT(-2);
1283 CONVERT(VarI2FromDate
, -0.6); EXPECT(-1);
1284 CONVERT(VarI2FromDate
, -0.5); EXPECT(0);
1285 CONVERT(VarI2FromDate
, -0.4); EXPECT(0);
1286 CONVERT(VarI2FromDate
, 0.4); EXPECT(0);
1287 CONVERT(VarI2FromDate
, 0.5); EXPECT(0);
1288 CONVERT(VarI2FromDate
, 0.6); EXPECT(1);
1289 CONVERT(VarI2FromDate
, 1.5); EXPECT(2);
1292 static void test_VarI2FromCy(void)
1296 CHECKPTR(VarI2FromCy
);
1297 CONVERT_CY(VarI2FromCy
,-32769); EXPECT_OVERFLOW
;
1298 CONVERT_CY(VarI2FromCy
,-32768); EXPECT(32768);
1299 CONVERT_CY(VarI2FromCy
,-1); EXPECT(-1);
1300 CONVERT_CY(VarI2FromCy
,0); EXPECT(0);
1301 CONVERT_CY(VarI2FromCy
,1); EXPECT(1);
1302 CONVERT_CY(VarI2FromCy
,32767); EXPECT(32767);
1303 CONVERT_CY(VarI2FromCy
,32768); EXPECT_OVERFLOW
;
1306 CONVERT_CY(VarI2FromCy
,-1.5); EXPECT(-2);
1307 CONVERT_CY(VarI2FromCy
,-0.6); EXPECT(-1);
1308 CONVERT_CY(VarI2FromCy
,-0.5); EXPECT(0);
1309 CONVERT_CY(VarI2FromCy
,-0.4); EXPECT(0);
1310 CONVERT_CY(VarI2FromCy
,0.4); EXPECT(0);
1311 CONVERT_CY(VarI2FromCy
,0.5); EXPECT(0);
1312 CONVERT_CY(VarI2FromCy
,0.6); EXPECT(1);
1313 CONVERT_CY(VarI2FromCy
,1.5); EXPECT(2);
1316 static void test_VarI2FromDec(void)
1320 CHECKPTR(VarI2FromDec
);
1322 CONVERT_BADDEC(VarI2FromDec
);
1324 CONVERT_DEC(VarI2FromDec
,0,0x80,0,32769); EXPECT_OVERFLOW
;
1325 CONVERT_DEC(VarI2FromDec
,0,0x80,0,32768); EXPECT(-32768);
1326 CONVERT_DEC(VarI2FromDec
,0,0x80,0,1); EXPECT(-1);
1327 CONVERT_DEC(VarI2FromDec
,0,0,0,0); EXPECT(0);
1328 CONVERT_DEC(VarI2FromDec
,0,0,0,1); EXPECT(1);
1329 CONVERT_DEC(VarI2FromDec
,0,0,0,32767); EXPECT(32767);
1330 CONVERT_DEC(VarI2FromDec
,0,0,0,32768); EXPECT_OVERFLOW
;
1332 CONVERT_DEC(VarI2FromDec
,2,0x80,0,3276800); EXPECT(-32768);
1333 CONVERT_DEC(VarI2FromDec
,2,0,0,3276700); EXPECT(32767);
1334 CONVERT_DEC(VarI2FromDec
,2,0,0,3276800); EXPECT_OVERFLOW
;
1337 static void test_VarI2FromStr(void)
1342 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
1344 CHECKPTR(VarI2FromStr
);
1346 CONVERT_STR(VarI2FromStr
,NULL
, 0); EXPECT_MISMATCH
;
1347 CONVERT_STR(VarI2FromStr
,"0", 0); EXPECT(0);
1348 CONVERT_STR(VarI2FromStr
,"-32769", 0); EXPECT_OVERFLOW
;
1349 CONVERT_STR(VarI2FromStr
,"-32768", 0); EXPECT(-32768);
1350 CONVERT_STR(VarI2FromStr
,"32767", 0); EXPECT(32767);
1351 CONVERT_STR(VarI2FromStr
,"32768", 0); EXPECT_OVERFLOW
;
1354 CONVERT_STR(VarI2FromStr
,"-1.5", LOCALE_NOUSEROVERRIDE
); EXPECT(-2);
1355 CONVERT_STR(VarI2FromStr
,"-0.6", LOCALE_NOUSEROVERRIDE
); EXPECT(-1);
1356 CONVERT_STR(VarI2FromStr
,"-0.5", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1357 CONVERT_STR(VarI2FromStr
,"-0.4", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1358 CONVERT_STR(VarI2FromStr
,"0.4", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1359 CONVERT_STR(VarI2FromStr
,"0.5", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1360 CONVERT_STR(VarI2FromStr
,"0.6", LOCALE_NOUSEROVERRIDE
); EXPECT(1);
1361 CONVERT_STR(VarI2FromStr
,"1.5", LOCALE_NOUSEROVERRIDE
); EXPECT(2);
1364 static void test_VarI2Copy(void)
1366 COPYTEST(1, VT_I2
, V_I2(&vSrc
), V_I2(&vDst
), V_I2REF(&vSrc
), V_I2REF(&vDst
), "%d");
1369 static void test_VarI2ChangeTypeEx(void)
1371 CONVVARS(CONV_TYPE
);
1372 VARIANTARG vSrc
, vDst
;
1376 INITIAL_TYPETEST(VT_I2
, V_I2
, "%d");
1378 NEGATIVE_TYPETEST(VT_I2
, V_I2
, "%d", VT_UI2
, V_UI2
);
1382 #define CONV_TYPE USHORT
1384 static void test_VarUI2FromI1(void)
1386 CONVVARS(signed char);
1389 CHECKPTR(VarUI2FromI1
);
1390 OVERFLOWRANGE(VarUI2FromI1
, -128, 0);
1391 CONVERTRANGE(VarUI2FromI1
, 0, 128);
1394 static void test_VarUI2FromI2(void)
1399 CHECKPTR(VarUI2FromI2
);
1400 OVERFLOWRANGE(VarUI2FromI2
, -32768, 0);
1401 CONVERTRANGE(VarUI2FromI2
, 0, 32768);
1404 static void test_VarUI2FromI4(void)
1409 CHECKPTR(VarUI2FromI4
);
1410 OVERFLOWRANGE(VarUI2FromI4
, -32768, 0);
1411 CONVERT(VarUI2FromI4
, 0); EXPECT(0);
1412 CONVERT(VarUI2FromI4
, 65535); EXPECT(65535);
1413 CONVERT(VarUI2FromI4
, 65536); EXPECT_OVERFLOW
;
1416 static void test_VarUI2FromI8(void)
1421 CHECKPTR(VarUI2FromI8
);
1422 OVERFLOWRANGE(VarUI2FromI8
, -32768, 0);
1423 CONVERT(VarUI2FromI8
, 0); EXPECT(0);
1424 CONVERT(VarUI2FromI8
, 65535); EXPECT(65535);
1425 CONVERT(VarUI2FromI8
, 65536); EXPECT_OVERFLOW
;
1428 static void test_VarUI2FromUI1(void)
1433 CHECKPTR(VarUI2FromUI1
);
1434 CONVERTRANGE(VarUI2FromUI1
, 0, 256);
1437 static void test_VarUI2FromUI4(void)
1441 CHECKPTR(VarUI2FromUI4
);
1442 CONVERT(VarUI2FromUI4
, 0); EXPECT(0);
1443 CONVERT(VarUI2FromUI4
, 65535); EXPECT(65535);
1444 CONVERT(VarUI2FromUI4
, 65536); EXPECT_OVERFLOW
;
1447 static void test_VarUI2FromUI8(void)
1451 CHECKPTR(VarUI2FromUI8
);
1452 CONVERT(VarUI2FromUI8
, 0); EXPECT(0);
1453 CONVERT(VarUI2FromUI8
, 65535); EXPECT(65535);
1454 CONVERT(VarUI2FromUI8
, 65536); EXPECT_OVERFLOW
;
1457 static void test_VarUI2FromBool(void)
1459 CONVVARS(VARIANT_BOOL
);
1462 CHECKPTR(VarUI2FromBool
);
1463 CONVERT(VarUI2FromBool
, -1); EXPECT(65535); /* Wraps! */
1464 CONVERTRANGE(VarUI2FromBool
, 0, 32768);
1467 static void test_VarUI2FromR4(void)
1471 CHECKPTR(VarUI2FromR4
);
1472 CONVERT(VarUI2FromR4
, -1.0f
); EXPECT_OVERFLOW
;
1473 CONVERT(VarUI2FromR4
, 0.0f
); EXPECT(0);
1474 CONVERT(VarUI2FromR4
, 1.0f
); EXPECT(1);
1475 CONVERT(VarUI2FromR4
, 65535.0f
); EXPECT(65535);
1476 CONVERT(VarUI2FromR4
, 65536.0f
); EXPECT_OVERFLOW
;
1479 CONVERT(VarUI2FromR4
, -1.5f
); EXPECT_OVERFLOW
;
1480 CONVERT(VarUI2FromR4
, -0.6f
); EXPECT_OVERFLOW
;
1481 CONVERT(VarUI2FromR4
, -0.5f
); EXPECT(0);
1482 CONVERT(VarUI2FromR4
, -0.4f
); EXPECT(0);
1483 CONVERT(VarUI2FromR4
, 0.4f
); EXPECT(0);
1484 CONVERT(VarUI2FromR4
, 0.5f
); EXPECT(0);
1485 CONVERT(VarUI2FromR4
, 0.6f
); EXPECT(1);
1486 CONVERT(VarUI2FromR4
, 1.5f
); EXPECT(2);
1489 static void test_VarUI2FromR8(void)
1493 CHECKPTR(VarUI2FromR8
);
1494 CONVERT(VarUI2FromR8
, -1.0); EXPECT_OVERFLOW
;
1495 CONVERT(VarUI2FromR8
, 0.0); EXPECT(0);
1496 CONVERT(VarUI2FromR8
, 1.0); EXPECT(1);
1497 CONVERT(VarUI2FromR8
, 65535.0); EXPECT(65535);
1498 CONVERT(VarUI2FromR8
, 65536.0); EXPECT_OVERFLOW
;
1501 CONVERT(VarUI2FromR8
, -1.5); EXPECT_OVERFLOW
;
1502 CONVERT(VarUI2FromR8
, -0.6); EXPECT_OVERFLOW
;
1503 CONVERT(VarUI2FromR8
, -0.5); EXPECT(0);
1504 CONVERT(VarUI2FromR8
, -0.4); EXPECT(0);
1505 CONVERT(VarUI2FromR8
, 0.4); EXPECT(0);
1506 CONVERT(VarUI2FromR8
, 0.5); EXPECT(0);
1507 CONVERT(VarUI2FromR8
, 0.6); EXPECT(1);
1508 CONVERT(VarUI2FromR8
, 1.5); EXPECT(2);
1511 static void test_VarUI2FromDate(void)
1515 CHECKPTR(VarUI2FromDate
);
1516 CONVERT(VarUI2FromDate
, -1.0); EXPECT_OVERFLOW
;
1517 CONVERT(VarUI2FromDate
, 0.0); EXPECT(0);
1518 CONVERT(VarUI2FromDate
, 1.0); EXPECT(1);
1519 CONVERT(VarUI2FromDate
, 65535.0); EXPECT(65535);
1520 CONVERT(VarUI2FromDate
, 65536.0); EXPECT_OVERFLOW
;
1523 CONVERT(VarUI2FromDate
, -1.5); EXPECT_OVERFLOW
;
1524 CONVERT(VarUI2FromDate
, -0.6); EXPECT_OVERFLOW
;
1525 CONVERT(VarUI2FromDate
, -0.5); EXPECT(0);
1526 CONVERT(VarUI2FromDate
, -0.4); EXPECT(0);
1527 CONVERT(VarUI2FromDate
, 0.4); EXPECT(0);
1528 CONVERT(VarUI2FromDate
, 0.5); EXPECT(0);
1529 CONVERT(VarUI2FromDate
, 0.6); EXPECT(1);
1530 CONVERT(VarUI2FromDate
, 1.5); EXPECT(2);
1533 static void test_VarUI2FromCy(void)
1537 CHECKPTR(VarUI2FromCy
);
1538 CONVERT_CY(VarUI2FromCy
,-1); EXPECT_OVERFLOW
;
1539 CONVERT_CY(VarUI2FromCy
,0); EXPECT(0);
1540 CONVERT_CY(VarUI2FromCy
,1); EXPECT(1);
1541 CONVERT_CY(VarUI2FromCy
,65535); EXPECT(65535);
1542 CONVERT_CY(VarUI2FromCy
,65536); EXPECT_OVERFLOW
;
1545 CONVERT_CY(VarUI2FromCy
,-1.5); EXPECT_OVERFLOW
;
1546 CONVERT_CY(VarUI2FromCy
,-0.6); EXPECT_OVERFLOW
;
1547 CONVERT_CY(VarUI2FromCy
,-0.5); EXPECT(0);
1548 CONVERT_CY(VarUI2FromCy
,-0.4); EXPECT(0);
1549 CONVERT_CY(VarUI2FromCy
,0.4); EXPECT(0);
1550 CONVERT_CY(VarUI2FromCy
,0.5); EXPECT(0);
1551 CONVERT_CY(VarUI2FromCy
,0.6); EXPECT(1);
1552 CONVERT_CY(VarUI2FromCy
,1.5); EXPECT(2);
1555 static void test_VarUI2FromDec(void)
1559 CHECKPTR(VarUI2FromDec
);
1561 CONVERT_BADDEC(VarUI2FromDec
);
1563 CONVERT_DEC(VarUI2FromDec
,0,0x80,0,1); EXPECT_OVERFLOW
;
1564 CONVERT_DEC(VarUI2FromDec
,0,0,0,0); EXPECT(0);
1565 CONVERT_DEC(VarUI2FromDec
,0,0,0,1); EXPECT(1);
1566 CONVERT_DEC(VarUI2FromDec
,0,0,0,65535); EXPECT(65535);
1567 CONVERT_DEC(VarUI2FromDec
,0,0,0,65536); EXPECT_OVERFLOW
;
1569 CONVERT_DEC(VarUI2FromDec
,2,0x80,0,100); EXPECT_OVERFLOW
;
1570 CONVERT_DEC(VarUI2FromDec
,2,0,0,6553500); EXPECT(65535);
1571 CONVERT_DEC(VarUI2FromDec
,2,0,0,6553600); EXPECT_OVERFLOW
;
1574 static void test_VarUI2FromStr(void)
1579 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
1581 CHECKPTR(VarUI2FromStr
);
1583 CONVERT_STR(VarUI2FromStr
,NULL
, 0); EXPECT_MISMATCH
;
1584 CONVERT_STR(VarUI2FromStr
,"0", 0); EXPECT(0);
1585 CONVERT_STR(VarUI2FromStr
,"-1", 0); EXPECT_OVERFLOW
;
1586 CONVERT_STR(VarUI2FromStr
,"65535", 0); EXPECT(65535);
1587 CONVERT_STR(VarUI2FromStr
,"65536", 0); EXPECT_OVERFLOW
;
1590 CONVERT_STR(VarUI2FromStr
,"-1.5", LOCALE_NOUSEROVERRIDE
); EXPECT_OVERFLOW
;
1591 CONVERT_STR(VarUI2FromStr
,"-0.6", LOCALE_NOUSEROVERRIDE
); EXPECT_OVERFLOW
;
1592 CONVERT_STR(VarUI2FromStr
,"-0.5", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1593 CONVERT_STR(VarUI2FromStr
,"-0.4", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1594 CONVERT_STR(VarUI2FromStr
,"0.4", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1595 CONVERT_STR(VarUI2FromStr
,"0.5", LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1596 CONVERT_STR(VarUI2FromStr
,"0.6", LOCALE_NOUSEROVERRIDE
); EXPECT(1);
1597 CONVERT_STR(VarUI2FromStr
,"1.5", LOCALE_NOUSEROVERRIDE
); EXPECT(2);
1600 static void test_VarUI2Copy(void)
1604 COPYTEST(1, VT_UI2
, V_UI2(&vSrc
), V_UI2(&vDst
), V_UI2REF(&vSrc
), V_UI2REF(&vDst
), "%d");
1608 static void test_VarUI2ChangeTypeEx(void)
1610 CONVVARS(CONV_TYPE
);
1611 VARIANTARG vSrc
, vDst
;
1617 INITIAL_TYPETEST(VT_UI2
, V_UI2
, "%d");
1619 NEGATIVE_TYPETEST(VT_UI2
, V_UI2
, "%d", VT_I2
, V_I2
);
1628 #define CONV_TYPE LONG
1630 #define EXPECTRES(res, x) _EXPECTRES(res, x, "%d")
1633 static void test_VarI4FromI1(void)
1635 CONVVARS(signed char);
1638 CHECKPTR(VarI4FromI1
);
1639 CONVERTRANGE(VarI4FromI1
, -128, 128);
1642 static void test_VarI4FromI2(void)
1647 CHECKPTR(VarI4FromI2
);
1648 CONVERTRANGE(VarI4FromI2
, -32768, 32768);
1651 static void test_VarI4FromI8(void)
1655 CHECKPTR(VarI4FromI8
);
1656 CHECKPTR(VarI4FromDec
);
1658 CONVERT(VarI4FromI8
, -1); EXPECT(-1);
1659 CONVERT(VarI4FromI8
, 0); EXPECT(0);
1660 CONVERT(VarI4FromI8
, 1); EXPECT(1);
1662 CONVERT_I8(VarI4FromI8
, -1, 2147483647ul); EXPECT_OVERFLOW
;
1663 CONVERT_I8(VarI4FromI8
, -1, 2147483648ul); EXPECT(-2147483647 - 1);
1664 CONVERT_I8(VarI4FromI8
, 0, 2147483647ul); EXPECT(2147483647);
1665 CONVERT_I8(VarI4FromI8
, 0, 2147483648ul); EXPECT_OVERFLOW
;
1668 static void test_VarI4FromUI1(void)
1673 CHECKPTR(VarI4FromUI1
);
1674 CONVERTRANGE(VarI4FromUI1
, 0, 256);
1677 static void test_VarI4FromUI2(void)
1682 CHECKPTR(VarI4FromUI2
);
1683 CONVERTRANGE(VarI4FromUI2
, 0, 65536);
1686 static void test_VarI4FromUI4(void)
1690 CHECKPTR(VarI4FromUI4
);
1691 CONVERT(VarI4FromUI4
, 0); EXPECT(0);
1692 CONVERT(VarI4FromUI4
, 1); EXPECT(1);
1693 CONVERT(VarI4FromUI4
, 2147483647); EXPECT(2147483647);
1694 CONVERT(VarI4FromUI4
, 2147483648ul); EXPECT_OVERFLOW
;
1697 static void test_VarI4FromUI8(void)
1701 CHECKPTR(VarI4FromUI8
);
1702 CONVERT(VarI4FromUI8
, 0); EXPECT(0);
1703 CONVERT(VarI4FromUI8
, 1); EXPECT(1);
1704 CONVERT(VarI4FromUI8
, 2147483647); EXPECT(2147483647);
1705 CONVERT(VarI4FromUI8
, 2147483648ul); EXPECT_OVERFLOW
;
1708 static void test_VarI4FromBool(void)
1710 CONVVARS(VARIANT_BOOL
);
1713 CHECKPTR(VarI4FromBool
);
1714 CONVERTRANGE(VarI4FromBool
, -32768, 32768);
1717 static void test_VarI4FromR4(void)
1721 CHECKPTR(VarI4FromR4
);
1723 /* min/max values are not exactly representable in a float */
1724 CONVERT(VarI4FromR4
, -1.0f
); EXPECT(-1);
1725 CONVERT(VarI4FromR4
, 0.0f
); EXPECT(0);
1726 CONVERT(VarI4FromR4
, 1.0f
); EXPECT(1);
1728 CONVERT(VarI4FromR4
, -1.5f
); EXPECT(-2);
1729 CONVERT(VarI4FromR4
, -0.6f
); EXPECT(-1);
1730 CONVERT(VarI4FromR4
, -0.5f
); EXPECT(0);
1731 CONVERT(VarI4FromR4
, -0.4f
); EXPECT(0);
1732 CONVERT(VarI4FromR4
, 0.4f
); EXPECT(0);
1733 CONVERT(VarI4FromR4
, 0.5f
); EXPECT(0);
1734 CONVERT(VarI4FromR4
, 0.6f
); EXPECT(1);
1735 CONVERT(VarI4FromR4
, 1.5f
); EXPECT(2);
1738 static void test_VarI4FromR8(void)
1742 CHECKPTR(VarI4FromR8
);
1743 CONVERT(VarI4FromR8
, -2147483649.0); EXPECT_OVERFLOW
;
1744 CONVERT(VarI4FromR8
, -2147483648.0); EXPECT(-2147483647 - 1);
1745 CONVERT(VarI4FromR8
, -1.0); EXPECT(-1);
1746 CONVERT(VarI4FromR8
, 0.0); EXPECT(0);
1747 CONVERT(VarI4FromR8
, 1.0); EXPECT(1);
1748 CONVERT(VarI4FromR8
, 2147483647.0); EXPECT(2147483647);
1749 CONVERT(VarI4FromR8
, 2147483648.0); EXPECT_OVERFLOW
;
1751 CONVERT(VarI4FromR8
, -1.5); EXPECT(-2);
1752 CONVERT(VarI4FromR8
, -0.6); EXPECT(-1);
1753 CONVERT(VarI4FromR8
, -0.5); EXPECT(0);
1754 CONVERT(VarI4FromR8
, -0.4); EXPECT(0);
1755 CONVERT(VarI4FromR8
, 0.4); EXPECT(0);
1756 CONVERT(VarI4FromR8
, 0.5); EXPECT(0);
1757 CONVERT(VarI4FromR8
, 0.6); EXPECT(1);
1758 CONVERT(VarI4FromR8
, 1.5); EXPECT(2);
1761 static void test_VarI4FromDate(void)
1765 CHECKPTR(VarI4FromDate
);
1766 CONVERT(VarI4FromDate
, -2147483649.0); EXPECT_OVERFLOW
;
1767 CONVERT(VarI4FromDate
, -2147483648.0); EXPECT(-2147483647 - 1);
1768 CONVERT(VarI4FromDate
, -1.0); EXPECT(-1);
1769 CONVERT(VarI4FromDate
, 0.0); EXPECT(0);
1770 CONVERT(VarI4FromDate
, 1.0); EXPECT(1);
1771 CONVERT(VarI4FromDate
, 2147483647.0); EXPECT(2147483647);
1772 CONVERT(VarI4FromDate
, 2147483648.0); EXPECT_OVERFLOW
;
1774 CONVERT(VarI4FromDate
, -1.5); EXPECT(-2);
1775 CONVERT(VarI4FromDate
, -0.6); EXPECT(-1);
1776 CONVERT(VarI4FromDate
, -0.5); EXPECT(0);
1777 CONVERT(VarI4FromDate
, -0.4); EXPECT(0);
1778 CONVERT(VarI4FromDate
, 0.4); EXPECT(0);
1779 CONVERT(VarI4FromDate
, 0.5); EXPECT(0);
1780 CONVERT(VarI4FromDate
, 0.6); EXPECT(1);
1781 CONVERT(VarI4FromDate
, 1.5); EXPECT(2);
1784 static void test_VarI4FromCy(void)
1788 CHECKPTR(VarI4FromCy
);
1789 CONVERT_CY(VarI4FromCy
,-1); EXPECT(-1);
1790 CONVERT_CY(VarI4FromCy
,0); EXPECT(0);
1791 CONVERT_CY(VarI4FromCy
,1); EXPECT(1);
1793 CONVERT_CY64(VarI4FromCy
,-1,2147483647ul); EXPECT_OVERFLOW
;
1794 CONVERT_CY64(VarI4FromCy
,-1,2147483648ul); EXPECT(-2147483647 - 1);
1795 CONVERT_CY64(VarI4FromCy
,0,2147483647ul); EXPECT(2147483647ul);
1796 CONVERT_CY64(VarI4FromCy
,0,2147483648ul); EXPECT_OVERFLOW
;
1798 CONVERT_CY(VarI4FromCy
,-1.5); EXPECT(-2);
1799 CONVERT_CY(VarI4FromCy
,-0.6); EXPECT(-1);
1800 CONVERT_CY(VarI4FromCy
,-0.5); EXPECT(0);
1801 CONVERT_CY(VarI4FromCy
,-0.4); EXPECT(0);
1802 CONVERT_CY(VarI4FromCy
,0.4); EXPECT(0);
1803 CONVERT_CY(VarI4FromCy
,0.5); EXPECT(0);
1804 CONVERT_CY(VarI4FromCy
,0.6); EXPECT(1);
1805 CONVERT_CY(VarI4FromCy
,1.5); EXPECT(2);
1808 static void test_VarI4FromDec(void)
1812 CHECKPTR(VarI4FromDec
);
1814 CONVERT_BADDEC(VarI4FromDec
);
1816 CONVERT_DEC(VarI4FromDec
,0,0x80,0,1); EXPECT(-1);
1817 CONVERT_DEC(VarI4FromDec
,0,0,0,0); EXPECT(0);
1818 CONVERT_DEC(VarI4FromDec
,0,0,0,1); EXPECT(1);
1820 CONVERT_DEC64(VarI4FromDec
,0,0x80,0,0,2147483649ul); EXPECT_OVERFLOW
;
1821 CONVERT_DEC64(VarI4FromDec
,0,0x80,0,0,2147483648ul); EXPECT(-2147483647 - 1);
1822 CONVERT_DEC64(VarI4FromDec
,0,0,0,0,2147483647ul); EXPECT(2147483647ul);
1823 CONVERT_DEC64(VarI4FromDec
,0,0,0,0,2147483648ul); EXPECT_OVERFLOW
;
1825 CONVERT_DEC64(VarI4FromDec
,2,0x80,0,50,100); EXPECT_OVERFLOW
;
1826 CONVERT_DEC64(VarI4FromDec
,2,0x80,0,50,0); EXPECT(-2147483647 - 1);
1827 CONVERT_DEC64(VarI4FromDec
,2,0,0,49,4294967196ul); EXPECT(2147483647);
1828 CONVERT_DEC64(VarI4FromDec
,2,0,0,50,0); EXPECT_OVERFLOW
;
1831 static void test_VarI4FromStr(void)
1836 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
1838 CHECKPTR(VarI4FromStr
);
1840 CONVERT_STR(VarI4FromStr
,NULL
,0); EXPECT_MISMATCH
;
1841 CONVERT_STR(VarI4FromStr
,"0",0); EXPECT(0);
1842 CONVERT_STR(VarI4FromStr
,"-2147483649",0); EXPECT_OVERFLOW
;
1843 CONVERT_STR(VarI4FromStr
,"-2147483648",0); EXPECT(-2147483647 -1);
1844 CONVERT_STR(VarI4FromStr
,"2147483647",0); EXPECT(2147483647);
1845 CONVERT_STR(VarI4FromStr
,"2147483648",0); EXPECT_OVERFLOW
;
1848 CONVERT_STR(VarI4FromStr
,"-1.5",LOCALE_NOUSEROVERRIDE
); EXPECT(-2);
1849 CONVERT_STR(VarI4FromStr
,"-0.6",LOCALE_NOUSEROVERRIDE
); EXPECT(-1);
1850 CONVERT_STR(VarI4FromStr
,"-0.5",LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1851 CONVERT_STR(VarI4FromStr
,"-0.4",LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1852 CONVERT_STR(VarI4FromStr
,"0.4",LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1853 CONVERT_STR(VarI4FromStr
,"0.5",LOCALE_NOUSEROVERRIDE
); EXPECT(0);
1854 CONVERT_STR(VarI4FromStr
,"0.6",LOCALE_NOUSEROVERRIDE
); EXPECT(1);
1855 CONVERT_STR(VarI4FromStr
,"1.5",LOCALE_NOUSEROVERRIDE
); EXPECT(2);
1858 static void test_VarI4Copy(void)
1860 COPYTEST(1, VT_I4
, V_I4(&vSrc
), V_I4(&vDst
), V_I4REF(&vSrc
), V_I4REF(&vDst
), "%d");
1863 static void test_VarI4ChangeTypeEx(void)
1865 CONVVARS(CONV_TYPE
);
1866 VARIANTARG vSrc
, vDst
;
1870 INITIAL_TYPETEST(VT_I4
, V_I4
, "%d");
1872 NEGATIVE_TYPETEST(VT_I4
, V_I4
, "%d", VT_UI4
, V_UI4
);
1876 #define CONV_TYPE ULONG
1878 #define EXPECTRES(res, x) _EXPECTRES(res, x, "%u")
1880 static void test_VarUI4FromI1(void)
1882 CONVVARS(signed char);
1885 CHECKPTR(VarUI4FromI1
);
1886 OVERFLOWRANGE(VarUI4FromI1
, -127, 0);
1887 CONVERTRANGE(VarUI4FromI1
, 0, 128);
1890 static void test_VarUI4FromI2(void)
1895 CHECKPTR(VarUI4FromI2
);
1896 OVERFLOWRANGE(VarUI4FromI2
, -32768, 0);
1897 CONVERTRANGE(VarUI4FromI2
, 0, 32768);
1900 static void test_VarUI4FromUI2(void)
1905 CHECKPTR(VarUI4FromUI2
);
1906 CONVERTRANGE(VarUI4FromUI2
, 0, 65536);
1909 static void test_VarUI4FromI8(void)
1913 CHECKPTR(VarUI4FromI8
);
1914 CONVERT(VarUI4FromI8
, -1); EXPECT_OVERFLOW
;
1915 CONVERT(VarUI4FromI8
, 0); EXPECT(0);
1916 CONVERT(VarUI4FromI8
, 1); EXPECT(1);
1917 CONVERT(VarUI4FromI8
, 4294967295ul); EXPECT(4294967295ul);
1918 CONVERT_I8(VarUI4FromI8
, 1, 0); EXPECT_OVERFLOW
;
1921 static void test_VarUI4FromUI1(void)
1926 CHECKPTR(VarUI4FromUI1
);
1927 CONVERTRANGE(VarUI4FromUI1
, 0, 256);
1930 static void test_VarUI4FromI4(void)
1934 CHECKPTR(VarUI4FromI4
);
1935 CONVERT(VarUI4FromI4
, -1); EXPECT_OVERFLOW
;
1936 CONVERT(VarUI4FromI4
, 0); EXPECT(0);
1937 CONVERT(VarUI4FromI4
, 1); EXPECT(1);
1938 CONVERT(VarUI4FromI4
, 2147483647); EXPECT(2147483647);
1941 static void test_VarUI4FromUI8(void)
1945 CHECKPTR(VarUI4FromUI8
);
1946 CONVERT(VarUI4FromUI8
, 0); EXPECT(0);
1947 CONVERT(VarUI4FromUI8
, 1); EXPECT(1);
1948 CONVERT(VarUI4FromI8
, 4294967295ul); EXPECT(4294967295ul);
1949 CONVERT_I8(VarUI4FromI8
, 1, 0); EXPECT_OVERFLOW
;
1952 static void test_VarUI4FromBool(void)
1954 CONVVARS(VARIANT_BOOL
);
1957 CHECKPTR(VarUI4FromBool
);
1958 CONVERTRANGE(VarUI4FromBool
, -32768, 32768);
1961 static void test_VarUI4FromR4(void)
1965 CHECKPTR(VarUI4FromR4
);
1966 /* We can't test max values as they are not exactly representable in a float */
1967 CONVERT(VarUI4FromR4
, -1.0f
); EXPECT_OVERFLOW
;
1968 CONVERT(VarUI4FromR4
, 0.0f
); EXPECT(0);
1969 CONVERT(VarUI4FromR4
, 1.0f
); EXPECT(1);
1971 CONVERT(VarUI4FromR4
, -1.5f
); EXPECT_OVERFLOW
;
1972 CONVERT(VarUI4FromR4
, -0.6f
); EXPECT_OVERFLOW
;
1973 CONVERT(VarUI4FromR4
, -0.5f
); EXPECT(0);
1974 CONVERT(VarUI4FromR4
, -0.4f
); EXPECT(0);
1975 CONVERT(VarUI4FromR4
, 0.4f
); EXPECT(0);
1976 CONVERT(VarUI4FromR4
, 0.5f
); EXPECT(0);
1977 CONVERT(VarUI4FromR4
, 0.6f
); EXPECT(1);
1978 CONVERT(VarUI4FromR4
, 1.5f
); EXPECT(2);
1982 static void test_VarUI4FromR8(void)
1986 CHECKPTR(VarUI4FromR8
);
1987 CONVERT(VarUI4FromR8
, -1.0); EXPECT_OVERFLOW
;
1988 CONVERT(VarUI4FromR8
, 0.0); EXPECT(0);
1989 CONVERT(VarUI4FromR8
, 1.0); EXPECT(1);
1990 CONVERT(VarUI4FromR8
, 4294967295.0); EXPECT(4294967295ul);
1991 CONVERT(VarUI4FromR8
, 4294967296.0); EXPECT_OVERFLOW
;
1993 CONVERT(VarUI4FromR8
, -1.5); EXPECT_OVERFLOW
;
1994 CONVERT(VarUI4FromR8
, -0.6); EXPECT_OVERFLOW
;
1995 CONVERT(VarUI4FromR8
, -0.5); EXPECT(0);
1996 CONVERT(VarUI4FromR8
, -0.4); EXPECT(0);
1997 CONVERT(VarUI4FromR8
, 0.4); EXPECT(0);
1998 CONVERT(VarUI4FromR8
, 0.5); EXPECT(0);
1999 CONVERT(VarUI4FromR8
, 0.6); EXPECT(1);
2000 CONVERT(VarUI4FromR8
, 1.5); EXPECT(2);
2003 static void test_VarUI4FromDate(void)
2007 CHECKPTR(VarUI4FromDate
);
2008 CONVERT(VarUI4FromDate
, -1.0); EXPECT_OVERFLOW
;
2009 CONVERT(VarUI4FromDate
, 0.0); EXPECT(0);
2010 CONVERT(VarUI4FromDate
, 1.0); EXPECT(1);
2011 CONVERT(VarUI4FromDate
, 4294967295.0); EXPECT(4294967295ul);
2012 CONVERT(VarUI4FromDate
, 4294967296.0); EXPECT_OVERFLOW
;
2014 CONVERT(VarUI4FromDate
, -1.5); EXPECT_OVERFLOW
;
2015 CONVERT(VarUI4FromDate
, -0.6); EXPECT_OVERFLOW
;
2016 CONVERT(VarUI4FromDate
, -0.5); EXPECT(0);
2017 CONVERT(VarUI4FromDate
, -0.4); EXPECT(0);
2018 CONVERT(VarUI4FromDate
, 0.4); EXPECT(0);
2019 CONVERT(VarUI4FromDate
, 0.5); EXPECT(0);
2020 CONVERT(VarUI4FromDate
, 0.6); EXPECT(1);
2021 CONVERT(VarUI4FromDate
, 1.5); EXPECT(2);
2024 static void test_VarUI4FromCy(void)
2028 CHECKPTR(VarUI4FromCy
);
2029 CONVERT_CY(VarUI4FromCy
,-1); EXPECT_OVERFLOW
;
2030 CONVERT_CY(VarUI4FromCy
,0); EXPECT(0);
2031 CONVERT_CY(VarUI4FromCy
,1); EXPECT(1);
2032 CONVERT_CY64(VarUI4FromCy
,0,4294967295ul); EXPECT(4294967295ul);
2033 CONVERT_CY64(VarUI4FromCy
,1,0); EXPECT_OVERFLOW
;
2035 CONVERT_CY(VarUI4FromCy
,-1.5); EXPECT_OVERFLOW
;
2036 CONVERT_CY(VarUI4FromCy
,-0.6); EXPECT_OVERFLOW
;
2037 CONVERT_CY(VarUI4FromCy
,-0.5); EXPECT(0);
2038 CONVERT_CY(VarUI4FromCy
,-0.4); EXPECT(0);
2039 CONVERT_CY(VarUI4FromCy
,0.4); EXPECT(0);
2040 CONVERT_CY(VarUI4FromCy
,0.5); EXPECT(0);
2041 CONVERT_CY(VarUI4FromCy
,0.6); EXPECT(1);
2042 CONVERT_CY(VarUI4FromCy
,1.5); EXPECT(2);
2045 static void test_VarUI4FromDec(void)
2049 CHECKPTR(VarUI4FromDec
);
2051 CONVERT_BADDEC(VarUI4FromDec
);
2053 CONVERT_DEC(VarUI4FromDec
,0,0x80,0,1); EXPECT_OVERFLOW
;
2054 CONVERT_DEC(VarUI4FromDec
,0,0,0,0); EXPECT(0);
2055 CONVERT_DEC(VarUI4FromDec
,0,0,0,1); EXPECT(1);
2056 CONVERT_DEC64(VarUI4FromDec
,0,0,0,0,4294967295ul); EXPECT(4294967295ul);
2057 CONVERT_DEC64(VarUI4FromDec
,0,0,0,1,0); EXPECT_OVERFLOW
;
2059 CONVERT_DEC64(VarUI4FromDec
,2,0,0,99,4294967196ul); EXPECT(4294967295ul);
2060 CONVERT_DEC64(VarUI4FromDec
,2,0,0,100,0); EXPECT_OVERFLOW
;
2063 static void test_VarUI4FromStr(void)
2068 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
2070 CHECKPTR(VarUI4FromStr
);
2072 CONVERT_STR(VarUI4FromStr
,NULL
,0); EXPECT_MISMATCH
;
2073 CONVERT_STR(VarUI4FromStr
,"-1",0); EXPECT_OVERFLOW
;
2074 CONVERT_STR(VarUI4FromStr
,"0",0); EXPECT(0);
2075 CONVERT_STR(VarUI4FromStr
,"4294967295",0); EXPECT(4294967295ul);
2076 CONVERT_STR(VarUI4FromStr
,"4294967296",0); EXPECT_OVERFLOW
;
2079 CONVERT_STR(VarUI4FromStr
,"-1.5",LOCALE_NOUSEROVERRIDE
); EXPECT_OVERFLOW
;
2080 CONVERT_STR(VarUI4FromStr
,"-0.6",LOCALE_NOUSEROVERRIDE
); EXPECT_OVERFLOW
;
2081 CONVERT_STR(VarUI4FromStr
,"-0.5",LOCALE_NOUSEROVERRIDE
); EXPECT(0);
2082 CONVERT_STR(VarUI4FromStr
,"-0.4",LOCALE_NOUSEROVERRIDE
); EXPECT(0);
2083 CONVERT_STR(VarUI4FromStr
,"0.4",LOCALE_NOUSEROVERRIDE
); EXPECT(0);
2084 CONVERT_STR(VarUI4FromStr
,"0.5",LOCALE_NOUSEROVERRIDE
); EXPECT(0);
2085 CONVERT_STR(VarUI4FromStr
,"0.6",LOCALE_NOUSEROVERRIDE
); EXPECT(1);
2086 CONVERT_STR(VarUI4FromStr
,"1.5",LOCALE_NOUSEROVERRIDE
); EXPECT(2);
2089 static void test_VarUI4Copy(void)
2093 COPYTEST(1u, VT_UI4
, V_UI4(&vSrc
), V_UI4(&vDst
), V_UI4REF(&vSrc
), V_UI4REF(&vDst
), "%u");
2097 static void test_VarUI4ChangeTypeEx(void)
2099 CONVVARS(CONV_TYPE
);
2100 VARIANTARG vSrc
, vDst
;
2106 INITIAL_TYPETEST(VT_UI4
, V_UI4
, "%u");
2108 NEGATIVE_TYPETEST(VT_UI4
, V_UI4
, "%u", VT_I4
, V_I4
);
2117 #define CONV_TYPE LONG64
2119 #define EXPECTRES(res, x) \
2120 ok(hres == S_OK || ((HRESULT)res != S_OK && hres == (HRESULT)res), \
2121 "expected hres " #x ", got hres=0x%08x\n", hres)
2123 #define EXPECTI8(x) \
2124 ok((hres == S_OK && out == (CONV_TYPE)(x)), \
2125 "expected " #x "(%u,%u), got (%u,%u); hres=0x%08x\n", \
2126 (ULONG)((LONG64)(x) >> 32), (ULONG)((x) & 0xffffffff), \
2127 (ULONG)(out >> 32), (ULONG)(out & 0xffffffff), hres)
2129 #define EXPECTI864(x,y) \
2130 ok(hres == S_OK && (out >> 32) == (CONV_TYPE)(x) && (out & 0xffffffff) == (CONV_TYPE)(y), \
2131 "expected " #x "(%u,%u), got (%u,%u); hres=0x%08x\n", \
2132 (ULONG)(x), (ULONG)(y), \
2133 (ULONG)(out >> 32), (ULONG)(out & 0xffffffff), hres)
2135 static void test_VarI8FromI1(void)
2137 CONVVARS(signed char);
2140 CHECKPTR(VarI8FromI1
);
2141 for (i
= -128; i
< 128; i
++)
2143 CONVERT(VarI8FromI1
,i
); EXPECTI8(i
);
2147 static void test_VarI8FromUI1(void)
2152 CHECKPTR(VarI8FromUI1
);
2153 for (i
= 0; i
< 256; i
++)
2155 CONVERT(VarI8FromUI1
,i
); EXPECTI8(i
);
2159 static void test_VarI8FromI2(void)
2164 CHECKPTR(VarI8FromI2
);
2165 for (i
= -32768; i
< 32768; i
++)
2167 CONVERT(VarI8FromI2
,i
); EXPECTI8(i
);
2171 static void test_VarI8FromUI2(void)
2176 CHECKPTR(VarI8FromUI2
);
2177 for (i
= -0; i
< 65535; i
++)
2179 CONVERT(VarI8FromUI2
,i
); EXPECTI8(i
);
2183 static void test_VarI8FromUI4(void)
2187 CHECKPTR(VarI8FromUI4
);
2188 CONVERT(VarI8FromUI4
, 0); EXPECTI8(0);
2189 CONVERT(VarI8FromUI4
, 1); EXPECTI8(1);
2190 CONVERT(VarI8FromUI4
, 4294967295ul); EXPECTI8(4294967295ul);
2193 static void test_VarI8FromR4(void)
2197 CHECKPTR(VarI8FromR4
);
2199 CONVERT(VarI8FromR4
, -128.0f
); EXPECTI8(-128);
2200 CONVERT(VarI8FromR4
, -1.0f
); EXPECTI8(-1);
2201 CONVERT(VarI8FromR4
, 0.0f
); EXPECTI8(0);
2202 CONVERT(VarI8FromR4
, 1.0f
); EXPECTI8(1);
2203 CONVERT(VarI8FromR4
, 127.0f
); EXPECTI8(127);
2205 CONVERT(VarI8FromR4
, -1.5f
); EXPECTI8(-2);
2206 CONVERT(VarI8FromR4
, -0.6f
); EXPECTI8(-1);
2207 CONVERT(VarI8FromR4
, -0.5f
); EXPECTI8(0);
2208 CONVERT(VarI8FromR4
, -0.4f
); EXPECTI8(0);
2209 CONVERT(VarI8FromR4
, 0.4f
); EXPECTI8(0);
2210 CONVERT(VarI8FromR4
, 0.5f
); EXPECTI8(0);
2211 CONVERT(VarI8FromR4
, 0.6f
); EXPECTI8(1);
2212 CONVERT(VarI8FromR4
, 1.5f
); EXPECTI8(2);
2215 static void test_VarI8FromR8(void)
2219 CHECKPTR(VarI8FromR8
);
2220 CONVERT(VarI8FromR8
, -128.0); EXPECTI8(-128);
2221 CONVERT(VarI8FromR8
, -1.0); EXPECTI8(-1);
2222 CONVERT(VarI8FromR8
, 0.0); EXPECTI8(0);
2223 CONVERT(VarI8FromR8
, 1.0); EXPECTI8(1);
2224 CONVERT(VarI8FromR8
, 127.0); EXPECTI8(127);
2226 CONVERT(VarI8FromR8
, -1.5); EXPECTI8(-2);
2227 CONVERT(VarI8FromR8
, -0.6); EXPECTI8(-1);
2228 CONVERT(VarI8FromR8
, -0.5); EXPECTI8(0);
2229 CONVERT(VarI8FromR8
, -0.4); EXPECTI8(0);
2230 CONVERT(VarI8FromR8
, 0.4); EXPECTI8(0);
2231 CONVERT(VarI8FromR8
, 0.5); EXPECTI8(0);
2232 CONVERT(VarI8FromR8
, 0.6); EXPECTI8(1);
2233 CONVERT(VarI8FromR8
, 1.5); EXPECTI8(2);
2236 static void test_VarI8FromDate(void)
2240 CHECKPTR(VarI8FromDate
);
2241 CONVERT(VarI8FromDate
, -128.0); EXPECTI8(-128);
2242 CONVERT(VarI8FromDate
, -1.0); EXPECTI8(-1);
2243 CONVERT(VarI8FromDate
, 0.0); EXPECTI8(0);
2244 CONVERT(VarI8FromDate
, 1.0); EXPECTI8(1);
2245 CONVERT(VarI8FromDate
, 127.0); EXPECTI8(127);
2247 CONVERT(VarI8FromDate
, -1.5); EXPECTI8(-2);
2248 CONVERT(VarI8FromDate
, -0.6); EXPECTI8(-1);
2249 CONVERT(VarI8FromDate
, -0.5); EXPECTI8(0);
2250 CONVERT(VarI8FromDate
, -0.4); EXPECTI8(0);
2251 CONVERT(VarI8FromDate
, 0.4); EXPECTI8(0);
2252 CONVERT(VarI8FromDate
, 0.5); EXPECTI8(0);
2253 CONVERT(VarI8FromDate
, 0.6); EXPECTI8(1);
2254 CONVERT(VarI8FromDate
, 1.5); EXPECTI8(2);
2257 static void test_VarI8FromBool(void)
2259 CONVVARS(VARIANT_BOOL
);
2262 CHECKPTR(VarI8FromBool
);
2263 for (i
= -32768; i
< 32768; i
++)
2265 CONVERT(VarI8FromBool
,i
); EXPECTI8(i
);
2269 static void test_VarI8FromUI8(void)
2273 CHECKPTR(VarI8FromUI8
);
2274 CONVERT(VarI8FromUI8
, 0); EXPECTI8(0);
2275 CONVERT(VarI8FromUI8
, 1); EXPECTI8(1);
2276 CONVERT_I8(VarI8FromUI8
, 0x7fffffff, 0xffffffff); EXPECTI864(0x7fffffff, 0xffffffff);
2277 CONVERT_I8(VarI8FromUI8
, 0x80000000, 0); EXPECT_OVERFLOW
;
2280 static void test_VarI8FromCy(void)
2284 CHECKPTR(VarI8FromCy
);
2285 CONVERT_CY(VarI8FromCy
,-128); EXPECTI8(-129);
2286 CONVERT_CY(VarI8FromCy
,-1); EXPECTI8(-2);
2287 CONVERT_CY(VarI8FromCy
,0); EXPECTI8(0);
2288 CONVERT_CY(VarI8FromCy
,1); EXPECTI8(1);
2289 CONVERT_CY(VarI8FromCy
,127); EXPECTI8(127);
2291 CONVERT_CY(VarI8FromCy
,-1.5); EXPECTI8(-2);
2292 CONVERT_CY(VarI8FromCy
,-0.6); EXPECTI8(-1);
2293 CONVERT_CY(VarI8FromCy
,-0.5); EXPECTI8(-1);
2294 CONVERT_CY(VarI8FromCy
,-0.4); EXPECTI8(-1);
2295 CONVERT_CY(VarI8FromCy
,0.4); EXPECTI8(0);
2296 CONVERT_CY(VarI8FromCy
,0.5); EXPECTI8(0);
2297 CONVERT_CY(VarI8FromCy
,0.6); EXPECTI8(1);
2298 CONVERT_CY(VarI8FromCy
,1.5); EXPECTI8(2);
2301 static void test_VarI8FromDec(void)
2305 CHECKPTR(VarI8FromDec
);
2307 CONVERT_BADDEC(VarI8FromDec
);
2309 CONVERT_DEC(VarI8FromDec
,0,0x80,0,128); EXPECTI8(-128);
2310 CONVERT_DEC(VarI8FromDec
,0,0x80,0,1); EXPECTI8(-1);
2311 CONVERT_DEC(VarI8FromDec
,0,0,0,0); EXPECTI8(0);
2312 CONVERT_DEC(VarI8FromDec
,0,0,0,1); EXPECTI8(1);
2313 CONVERT_DEC(VarI8FromDec
,0,0,0,127); EXPECTI8(127);
2315 CONVERT_DEC(VarI8FromDec
,2,0x80,0,12700); EXPECTI8(-127);
2316 CONVERT_DEC(VarI8FromDec
,2,0,0,12700); EXPECTI8(127);
2319 static void test_VarI8FromStr(void)
2324 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
2326 CHECKPTR(VarI8FromStr
);
2328 CONVERT_STR(VarI8FromStr
,NULL
,0); EXPECT_MISMATCH
;
2329 CONVERT_STR(VarI8FromStr
,"0",0); EXPECTI8(0);
2330 CONVERT_STR(VarI8FromStr
,"-1",0); EXPECTI8(-1);
2331 CONVERT_STR(VarI8FromStr
,"2147483647",0); EXPECTI8(2147483647);
2333 CONVERT_STR(VarI8FromStr
,"-1.5",LOCALE_NOUSEROVERRIDE
); EXPECTI8(-2);
2334 CONVERT_STR(VarI8FromStr
,"-0.6",LOCALE_NOUSEROVERRIDE
); EXPECTI8(-1);
2335 CONVERT_STR(VarI8FromStr
,"-0.5",LOCALE_NOUSEROVERRIDE
); EXPECTI8(0);
2336 CONVERT_STR(VarI8FromStr
,"-0.4",LOCALE_NOUSEROVERRIDE
); EXPECTI8(0);
2337 CONVERT_STR(VarI8FromStr
,"0.4",LOCALE_NOUSEROVERRIDE
); EXPECTI8(0);
2338 CONVERT_STR(VarI8FromStr
,"0.5",LOCALE_NOUSEROVERRIDE
); EXPECTI8(0);
2339 CONVERT_STR(VarI8FromStr
,"0.6",LOCALE_NOUSEROVERRIDE
); EXPECTI8(1);
2340 CONVERT_STR(VarI8FromStr
,"1.5",LOCALE_NOUSEROVERRIDE
); EXPECTI8(2);
2343 static void test_VarI8Copy(void)
2346 VARIANTARG vSrc
, vDst
;
2349 if (!HAVE_OLEAUT32_I8
)
2351 skip("I8 and UI8 data types are not available\n");
2357 V_VT(&vSrc
) = VT_I8
;
2359 hres
= VariantCopy(&vDst
, &vSrc
);
2360 ok(hres
== S_OK
&& V_VT(&vDst
) == VT_I8
&& V_I8(&vDst
) == in
,
2361 "copy hres 0x%X, type %d, value (%x%08x) %x%08x\n",
2362 hres
, V_VT(&vDst
), (UINT
)(in
>> 32), (UINT
)in
, (UINT
)(V_I8(&vDst
) >> 32), (UINT
)V_I8(&vDst
) );
2363 V_VT(&vSrc
) = VT_I8
|VT_BYREF
;
2364 V_I8REF(&vSrc
) = &in
;
2365 hres
= VariantCopy(&vDst
, &vSrc
);
2366 ok(hres
== S_OK
&& V_VT(&vDst
) == (VT_I8
|VT_BYREF
) && V_I8REF(&vDst
) == &in
,
2367 "ref hres 0x%X, type %d, ref (%p) %p\n", hres
, V_VT(&vDst
), &in
, V_I8REF(&vDst
));
2368 hres
= VariantCopyInd(&vDst
, &vSrc
);
2369 ok(hres
== S_OK
&& V_VT(&vDst
) == VT_I8
&& V_I8(&vDst
) == in
,
2370 "copy hres 0x%X, type %d, value (%x%08x) %x%08x\n",
2371 hres
, V_VT(&vDst
), (UINT
)(in
>> 32), (UINT
)in
, (UINT
)(V_I8(&vDst
) >> 32), (UINT
)V_I8(&vDst
) );
2374 static void test_VarI8ChangeTypeEx(void)
2376 CONVVARS(CONV_TYPE
);
2377 VARIANTARG vSrc
, vDst
;
2379 if (!HAVE_OLEAUT32_I8
)
2381 skip("I8 and UI8 data types are not available\n");
2387 INITIAL_TYPETESTI8(VT_I8
, V_I8
);
2391 /* Adapt the test macros to UI8 */
2393 #define CONV_TYPE ULONG64
2395 static void test_VarUI8FromI1(void)
2397 CONVVARS(signed char);
2400 CHECKPTR(VarUI8FromI1
);
2401 for (i
= -128; i
< 128; i
++)
2403 CONVERT(VarUI8FromI1
,i
);
2411 static void test_VarUI8FromUI1(void)
2416 CHECKPTR(VarUI8FromUI1
);
2417 for (i
= 0; i
< 256; i
++)
2419 CONVERT(VarUI8FromUI1
,i
); EXPECTI8(i
);
2423 static void test_VarUI8FromI2(void)
2428 CHECKPTR(VarUI8FromI2
);
2429 for (i
= -32768; i
< 32768; i
++)
2431 CONVERT(VarUI8FromI2
,i
);
2439 static void test_VarUI8FromUI2(void)
2444 CHECKPTR(VarUI8FromUI2
);
2445 for (i
= 0; i
< 65535; i
++)
2447 CONVERT(VarUI8FromUI2
,i
); EXPECTI8(i
);
2451 static void test_VarUI8FromUI4(void)
2455 CHECKPTR(VarUI8FromUI4
);
2456 CONVERT(VarUI8FromUI4
, 0); EXPECTI8(0);
2457 CONVERT(VarUI8FromUI4
, 0xffffffff); EXPECTI8(0xffffffff);
2460 static void test_VarUI8FromR4(void)
2464 CHECKPTR(VarUI8FromR4
);
2465 CONVERT(VarUI8FromR4
, -1.0f
); EXPECT_OVERFLOW
;
2466 CONVERT(VarUI8FromR4
, 0.0f
); EXPECTI8(0);
2467 CONVERT(VarUI8FromR4
, 1.0f
); EXPECTI8(1);
2468 CONVERT(VarUI8FromR4
, 255.0f
); EXPECTI8(255);
2470 CONVERT(VarUI8FromR4
, -1.5f
); EXPECT_OVERFLOW
;
2471 CONVERT(VarUI8FromR4
, -0.6f
); EXPECT_OVERFLOW
;
2472 CONVERT(VarUI8FromR4
, -0.5f
); EXPECTI8(0);
2473 CONVERT(VarUI8FromR4
, -0.4f
); EXPECTI8(0);
2474 CONVERT(VarUI8FromR4
, 0.4f
); EXPECTI8(0);
2475 CONVERT(VarUI8FromR4
, 0.5f
); EXPECTI8(0);
2476 CONVERT(VarUI8FromR4
, 0.6f
); EXPECTI8(1);
2477 CONVERT(VarUI8FromR4
, 1.5f
); EXPECTI8(2);
2480 static void test_VarUI8FromR8(void)
2484 CHECKPTR(VarUI8FromR8
);
2485 CONVERT(VarUI8FromR8
, -1.0); EXPECT_OVERFLOW
;
2486 CONVERT(VarUI8FromR8
, 0.0); EXPECTI8(0);
2487 CONVERT(VarUI8FromR8
, 1.0); EXPECTI8(1);
2488 CONVERT(VarUI8FromR8
, 255.0); EXPECTI8(255);
2490 CONVERT(VarUI8FromR8
, -1.5); EXPECT_OVERFLOW
;
2491 CONVERT(VarUI8FromR8
, -0.6); EXPECT_OVERFLOW
;
2492 CONVERT(VarUI8FromR8
, -0.5); EXPECTI8(0);
2493 CONVERT(VarUI8FromR8
, -0.4); EXPECTI8(0);
2494 CONVERT(VarUI8FromR8
, 0.4); EXPECTI8(0);
2495 CONVERT(VarUI8FromR8
, 0.5); EXPECTI8(0);
2496 CONVERT(VarUI8FromR8
, 0.6); EXPECTI8(1);
2497 CONVERT(VarUI8FromR8
, 1.5); EXPECTI8(2);
2500 static void test_VarUI8FromDate(void)
2504 CHECKPTR(VarUI8FromDate
);
2505 CONVERT(VarUI8FromDate
, -1.0); EXPECT_OVERFLOW
;
2506 CONVERT(VarUI8FromDate
, 0.0); EXPECTI8(0);
2507 CONVERT(VarUI8FromDate
, 1.0); EXPECTI8(1);
2508 CONVERT(VarUI8FromDate
, 255.0); EXPECTI8(255);
2510 CONVERT(VarUI8FromDate
, -1.5); EXPECT_OVERFLOW
;
2511 CONVERT(VarUI8FromDate
, -0.6); EXPECT_OVERFLOW
;
2512 CONVERT(VarUI8FromDate
, -0.5); EXPECTI8(0);
2513 CONVERT(VarUI8FromDate
, -0.4); EXPECTI8(0);
2514 CONVERT(VarUI8FromDate
, 0.4); EXPECTI8(0);
2515 CONVERT(VarUI8FromDate
, 0.5); EXPECTI8(0);
2516 CONVERT(VarUI8FromDate
, 0.6); EXPECTI8(1);
2517 CONVERT(VarUI8FromDate
, 1.5); EXPECTI8(2);
2520 static void test_VarUI8FromBool(void)
2522 CONVVARS(VARIANT_BOOL
);
2525 CHECKPTR(VarUI8FromBool
);
2526 CONVERTRANGE(VarUI8FromBool
, -32768, 32768);
2529 static void test_VarUI8FromI8(void)
2533 CHECKPTR(VarUI8FromI8
);
2534 CONVERT(VarUI8FromI8
, -1); EXPECT_OVERFLOW
;
2535 CONVERT(VarUI8FromI8
, 0); EXPECTI8(0);
2536 CONVERT(VarUI8FromI8
, 1); EXPECTI8(1);
2539 static void test_VarUI8FromCy(void)
2543 CHECKPTR(VarUI8FromCy
);
2544 CONVERT_CY(VarUI8FromCy
,-1); EXPECT_OVERFLOW
;
2545 CONVERT_CY(VarUI8FromCy
,0); EXPECTI8(0);
2546 CONVERT_CY(VarUI8FromCy
,1); EXPECTI8(1);
2547 CONVERT_CY(VarUI8FromCy
,255); EXPECTI8(255);
2549 CONVERT_CY(VarUI8FromCy
,-1.5); EXPECT_OVERFLOW
;
2550 CONVERT_CY(VarUI8FromCy
,-0.6); EXPECT_OVERFLOW
;
2551 CONVERT_CY(VarUI8FromCy
,-0.5); EXPECTI8(0);
2552 CONVERT_CY(VarUI8FromCy
,-0.4); EXPECTI8(0);
2553 CONVERT_CY(VarUI8FromCy
,0.4); EXPECTI8(0);
2554 CONVERT_CY(VarUI8FromCy
,0.5); EXPECTI8(0);
2555 CONVERT_CY(VarUI8FromCy
,0.6); EXPECTI8(1);
2556 CONVERT_CY(VarUI8FromCy
,1.5); EXPECTI8(2);
2559 static void test_VarUI8FromDec(void)
2563 CHECKPTR(VarUI8FromDec
);
2565 CONVERT_BADDEC(VarUI8FromDec
);
2567 /* This returns 1 under native; Wine fixes this bug and returns overflow */
2570 CONVERT_DEC(VarUI8FromDec
,0,0x80,0,1);
2573 CONVERT_DEC(VarUI8FromDec
,0,0,0,0); EXPECTI8(0);
2574 CONVERT_DEC(VarUI8FromDec
,0,0,0,1); EXPECTI8(1);
2575 CONVERT_DEC(VarUI8FromDec
,0,0,0,255); EXPECTI8(255);
2577 CONVERT_DEC(VarUI8FromDec
,2,0x80,0,100); EXPECT_OVERFLOW
;
2578 CONVERT_DEC(VarUI8FromDec
,2,0,0,25500); EXPECTI8(255);
2581 static void test_VarUI8FromStr(void)
2586 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
2588 CHECKPTR(VarUI8FromStr
);
2590 CONVERT_STR(VarUI8FromStr
,NULL
,0); EXPECT_MISMATCH
;
2591 CONVERT_STR(VarUI8FromStr
,"0",0); EXPECTI8(0);
2592 CONVERT_STR(VarUI8FromStr
,"-1",0); EXPECT_OVERFLOW
;
2593 CONVERT_STR(VarUI8FromStr
,"2147483647",0); EXPECTI8(2147483647);
2595 CONVERT_STR(VarUI8FromStr
,"-1.5",LOCALE_NOUSEROVERRIDE
); EXPECT_OVERFLOW
;
2596 CONVERT_STR(VarUI8FromStr
,"-0.6",LOCALE_NOUSEROVERRIDE
); EXPECT_OVERFLOW
;
2597 CONVERT_STR(VarUI8FromStr
,"-0.5",LOCALE_NOUSEROVERRIDE
); EXPECTI8(0);
2598 CONVERT_STR(VarUI8FromStr
,"-0.4",LOCALE_NOUSEROVERRIDE
); EXPECTI8(0);
2599 CONVERT_STR(VarUI8FromStr
,"0.4",LOCALE_NOUSEROVERRIDE
); EXPECTI8(0);
2600 CONVERT_STR(VarUI8FromStr
,"0.5",LOCALE_NOUSEROVERRIDE
); EXPECTI8(0);
2601 CONVERT_STR(VarUI8FromStr
,"0.6",LOCALE_NOUSEROVERRIDE
); EXPECTI8(1);
2602 CONVERT_STR(VarUI8FromStr
,"1.5",LOCALE_NOUSEROVERRIDE
); EXPECTI8(2);
2605 static void test_VarUI8Copy(void)
2608 VARIANTARG vSrc
, vDst
;
2611 if (!HAVE_OLEAUT32_I8
)
2613 skip("I8 and UI8 data types are not available\n");
2619 V_VT(&vSrc
) = VT_UI8
;
2621 hres
= VariantCopy(&vDst
, &vSrc
);
2622 ok(hres
== S_OK
&& V_VT(&vDst
) == VT_UI8
&& V_UI8(&vDst
) == in
,
2623 "copy hres 0x%X, type %d, value (%x%08x) %x%08x\n",
2624 hres
, V_VT(&vDst
), (UINT
)(in
>> 32), (UINT
)in
, (UINT
)(V_UI8(&vDst
) >> 32), (UINT
)V_UI8(&vDst
) );
2625 V_VT(&vSrc
) = VT_UI8
|VT_BYREF
;
2626 V_UI8REF(&vSrc
) = &in
;
2627 hres
= VariantCopy(&vDst
, &vSrc
);
2628 ok(hres
== S_OK
&& V_VT(&vDst
) == (VT_UI8
|VT_BYREF
) && V_UI8REF(&vDst
) == &in
,
2629 "ref hres 0x%X, type %d, ref (%p) %p\n", hres
, V_VT(&vDst
), &in
, V_UI8REF(&vDst
));
2630 hres
= VariantCopyInd(&vDst
, &vSrc
);
2631 ok(hres
== S_OK
&& V_VT(&vDst
) == VT_UI8
&& V_UI8(&vDst
) == in
,
2632 "copy hres 0x%X, type %d, value (%x%08x) %x%08x\n",
2633 hres
, V_VT(&vDst
), (UINT
)(in
>> 32), (UINT
)in
, (UINT
)(V_UI8(&vDst
) >> 32), (UINT
)V_UI8(&vDst
) );
2636 static void test_VarUI8ChangeTypeEx(void)
2638 CONVVARS(CONV_TYPE
);
2639 VARIANTARG vSrc
, vDst
;
2641 if (!HAVE_OLEAUT32_I8
)
2643 skip("I8 and UI8 data types are not available\n");
2649 INITIAL_TYPETESTI8(VT_UI8
, V_UI8
);
2658 #define CONV_TYPE float
2660 #define EXPECTRES(res, x) _EXPECTRES(res, x, "%15.15f")
2662 static void test_VarR4FromI1(void)
2664 CONVVARS(signed char);
2667 CHECKPTR(VarR4FromI1
);
2668 CONVERTRANGE(VarR4FromI1
, -128, 128);
2671 static void test_VarR4FromUI1(void)
2676 CHECKPTR(VarR4FromUI1
);
2677 CONVERTRANGE(VarR4FromUI1
, 0, 256);
2680 static void test_VarR4FromI2(void)
2685 CHECKPTR(VarR4FromI2
);
2686 CONVERTRANGE(VarR4FromI2
, -32768, 32768);
2689 static void test_VarR4FromUI2(void)
2694 CHECKPTR(VarR4FromUI2
);
2695 CONVERTRANGE(VarR4FromUI2
, 0, 65536);
2698 static void test_VarR4FromI4(void)
2702 CHECKPTR(VarR4FromI4
);
2703 CONVERT(VarR4FromI4
, -2147483647-1); EXPECT(-2147483648.0f
);
2704 CONVERT(VarR4FromI4
, -1); EXPECT(-1.0f
);
2705 CONVERT(VarR4FromI4
, 0); EXPECT(0.0f
);
2706 CONVERT(VarR4FromI4
, 1); EXPECT(1.0f
);
2707 CONVERT(VarR4FromI4
, 2147483647); EXPECT(2147483647.0f
);
2710 static void test_VarR4FromUI4(void)
2712 CONVVARS(unsigned int);
2714 CHECKPTR(VarR4FromUI4
);
2715 CONVERT(VarR4FromUI4
, 0); EXPECT(0.0f
);
2716 CONVERT(VarR4FromUI4
, 1); EXPECT(1.0f
);
2717 #if defined(__i386__) && (defined(_MSC_VER) || defined(__GNUC__))
2718 CONVERT(VarR4FromUI4
, 0xffffffff); EXPECT(4294967296.0f
);
2722 static void test_VarR4FromR8(void)
2726 CHECKPTR(VarR4FromR8
);
2727 CONVERT(VarR4FromR8
, -1.0); EXPECT(-1.0f
);
2728 CONVERT(VarR4FromR8
, 0.0); EXPECT(0.0f
);
2729 CONVERT(VarR4FromR8
, 1.0); EXPECT(1.0f
);
2730 CONVERT(VarR4FromR8
, 1.5); EXPECT(1.5f
);
2732 /* Skip rounding tests - no rounding is done */
2735 static void test_VarR4FromBool(void)
2737 CONVVARS(VARIANT_BOOL
);
2739 CHECKPTR(VarR4FromBool
);
2740 CONVERT(VarR4FromBool
, VARIANT_TRUE
); EXPECT(VARIANT_TRUE
* 1.0f
);
2741 CONVERT(VarR4FromBool
, VARIANT_FALSE
); EXPECT(VARIANT_FALSE
* 1.0f
);
2744 static void test_VarR4FromCy(void)
2748 CHECKPTR(VarR4FromCy
);
2749 CONVERT_CY(VarR4FromCy
,-32768); EXPECT(-32768.0f
);
2750 CONVERT_CY(VarR4FromCy
,-1); EXPECT(-1.0f
);
2751 CONVERT_CY(VarR4FromCy
,0); EXPECT(0.0f
);
2752 CONVERT_CY(VarR4FromCy
,1); EXPECT(1.0f
);
2753 CONVERT_CY(VarR4FromCy
,32768); EXPECT(32768.0f
);
2755 CONVERT_CY(VarR4FromCy
,-1.5); EXPECT(-1.5f
);
2756 CONVERT_CY(VarR4FromCy
,-0.6); EXPECT(-0.6f
);
2757 CONVERT_CY(VarR4FromCy
,-0.5); EXPECT(-0.5f
);
2758 CONVERT_CY(VarR4FromCy
,-0.4); EXPECT(-0.4f
);
2759 CONVERT_CY(VarR4FromCy
,0.4); EXPECT(0.4f
);
2760 CONVERT_CY(VarR4FromCy
,0.5); EXPECT(0.5f
);
2761 CONVERT_CY(VarR4FromCy
,0.6); EXPECT(0.6f
);
2762 CONVERT_CY(VarR4FromCy
,1.5); EXPECT(1.5f
);
2765 static void test_VarR4FromI8(void)
2769 CHECKPTR(VarR4FromI8
);
2770 CONVERT(VarR4FromI8
, -1); EXPECT(-1.0f
);
2771 CONVERT(VarR4FromI8
, 0); EXPECT(0.0f
);
2772 CONVERT(VarR4FromI8
, 1); EXPECT(1.0f
);
2775 static void test_VarR4FromUI8(void)
2779 CHECKPTR(VarR4FromUI8
);
2780 CONVERT(VarR4FromUI8
, 0); EXPECT(0.0f
);
2781 CONVERT(VarR4FromUI8
, 1); EXPECT(1.0f
);
2784 static void test_VarR4FromDec(void)
2788 CHECKPTR(VarR4FromDec
);
2790 CONVERT_BADDEC(VarR4FromDec
);
2792 CONVERT_DEC(VarR4FromDec
,0,0x80,0,32768); EXPECT(-32768.0f
);
2793 CONVERT_DEC(VarR4FromDec
,0,0x80,0,1); EXPECT(-1.0f
);
2794 CONVERT_DEC(VarR4FromDec
,0,0,0,0); EXPECT(0.0f
);
2795 CONVERT_DEC(VarR4FromDec
,0,0,0,1); EXPECT(1.0f
);
2796 CONVERT_DEC(VarR4FromDec
,0,0,0,32767); EXPECT(32767.0f
);
2798 CONVERT_DEC(VarR4FromDec
,2,0x80,0,3276800); EXPECT(-32768.0f
);
2799 CONVERT_DEC(VarR4FromDec
,2,0,0,3276700); EXPECT(32767.0f
);
2801 CONVERT_DEC(VarR4FromDec
,0,0,1,0); EXPECT(18446744073709551616.0f
);
2804 static void test_VarR4FromDate(void)
2808 CHECKPTR(VarR4FromDate
);
2809 CONVERT(VarR4FromDate
, -1.0); EXPECT(-1.0f
);
2810 CONVERT(VarR4FromDate
, 0.0); EXPECT(0.0f
);
2811 CONVERT(VarR4FromDate
, 1.0); EXPECT(1.0f
);
2814 static void test_VarR4FromStr(void)
2819 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
2821 CHECKPTR(VarR4FromStr
);
2823 CONVERT_STR(VarR4FromStr
,NULL
,0); EXPECT_MISMATCH
;
2824 CONVERT_STR(VarR4FromStr
,"-1", 0); EXPECT(-1.0f
);
2825 CONVERT_STR(VarR4FromStr
,"0", 0); EXPECT(0.0f
);
2826 CONVERT_STR(VarR4FromStr
,"1", 0); EXPECT(1.0f
);
2828 CONVERT_STR(VarR4FromStr
,"-1.5",LOCALE_NOUSEROVERRIDE
); EXPECT(-1.5f
);
2829 CONVERT_STR(VarR4FromStr
,"-0.6",LOCALE_NOUSEROVERRIDE
); EXPECT(-0.6f
);
2830 CONVERT_STR(VarR4FromStr
,"-0.5",LOCALE_NOUSEROVERRIDE
); EXPECT(-0.5f
);
2831 CONVERT_STR(VarR4FromStr
,"-0.4",LOCALE_NOUSEROVERRIDE
); EXPECT(-0.4f
);
2832 CONVERT_STR(VarR4FromStr
,"0.4",LOCALE_NOUSEROVERRIDE
); EXPECT(0.4f
);
2833 CONVERT_STR(VarR4FromStr
,"0.5",LOCALE_NOUSEROVERRIDE
); EXPECT(0.5f
);
2834 CONVERT_STR(VarR4FromStr
,"0.6",LOCALE_NOUSEROVERRIDE
); EXPECT(0.6f
);
2835 CONVERT_STR(VarR4FromStr
,"1.5",LOCALE_NOUSEROVERRIDE
); EXPECT(1.5f
);
2838 static void test_VarR4Copy(void)
2840 COPYTEST(77665544.0f
, VT_R4
, V_R4(&vSrc
), V_R4(&vDst
), V_R4REF(&vSrc
),V_R4REF(&vDst
), "%15.15f");
2843 static void test_VarR4ChangeTypeEx(void)
2845 #ifdef HAS_UINT64_TO_FLOAT
2846 CONVVARS(CONV_TYPE
);
2847 VARIANTARG vSrc
, vDst
;
2851 INITIAL_TYPETEST(VT_R4
, V_R4
, "%f");
2861 #define CONV_TYPE double
2863 #define EXPECTRES(res, x) _EXPECTRES(res, x, "%15.15f")
2865 static void test_VarR8FromI1(void)
2867 CONVVARS(signed char);
2870 CHECKPTR(VarR8FromI1
);
2871 CONVERTRANGE(VarR8FromI1
, -128, 128);
2874 static void test_VarR8FromUI1(void)
2879 CHECKPTR(VarR8FromUI1
);
2880 CONVERTRANGE(VarR8FromUI1
, 0, 256);
2883 static void test_VarR8FromI2(void)
2888 CHECKPTR(VarR8FromI2
);
2889 CONVERTRANGE(VarR8FromI2
, -32768, 32768);
2892 static void test_VarR8FromUI2(void)
2897 CHECKPTR(VarR8FromUI2
);
2898 CONVERTRANGE(VarR8FromUI2
, 0, 65536);
2901 static void test_VarR8FromI4(void)
2905 CHECKPTR(VarR8FromI4
);
2906 CONVERT(VarR8FromI4
, -2147483647-1); EXPECT(-2147483648.0);
2907 CONVERT(VarR8FromI4
, -1); EXPECT(-1.0);
2908 CONVERT(VarR8FromI4
, 0); EXPECT(0.0);
2909 CONVERT(VarR8FromI4
, 1); EXPECT(1.0);
2910 CONVERT(VarR8FromI4
, 0x7fffffff); EXPECT(2147483647.0);
2913 static void test_VarR8FromUI4(void)
2915 CONVVARS(unsigned int);
2917 CHECKPTR(VarR8FromUI4
);
2918 CONVERT(VarR8FromUI4
, 0); EXPECT(0.0);
2919 CONVERT(VarR8FromUI4
, 1); EXPECT(1.0);
2920 CONVERT(VarR8FromUI4
, 0xffffffff); EXPECT(4294967295.0);
2923 static void test_VarR8FromR4(void)
2927 CHECKPTR(VarR8FromR4
);
2928 CONVERT(VarR8FromR4
, -1.0f
); EXPECT(-1.0);
2929 CONVERT(VarR8FromR4
, 0.0f
); EXPECT(0.0);
2930 CONVERT(VarR8FromR4
, 1.0f
); EXPECT(1.0);
2931 CONVERT(VarR8FromR4
, 1.5f
); EXPECT(1.5);
2933 /* Skip rounding tests - no rounding is done */
2936 static void test_VarR8FromBool(void)
2938 CONVVARS(VARIANT_BOOL
);
2940 CHECKPTR(VarR8FromBool
);
2941 CONVERT(VarR8FromBool
, VARIANT_TRUE
); EXPECT(VARIANT_TRUE
* 1.0);
2942 CONVERT(VarR8FromBool
, VARIANT_FALSE
); EXPECT(VARIANT_FALSE
* 1.0);
2945 static void test_VarR8FromCy(void)
2949 CHECKPTR(VarR8FromCy
);
2950 CONVERT_CY(VarR8FromCy
,-32769); EXPECT(-32769.0);
2951 CONVERT_CY(VarR8FromCy
,-32768); EXPECT(-32768.0);
2952 CONVERT_CY(VarR8FromCy
,-1); EXPECT(-1.0);
2953 CONVERT_CY(VarR8FromCy
,0); EXPECT(0.0);
2954 CONVERT_CY(VarR8FromCy
,1); EXPECT(1.0);
2955 CONVERT_CY(VarR8FromCy
,32767); EXPECT(32767.0);
2956 CONVERT_CY(VarR8FromCy
,32768); EXPECT(32768.0);
2958 CONVERT_CY(VarR8FromCy
,-1.5); EXPECT(-1.5);
2959 CONVERT_CY(VarR8FromCy
,-0.6); EXPECT(-0.6);
2960 CONVERT_CY(VarR8FromCy
,-0.5); EXPECT(-0.5);
2961 CONVERT_CY(VarR8FromCy
,-0.4); EXPECT(-0.4);
2962 CONVERT_CY(VarR8FromCy
,0.4); EXPECT(0.4);
2963 CONVERT_CY(VarR8FromCy
,0.5); EXPECT(0.5);
2964 CONVERT_CY(VarR8FromCy
,0.6); EXPECT(0.6);
2965 CONVERT_CY(VarR8FromCy
,1.5); EXPECT(1.5);
2968 static void test_VarR8FromI8(void)
2972 CHECKPTR(VarR8FromI8
);
2973 CONVERT(VarR8FromI8
, -1); EXPECT(-1.0);
2974 CONVERT(VarR8FromI8
, 0); EXPECT(0.0);
2975 CONVERT(VarR8FromI8
, 1); EXPECT(1.0);
2976 #if defined(__i386__) && (defined(_MSC_VER) || defined(__GNUC__))
2977 CONVERT_I8(VarR8FromI8
, 0x7fffffff,0xffffffff); EXPECT(9223372036854775808.0);
2981 static void test_VarR8FromUI8(void)
2985 CHECKPTR(VarR8FromUI8
);
2986 CONVERT(VarR8FromUI8
, 0); EXPECT(0.0);
2987 CONVERT(VarR8FromUI8
, 1); EXPECT(1.0);
2988 #if defined(__i386__) && (defined(_MSC_VER) || defined(__GNUC__))
2989 CONVERT_I8(VarR8FromUI8
, 0x80000000,0); EXPECT(9223372036854775808.0);
2993 static void test_VarR8FromDec(void)
2997 CHECKPTR(VarR8FromDec
);
2999 CONVERT_BADDEC(VarR8FromDec
);
3001 CONVERT_DEC(VarR8FromDec
,0,0x80,0,32768); EXPECT(-32768.0);
3002 CONVERT_DEC(VarR8FromDec
,0,0x80,0,1); EXPECT(-1.0);
3003 CONVERT_DEC(VarR8FromDec
,0,0,0,0); EXPECT(0.0);
3004 CONVERT_DEC(VarR8FromDec
,0,0,0,1); EXPECT(1.0);
3005 CONVERT_DEC(VarR8FromDec
,0,0,0,32767); EXPECT(32767.0);
3007 CONVERT_DEC(VarR8FromDec
,2,0x80,0,3276800); EXPECT(-32768.0);
3008 CONVERT_DEC(VarR8FromDec
,2,0,0,3276700); EXPECT(32767.0);
3010 CONVERT_DEC(VarR8FromDec
,0,0,1,0); EXPECT(18446744073709551616.0);
3013 static void test_VarR8FromDate(void)
3017 CHECKPTR(VarR8FromDate
);
3018 CONVERT(VarR8FromDate
, -1.0); EXPECT(-1.0);
3019 CONVERT(VarR8FromDate
, -0.0); EXPECT(0.0);
3020 CONVERT(VarR8FromDate
, 1.0); EXPECT(1.0);
3023 static void test_VarR8FromStr(void)
3028 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
3030 CHECKPTR(VarR8FromStr
);
3032 CONVERT_STR(VarR8FromStr
,NULL
,0); EXPECT_MISMATCH
;
3033 CONVERT_STR(VarR8FromStr
,"",0); EXPECT_MISMATCH
;
3034 CONVERT_STR(VarR8FromStr
," ",0); EXPECT_MISMATCH
;
3036 CONVERT_STR(VarR8FromStr
,"0",LOCALE_NOUSEROVERRIDE
); EXPECT(0.0);
3037 CONVERT_STR(VarR8FromStr
,"-1.5",LOCALE_NOUSEROVERRIDE
); EXPECT(-1.5);
3038 CONVERT_STR(VarR8FromStr
,"-0.6",LOCALE_NOUSEROVERRIDE
); EXPECT(-0.6);
3039 CONVERT_STR(VarR8FromStr
,"-0.5",LOCALE_NOUSEROVERRIDE
); EXPECT(-0.5);
3040 CONVERT_STR(VarR8FromStr
,"-0.4",LOCALE_NOUSEROVERRIDE
); EXPECT(-0.4);
3041 CONVERT_STR(VarR8FromStr
,"0.4",LOCALE_NOUSEROVERRIDE
); EXPECT(0.4);
3042 CONVERT_STR(VarR8FromStr
,"0.5",LOCALE_NOUSEROVERRIDE
); EXPECT(0.5);
3043 CONVERT_STR(VarR8FromStr
,"0.6",LOCALE_NOUSEROVERRIDE
); EXPECT(0.6);
3044 CONVERT_STR(VarR8FromStr
,"1.5",LOCALE_NOUSEROVERRIDE
); EXPECT(1.5);
3046 /* We already have exhaustive tests for number parsing, so skip those tests here */
3049 static void test_VarR8Copy(void)
3051 COPYTEST(77665544.0, VT_R8
, V_R8(&vSrc
), V_R8(&vDst
), V_R8REF(&vSrc
),V_R8REF(&vDst
), "%16.16g");
3054 static void test_VarR8ChangeTypeEx(void)
3056 #ifdef HAS_UINT64_TO_FLOAT
3057 CONVVARS(CONV_TYPE
);
3058 VARIANTARG vSrc
, vDst
;
3062 INITIAL_TYPETEST(VT_R8
, V_R8
, "%g");
3067 #define MATHRND(l, r) left = l; right = r; hres = pVarR8Round(left, right, &out)
3069 static void test_VarR8Round(void)
3072 double left
= 0.0, out
;
3075 CHECKPTR(VarR8Round
);
3076 MATHRND(0.5432, 5); EXPECT(0.5432);
3077 MATHRND(0.5432, 4); EXPECT(0.5432);
3078 MATHRND(0.5432, 3); EXPECT(0.543);
3079 MATHRND(0.5432, 2); EXPECT(0.54);
3080 MATHRND(0.5432, 1); EXPECT(0.5);
3081 MATHRND(0.5532, 0); EXPECT(1);
3082 MATHRND(0.5532, -1); EXPECT_INVALID
;
3084 MATHRND(0.5568, 5); EXPECT(0.5568);
3085 MATHRND(0.5568, 4); EXPECT(0.5568);
3086 MATHRND(0.5568, 3); EXPECT(0.557);
3087 MATHRND(0.5568, 2); EXPECT(0.56);
3088 MATHRND(0.5568, 1); EXPECT(0.6);
3089 MATHRND(0.5568, 0); EXPECT(1);
3090 MATHRND(0.5568, -1); EXPECT_INVALID
;
3092 MATHRND(0.4999, 0); EXPECT(0);
3093 MATHRND(0.5000, 0); EXPECT(0);
3094 MATHRND(0.5001, 0); EXPECT(1);
3095 MATHRND(1.4999, 0); EXPECT(1);
3096 MATHRND(1.5000, 0); EXPECT(2);
3097 MATHRND(1.5001, 0); EXPECT(2);
3105 #define CONV_TYPE DATE
3107 static void test_VarDateFromI1(void)
3109 CONVVARS(signed char);
3112 CHECKPTR(VarDateFromI1
);
3113 CONVERTRANGE(VarDateFromI1
, -128, 128);
3116 static void test_VarDateFromUI1(void)
3121 CHECKPTR(VarDateFromUI1
);
3122 CONVERTRANGE(VarDateFromUI1
, 0, 256);
3125 static void test_VarDateFromI2(void)
3130 CHECKPTR(VarDateFromI2
);
3131 CONVERTRANGE(VarDateFromI2
, -32768, 32768);
3134 static void test_VarDateFromUI2(void)
3139 CHECKPTR(VarDateFromUI2
);
3140 CONVERTRANGE(VarDateFromUI2
, 0, 65536);
3143 static void test_VarDateFromI4(void)
3147 CHECKPTR(VarDateFromI4
);
3148 CONVERT(VarDateFromI4
, DATE_MIN
-1);
3149 if (hres
!= DISP_E_TYPEMISMATCH
) /* Early versions return this, incorrectly */
3151 CONVERT(VarDateFromI4
, DATE_MIN
); EXPECT(DATE_MIN
);
3152 CONVERT(VarDateFromI4
, -1); EXPECT(-1.0);
3153 CONVERT(VarDateFromI4
, 0); EXPECT(0.0);
3154 CONVERT(VarDateFromI4
, 1); EXPECT(1.0);
3155 CONVERT(VarDateFromI4
, DATE_MAX
); EXPECT(DATE_MAX
);
3156 CONVERT(VarDateFromI4
, DATE_MAX
+1);
3157 if (hres
!= DISP_E_TYPEMISMATCH
) /* Early versions return this, incorrectly */
3161 static void test_VarDateFromUI4(void)
3163 CONVVARS(unsigned int);
3165 CHECKPTR(VarDateFromUI4
);
3166 CONVERT(VarDateFromUI4
, 0); EXPECT(0.0);
3167 CONVERT(VarDateFromUI4
, 1); EXPECT(1.0);
3168 CONVERT(VarDateFromUI4
, DATE_MAX
); EXPECT(DATE_MAX
);
3169 CONVERT(VarDateFromUI4
, DATE_MAX
+1);
3170 if (hres
!= DISP_E_TYPEMISMATCH
) /* Early versions return this, incorrectly */
3174 static void test_VarDateFromR4(void)
3178 CHECKPTR(VarDateFromR4
);
3179 CONVERT(VarDateFromR4
, -1.0f
); EXPECT(-1.0);
3180 CONVERT(VarDateFromR4
, 0.0f
); EXPECT(0.0);
3181 CONVERT(VarDateFromR4
, 1.0f
); EXPECT(1.0);
3182 CONVERT(VarDateFromR4
, 1.5f
); EXPECT(1.5);
3185 static void test_VarDateFromR8(void)
3189 CHECKPTR(VarDateFromR8
);
3190 CONVERT(VarDateFromR8
, -1.0f
); EXPECT(-1.0);
3191 CONVERT(VarDateFromR8
, 0.0f
); EXPECT(0.0);
3192 CONVERT(VarDateFromR8
, 1.0f
); EXPECT(1.0);
3193 CONVERT(VarDateFromR8
, 1.5f
); EXPECT(1.5);
3196 static void test_VarDateFromBool(void)
3198 CONVVARS(VARIANT_BOOL
);
3200 CHECKPTR(VarDateFromBool
);
3201 CONVERT(VarDateFromBool
, VARIANT_TRUE
); EXPECT(VARIANT_TRUE
* 1.0);
3202 CONVERT(VarDateFromBool
, VARIANT_FALSE
); EXPECT(VARIANT_FALSE
* 1.0);
3205 static void test_VarDateFromCy(void)
3209 CHECKPTR(VarDateFromCy
);
3210 CONVERT_CY(VarDateFromCy
,-32769); EXPECT(-32769.0);
3211 CONVERT_CY(VarDateFromCy
,-32768); EXPECT(-32768.0);
3212 CONVERT_CY(VarDateFromCy
,-1); EXPECT(-1.0);
3213 CONVERT_CY(VarDateFromCy
,0); EXPECT(0.0);
3214 CONVERT_CY(VarDateFromCy
,1); EXPECT(1.0);
3215 CONVERT_CY(VarDateFromCy
,32767); EXPECT(32767.0);
3216 CONVERT_CY(VarDateFromCy
,32768); EXPECT(32768.0);
3218 CONVERT_CY(VarDateFromCy
,-1.5); EXPECT(-1.5);
3219 CONVERT_CY(VarDateFromCy
,-0.6); EXPECT(-0.6);
3220 CONVERT_CY(VarDateFromCy
,-0.5); EXPECT(-0.5);
3221 CONVERT_CY(VarDateFromCy
,-0.4); EXPECT(-0.4);
3222 CONVERT_CY(VarDateFromCy
,0.4); EXPECT(0.4);
3223 CONVERT_CY(VarDateFromCy
,0.5); EXPECT(0.5);
3224 CONVERT_CY(VarDateFromCy
,0.6); EXPECT(0.6);
3225 CONVERT_CY(VarDateFromCy
,1.5); EXPECT(1.5);
3228 static void test_VarDateFromI8(void)
3232 CHECKPTR(VarDateFromI8
);
3233 CONVERT(VarDateFromI8
, DATE_MIN
-1); EXPECT_OVERFLOW
;
3234 CONVERT(VarDateFromI8
, DATE_MIN
); EXPECT(DATE_MIN
);
3235 CONVERT(VarDateFromI8
, -1); EXPECT(-1.0);
3236 CONVERT(VarDateFromI8
, 0); EXPECT(0.0);
3237 CONVERT(VarDateFromI8
, 1); EXPECT(1.0);
3238 CONVERT(VarDateFromI8
, DATE_MAX
); EXPECT(DATE_MAX
);
3239 CONVERT(VarDateFromI8
, DATE_MAX
+1); EXPECT_OVERFLOW
;
3242 static void test_VarDateFromUI8(void)
3246 CHECKPTR(VarDateFromUI8
);
3247 CONVERT(VarDateFromUI8
, 0); EXPECT(0.0);
3248 CONVERT(VarDateFromUI8
, 1); EXPECT(1.0);
3249 CONVERT(VarDateFromUI8
, DATE_MAX
); EXPECT(DATE_MAX
);
3250 CONVERT(VarDateFromUI8
, DATE_MAX
+1); EXPECT_OVERFLOW
;
3253 static void test_VarDateFromDec(void)
3257 CHECKPTR(VarDateFromDec
);
3259 CONVERT_BADDEC(VarDateFromDec
);
3261 CONVERT_DEC(VarDateFromDec
,0,0x80,0,32768); EXPECT(-32768.0);
3262 CONVERT_DEC(VarDateFromDec
,0,0x80,0,1); EXPECT(-1.0);
3263 CONVERT_DEC(VarDateFromDec
,0,0,0,0); EXPECT(0.0);
3264 CONVERT_DEC(VarDateFromDec
,0,0,0,1); EXPECT(1.0);
3265 CONVERT_DEC(VarDateFromDec
,0,0,0,32767); EXPECT(32767.0);
3267 CONVERT_DEC(VarDateFromDec
,2,0x80,0,3276800); EXPECT(-32768.0);
3268 CONVERT_DEC(VarDateFromDec
,2,0,0,3276700); EXPECT(32767.0);
3272 buff[0] = '\0'; out = 0.0; \
3273 if (str) MultiByteToWideChar(CP_ACP,0,str,-1,buff,sizeof(buff)/sizeof(WCHAR)); \
3274 hres = pVarDateFromStr(str ? buff : NULL,lcid,LOCALE_NOUSEROVERRIDE,&out)
3276 #define MKRELDATE(day,mth) st.wMonth = mth; st.wDay = day; \
3277 pSystemTimeToVariantTime(&st,&relative)
3279 static const char * const BadDateStrings
[] =
3281 "True", "False", /* Plain text */
3282 "0.", ".0", "-1.1", "1.1-", /* Partial specifications */
3283 "1;2;3", "1*2*3", "1@2@3", "1#2#3", "(1:2)","<1:2>","1|2|3", /* Bad chars */
3284 "0", "1", /* 1 element */
3285 "0.60", "24.00", "0:60", "24:00", "1 2 am", "1 am 2", /* 2 elements */
3286 "1.5 2", "1 5.2", "2 32 3", "1 2 am 3", /* 3 elements */
3287 "1 2.3 4", "1.2.3 4", "1 2.3.4", "1.2 3.4", "1.2.3.4", "1 2 3 4",
3288 "1 am 2 3.4", "1 2 am 3.4", "1.2 3 am 4", "1.2 3 4 am", /* 4 elements */
3289 "1.2.3.4.5", "1.2.3.4 5", "1.2.3 4.5", "1.2 3.4.5", "1.2 3.4 5", "1.2 3 4.5",
3290 "1 2.3.4.5", "1 2.3.4 5", "1 2.3 4.5", "1 2.3 4 5", "1 2 3.4 5", "1 2 3 4 5",
3291 "1.2.3 4 am 5", "1.2.3 4 5 am", "1.2 3 am 4 5",
3292 "1.2 3 4 am 5", "1.2 3 4 5 am", "1 am 2 3.4.5", "1 2 am 3.4.5",
3293 "1 am 2 3 4.5", "1 2 am 3 4.5", "1 2 3 am 4.5", /* 5 elements */
3295 "1.2.3.4.5.6", "1.2.3.4.5 6", "1.2.3.4 5.6", "1.2.3.4 5 6", "1.2.3 4.5.6",
3296 "1.2.3 4.5 6", "1.2.3 4 5.6", "1.2 3.4.5.6", "1.2 3.4.5 6", "1.2 3.4 5.6",
3297 "1.2 3.4 5 6", "1.2 3 4.5.6", "1.2 3 4.5 6", "1.2 3 4 5.6", "1.2 3 4 5 6",
3298 "1 2.3.4.5.6", "1 2.3.4.5 6", "1 2.3.4 5.6", "1 2.3.4 5 6", "1 2.3 4.5.6",
3300 /* following throws an exception on winME */
3301 "1 2.3 4.5 6", "1 2.3 4 5.6", "1 2.3 4 5 6", "1 2 3.4.5.6", "1 2 3.4.5 6",
3303 "1 2 3.4 5.6", "1 2 3.4 5 6", "1 2 3 4.5 6", "1 2 3 4 5.6", "1 2 3 4 5 6",
3305 /* following throws an exception on winME */
3306 "1.2.3 4 am 5 6", "1.2.3 4 5 am 6", "1.2.3 4 5 6 am", "1 am 2 3 4.5.6",
3308 "1 2 am 3 4.5.6", "1 2 3 am 4.5.6"
3311 static void test_VarDateFromStr(void)
3320 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
3322 CHECKPTR(VarDateFromStr
);
3323 CHECKPTR(SystemTimeToVariantTime
);
3325 /* Some date formats are relative, so we need to find the current year */
3327 st
.wHour
= st
.wMinute
= st
.wSecond
= st
.wMilliseconds
= 0;
3328 DFS(NULL
); EXPECT_MISMATCH
;
3330 /* Floating point number are not recognised */
3333 EXPECT_DBL(0.0); /* Very old versions accept this string */
3337 /* 1 element - can only be a time, and only if it has am/pm */
3338 DFS("1 am"); EXPECT_DBL(0.04166666666666666);
3340 /* A decimal point is treated as a time separator.
3341 * The following are converted as hours/minutes.
3343 DFS("0.1"); EXPECT_DBL(0.0006944444444444445);
3344 DFS("0.40"); EXPECT_DBL(0.02777777777777778);
3345 DFS("2.5"); EXPECT_DBL(0.08680555555555555);
3346 /* A colon acts as a decimal point */
3347 DFS("0:1"); EXPECT_DBL(0.0006944444444444445);
3348 DFS("0:20"); EXPECT_DBL(0.01388888888888889);
3349 DFS("0:40"); EXPECT_DBL(0.02777777777777778);
3350 DFS("3:5"); EXPECT_DBL(0.1284722222222222);
3351 /* Check the am/pm limits */
3352 DFS("00:00 AM"); EXPECT_DBL(0.0);
3353 DFS("00:00 a"); EXPECT_DBL(0.0);
3354 DFS("12:59 AM"); EXPECT_DBL(0.04097222222222222);
3355 DFS("12:59 A"); EXPECT_DBL(0.04097222222222222);
3356 DFS("00:00 pm"); EXPECT_DBL(0.5);
3357 DFS("00:00 p"); EXPECT_DBL(0.5);
3358 DFS("12:59 pm"); EXPECT_DBL(0.5409722222222222);
3359 DFS("12:59 p"); EXPECT_DBL(0.5409722222222222);
3360 /* AM/PM is ignored if hours > 12 */
3361 DFS("13:00 AM"); EXPECT_DBL(0.5416666666666666);
3362 DFS("13:00 PM"); EXPECT_DBL(0.5416666666666666);
3364 /* Space, dash and slash all indicate a date format. */
3365 /* If both numbers are valid month values => month/day of current year */
3366 DFS("1 2"); MKRELDATE(2,1); EXPECT_DBL(relative
);
3367 DFS("2 1"); MKRELDATE(1,2); EXPECT_DBL(relative
);
3368 /* one number not valid month, is a valid day, other number valid month:
3369 * that number becomes the day.
3371 DFS("14 1"); MKRELDATE(14,1); EXPECT_DBL(relative
);
3372 DFS("1 14"); EXPECT_DBL(relative
);
3373 /* If the numbers can't be day/month, they are assumed to be year/month */
3374 DFS("30 2"); EXPECT_DBL(10990.0);
3375 DFS("2 30"); EXPECT_DBL(10990.0);
3376 DFS("32 49"); EXPECT_MISMATCH
; /* Can't be any format */
3377 DFS("0 49"); EXPECT_MISMATCH
; /* Can't be any format */
3378 /* If a month name is given the other number is the day */
3379 DFS("Jan 2"); MKRELDATE(2,1); EXPECT_DBL(relative
);
3380 DFS("2 Jan"); EXPECT_DBL(relative
);
3381 /* Unless it can't be, in which case it becomes the year */
3382 DFS("Jan 35"); EXPECT_DBL(12785.0);
3383 DFS("35 Jan"); EXPECT_DBL(12785.0);
3384 DFS("Jan-35"); EXPECT_DBL(12785.0);
3385 DFS("35-Jan"); EXPECT_DBL(12785.0);
3386 DFS("Jan/35"); EXPECT_DBL(12785.0);
3387 DFS("35/Jan"); EXPECT_DBL(12785.0);
3389 /* 3 numbers and time separator => h:m:s */
3390 DFS("0.1.0"); EXPECT_DBL(0.0006944444444444445);
3391 DFS("1.5.2"); EXPECT_DBL(0.04516203703703704);
3392 /* 3 numbers => picks date giving preference to lcid format */
3393 DFS("1 2 3"); EXPECT_DBL(37623.0);
3394 DFS("14 2 3"); EXPECT_DBL(41673.0);
3395 DFS("2 14 3"); EXPECT_DBL(37666.0);
3396 DFS("2 3 14"); EXPECT_DBL(41673.0);
3397 DFS("32 2 3"); EXPECT_DBL(11722.0);
3398 DFS("2 3 32"); EXPECT_DBL(11722.0);
3399 DFS("1 2 29"); EXPECT_DBL(47120.0);
3400 /* After 30, two digit dates are expected to be in the 1900's */
3401 DFS("1 2 30"); EXPECT_DBL(10960.0);
3402 DFS("1 2 31"); EXPECT_DBL(11325.0);
3403 DFS("3 am 1 2"); MKRELDATE(2,1); relative
+= 0.125; EXPECT_DBL(relative
);
3404 DFS("1 2 3 am"); EXPECT_DBL(relative
);
3406 /* 4 elements -interpreted as 2 digit date & time */
3407 DFS("1.2 3 4"); MKRELDATE(4,3); relative
+= 0.04305555556; EXPECT_DBL(relative
);
3408 DFS("3 4 1.2"); EXPECT_DBL(relative
);
3409 /* 5 elements - interpreted as 2 & 3 digit date/times */
3410 DFS("1.2.3 4 5"); MKRELDATE(5,4); relative
+= 0.04309027778; EXPECT_DBL(relative
);
3411 DFS("1.2 3 4 5"); EXPECT_DBL(38415.04305555556);
3413 /* following throws an exception on winME */
3414 DFS("1 2 3.4.5"); MKRELDATE(2,1); relative
+= 0.12783564815; EXPECT_DBL(relative
);
3416 DFS("1 2 3 4.5"); EXPECT_DBL(37623.17013888889);
3417 /* 6 elements - interpreted as 3 digit date/times */
3418 DFS("1.2.3 4 5 6"); EXPECT_DBL(38812.04309027778);
3419 DFS("1 2 3 4.5.6"); EXPECT_DBL(37623.17020833334);
3421 for (i
= 0; i
< sizeof(BadDateStrings
)/sizeof(char*); i
++)
3423 DFS(BadDateStrings
[i
]); EXPECT_MISMATCH
;
3426 /* Some normal-ish strings */
3427 DFS("2 January, 1970"); EXPECT_DBL(25570.0);
3428 DFS("2 January 1970"); EXPECT_DBL(25570.0);
3429 DFS("2 Jan 1970"); EXPECT_DBL(25570.0);
3430 DFS("2/Jan/1970"); EXPECT_DBL(25570.0);
3431 DFS("2-Jan-1970"); EXPECT_DBL(25570.0);
3432 DFS("1 2 1970"); EXPECT_DBL(25570.0);
3433 DFS("1/2/1970"); EXPECT_DBL(25570.0);
3434 DFS("1-2-1970"); EXPECT_DBL(25570.0);
3435 /* Native fails "1999 January 3, 9AM". I consider that a bug in native */
3438 static void test_VarDateCopy(void)
3440 COPYTEST(77665544.0, VT_DATE
, V_DATE(&vSrc
), V_DATE(&vDst
), V_DATEREF(&vSrc
),
3441 V_DATEREF(&vDst
), "%16.16g");
3444 static const char* wtoascii(LPWSTR lpszIn
)
3446 static char buff
[256];
3447 WideCharToMultiByte(CP_ACP
, 0, lpszIn
, -1, buff
, sizeof(buff
), NULL
, NULL
);
3451 static void test_VarDateChangeTypeEx(void)
3453 static const WCHAR sz25570
[] = {
3454 '1','/','2','/','1','9','7','0','\0' };
3455 static const WCHAR sz25570_2
[] = {
3456 '1','/','2','/','7','0','\0' };
3457 static const WCHAR sz25570Nls
[] = {
3458 '1','/','2','/','1','9','7','0',' ','1','2',':','0','0',':','0','0',' ','A','M','\0' };
3459 CONVVARS(CONV_TYPE
);
3460 VARIANTARG vSrc
, vDst
;
3465 #ifdef HAS_UINT64_TO_FLOAT
3466 INITIAL_TYPETEST(VT_DATE
, V_DATE
, "%g");
3470 V_VT(&vDst
) = VT_EMPTY
;
3471 V_VT(&vSrc
) = VT_DATE
;
3472 V_DATE(&vSrc
) = 25570.0;
3473 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
3475 hres
= VariantChangeTypeEx(&vDst
, &vSrc
, lcid
, VARIANT_NOUSEROVERRIDE
, VT_BSTR
);
3476 ok(hres
== S_OK
&& V_VT(&vDst
) == VT_BSTR
&& V_BSTR(&vDst
) &&
3477 (!lstrcmpW(V_BSTR(&vDst
), sz25570
) || !lstrcmpW(V_BSTR(&vDst
), sz25570_2
)),
3478 "hres=0x%X, type=%d (should be VT_BSTR), *bstr=%s\n",
3479 hres
, V_VT(&vDst
), V_BSTR(&vDst
) ? wtoascii(V_BSTR(&vDst
)) : "?");
3481 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
3482 if (HAVE_OLEAUT32_LOCALES
)
3484 hres
= VariantChangeTypeEx(&vDst
, &vSrc
, lcid
, VARIANT_NOUSEROVERRIDE
|VARIANT_USE_NLS
, VT_BSTR
);
3485 ok(hres
== S_OK
&& V_VT(&vDst
) == VT_BSTR
&& V_BSTR(&vDst
) && !lstrcmpW(V_BSTR(&vDst
), sz25570Nls
),
3486 "hres=0x%X, type=%d (should be VT_BSTR), *bstr=%s\n",
3487 hres
, V_VT(&vDst
), V_BSTR(&vDst
) ? wtoascii(V_BSTR(&vDst
)) : "?");
3496 #define CONV_TYPE CY
3498 #define EXPECTRES(res, x) \
3499 ok(hres == S_OK || ((HRESULT)res != S_OK && hres == (HRESULT)res), \
3500 "expected hres " #x ", got hres=0x%08x\n", hres)
3502 #define EXPECTCY(x) \
3503 ok((hres == S_OK && out.int64 == (LONGLONG)(x*CY_MULTIPLIER)), \
3504 "expected " #x "*CY_MULTIPLIER, got (%8x %8x); hres=0x%08x\n", S(out).Hi, S(out).Lo, hres)
3506 #define EXPECTCY64(x,y) \
3507 ok(hres == S_OK && S(out).Hi == (LONG)x && S(out).Lo == y, \
3508 "expected " #x #y "(%u,%u), got (%u,%u); hres=0x%08x\n", \
3509 (ULONG)(x), (ULONG)(y), S(out).Hi, S(out).Lo, hres)
3511 static void test_VarCyFromI1(void)
3513 CONVVARS(signed char);
3516 CHECKPTR(VarCyFromI1
);
3517 for (i
= -128; i
< 128; i
++)
3519 CONVERT(VarCyFromI1
,i
); EXPECTCY(i
);
3523 static void test_VarCyFromUI1(void)
3528 CHECKPTR(VarCyFromUI1
);
3529 for (i
= 0; i
< 256; i
++)
3531 CONVERT(VarCyFromUI1
,i
); EXPECTCY(i
);
3535 static void test_VarCyFromI2(void)
3540 CHECKPTR(VarCyFromI2
);
3541 for (i
= -16384; i
< 16384; i
++)
3543 CONVERT(VarCyFromI2
,i
); EXPECTCY(i
);
3547 static void test_VarCyFromUI2(void)
3552 CHECKPTR(VarCyFromUI2
);
3553 for (i
= 0; i
< 32768; i
++)
3555 CONVERT(VarCyFromUI2
,i
); EXPECTCY(i
);
3559 static void test_VarCyFromI4(void)
3563 CHECKPTR(VarCyFromI4
);
3564 CONVERT(VarCyFromI4
, -1); EXPECTCY(-1);
3565 CONVERT(VarCyFromI4
, 0); EXPECTCY(0);
3566 CONVERT(VarCyFromI4
, 1); EXPECTCY(1);
3567 CONVERT(VarCyFromI4
, 0x7fffffff); EXPECTCY64(0x1387, 0xffffd8f0);
3568 CONVERT(VarCyFromI4
, 0x80000000); EXPECTCY64(0xffffec78, 0);
3571 static void test_VarCyFromUI4(void)
3573 CONVVARS(unsigned int);
3575 CHECKPTR(VarCyFromUI4
);
3576 CONVERT(VarCyFromUI4
, 0); EXPECTCY(0);
3577 CONVERT(VarCyFromUI4
, 1); EXPECTCY(1);
3578 CONVERT(VarCyFromUI4
, 0x80000000); EXPECTCY64(5000, 0);
3581 static void test_VarCyFromR4(void)
3585 CHECKPTR(VarCyFromR4
);
3586 CONVERT(VarCyFromR4
, -1.0f
); EXPECTCY(-1);
3587 CONVERT(VarCyFromR4
, 0.0f
); EXPECTCY(0);
3588 CONVERT(VarCyFromR4
, 1.0f
); EXPECTCY(1);
3589 CONVERT(VarCyFromR4
, 1.5f
); EXPECTCY(1.5);
3591 CONVERT(VarCyFromR4
, -1.5f
); EXPECTCY(-1.5);
3592 CONVERT(VarCyFromR4
, -0.6f
); EXPECTCY(-0.6);
3593 CONVERT(VarCyFromR4
, -0.5f
); EXPECTCY(-0.5);
3594 CONVERT(VarCyFromR4
, -0.4f
); EXPECTCY(-0.4);
3595 CONVERT(VarCyFromR4
, 0.4f
); EXPECTCY(0.4);
3596 CONVERT(VarCyFromR4
, 0.5f
); EXPECTCY(0.5);
3597 CONVERT(VarCyFromR4
, 0.6f
); EXPECTCY(0.6);
3598 CONVERT(VarCyFromR4
, 1.5f
); EXPECTCY(1.5);
3599 CONVERT(VarCyFromR4
, 1.00009f
); EXPECTCY(1.0001);
3600 CONVERT(VarCyFromR4
, -1.00001f
); EXPECTCY(-1);
3601 CONVERT(VarCyFromR4
, -1.00005f
); EXPECTCY(-1);
3602 CONVERT(VarCyFromR4
, -0.00009f
); EXPECTCY(-0.0001);
3603 CONVERT(VarCyFromR4
, -0.00005f
); EXPECTCY(0);
3604 CONVERT(VarCyFromR4
, -0.00001f
); EXPECTCY(0);
3605 CONVERT(VarCyFromR4
, 0.00001f
); EXPECTCY(0);
3606 CONVERT(VarCyFromR4
, 0.00005f
); EXPECTCY(0);
3607 CONVERT(VarCyFromR4
, 0.00009f
); EXPECTCY(0.0001);
3608 CONVERT(VarCyFromR4
, -1.00001f
); EXPECTCY(-1);
3609 CONVERT(VarCyFromR4
, -1.00005f
); EXPECTCY(-1);
3610 CONVERT(VarCyFromR4
, -1.00009f
); EXPECTCY(-1.0001);
3613 static void test_VarCyFromR8(void)
3617 CHECKPTR(VarCyFromR8
);
3619 #if defined(__i386__) && (defined(_MSC_VER) || defined(__GNUC__))
3620 /* Test our rounding is exactly the same. This fails if the special x86
3621 * code is taken out of VarCyFromR8.
3623 CONVERT(VarCyFromR8
, -461168601842738.7904); EXPECTCY64(0xbfffffff, 0xffffff23);
3626 CONVERT(VarCyFromR8
, -4611686018427388416.1); EXPECT_OVERFLOW
;
3627 CONVERT(VarCyFromR8
, -1.0); EXPECTCY(-1);
3628 CONVERT(VarCyFromR8
, -0.0); EXPECTCY(0);
3629 CONVERT(VarCyFromR8
, 1.0); EXPECTCY(1);
3630 CONVERT(VarCyFromR8
, 4611686018427387648.0); EXPECT_OVERFLOW
;
3633 CONVERT(VarCyFromR8
, -1.5f
); EXPECTCY(-1.5);
3634 CONVERT(VarCyFromR8
, -0.6f
); EXPECTCY(-0.6);
3635 CONVERT(VarCyFromR8
, -0.5f
); EXPECTCY(-0.5);
3636 CONVERT(VarCyFromR8
, -0.4f
); EXPECTCY(-0.4);
3637 CONVERT(VarCyFromR8
, 0.4f
); EXPECTCY(0.4);
3638 CONVERT(VarCyFromR8
, 0.5f
); EXPECTCY(0.5);
3639 CONVERT(VarCyFromR8
, 0.6f
); EXPECTCY(0.6);
3640 CONVERT(VarCyFromR8
, 1.5f
); EXPECTCY(1.5);
3641 CONVERT(VarCyFromR8
, 1.00009f
); EXPECTCY(1.0001);
3642 CONVERT(VarCyFromR8
, -1.00001f
); EXPECTCY(-1);
3643 CONVERT(VarCyFromR8
, -1.00005f
); EXPECTCY(-1);
3644 CONVERT(VarCyFromR8
, -0.00009f
); EXPECTCY(-0.0001);
3645 CONVERT(VarCyFromR8
, -0.00005f
); EXPECTCY(0);
3646 CONVERT(VarCyFromR8
, -0.00001f
); EXPECTCY(0);
3647 CONVERT(VarCyFromR8
, 0.00001f
); EXPECTCY(0);
3648 CONVERT(VarCyFromR8
, 0.00005f
); EXPECTCY(0);
3649 CONVERT(VarCyFromR8
, 0.00009f
); EXPECTCY(0.0001);
3650 CONVERT(VarCyFromR8
, -1.00001f
); EXPECTCY(-1);
3651 CONVERT(VarCyFromR8
, -1.00005f
); EXPECTCY(-1);
3652 CONVERT(VarCyFromR8
, -1.00009f
); EXPECTCY(-1.0001);
3655 static void test_VarCyFromBool(void)
3657 CONVVARS(VARIANT_BOOL
);
3660 CHECKPTR(VarCyFromBool
);
3661 for (i
= -32768; i
< 32768; i
++)
3663 CONVERT(VarCyFromBool
, i
); EXPECTCY(i
);
3667 static void test_VarCyFromI8(void)
3671 CHECKPTR(VarCyFromI8
);
3672 CONVERT_I8(VarCyFromI8
, -214749, 2728163227ul); EXPECT_OVERFLOW
;
3673 CONVERT_I8(VarCyFromI8
, -214749, 2728163228ul); EXPECTCY64(2147483648ul,15808);
3674 CONVERT(VarCyFromI8
, -1); EXPECTCY(-1);
3675 CONVERT(VarCyFromI8
, 0); EXPECTCY(0);
3676 CONVERT(VarCyFromI8
, 1); EXPECTCY(1);
3677 CONVERT_I8(VarCyFromI8
, 214748, 1566804068); EXPECTCY64(2147483647ul, 4294951488ul);
3678 CONVERT_I8(VarCyFromI8
, 214748, 1566804069); EXPECT_OVERFLOW
;
3681 static void test_VarCyFromUI8(void)
3685 CHECKPTR(VarCyFromUI8
);
3686 CONVERT(VarCyFromUI8
, 0); EXPECTCY(0);
3687 CONVERT(VarCyFromUI8
, 1); EXPECTCY(1);
3688 CONVERT_I8(VarCyFromUI8
, 214748, 1566804068); EXPECTCY64(2147483647ul, 4294951488ul);
3689 CONVERT_I8(VarCyFromUI8
, 214748, 1566804069); EXPECT_OVERFLOW
;
3692 static void test_VarCyFromDec(void)
3696 CHECKPTR(VarCyFromDec
);
3698 CONVERT_BADDEC(VarCyFromDec
);
3700 CONVERT_DEC(VarCyFromDec
,0,0x80,0,1); EXPECTCY(-1);
3701 CONVERT_DEC(VarCyFromDec
,0,0,0,0); EXPECTCY(0);
3702 CONVERT_DEC(VarCyFromDec
,0,0,0,1); EXPECTCY(1);
3704 CONVERT_DEC64(VarCyFromDec
,0,0,0,214748, 1566804068); EXPECTCY64(2147483647ul, 4294951488ul);
3705 CONVERT_DEC64(VarCyFromDec
,0,0,0,214748, 1566804069); EXPECT_OVERFLOW
;
3707 CONVERT_DEC(VarCyFromDec
,2,0,0,100); EXPECTCY(1);
3708 CONVERT_DEC(VarCyFromDec
,2,0x80,0,100); EXPECTCY(-1);
3709 CONVERT_DEC(VarCyFromDec
,2,0x80,0,1); EXPECTCY(-0.01);
3710 CONVERT_DEC(VarCyFromDec
,2,0,0,1); EXPECTCY(0.01);
3711 CONVERT_DEC(VarCyFromDec
,2,0x80,0,1); EXPECTCY(-0.01);
3712 CONVERT_DEC(VarCyFromDec
,2,0,0,999); EXPECTCY(9.99);
3713 CONVERT_DEC(VarCyFromDec
,2,0x80,0,999); EXPECTCY(-9.99);
3714 CONVERT_DEC(VarCyFromDec
,2,0,0,1500); EXPECTCY(15);
3715 CONVERT_DEC(VarCyFromDec
,2,0x80,0,1500); EXPECTCY(-15);
3718 static void test_VarCyFromDate(void)
3722 CHECKPTR(VarCyFromDate
);
3724 #if defined(__i386__) && (defined(_MSC_VER) || defined(__GNUC__))
3725 CONVERT(VarCyFromR8
, -461168601842738.7904); EXPECTCY64(0xbfffffff, 0xffffff23);
3728 CONVERT(VarCyFromDate
, -1.0); EXPECTCY(-1);
3729 CONVERT(VarCyFromDate
, -0.0); EXPECTCY(0);
3730 CONVERT(VarCyFromDate
, 1.0); EXPECTCY(1);
3731 CONVERT(VarCyFromDate
, -4611686018427388416.1); EXPECT_OVERFLOW
;
3732 CONVERT(VarCyFromDate
, 4611686018427387648.0); EXPECT_OVERFLOW
;
3735 CONVERT(VarCyFromDate
, -1.5f
); EXPECTCY(-1.5);
3736 CONVERT(VarCyFromDate
, -0.6f
); EXPECTCY(-0.6);
3737 CONVERT(VarCyFromDate
, -0.5f
); EXPECTCY(-0.5);
3738 CONVERT(VarCyFromDate
, -0.4f
); EXPECTCY(-0.4);
3739 CONVERT(VarCyFromDate
, 0.4f
); EXPECTCY(0.4);
3740 CONVERT(VarCyFromDate
, 0.5f
); EXPECTCY(0.5);
3741 CONVERT(VarCyFromDate
, 0.6f
); EXPECTCY(0.6);
3742 CONVERT(VarCyFromDate
, 1.5f
); EXPECTCY(1.5);
3743 CONVERT(VarCyFromDate
, 1.00009f
); EXPECTCY(1.0001);
3744 CONVERT(VarCyFromDate
, -1.00001f
); EXPECTCY(-1);
3745 CONVERT(VarCyFromDate
, -1.00005f
); EXPECTCY(-1);
3746 CONVERT(VarCyFromDate
, -0.00009f
); EXPECTCY(-0.0001);
3747 CONVERT(VarCyFromDate
, -0.00005f
); EXPECTCY(0);
3748 CONVERT(VarCyFromDate
, -0.00001f
); EXPECTCY(0);
3749 CONVERT(VarCyFromDate
, 0.00001f
); EXPECTCY(0);
3750 CONVERT(VarCyFromDate
, 0.00005f
); EXPECTCY(0);
3751 CONVERT(VarCyFromDate
, 0.00009f
); EXPECTCY(0.0001);
3752 CONVERT(VarCyFromDate
, -1.00001f
); EXPECTCY(-1);
3753 CONVERT(VarCyFromDate
, -1.00005f
); EXPECTCY(-1);
3754 CONVERT(VarCyFromDate
, -1.00009f
); EXPECTCY(-1.0001);
3757 #define MATHVARS1 HRESULT hres; double left = 0.0; CY cyLeft, out
3758 #define MATHVARS2 MATHVARS1; double right = 0.0; CY cyRight
3759 #define MATH1(func, l) left = (double)l; pVarCyFromR8(left, &cyLeft); hres = p##func(cyLeft, &out)
3760 #define MATH2(func, l, r) left = (double)l; right = (double)r; \
3761 pVarCyFromR8(left, &cyLeft); pVarCyFromR8(right, &cyRight); \
3762 hres = p##func(cyLeft, cyRight, &out)
3764 static void test_VarCyAdd(void)
3769 MATH2(VarCyAdd
, 0.5, 0.5); EXPECTCY(1);
3770 MATH2(VarCyAdd
, 0.5, -0.4); EXPECTCY(0.1);
3771 MATH2(VarCyAdd
, 0.5, -0.6); EXPECTCY(-0.1);
3772 MATH2(VarCyAdd
, -0.5, -0.5); EXPECTCY(-1);
3773 MATH2(VarCyAdd
, -922337203685476.0, -922337203685476.0); EXPECT_OVERFLOW
;
3774 MATH2(VarCyAdd
, -922337203685476.0, 922337203685476.0); EXPECTCY(0);
3775 MATH2(VarCyAdd
, 922337203685476.0, -922337203685476.0); EXPECTCY(0);
3776 MATH2(VarCyAdd
, 922337203685476.0, 922337203685476.0); EXPECT_OVERFLOW
;
3779 static void test_VarCyMul(void)
3784 MATH2(VarCyMul
, 534443.0, 0.0); EXPECTCY(0);
3785 MATH2(VarCyMul
, 0.5, 0.5); EXPECTCY(0.25);
3786 MATH2(VarCyMul
, 0.5, -0.4); EXPECTCY(-0.2);
3787 MATH2(VarCyMul
, 0.5, -0.6); EXPECTCY(-0.3);
3788 MATH2(VarCyMul
, -0.5, -0.5); EXPECTCY(0.25);
3789 MATH2(VarCyMul
, 922337203685476.0, 20000); EXPECT_OVERFLOW
;
3792 static void test_VarCySub(void)
3797 MATH2(VarCySub
, 0.5, 0.5); EXPECTCY(0);
3798 MATH2(VarCySub
, 0.5, -0.4); EXPECTCY(0.9);
3799 MATH2(VarCySub
, 0.5, -0.6); EXPECTCY(1.1);
3800 MATH2(VarCySub
, -0.5, -0.5); EXPECTCY(0);
3801 MATH2(VarCySub
, -922337203685476.0, -922337203685476.0); EXPECTCY(0);
3802 MATH2(VarCySub
, -922337203685476.0, 922337203685476.0); EXPECT_OVERFLOW
;
3803 MATH2(VarCySub
, 922337203685476.0, -922337203685476.0); EXPECT_OVERFLOW
;
3804 MATH2(VarCySub
, 922337203685476.0, 922337203685476.0); EXPECTCY(0);
3807 static void test_VarCyAbs(void)
3812 MATH1(VarCyAbs
, 0.5); EXPECTCY(0.5);
3813 MATH1(VarCyAbs
, -0.5); EXPECTCY(0.5);
3814 MATH1(VarCyAbs
, 922337203685476.0); EXPECTCY64(2147483647ul,4294951488ul);
3815 MATH1(VarCyAbs
, -922337203685476.0); EXPECTCY64(2147483647ul,4294951488ul);
3818 static void test_VarCyNeg(void)
3823 MATH1(VarCyNeg
, 0.5); EXPECTCY(-0.5);
3824 MATH1(VarCyNeg
, -0.5); EXPECTCY(0.5);
3825 MATH1(VarCyNeg
, 922337203685476.0); EXPECTCY64(2147483648ul,15808);
3826 MATH1(VarCyNeg
, -922337203685476.0); EXPECTCY64(2147483647ul,4294951488ul);
3829 #define MATHMULI4(l, r) left = l; right = r; pVarCyFromR8(left, &cyLeft); \
3830 hres = pVarCyMulI4(cyLeft, right, &out)
3832 static void test_VarCyMulI4(void)
3837 CHECKPTR(VarCyMulI4
);
3838 MATHMULI4(534443.0, 0); EXPECTCY(0);
3839 MATHMULI4(0.5, 1); EXPECTCY(0.5);
3840 MATHMULI4(0.5, 2); EXPECTCY(1);
3841 MATHMULI4(922337203685476.0, 1); EXPECTCY64(2147483647ul,4294951488ul);
3842 MATHMULI4(922337203685476.0, 2); EXPECT_OVERFLOW
;
3845 #define MATHMULI8(l, r) left = l; right = r; pVarCyFromR8(left, &cyLeft); \
3846 hres = pVarCyMulI8(cyLeft, right, &out)
3848 static void test_VarCyMulI8(void)
3853 CHECKPTR(VarCyMulI8
);
3854 MATHMULI8(534443.0, 0); EXPECTCY(0);
3855 MATHMULI8(0.5, 1); EXPECTCY(0.5);
3856 MATHMULI8(0.5, 2); EXPECTCY(1);
3857 MATHMULI8(922337203685476.0, 1); EXPECTCY64(2147483647ul,4294951488ul);
3858 MATHMULI8(922337203685476.0, 2); EXPECT_OVERFLOW
;
3861 #define MATHCMP(l, r) left = l; right = r; pVarCyFromR8(left, &cyLeft); pVarCyFromR8(right, &cyRight); \
3862 hres = pVarCyCmp(cyLeft, cyRight); out.int64 = hres
3864 static void test_VarCyCmp(void)
3869 MATHCMP(-1.0, -1.0); EXPECT_EQ
;
3870 MATHCMP(-1.0, 0.0); EXPECT_LT
;
3871 MATHCMP(-1.0, 1.0); EXPECT_LT
;
3872 MATHCMP(-1.0, 2.0); EXPECT_LT
;
3873 MATHCMP(0.0, 1.0); EXPECT_LT
;
3874 MATHCMP(0.0, 0.0); EXPECT_EQ
;
3875 MATHCMP(0.0, -1.0); EXPECT_GT
;
3876 MATHCMP(1.0, -1.0); EXPECT_GT
;
3877 MATHCMP(1.0, 0.0); EXPECT_GT
;
3878 MATHCMP(1.0, 1.0); EXPECT_EQ
;
3879 MATHCMP(1.0, 2.0); EXPECT_LT
;
3882 #define MATHCMPR8(l, r) left = l; right = r; pVarCyFromR8(left, &cyLeft); \
3883 hres = pVarCyCmpR8(cyLeft, right); out.int64 = hres
3885 static void test_VarCyCmpR8(void)
3890 CHECKPTR(VarCyCmpR8
);
3891 MATHCMPR8(-1.0, -1.0); EXPECT_EQ
;
3892 MATHCMPR8(-1.0, 0.0); EXPECT_LT
;
3893 MATHCMPR8(-1.0, 1.0); EXPECT_LT
;
3894 MATHCMPR8(-1.0, 2.0); EXPECT_LT
;
3895 MATHCMPR8(0.0, 1.0); EXPECT_LT
;
3896 MATHCMPR8(0.0, 0.0); EXPECT_EQ
;
3897 MATHCMPR8(0.0, -1.0); EXPECT_GT
;
3898 MATHCMPR8(1.0, -1.0); EXPECT_GT
;
3899 MATHCMPR8(1.0, 0.0); EXPECT_GT
;
3900 MATHCMPR8(1.0, 1.0); EXPECT_EQ
;
3901 MATHCMPR8(1.0, 2.0); EXPECT_LT
;
3905 #define MATHRND(l, r) left = l; right = r; pVarCyFromR8(left, &cyLeft); \
3906 hres = pVarCyRound(cyLeft, right, &out)
3908 static void test_VarCyRound(void)
3913 CHECKPTR(VarCyRound
);
3914 MATHRND(0.5432, 5); EXPECTCY(0.5432);
3915 MATHRND(0.5432, 4); EXPECTCY(0.5432);
3916 MATHRND(0.5432, 3); EXPECTCY(0.543);
3917 MATHRND(0.5432, 2); EXPECTCY(0.54);
3918 MATHRND(0.5432, 1); EXPECTCY(0.5);
3919 MATHRND(0.5532, 0); EXPECTCY(1);
3920 MATHRND(0.5532, -1); EXPECT_INVALID
;
3922 MATHRND(0.5568, 5); EXPECTCY(0.5568);
3923 MATHRND(0.5568, 4); EXPECTCY(0.5568);
3924 MATHRND(0.5568, 3); EXPECTCY(0.557);
3925 MATHRND(0.5568, 2); EXPECTCY(0.56);
3926 MATHRND(0.5568, 1); EXPECTCY(0.6);
3927 MATHRND(0.5568, 0); EXPECTCY(1);
3928 MATHRND(0.5568, -1); EXPECT_INVALID
;
3930 MATHRND(0.4999, 0); EXPECTCY(0);
3931 MATHRND(0.5000, 0); EXPECTCY(0);
3932 MATHRND(0.5001, 0); EXPECTCY(1);
3933 MATHRND(1.4999, 0); EXPECTCY(1);
3934 MATHRND(1.5000, 0); EXPECTCY(2);
3935 MATHRND(1.5001, 0); EXPECTCY(2);
3938 #define MATHFIX(l) left = l; pVarCyFromR8(left, &cyLeft); \
3939 hres = pVarCyFix(cyLeft, &out)
3941 static void test_VarCyFix(void)
3946 MATHFIX(-1.0001); EXPECTCY(-1);
3947 MATHFIX(-1.4999); EXPECTCY(-1);
3948 MATHFIX(-1.5001); EXPECTCY(-1);
3949 MATHFIX(-1.9999); EXPECTCY(-1);
3950 MATHFIX(-0.0001); EXPECTCY(0);
3951 MATHFIX(-0.4999); EXPECTCY(0);
3952 MATHFIX(-0.5001); EXPECTCY(0);
3953 MATHFIX(-0.9999); EXPECTCY(0);
3954 MATHFIX(0.0001); EXPECTCY(0);
3955 MATHFIX(0.4999); EXPECTCY(0);
3956 MATHFIX(0.5001); EXPECTCY(0);
3957 MATHFIX(0.9999); EXPECTCY(0);
3958 MATHFIX(1.0001); EXPECTCY(1);
3959 MATHFIX(1.4999); EXPECTCY(1);
3960 MATHFIX(1.5001); EXPECTCY(1);
3961 MATHFIX(1.9999); EXPECTCY(1);
3964 #define MATHINT(l) left = l; pVarCyFromR8(left, &cyLeft); \
3965 hres = pVarCyInt(cyLeft, &out)
3967 static void test_VarCyInt(void)
3972 MATHINT(-1.0001); EXPECTCY(-2);
3973 MATHINT(-1.4999); EXPECTCY(-2);
3974 MATHINT(-1.5001); EXPECTCY(-2);
3975 MATHINT(-1.9999); EXPECTCY(-2);
3976 MATHINT(-0.0001); EXPECTCY(-1);
3977 MATHINT(-0.4999); EXPECTCY(-1);
3978 MATHINT(-0.5001); EXPECTCY(-1);
3979 MATHINT(-0.9999); EXPECTCY(-1);
3980 MATHINT(0.0001); EXPECTCY(0);
3981 MATHINT(0.4999); EXPECTCY(0);
3982 MATHINT(0.5001); EXPECTCY(0);
3983 MATHINT(0.9999); EXPECTCY(0);
3984 MATHINT(1.0001); EXPECTCY(1);
3985 MATHINT(1.4999); EXPECTCY(1);
3986 MATHINT(1.5001); EXPECTCY(1);
3987 MATHINT(1.9999); EXPECTCY(1);
3995 #define CONV_TYPE DECIMAL
3997 #define EXPECTRES(res, x) \
3998 ok(hres == S_OK || ((HRESULT)res != S_OK && hres == (HRESULT)res), \
3999 "expected hres " #x ", got hres=0x%08x\n", hres)
4001 #define EXPECTDEC(scl, sgn, hi, lo) ok(hres == S_OK && \
4002 S(U(out)).scale == (BYTE)(scl) && S(U(out)).sign == (BYTE)(sgn) && \
4003 out.Hi32 == (ULONG)(hi) && U1(out).Lo64 == (ULONG64)(lo), \
4004 "expected (%d,%d,%d,(%x %x)), got (%d,%d,%d,(%x %x)) hres 0x%08x\n", \
4005 scl, sgn, hi, (LONG)((LONG64)(lo) >> 32), (LONG)((lo) & 0xffffffff), S(U(out)).scale, \
4006 S(U(out)).sign, out.Hi32, S1(U1(out)).Mid32, S1(U1(out)).Lo32, hres)
4008 #define EXPECTDEC64(scl, sgn, hi, mid, lo) ok(hres == S_OK && \
4009 S(U(out)).scale == (BYTE)(scl) && S(U(out)).sign == (BYTE)(sgn) && \
4010 out.Hi32 == (ULONG)(hi) && S1(U1(out)).Mid32 == (ULONG)(mid) && \
4011 S1(U1(out)).Lo32 == (ULONG)(lo), \
4012 "expected (%d,%d,%d,(%x %x)), got (%d,%d,%d,(%x %x)) hres 0x%08x\n", \
4013 scl, sgn, hi, (LONG)(mid), (LONG)(lo), S(U(out)).scale, \
4014 S(U(out)).sign, out.Hi32, S1(U1(out)).Mid32, S1(U1(out)).Lo32, hres)
4016 #define EXPECTDECI if (i < 0) EXPECTDEC(0, 0x80, 0, -i); else EXPECTDEC(0, 0, 0, i)
4018 static void test_VarDecFromI1(void)
4020 CONVVARS(signed char);
4023 CHECKPTR(VarDecFromI1
);
4024 for (i
= -128; i
< 128; i
++)
4026 CONVERT(VarDecFromI1
,i
); EXPECTDECI
;
4030 static void test_VarDecFromI2(void)
4035 CHECKPTR(VarDecFromI2
);
4036 for (i
= -32768; i
< 32768; i
++)
4038 CONVERT(VarDecFromI2
,i
); EXPECTDECI
;
4042 static void test_VarDecFromI4(void)
4047 CHECKPTR(VarDecFromI4
);
4048 for (i
= -32768; i
< 32768; i
++)
4050 CONVERT(VarDecFromI4
,i
); EXPECTDECI
;
4054 static void test_VarDecFromI8(void)
4059 CHECKPTR(VarDecFromI8
);
4060 for (i
= -32768; i
< 32768; i
++)
4062 CONVERT(VarDecFromI8
,i
); EXPECTDECI
;
4066 static void test_VarDecFromUI1(void)
4071 CHECKPTR(VarDecFromUI1
);
4072 for (i
= 0; i
< 256; i
++)
4074 CONVERT(VarDecFromUI1
,i
); EXPECTDECI
;
4078 static void test_VarDecFromUI2(void)
4083 CHECKPTR(VarDecFromUI2
);
4084 for (i
= 0; i
< 65536; i
++)
4086 CONVERT(VarDecFromUI2
,i
); EXPECTDECI
;
4090 static void test_VarDecFromUI4(void)
4095 CHECKPTR(VarDecFromUI4
);
4096 for (i
= 0; i
< 65536; i
++)
4098 CONVERT(VarDecFromUI4
,i
); EXPECTDECI
;
4102 static void test_VarDecFromUI8(void)
4107 CHECKPTR(VarDecFromUI8
);
4108 for (i
= 0; i
< 65536; i
++)
4110 CONVERT(VarDecFromUI8
,i
); EXPECTDECI
;
4114 static void test_VarDecFromBool(void)
4119 CHECKPTR(VarDecFromBool
);
4120 /* Test all possible type values. Note that the result is reduced to 0 or -1 */
4121 for (i
= -32768; i
< 0; i
++)
4123 CONVERT(VarDecFromBool
,i
);
4125 EXPECTDEC(0,0x80,0,1);
4131 static void test_VarDecFromR4(void)
4135 CHECKPTR(VarDecFromR4
);
4137 CONVERT(VarDecFromR4
,-0.6f
); EXPECTDEC(1,0x80,0,6);
4138 CONVERT(VarDecFromR4
,-0.5f
); EXPECTDEC(1,0x80,0,5);
4139 CONVERT(VarDecFromR4
,-0.4f
); EXPECTDEC(1,0x80,0,4);
4140 CONVERT(VarDecFromR4
,0.0f
); EXPECTDEC(0,0,0,0);
4141 CONVERT(VarDecFromR4
,0.4f
); EXPECTDEC(1,0,0,4);
4142 CONVERT(VarDecFromR4
,0.5f
); EXPECTDEC(1,0,0,5);
4143 CONVERT(VarDecFromR4
,0.6f
); EXPECTDEC(1,0,0,6);
4146 static void test_VarDecFromR8(void)
4150 CHECKPTR(VarDecFromR8
);
4152 CONVERT(VarDecFromR8
,-0.6); EXPECTDEC(1,0x80,0,6);
4153 CONVERT(VarDecFromR8
,-0.5); EXPECTDEC(1,0x80,0,5);
4154 CONVERT(VarDecFromR8
,-0.4); EXPECTDEC(1,0x80,0,4);
4155 CONVERT(VarDecFromR8
,0.0); EXPECTDEC(0,0,0,0);
4156 CONVERT(VarDecFromR8
,0.4); EXPECTDEC(1,0,0,4);
4157 CONVERT(VarDecFromR8
,0.5); EXPECTDEC(1,0,0,5);
4158 CONVERT(VarDecFromR8
,0.6); EXPECTDEC(1,0,0,6);
4161 static void test_VarDecFromDate(void)
4165 CHECKPTR(VarDecFromDate
);
4167 CONVERT(VarDecFromDate
,-0.6); EXPECTDEC(1,0x80,0,6);
4168 CONVERT(VarDecFromDate
,-0.5); EXPECTDEC(1,0x80,0,5);
4169 CONVERT(VarDecFromDate
,-0.4); EXPECTDEC(1,0x80,0,4);
4170 CONVERT(VarDecFromDate
,0.0); EXPECTDEC(0,0,0,0);
4171 CONVERT(VarDecFromDate
,0.4); EXPECTDEC(1,0,0,4);
4172 CONVERT(VarDecFromDate
,0.5); EXPECTDEC(1,0,0,5);
4173 CONVERT(VarDecFromDate
,0.6); EXPECTDEC(1,0,0,6);
4176 static void test_VarDecFromStr(void)
4181 CHECKPTR(VarDecFromStr
);
4183 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
, SUBLANG_ENGLISH_US
), SORT_DEFAULT
);
4185 CONVERT_STR(VarDecFromStr
,NULL
,0); EXPECT_MISMATCH
;
4186 CONVERT_STR(VarDecFromStr
,"-1", LOCALE_NOUSEROVERRIDE
); EXPECTDEC(0,0x80,0,1);
4187 CONVERT_STR(VarDecFromStr
,"0", LOCALE_NOUSEROVERRIDE
); EXPECTDEC(0,0,0,0);
4188 CONVERT_STR(VarDecFromStr
,"1", LOCALE_NOUSEROVERRIDE
); EXPECTDEC(0,0,0,1);
4189 CONVERT_STR(VarDecFromStr
,"0.5", LOCALE_NOUSEROVERRIDE
); EXPECTDEC(1,0,0,5);
4190 CONVERT_STR(VarDecFromStr
,"4294967296", LOCALE_NOUSEROVERRIDE
); EXPECTDEC64(0,0,0,1,0);
4191 CONVERT_STR(VarDecFromStr
,"18446744073709551616", LOCALE_NOUSEROVERRIDE
); EXPECTDEC(0,0,1,0);
4192 CONVERT_STR(VarDecFromStr
,"4294967296.0", LOCALE_NOUSEROVERRIDE
); EXPECTDEC64(0,0,0,1,0);
4193 CONVERT_STR(VarDecFromStr
,"18446744073709551616.0", LOCALE_NOUSEROVERRIDE
); EXPECTDEC(0,0,1,0);
4196 static void test_VarDecFromCy(void)
4200 CHECKPTR(VarDecFromCy
);
4202 CONVERT_CY(VarDecFromCy
, -1); EXPECTDEC(4,0x80,0,10000);
4203 CONVERT_CY(VarDecFromCy
, 0); EXPECTDEC(4,0,0,0);
4204 CONVERT_CY(VarDecFromCy
, 1); EXPECTDEC(4,0,0,10000);
4205 CONVERT_CY(VarDecFromCy
, 0.5); EXPECTDEC(4,0,0,5000);
4209 #define MATHVARS1 HRESULT hres; DECIMAL l, out
4211 #define MATHVARS2 MATHVARS1; DECIMAL r
4213 #define MATH1(func) hres = p##func(&l, &out)
4215 #define MATH2(func) hres = p##func(&l, &r, &out)
4217 static void test_VarDecAbs(void)
4221 CHECKPTR(VarDecAbs
);
4222 SETDEC(l
,0,0x80,0,1); MATH1(VarDecAbs
); EXPECTDEC(0,0,0,1);
4223 SETDEC(l
,0,0,0,0); MATH1(VarDecAbs
); EXPECTDEC(0,0,0,0);
4224 SETDEC(l
,0,0x80,0,0); MATH1(VarDecAbs
); EXPECTDEC(0,0,0,0);
4225 SETDEC(l
,0,0,0,1); MATH1(VarDecAbs
); EXPECTDEC(0,0,0,1);
4227 /* Doesn't check for invalid input */
4228 SETDEC(l
,0,0x7f,0,1); MATH1(VarDecAbs
); EXPECTDEC(0,0x7f,0,1);
4229 SETDEC(l
,0,0x80,29,1); MATH1(VarDecAbs
); EXPECTDEC(0,0,29,1);
4232 static void test_VarDecNeg(void)
4236 CHECKPTR(VarDecNeg
);
4237 SETDEC(l
,0,0x80,0,1); MATH1(VarDecNeg
); EXPECTDEC(0,0,0,1);
4238 SETDEC(l
,0,0,0,0); MATH1(VarDecNeg
); EXPECTDEC(0,0x80,0,0); /* '-0'! */
4239 SETDEC(l
,0,0x80,0,0); MATH1(VarDecNeg
); EXPECTDEC(0,0,0,0);
4240 SETDEC(l
,0,0,0,1); MATH1(VarDecNeg
); EXPECTDEC(0,0x80,0,1);
4242 /* Doesn't check for invalid input */
4243 SETDEC(l
,0,0x7f,0,1); MATH1(VarDecNeg
); EXPECTDEC(0,0xff,0,1);
4244 SETDEC(l
,0,0x80,29,1); MATH1(VarDecNeg
); EXPECTDEC(0,0,29,1);
4245 SETDEC(l
,0,0,29,1); MATH1(VarDecNeg
); EXPECTDEC(0,0x80,29,1);
4248 static void test_VarDecAdd(void)
4252 CHECKPTR(VarDecAdd
);
4253 SETDEC(l
,0,0,0,0); SETDEC(r
,0,0,0,0); MATH2(VarDecAdd
); EXPECTDEC(0,0,0,0);
4254 SETDEC(l
,0,0,0,0); SETDEC(r
,0,0x80,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0x80,0,1);
4255 SETDEC(l
,0,0,0,0); SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0,0,1);
4257 SETDEC(l
,0,0,0,1); SETDEC(r
,0,0,0,0); MATH2(VarDecAdd
); EXPECTDEC(0,0,0,1);
4258 SETDEC(l
,0,0,0,1); SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0,0,2);
4259 SETDEC(l
,0,0,0,1); SETDEC(r
,0,0x80,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0x80,0,0); /* '-0'! */
4260 SETDEC(l
,0,0,0,1); SETDEC(r
,0,0x80,0,2); MATH2(VarDecAdd
); EXPECTDEC(0,0x80,0,1);
4262 SETDEC(l
,0,0x80,0,0); SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0,0,1);
4263 SETDEC(l
,0,0x80,0,1); SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0,0,0);
4264 SETDEC(l
,0,0x80,0,1); SETDEC(r
,0,0,0,2); MATH2(VarDecAdd
); EXPECTDEC(0,0,0,1);
4265 SETDEC(l
,0,0x80,0,1); SETDEC(r
,0,0x80,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0x80,0,2);
4266 SETDEC(l
,0,0x80,0,2); SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0x80,0,1);
4268 SETDEC(l
,0,0,0,0xffffffff); SETDEC(r
,0,0x80,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0,0,0xfffffffe);
4269 SETDEC(l
,0,0,0,0xffffffff); SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0,0,(ULONG64
)1 << 32);
4270 SETDEC(l
,0,0,0,0xffffffff); SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0,0,(ULONG64
)1 << 32);
4272 SETDEC64(l
,0,0,0,0xffffffff,0); SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
); EXPECTDEC64(0,0,0,0xffffffff,1);
4273 SETDEC64(l
,0,0,0,0xffffffff,0); SETDEC(r
,0,0x80,0,1); MATH2(VarDecAdd
);
4274 EXPECTDEC64(0,0,0,0xfffffffe,0xffffffff);
4276 SETDEC64(l
,0,0,0,0xffffffff,0xffffffff); SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0,1,0);
4277 SETDEC64(l
,0,0,0,0xffffffff,0xffffffff); SETDEC(r
,0,0x80,0,1); MATH2(VarDecAdd
);
4278 EXPECTDEC64(0,0,0,0xffffffff,0xfffffffe);
4280 SETDEC(l
,0,0,0xffffffff,0); SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
); EXPECTDEC(0,0,0xffffffff,1);
4281 SETDEC(l
,0,0,0xffffffff,0); SETDEC(r
,0,0x80,0,1); MATH2(VarDecAdd
);
4282 EXPECTDEC64(0,0,0xfffffffe,0xffffffff,0xffffffff);
4284 SETDEC64(l
,0,0,0xffffffff,0xffffffff,0xffffffff);SETDEC(r
,0,0x80,0,1); MATH2(VarDecAdd
);
4285 EXPECTDEC64(0,0,0xffffffff,0xffffffff,0xfffffffe);
4286 SETDEC64(l
,0,0,0xffffffff,0xffffffff,0xffffffff);SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
);
4287 ok(hres
== DISP_E_OVERFLOW
,"Expected overflow, got (%d,%d,%d,(%8x,%8x)x) hres 0x%08x\n",
4288 S(U(out
)).scale
, S(U(out
)).sign
, out
.Hi32
, S1(U1(out
)).Mid32
, S1(U1(out
)).Lo32
, hres
);
4290 /* Promotes to the highest scale, so here the results are in the scale of 2 */
4291 SETDEC(l
,2,0,0,0); SETDEC(r
,0,0,0,0); MATH2(VarDecAdd
); EXPECTDEC(2,0,0,0);
4292 SETDEC(l
,2,0,0,100); SETDEC(r
,0,0,0,1); MATH2(VarDecAdd
); EXPECTDEC(2,0,0,200);
4295 static void test_VarDecSub(void)
4299 CHECKPTR(VarDecSub
);
4300 SETDEC(l
,0,0,0,0); SETDEC(r
,0,0,0,0); MATH2(VarDecSub
); EXPECTDEC(0,0x80,0,0);
4301 SETDEC(l
,0,0,0,0); SETDEC(r
,0,0,0,1); MATH2(VarDecSub
); EXPECTDEC(0,0x80,0,1);
4302 SETDEC(l
,0,0,0,1); SETDEC(r
,0,0,0,1); MATH2(VarDecSub
); EXPECTDEC(0,0x80,0,0);
4303 SETDEC(l
,0,0,0,1); SETDEC(r
,0,0x80,0,1); MATH2(VarDecSub
); EXPECTDEC(0,0,0,2);
4306 static void test_VarDecMul(void)
4310 CHECKPTR(VarDecMul
);
4311 SETDEC(l
,0,0,0,0); SETDEC(r
,0,0,0,0); MATH2(VarDecMul
); EXPECTDEC(0,0,0,0);
4312 SETDEC(l
,0,0,0,1); SETDEC(r
,0,0,0,0); MATH2(VarDecMul
); EXPECTDEC(0,0,0,0);
4313 SETDEC(l
,0,0,0,0); SETDEC(r
,0,0,0,1); MATH2(VarDecMul
); EXPECTDEC(0,0,0,0);
4314 SETDEC(l
,0,0,0,1); SETDEC(r
,0,0,0,1); MATH2(VarDecMul
); EXPECTDEC(0,0,0,1);
4315 SETDEC(l
,0,0,0,45000);SETDEC(r
,0,0,0,2); MATH2(VarDecMul
); EXPECTDEC(0,0,0,90000);
4316 SETDEC(l
,0,0,0,2); SETDEC(r
,0,0,0,45000); MATH2(VarDecMul
); EXPECTDEC(0,0,0,90000);
4318 SETDEC(l
,0,0x80,0,2); SETDEC(r
,0,0,0,2); MATH2(VarDecMul
); EXPECTDEC(0,0x80,0,4);
4319 SETDEC(l
,0,0,0,2); SETDEC(r
,0,0x80,0,2); MATH2(VarDecMul
); EXPECTDEC(0,0x80,0,4);
4320 SETDEC(l
,0,0x80,0,2); SETDEC(r
,0,0x80,0,2); MATH2(VarDecMul
); EXPECTDEC(0,0,0,4);
4322 SETDEC(l
,4,0,0,2); SETDEC(r
,0,0,0,2); MATH2(VarDecMul
); EXPECTDEC(4,0,0,4);
4323 SETDEC(l
,0,0,0,2); SETDEC(r
,3,0,0,2); MATH2(VarDecMul
); EXPECTDEC(3,0,0,4);
4324 SETDEC(l
,4,0,0,2); SETDEC(r
,3,0,0,2); MATH2(VarDecMul
); EXPECTDEC(7,0,0,4);
4325 /* this last one shows that native oleaut32 does *not* gratuitously seize opportunities
4326 to reduce the scale if possible - the canonical result for the expected value is (6,0,0,1)
4328 SETDEC(l
,4,0,0,5); SETDEC(r
,3,0,0,2); MATH2(VarDecMul
); EXPECTDEC(7,0,0,10);
4330 SETDEC64(l
,0,0,0,0xFFFFFFFF,0xFFFFFFFF); SETDEC(r
,0,0,0,2); MATH2(VarDecMul
); EXPECTDEC64(0,0,1,0xFFFFFFFF,0xFFFFFFFE);
4331 SETDEC(l
,0,0,0,2); SETDEC64(r
,0,0,0,0xFFFFFFFF,0xFFFFFFFF); MATH2(VarDecMul
); EXPECTDEC64(0,0,1,0xFFFFFFFF,0xFFFFFFFE);
4332 SETDEC(l
,0,0,1,1); SETDEC(r
,0,0,0,0x80000000); MATH2(VarDecMul
); EXPECTDEC(0,0,0x80000000,0x80000000);
4333 SETDEC(l
,0,0,0,0x80000000); SETDEC(r
,0,0,1,1); MATH2(VarDecMul
); EXPECTDEC(0,0,0x80000000,0x80000000);
4335 /* near-overflow, used as a reference */
4336 SETDEC64(l
,0,0,0,0xFFFFFFFF,0xFFFFFFFF); SETDEC(r
,0,0,0,2000000000); MATH2(VarDecMul
);EXPECTDEC64(0,0,1999999999,0xFFFFFFFF,0x88CA6C00);
4337 /* actual overflow - right operand is 10 times the previous value */
4338 SETDEC64(l
,0,0,0,0xFFFFFFFF,0xFFFFFFFF); SETDEC64(r
,0,0,0,4,0xA817C800); MATH2(VarDecMul
);
4339 ok(hres
== DISP_E_OVERFLOW
,"Expected overflow, got (%d,%d,%d,(%8x,%8x)x) hres 0x%08x\n",
4340 S(U(out
)).scale
, S(U(out
)).sign
, out
.Hi32
, S1(U1(out
)).Mid32
, S1(U1(out
)).Lo32
, hres
);
4341 /* here, native oleaut32 has an opportunity to avert the overflow, by reducing the scale of the result */
4342 SETDEC64(l
,1,0,0,0xFFFFFFFF,0xFFFFFFFF); SETDEC64(r
,0,0,0,4,0xA817C800); MATH2(VarDecMul
);EXPECTDEC64(0,0,1999999999,0xFFFFFFFF,0x88CA6C00);
4344 /* near-overflow, used as a reference */
4345 SETDEC64(l
,0,0,1,0xFFFFFFFF,0xFFFFFFFE); SETDEC(r
,0,0,0,1000000000); MATH2(VarDecMul
);EXPECTDEC64(0,0,1999999999,0xFFFFFFFF,0x88CA6C00);
4346 /* actual overflow - right operand is 10 times the previous value */
4347 SETDEC64(l
,0,0,1,0xFFFFFFFF,0xFFFFFFFE); SETDEC64(r
,0,0,0,2,0x540BE400); MATH2(VarDecMul
);
4348 ok(hres
== DISP_E_OVERFLOW
,"Expected overflow, got (%d,%d,%d,(%8x,%8x)x) hres 0x%08x\n",
4349 S(U(out
)).scale
, S(U(out
)).sign
, out
.Hi32
, S1(U1(out
)).Mid32
, S1(U1(out
)).Lo32
, hres
);
4350 /* here, native oleaut32 has an opportunity to avert the overflow, by reducing the scale of the result */
4351 SETDEC64(l
,1,0,1,0xFFFFFFFF,0xFFFFFFFE); SETDEC64(r
,0,0,0,2,0x540BE400); MATH2(VarDecMul
);EXPECTDEC64(0,0,1999999999,0xFFFFFFFF,0x88CA6C00);
4353 /* this one shows that native oleaut32 is willing to lose significant digits in order to avert an overflow */
4354 SETDEC64(l
,2,0,0,0xFFFFFFFF,0xFFFFFFFF); SETDEC64(r
,0,0,0,9,0x502F9001); MATH2(VarDecMul
);EXPECTDEC64(1,0,0xee6b2800,0x19999998,0xab2e719a);
4357 static void test_VarDecDiv(void)
4361 CHECKPTR(VarDecDiv
);
4362 /* identity divisions */
4363 SETDEC(l
,0,0,0,0); SETDEC(r
,0,0,0,1); MATH2(VarDecDiv
); EXPECTDEC(0,0,0,0);
4364 SETDEC(l
,0,0,0,1); SETDEC(r
,0,0,0,1); MATH2(VarDecDiv
); EXPECTDEC(0,0,0,1);
4365 SETDEC(l
,1,0,0,1); SETDEC(r
,0,0,0,1); MATH2(VarDecDiv
); EXPECTDEC(1,0,0,1);
4367 /* exact divisions */
4368 SETDEC(l
,0,0,0,45); SETDEC(r
,0,0,0,9); MATH2(VarDecDiv
); EXPECTDEC(0,0,0,5);
4369 SETDEC(l
,1,0,0,45); SETDEC(r
,0,0,0,9); MATH2(VarDecDiv
); EXPECTDEC(1,0,0,5);
4370 SETDEC(l
,0,0,0,45); SETDEC(r
,1,0,0,9); MATH2(VarDecDiv
); EXPECTDEC(0,0,0,50);
4371 SETDEC(l
,1,0,0,45); SETDEC(r
,2,0,0,9); MATH2(VarDecDiv
); EXPECTDEC(0,0,0,50);
4372 /* these last three results suggest that native oleaut32 scales both operands down to zero
4373 before the division, but does *not* try to scale the result, even if it is possible -
4374 analogous to multiplication behavior
4376 SETDEC(l
,1,0,0,45); SETDEC(r
,1,0,0,9); MATH2(VarDecDiv
); EXPECTDEC(0,0,0,5);
4377 SETDEC(l
,2,0,0,450); SETDEC(r
,1,0,0,9); MATH2(VarDecDiv
); EXPECTDEC(1,0,0,50);
4379 /* inexact divisions */
4380 SETDEC(l
,0,0,0,1); SETDEC(r
,0,0,0,3); MATH2(VarDecDiv
); EXPECTDEC64(28,0,180700362,0x14b700cb,0x05555555);
4381 SETDEC(l
,1,0,0,1); SETDEC(r
,0,0,0,3); MATH2(VarDecDiv
); EXPECTDEC64(28,0,18070036,0x35458014,0x4d555555);
4382 SETDEC(l
,0,0,0,1); SETDEC(r
,1,0,0,3); MATH2(VarDecDiv
); EXPECTDEC64(28,0,1807003620,0xcf2607ee,0x35555555);
4383 SETDEC(l
,1,0,0,1); SETDEC(r
,2,0,0,3); MATH2(VarDecDiv
); EXPECTDEC64(28,0,1807003620,0xcf2607ee,0x35555555);
4384 SETDEC(l
,1,0,0,1); SETDEC(r
,1,0,0,3); MATH2(VarDecDiv
); EXPECTDEC64(28,0,180700362,0x14b700cb,0x05555555);
4385 SETDEC(l
,2,0,0,10); SETDEC(r
,1,0,0,3); MATH2(VarDecDiv
); EXPECTDEC64(28,0,180700362,0x14b700cb,0x05555555);
4387 /* this one shows that native oleaut32 rounds up the result */
4388 SETDEC(l
,0,0,0,2); SETDEC(r
,0,0,0,3); MATH2(VarDecDiv
); EXPECTDEC64(28,0,361400724,0x296e0196,0x0aaaaaab);
4391 SETDEC(l
,0,0x80,0,45); SETDEC(r
,0,0,0,9); MATH2(VarDecDiv
); EXPECTDEC(0,0x80,0,5);
4392 SETDEC(l
,0,0,0,45); SETDEC(r
,0,0x80,0,9); MATH2(VarDecDiv
);EXPECTDEC(0,0x80,0,5);
4393 SETDEC(l
,0,0x80,0,45); SETDEC(r
,0,0x80,0,9); MATH2(VarDecDiv
);EXPECTDEC(0,0,0,5);
4396 SETDEC(l
,0,0,0,0); SETDEC(r
,0,0,0,0); MATH2(VarDecDiv
);/* indeterminate */
4397 ok(hres
== DISP_E_DIVBYZERO
,"Expected division-by-zero, got (%d,%d,%d,(%8x,%8x)x) hres 0x%08x\n",
4398 S(U(out
)).scale
, S(U(out
)).sign
, out
.Hi32
, S1(U1(out
)).Mid32
, S1(U1(out
)).Lo32
, hres
);
4399 SETDEC(l
,0,0,0,1); SETDEC(r
,0,0,0,0); MATH2(VarDecDiv
);/* division by zero */
4400 ok(hres
== DISP_E_DIVBYZERO
,"Expected division-by-zero, got (%d,%d,%d,(%8x,%8x)x) hres 0x%08x\n",
4401 S(U(out
)).scale
, S(U(out
)).sign
, out
.Hi32
, S1(U1(out
)).Mid32
, S1(U1(out
)).Lo32
, hres
);
4405 static void test_VarDecCmp(void)
4409 CHECKPTR(VarDecCmp
);
4410 SETDEC(l
,0,0,0,1); SETDEC(out
,0,0,0,1); MATH1(VarDecCmp
); EXPECT_EQ
;
4411 SETDEC(l
,0,0,0,1); SETDEC(out
,0,0,0,0); MATH1(VarDecCmp
); EXPECT_GT
;
4412 SETDEC(l
,0,0,0,0); SETDEC(out
,0,0,0,1); MATH1(VarDecCmp
); EXPECT_LT
;
4420 #define CONV_TYPE VARIANT_BOOL
4422 #define _EXPECTRES(res, x, fs) \
4423 ok((hres == S_OK && out == (CONV_TYPE)(x)) || ((HRESULT)res != S_OK && hres == (HRESULT)res), \
4424 "expected " #x ", got " fs "; hres=0x%08x\n", out, hres)
4426 #define EXPECTRES(res, x) _EXPECTRES(res, x, "%d")
4428 #define CONVERTRANGE(func,start,end) for (i = start; i < end; i++) { \
4429 CONVERT(func, i); if (i) { EXPECT(VARIANT_TRUE); } else { EXPECT(VARIANT_FALSE); } }
4431 static void test_VarBoolFromI1(void)
4433 CONVVARS(signed char);
4436 CHECKPTR(VarBoolFromI1
);
4437 CONVERTRANGE(VarBoolFromI1
, -128, 128);
4440 static void test_VarBoolFromUI1(void)
4445 CHECKPTR(VarBoolFromUI1
);
4446 CONVERTRANGE(VarBoolFromUI1
, 0, 256);
4449 static void test_VarBoolFromI2(void)
4454 CHECKPTR(VarBoolFromI2
);
4455 CONVERTRANGE(VarBoolFromI2
, -32768, 32768);
4458 static void test_VarBoolFromUI2(void)
4463 CHECKPTR(VarBoolFromUI2
);
4464 CONVERTRANGE(VarBoolFromUI2
, 0, 65536);
4467 static void test_VarBoolFromI4(void)
4471 CHECKPTR(VarBoolFromI4
);
4472 CONVERT(VarBoolFromI4
, 0x80000000); EXPECT(VARIANT_TRUE
);
4473 CONVERT(VarBoolFromI4
, -1); EXPECT(VARIANT_TRUE
);
4474 CONVERT(VarBoolFromI4
, 0); EXPECT(VARIANT_FALSE
);
4475 CONVERT(VarBoolFromI4
, 1); EXPECT(VARIANT_TRUE
);
4476 CONVERT(VarBoolFromI4
, 0x7fffffff); EXPECT(VARIANT_TRUE
);
4479 static void test_VarBoolFromUI4(void)
4483 CHECKPTR(VarBoolFromUI4
);
4484 CONVERT(VarBoolFromI4
, 0); EXPECT(VARIANT_FALSE
);
4485 CONVERT(VarBoolFromI4
, 1); EXPECT(VARIANT_TRUE
);
4486 CONVERT(VarBoolFromI4
, 0x80000000); EXPECT(VARIANT_TRUE
);
4489 static void test_VarBoolFromR4(void)
4493 CHECKPTR(VarBoolFromR4
);
4494 CONVERT(VarBoolFromR4
, -1.0f
); EXPECT(VARIANT_TRUE
);
4495 CONVERT(VarBoolFromR4
, 0.0f
); EXPECT(VARIANT_FALSE
);
4496 CONVERT(VarBoolFromR4
, 1.0f
); EXPECT(VARIANT_TRUE
);
4497 CONVERT(VarBoolFromR4
, 1.5f
); EXPECT(VARIANT_TRUE
);
4500 CONVERT(VarBoolFromR4
, -1.5f
); EXPECT(VARIANT_TRUE
);
4501 CONVERT(VarBoolFromR4
, -0.6f
); EXPECT(VARIANT_TRUE
);
4502 CONVERT(VarBoolFromR4
, -0.5f
); EXPECT(VARIANT_TRUE
);
4503 CONVERT(VarBoolFromR4
, -0.4f
); EXPECT(VARIANT_TRUE
);
4504 CONVERT(VarBoolFromR4
, 0.4f
); EXPECT(VARIANT_TRUE
);
4505 CONVERT(VarBoolFromR4
, 0.5f
); EXPECT(VARIANT_TRUE
);
4506 CONVERT(VarBoolFromR4
, 0.6f
); EXPECT(VARIANT_TRUE
);
4507 CONVERT(VarBoolFromR4
, 1.5f
); EXPECT(VARIANT_TRUE
);
4510 static void test_VarBoolFromR8(void)
4514 /* Hopefully we made the point with R4 above that rounding is
4515 * irrelevant, so we'll skip that for R8 and Date
4517 CHECKPTR(VarBoolFromR8
);
4518 CONVERT(VarBoolFromR8
, -1.0); EXPECT(VARIANT_TRUE
);
4519 CONVERT(VarBoolFromR8
, -0.0); EXPECT(VARIANT_FALSE
);
4520 CONVERT(VarBoolFromR8
, 1.0); EXPECT(VARIANT_TRUE
);
4523 static void test_VarBoolFromCy(void)
4527 CHECKPTR(VarBoolFromCy
);
4528 CONVERT_CY(VarBoolFromCy
, -32769); EXPECT(VARIANT_TRUE
);
4529 CONVERT_CY(VarBoolFromCy
, -32768); EXPECT(VARIANT_TRUE
);
4530 CONVERT_CY(VarBoolFromCy
, -1); EXPECT(VARIANT_TRUE
);
4531 CONVERT_CY(VarBoolFromCy
, 0); EXPECT(VARIANT_FALSE
);
4532 CONVERT_CY(VarBoolFromCy
, 1); EXPECT(VARIANT_TRUE
);
4533 CONVERT_CY(VarBoolFromCy
, 32767); EXPECT(VARIANT_TRUE
);
4534 CONVERT_CY(VarBoolFromCy
, 32768); EXPECT(VARIANT_TRUE
);
4537 static void test_VarBoolFromI8(void)
4541 CHECKPTR(VarBoolFromI8
);
4542 CONVERT(VarBoolFromI8
, -1); EXPECT(VARIANT_TRUE
);
4543 CONVERT(VarBoolFromI8
, 0); EXPECT(VARIANT_FALSE
);
4544 CONVERT(VarBoolFromI8
, 1); EXPECT(VARIANT_TRUE
);
4547 static void test_VarBoolFromUI8(void)
4551 CHECKPTR(VarBoolFromUI8
);
4552 CONVERT(VarBoolFromUI8
, 0); EXPECT(VARIANT_FALSE
);
4553 CONVERT(VarBoolFromUI8
, 1); EXPECT(VARIANT_TRUE
);
4556 static void test_VarBoolFromDec(void)
4560 CHECKPTR(VarBoolFromDec
);
4561 CONVERT_BADDEC(VarBoolFromDec
);
4563 if (HAVE_OLEAUT32_DECIMAL
)
4565 /* Early versions of oleaut32 don't catch these errors */
4566 CONVERT_DEC(VarBoolFromDec
,29,0,0,0); EXPECT_INVALID
;
4567 CONVERT_DEC(VarBoolFromDec
,0,0x1,0,0); EXPECT_INVALID
;
4568 CONVERT_DEC(VarBoolFromDec
,0,0x40,0,0); EXPECT_INVALID
;
4569 CONVERT_DEC(VarBoolFromDec
,0,0x7f,0,0); EXPECT_INVALID
;
4572 CONVERT_DEC(VarBoolFromDec
,0,0x80,0,1); EXPECT(VARIANT_TRUE
);
4573 CONVERT_DEC(VarBoolFromDec
,0,0,0,0); EXPECT(VARIANT_FALSE
);
4574 CONVERT_DEC(VarBoolFromDec
,0,0,0,1); EXPECT(VARIANT_TRUE
);
4575 CONVERT_DEC(VarBoolFromDec
,0,0,1,0); EXPECT(VARIANT_TRUE
);
4577 CONVERT_DEC(VarBoolFromDec
,2,0,0,CY_MULTIPLIER
); EXPECT(VARIANT_TRUE
);
4578 CONVERT_DEC(VarBoolFromDec
,2,0x80,0,CY_MULTIPLIER
); EXPECT(VARIANT_TRUE
);
4581 static void test_VarBoolFromDate(void)
4585 CHECKPTR(VarBoolFromDate
);
4586 CONVERT(VarBoolFromDate
, -1.0); EXPECT(VARIANT_TRUE
);
4587 CONVERT(VarBoolFromDate
, -0.0); EXPECT(VARIANT_FALSE
);
4588 CONVERT(VarBoolFromDate
, 1.0); EXPECT(VARIANT_TRUE
);
4591 static void test_VarBoolFromStr(void)
4596 CHECKPTR(VarBoolFromStr
);
4598 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
, SUBLANG_ENGLISH_US
), SORT_DEFAULT
);
4600 CONVERT_STR(VarBoolFromStr
,NULL
,0);
4601 if (hres
!= E_INVALIDARG
)
4604 /* #FALSE# and #TRUE# Are always accepted */
4605 CONVERT_STR(VarBoolFromStr
,"#FALSE#",0); EXPECT(VARIANT_FALSE
);
4606 CONVERT_STR(VarBoolFromStr
,"#TRUE#",0); EXPECT(VARIANT_TRUE
);
4608 /* Match of #FALSE# and #TRUE# is case sensitive */
4609 CONVERT_STR(VarBoolFromStr
,"#False#",0); EXPECT_MISMATCH
;
4610 /* But match against English is not */
4611 CONVERT_STR(VarBoolFromStr
,"false",0); EXPECT(VARIANT_FALSE
);
4612 CONVERT_STR(VarBoolFromStr
,"False",0); EXPECT(VARIANT_FALSE
);
4613 /* On/Off and yes/no are not acceptable inputs, with any flags set */
4614 CONVERT_STR(VarBoolFromStr
,"On",0xffffffff); EXPECT_MISMATCH
;
4615 CONVERT_STR(VarBoolFromStr
,"Yes",0xffffffff); EXPECT_MISMATCH
;
4617 /* Change the LCID. This doesn't make any difference for text,unless we ask
4618 * to check local boolean text with the VARIANT_LOCALBOOL flag. */
4619 in
= MAKELCID(MAKELANGID(LANG_FRENCH
, SUBLANG_DEFAULT
), SORT_DEFAULT
);
4621 /* #FALSE# and #TRUE# are accepted in all locales */
4622 CONVERT_STR(VarBoolFromStr
,"#FALSE#",0); EXPECT(VARIANT_FALSE
);
4623 CONVERT_STR(VarBoolFromStr
,"#TRUE#",0); EXPECT(VARIANT_TRUE
);
4624 CONVERT_STR(VarBoolFromStr
,"#FALSE#",VARIANT_LOCALBOOL
); EXPECT(VARIANT_FALSE
);
4625 CONVERT_STR(VarBoolFromStr
,"#TRUE#",VARIANT_LOCALBOOL
); EXPECT(VARIANT_TRUE
);
4627 /* English is accepted regardless of the locale */
4628 CONVERT_STR(VarBoolFromStr
,"false",0); EXPECT(VARIANT_FALSE
);
4629 /* And is still not case sensitive */
4630 CONVERT_STR(VarBoolFromStr
,"False",0); EXPECT(VARIANT_FALSE
);
4632 if (HAVE_OLEAUT32_LOCALES
)
4634 /* French is rejected without VARIANT_LOCALBOOL */
4635 CONVERT_STR(VarBoolFromStr
,"faux",0); EXPECT_MISMATCH
;
4636 /* But accepted if this flag is given */
4637 CONVERT_STR(VarBoolFromStr
,"faux",VARIANT_LOCALBOOL
); EXPECT(VARIANT_FALSE
);
4638 /* Regardless of case - from this we assume locale text comparisons ignore case */
4639 CONVERT_STR(VarBoolFromStr
,"Faux",VARIANT_LOCALBOOL
); EXPECT(VARIANT_FALSE
);
4641 /* Changing the locale prevents the localised text from being compared -
4642 * this demonstrates that only the indicated LCID and English are searched */
4643 in
= MAKELCID(MAKELANGID(LANG_POLISH
, SUBLANG_DEFAULT
), SORT_DEFAULT
);
4644 CONVERT_STR(VarBoolFromStr
,"faux",VARIANT_LOCALBOOL
); EXPECT_MISMATCH
;
4647 /* Numeric strings are read as 0 or non-0 */
4648 CONVERT_STR(VarBoolFromStr
,"0",0); EXPECT(VARIANT_FALSE
);
4649 CONVERT_STR(VarBoolFromStr
,"-1",0); EXPECT(VARIANT_TRUE
);
4650 CONVERT_STR(VarBoolFromStr
,"+1",0); EXPECT(VARIANT_TRUE
);
4652 if (HAVE_OLEAUT32_LOCALES
)
4654 /* Numeric strings are read as floating point numbers. The line below fails
4655 * because '.' is not a valid decimal separator for Polish numbers */
4656 CONVERT_STR(VarBoolFromStr
,"0.1",LOCALE_NOUSEROVERRIDE
); EXPECT_MISMATCH
;
4659 /* Changing the lcid back to US English reads the r8 correctly */
4660 in
= MAKELCID(MAKELANGID(LANG_ENGLISH
, SUBLANG_ENGLISH_US
), SORT_DEFAULT
);
4661 CONVERT_STR(VarBoolFromStr
,"0.1",LOCALE_NOUSEROVERRIDE
); EXPECT(VARIANT_TRUE
);
4664 static void test_VarBoolCopy(void)
4666 COPYTEST(1, VT_BOOL
, V_BOOL(&vSrc
), V_BOOL(&vDst
), V_BOOLREF(&vSrc
), V_BOOLREF(&vDst
), "%d");
4669 #define BOOL_STR(flags, str) hres = VariantChangeTypeEx(&vDst, &vSrc, lcid, flags, VT_BSTR); \
4670 ok(hres == S_OK && V_VT(&vDst) == VT_BSTR && \
4671 V_BSTR(&vDst) && !memcmp(V_BSTR(&vDst), str, sizeof(str)), \
4672 "hres=0x%X, type=%d (should be VT_BSTR), *bstr='%c'\n", \
4673 hres, V_VT(&vDst), V_BSTR(&vDst) ? *V_BSTR(&vDst) : '?')
4675 static void test_VarBoolChangeTypeEx(void)
4677 static const WCHAR szTrue
[] = { 'T','r','u','e','\0' };
4678 static const WCHAR szFalse
[] = { 'F','a','l','s','e','\0' };
4679 static const WCHAR szFaux
[] = { 'F','a','u','x','\0' };
4680 CONVVARS(CONV_TYPE
);
4681 VARIANTARG vSrc
, vDst
;
4686 INITIAL_TYPETEST(VT_BOOL
, V_BOOL
, "%d");
4689 /* The common tests convert to a number. Try the different flags */
4690 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
, SUBLANG_ENGLISH_US
), SORT_DEFAULT
);
4692 V_VT(&vSrc
) = VT_BOOL
;
4697 BOOL_STR(VARIANT_ALPHABOOL
, szTrue
);
4699 BOOL_STR(VARIANT_ALPHABOOL
, szFalse
);
4702 if (HAVE_OLEAUT32_LOCALES
)
4704 lcid
= MAKELCID(MAKELANGID(LANG_FRENCH
, SUBLANG_DEFAULT
), SORT_DEFAULT
);
4706 /* VARIANT_ALPHABOOL is always English */
4707 BOOL_STR(VARIANT_ALPHABOOL
, szFalse
);
4708 /* VARIANT_LOCALBOOL uses the localised text */
4709 BOOL_STR(VARIANT_LOCALBOOL
, szFaux
);
4710 /* Both flags together acts as VARIANT_LOCALBOOL */
4711 BOOL_STR(VARIANT_ALPHABOOL
|VARIANT_LOCALBOOL
, szFaux
);
4719 static void test_VarBstrFromR4(void)
4721 static const WCHAR szNative
[] = { '6','5','4','3','2','2','.','3','\0' };
4722 static const WCHAR szZero
[] = {'0', '\0'};
4723 static const WCHAR szOneHalf_English
[] = { '0','.','5','\0' }; /* uses period */
4724 static const WCHAR szOneHalf_Spanish
[] = { '0',',','5','\0' }; /* uses comma */
4732 CHECKPTR(VarBstrFromR4
);
4734 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
, SUBLANG_ENGLISH_US
), SORT_DEFAULT
);
4735 lcid_spanish
= MAKELCID(MAKELANGID(LANG_SPANISH
, SUBLANG_SPANISH
), SORT_DEFAULT
);
4737 hres
= pVarBstrFromR4(f
, lcid
, 0, &bstr
);
4738 ok(hres
== S_OK
, "got hres 0x%08x\n", hres
);
4742 /* MSDN states that rounding of R4/R8 is dependent on the underlying
4743 * bit pattern of the number and so is architecture dependent. In this
4744 * case Wine returns .2 (which is more correct) and Native returns .3
4746 ok(memcmp(bstr
, szNative
, sizeof(szNative
)) == 0, "string different\n");
4751 hres
= pVarBstrFromR4(f
, lcid
, 0, &bstr
);
4752 ok(hres
== S_OK
, "got hres 0x%08x\n", hres
);
4755 ok(memcmp(bstr
, szZero
, sizeof(szZero
)) == 0, "negative zero (got %s)\n", wtoascii(bstr
));
4758 /* The following tests that lcid is used for decimal separator even without LOCALE_USE_NLS */
4760 hres
= pVarBstrFromR4(f
, lcid
, LOCALE_NOUSEROVERRIDE
, &bstr
);
4761 ok(hres
== S_OK
, "got hres 0x%08x\n", hres
);
4764 ok(memcmp(bstr
, szOneHalf_English
, sizeof(szOneHalf_English
)) == 0, "English locale failed (got %s)\n", wtoascii(bstr
));
4767 hres
= pVarBstrFromR4(f
, lcid_spanish
, LOCALE_NOUSEROVERRIDE
, &bstr
);
4768 ok(hres
== S_OK
, "got hres 0x%08x\n", hres
);
4771 ok(memcmp(bstr
, szOneHalf_Spanish
, sizeof(szOneHalf_Spanish
)) == 0, "Spanish locale failed (got %s)\n", wtoascii(bstr
));
4775 #define BSTR_DATE(dt,str) SysFreeString(bstr); bstr = NULL; \
4776 hres = pVarBstrFromDate(dt,lcid,LOCALE_NOUSEROVERRIDE,&bstr); \
4777 if (bstr) WideCharToMultiByte(CP_ACP, 0, bstr, -1, buff, sizeof(buff), 0, 0); \
4779 ok(hres == S_OK && !strcmp(str,buff), "Expected '%s', got '%s', hres = 0x%08x\n", \
4782 static void test_VarBstrFromDate(void)
4789 CHECKPTR(VarBstrFromDate
);
4790 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
4792 BSTR_DATE(0.0, "12:00:00 AM");
4793 BSTR_DATE(3.34, "1/2/1900 8:09:36 AM");
4794 BSTR_DATE(3339.34, "2/20/1909 8:09:36 AM");
4795 BSTR_DATE(365.00, "12/30/1900");
4796 BSTR_DATE(365.25, "12/30/1900 6:00:00 AM");
4797 BSTR_DATE(1461.0, "12/31/1903");
4798 BSTR_DATE(1461.5, "12/31/1903 12:00:00 PM");
4799 todo_wine
{ BSTR_DATE(-657434.0, "1/1/100"); }
4800 BSTR_DATE(2958465.0, "12/31/9999");
4803 #define BSTR_DEC(l, a, b, c, d, e) \
4804 SETDEC(l, a,b,c,d);\
4805 hres = VarBstrFromDec(&l, lcid, LOCALE_NOUSEROVERRIDE, &bstr);\
4806 ok(hres == S_OK, "got hres 0x%08x\n", hres);\
4807 if (hres== S_OK && bstr)\
4809 ok(lstrcmpW(bstr, e) == 0, "invalid number (got %s)\n", wtoascii(bstr));\
4812 #define BSTR_DEC64(l, a, b, c, x, d, e) \
4813 SETDEC64(l, a,b,c,x,d);\
4814 hres = VarBstrFromDec(&l, lcid, LOCALE_NOUSEROVERRIDE, &bstr);\
4815 ok(hres == S_OK, "got hres 0x%08x\n", hres);\
4816 if (hres== S_OK && bstr)\
4818 ok(lstrcmpW(bstr, e) == 0, "invalid number (got %s)\n", wtoascii(bstr));\
4821 static void test_VarBstrFromDec(void)
4828 static const WCHAR szZero
[] = {'0', '\0'};
4829 static const WCHAR szOne
[] = {'1', '\0'};
4830 static const WCHAR szOnePointFive
[] = {'1','.','5','\0'};
4831 static const WCHAR szMinusOnePointFive
[] = {'-','1','.','5','\0'};
4832 static const WCHAR szBigNum1
[] = {'4','2','9','4','9','6','7','2','9','5','\0'}; /* (1 << 32) - 1 */
4833 static const WCHAR szBigNum2
[] = {'4','2','9','4','9','6','7','2','9','6','\0'}; /* (1 << 32) */
4834 static const WCHAR szBigNum3
[] = {'1','8','4','4','6','7','4','4','0','7','3','7','0','9','5','5','1','6','1','5','\0'}; /* (1 << 64) - 1 */
4835 static const WCHAR szBigNum4
[] = {'1','8','4','4','6','7','4','4','0','7','3','7','0','9','5','5','1','6','1','6','\0'}; /* (1 << 64) */
4836 static const WCHAR szBigNum5
[] = {'7','9','2','2','8','1','6','2','5','1','4','2','6','4','3','3','7','5','9','3','5','4','3','9','5','0','3','3','5','\0'}; /* (1 << 96) - 1 */
4837 static const WCHAR szBigScale1
[] = {'0','.','0','0','0','0','0','0','0','0','0','1','\0'}; /* 1 * 10^-10 */
4838 static const WCHAR szBigScale2
[] = {'7','9','2','2','8','1','6','2','5','1','4','2','6','4','3','3','7','5','9','.','3','5','4','3','9','5','0','3','3','5','\0'}; /* ((1 << 96) - 1) * 10^-10 */
4839 static const WCHAR szBigScale3
[] = {'7','.','9','2','2','8','1','6','2','5','1','4','2','6','4','3','3','7','5','9','3','5','4','3','9','5','0','3','3','5','\0'}; /* ((1 << 96) - 1) * 10^-28 */
4841 static const WCHAR szSmallNumber_English
[] = {'0','.','0','0','0','9','\0'};
4842 static const WCHAR szSmallNumber_Spanish
[] = {'0',',','0','0','0','9','\0'};
4844 CHECKPTR(VarBstrFromDec
);
4845 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
4848 BSTR_DEC(l
, 0,0,0,0, szZero
);
4851 BSTR_DEC(l
, 0,0,0,1, szOne
);
4852 BSTR_DEC(l
, 1,0,0,10,szOne
);
4853 BSTR_DEC(l
, 2,0,0,100,szOne
);
4854 BSTR_DEC(l
, 3,0,0,1000,szOne
);
4856 /* check one point five */
4857 BSTR_DEC(l
, 1,0,0,15, szOnePointFive
);
4858 BSTR_DEC(l
, 2,0,0,150, szOnePointFive
);
4859 BSTR_DEC(l
, 3,0,0,1500, szOnePointFive
);
4861 /* check minus one point five */
4862 BSTR_DEC(l
, 1,0x80,0,15, szMinusOnePointFive
);
4864 /* check bignum (1) */
4865 BSTR_DEC(l
, 0,0,0,0xffffffff, szBigNum1
);
4867 /* check bignum (2) */
4868 BSTR_DEC64(l
, 0,0,0,1,0, szBigNum2
);
4870 /* check bignum (3) */
4871 BSTR_DEC64(l
, 0,0,0,0xffffffff,0xffffffff, szBigNum3
);
4873 /* check bignum (4) */
4874 BSTR_DEC(l
, 0,0,1,0, szBigNum4
);
4876 /* check bignum (5) */
4877 BSTR_DEC64(l
, 0,0,0xffffffff,0xffffffff,0xffffffff, szBigNum5
);
4879 /* check bigscale (1) */
4880 BSTR_DEC(l
, 10,0,0,1, szBigScale1
);
4882 /* check bigscale (2) */
4883 BSTR_DEC64(l
, 10,0,0xffffffffUL
,0xffffffff,0xffffffff, szBigScale2
);
4885 /* check bigscale (3) */
4886 BSTR_DEC64(l
, 28,0,0xffffffffUL
,0xffffffff,0xffffffff, szBigScale3
);
4888 /* check leading zeros and decimal sep. for English locale */
4889 BSTR_DEC(l
, 4,0,0,9, szSmallNumber_English
);
4890 BSTR_DEC(l
, 5,0,0,90, szSmallNumber_English
);
4891 BSTR_DEC(l
, 6,0,0,900, szSmallNumber_English
);
4892 BSTR_DEC(l
, 7,0,0,9000, szSmallNumber_English
);
4894 lcid
= MAKELCID(MAKELANGID(LANG_SPANISH
, SUBLANG_DEFAULT
), SORT_DEFAULT
);
4896 /* check leading zeros and decimal sep. for Spanish locale */
4897 BSTR_DEC(l
, 4,0,0,9, szSmallNumber_Spanish
);
4898 BSTR_DEC(l
, 5,0,0,90, szSmallNumber_Spanish
);
4899 BSTR_DEC(l
, 6,0,0,900, szSmallNumber_Spanish
);
4900 BSTR_DEC(l
, 7,0,0,9000, szSmallNumber_Spanish
);
4905 #define _VARBSTRCMP(left,right,lcid,flags,result) \
4906 hres = pVarBstrCmp(left,right,lcid,flags); \
4907 ok(hres == result, "VarBstrCmp: expected " #result ", got hres=0x%x\n", hres)
4908 #define VARBSTRCMP(left,right,flags,result) \
4909 _VARBSTRCMP(left,right,lcid,flags,result)
4911 static void test_VarBstrCmp(void)
4915 static const WCHAR sz
[] = {'W','u','r','s','c','h','t','\0'};
4916 static const WCHAR szempty
[] = {'\0'};
4917 static const WCHAR sz1
[] = { 'a',0 };
4918 static const WCHAR sz2
[] = { 'A',0 };
4919 static const WCHAR s1
[] = { 'a',0 };
4920 static const WCHAR s2
[] = { 'a',0,'b' };
4921 static const char sb1
[] = {1,0,1};
4922 static const char sb2
[] = {1,0,2};
4923 BSTR bstr
, bstrempty
, bstr2
;
4925 CHECKPTR(VarBstrCmp
);
4927 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
,SUBLANG_ENGLISH_US
),SORT_DEFAULT
);
4928 bstr
= SysAllocString(sz
);
4929 bstrempty
= SysAllocString(szempty
);
4931 /* NULL handling. Yepp, MSDN is totally wrong here */
4932 VARBSTRCMP(NULL
,NULL
,0,VARCMP_EQ
);
4933 VARBSTRCMP(bstr
,NULL
,0,VARCMP_GT
);
4934 VARBSTRCMP(NULL
,bstr
,0,VARCMP_LT
);
4936 /* NULL and empty string comparisons */
4937 VARBSTRCMP(bstrempty
,NULL
,0,VARCMP_EQ
);
4938 VARBSTRCMP(NULL
,bstrempty
,0,VARCMP_EQ
);
4940 SysFreeString(bstr
);
4941 bstr
= SysAllocString(sz1
);
4943 bstr2
= SysAllocString(sz2
);
4944 VARBSTRCMP(bstr
,bstr2
,0,VARCMP_LT
);
4945 VARBSTRCMP(bstr
,bstr2
,NORM_IGNORECASE
,VARCMP_EQ
);
4946 SysFreeString(bstr2
);
4947 /* These two strings are considered equal even though one is
4948 * NULL-terminated and the other not.
4950 bstr2
= SysAllocStringLen(s1
, sizeof(s1
) / sizeof(WCHAR
));
4951 VARBSTRCMP(bstr
,bstr2
,0,VARCMP_EQ
);
4952 SysFreeString(bstr2
);
4954 /* These two strings are not equal */
4955 bstr2
= SysAllocStringLen(s2
, sizeof(s2
) / sizeof(WCHAR
));
4956 VARBSTRCMP(bstr
,bstr2
,0,VARCMP_LT
);
4957 SysFreeString(bstr2
);
4959 SysFreeString(bstr
);
4961 /* When (LCID == 0) it should be a binary comparison
4962 * so these two strings could not match.
4964 bstr
= SysAllocStringByteLen(sb1
, sizeof(sb1
));
4965 bstr2
= SysAllocStringByteLen(sb2
, sizeof(sb2
));
4967 VARBSTRCMP(bstr
,bstr2
,0,VARCMP_LT
);
4968 SysFreeString(bstr2
);
4969 SysFreeString(bstr
);
4972 /* Get the internal representation of a BSTR */
4973 static inline LPINTERNAL_BSTR
Get(const BSTR lpszString
)
4975 return lpszString
? (LPINTERNAL_BSTR
)((char*)lpszString
- sizeof(DWORD
)) : NULL
;
4978 static inline BSTR
GetBSTR(const LPINTERNAL_BSTR bstr
)
4980 return (BSTR
)bstr
->szString
;
4983 static void test_SysStringLen(void)
4986 BSTR str
= GetBSTR(&bstr
);
4989 ok (SysStringLen(str
) == 0, "Expected dwLen 0, got %d\n", SysStringLen(str
));
4991 ok (SysStringLen(str
) == 1, "Expected dwLen 1, got %d\n", SysStringLen(str
));
4994 static void test_SysStringByteLen(void)
4997 BSTR str
= GetBSTR(&bstr
);
5000 ok (SysStringByteLen(str
) == 0, "Expected dwLen 0, got %d\n", SysStringLen(str
));
5002 ok (SysStringByteLen(str
) == 2, "Expected dwLen 2, got %d\n", SysStringByteLen(str
));
5005 static void test_SysAllocString(void)
5007 const OLECHAR szTest
[5] = { 'T','e','s','t','\0' };
5010 str
= SysAllocString(NULL
);
5011 ok (str
== NULL
, "Expected NULL, got %p\n", str
);
5013 str
= SysAllocString(szTest
);
5014 ok (str
!= NULL
, "Expected non-NULL\n");
5017 LPINTERNAL_BSTR bstr
= Get(str
);
5019 ok (bstr
->dwLen
== 8, "Expected 8, got %d\n", bstr
->dwLen
);
5020 ok (!lstrcmpW(bstr
->szString
, szTest
), "String different\n");
5025 static void test_SysAllocStringLen(void)
5027 const OLECHAR szTest
[5] = { 'T','e','s','t','\0' };
5030 /* Very early native dlls do not limit the size of strings, so skip this test */
5033 str
= SysAllocStringLen(szTest
, 0x80000000);
5035 ok (str
== NULL
, "Expected NULL, got %p\n", str
);
5039 str
= SysAllocStringLen(NULL
, 0);
5040 ok (str
!= NULL
, "Expected non-NULL\n");
5043 LPINTERNAL_BSTR bstr
= Get(str
);
5045 ok (bstr
->dwLen
== 0, "Expected 0, got %d\n", bstr
->dwLen
);
5046 ok (!bstr
->szString
[0], "String not empty\n");
5050 str
= SysAllocStringLen(szTest
, 4);
5051 ok (str
!= NULL
, "Expected non-NULL\n");
5054 LPINTERNAL_BSTR bstr
= Get(str
);
5056 ok (bstr
->dwLen
== 8, "Expected 8, got %d\n", bstr
->dwLen
);
5057 ok (!lstrcmpW(bstr
->szString
, szTest
), "String different\n");
5062 static void test_SysAllocStringByteLen(void)
5064 const OLECHAR szTest
[10] = { 'T','e','s','t','\0' };
5065 const CHAR szTestA
[6] = { 'T','e','s','t','\0','?' };
5068 str
= SysAllocStringByteLen(szTestA
, 0x80000000);
5069 ok (str
== NULL
, "Expected NULL, got %p\n", str
);
5071 str
= SysAllocStringByteLen(szTestA
, 0xffffffff);
5072 ok (str
== NULL
, "Expected NULL, got %p\n", str
);
5074 str
= SysAllocStringByteLen(NULL
, 0);
5075 ok (str
!= NULL
, "Expected non-NULL\n");
5078 LPINTERNAL_BSTR bstr
= Get(str
);
5080 ok (bstr
->dwLen
== 0, "Expected 0, got %d\n", bstr
->dwLen
);
5081 ok (!bstr
->szString
[0], "String not empty\n");
5085 str
= SysAllocStringByteLen(szTestA
, 4);
5086 ok (str
!= NULL
, "Expected non-NULL\n");
5089 LPINTERNAL_BSTR bstr
= Get(str
);
5091 ok (bstr
->dwLen
== 4, "Expected 4, got %d\n", bstr
->dwLen
);
5092 ok (!lstrcmpA((LPCSTR
)bstr
->szString
, szTestA
), "String different\n");
5096 /* Odd lengths are allocated rounded up, but truncated at the right position */
5097 str
= SysAllocStringByteLen(szTestA
, 3);
5098 ok (str
!= NULL
, "Expected non-NULL\n");
5101 const CHAR szTestTruncA
[4] = { 'T','e','s','\0' };
5102 LPINTERNAL_BSTR bstr
= Get(str
);
5104 ok (bstr
->dwLen
== 3, "Expected 3, got %d\n", bstr
->dwLen
);
5105 ok (!lstrcmpA((LPCSTR
)bstr
->szString
, szTestTruncA
), "String different\n");
5109 str
= SysAllocStringByteLen((LPCSTR
)szTest
, 8);
5110 ok (str
!= NULL
, "Expected non-NULL\n");
5113 LPINTERNAL_BSTR bstr
= Get(str
);
5115 ok (bstr
->dwLen
== 8, "Expected 8, got %d\n", bstr
->dwLen
);
5116 ok (!lstrcmpW(bstr
->szString
, szTest
), "String different\n");
5121 static void test_SysReAllocString(void)
5123 const OLECHAR szTest
[5] = { 'T','e','s','t','\0' };
5124 const OLECHAR szSmaller
[2] = { 'x','\0' };
5125 const OLECHAR szLarger
[7] = { 'L','a','r','g','e','r','\0' };
5128 str
= SysAllocStringLen(szTest
, 4);
5129 ok (str
!= NULL
, "Expected non-NULL\n");
5132 LPINTERNAL_BSTR bstr
;
5137 ok (bstr
->dwLen
== 8, "Expected 8, got %d\n", bstr
->dwLen
);
5138 ok (!lstrcmpW(bstr
->szString
, szTest
), "String different\n");
5140 changed
= SysReAllocString(&str
, szSmaller
);
5141 ok (changed
== 1, "Expected 1, got %d\n", changed
);
5142 ok (str
== oldstr
, "Created new string\n");
5144 ok (bstr
->dwLen
== 2, "Expected 2, got %d\n", bstr
->dwLen
);
5145 ok (!lstrcmpW(bstr
->szString
, szSmaller
), "String different\n");
5148 changed
= SysReAllocString(&str
, szLarger
);
5149 ok (changed
== 1, "Expected 1, got %d\n", changed
);
5150 /* Early versions always make new strings rather than resizing */
5151 /* ok (str == oldstr, "Created new string\n"); */
5153 ok (bstr
->dwLen
== 12, "Expected 12, got %d\n", bstr
->dwLen
);
5154 ok (!lstrcmpW(bstr
->szString
, szLarger
), "String different\n");
5160 static void test_SysReAllocStringLen(void)
5162 const OLECHAR szTest
[5] = { 'T','e','s','t','\0' };
5163 const OLECHAR szSmaller
[2] = { 'x','\0' };
5164 const OLECHAR szLarger
[7] = { 'L','a','r','g','e','r','\0' };
5167 str
= SysAllocStringLen(szTest
, 4);
5168 ok (str
!= NULL
, "Expected non-NULL\n");
5171 LPINTERNAL_BSTR bstr
;
5176 ok (bstr
->dwLen
== 8, "Expected 8, got %d\n", bstr
->dwLen
);
5177 ok (!lstrcmpW(bstr
->szString
, szTest
), "String different\n");
5179 changed
= SysReAllocStringLen(&str
, szSmaller
, 1);
5180 ok (changed
== 1, "Expected 1, got %d\n", changed
);
5181 ok (str
== oldstr
, "Created new string\n");
5183 ok (bstr
->dwLen
== 2, "Expected 2, got %d\n", bstr
->dwLen
);
5184 ok (!lstrcmpW(bstr
->szString
, szSmaller
), "String different\n");
5187 changed
= SysReAllocStringLen(&str
, szLarger
, 6);
5188 ok (changed
== 1, "Expected 1, got %d\n", changed
);
5189 /* Early versions always make new strings rather than resizing */
5190 /* ok (str == oldstr, "Created new string\n"); */
5192 ok (bstr
->dwLen
== 12, "Expected 12, got %d\n", bstr
->dwLen
);
5193 ok (!lstrcmpW(bstr
->szString
, szLarger
), "String different\n");
5195 changed
= SysReAllocStringLen(&str
, str
, 6);
5196 ok (changed
== 1, "Expected 1, got %d\n", changed
);
5202 static void test_BstrCopy(void)
5204 const CHAR szTestA
[6] = { 'T','e','s','t','\0','?' };
5205 const CHAR szTestTruncA
[4] = { 'T','e','s','\0' };
5206 LPINTERNAL_BSTR bstr
;
5211 str
= SysAllocStringByteLen(szTestA
, 3);
5212 ok (str
!= NULL
, "Expected non-NULL\n");
5215 V_VT(&vt1
) = VT_BSTR
;
5217 V_VT(&vt2
) = VT_EMPTY
;
5218 hres
= VariantCopy(&vt2
, &vt1
);
5219 ok (hres
== S_OK
,"Failed to copy binary bstring with hres 0x%08x\n", hres
);
5220 bstr
= Get(V_BSTR(&vt2
));
5221 ok (bstr
->dwLen
== 3, "Expected 3, got %d\n", bstr
->dwLen
);
5222 ok (!lstrcmpA((LPCSTR
)bstr
->szString
, szTestTruncA
), "String different\n");
5226 static void test_VarBstrCat(void)
5228 static const WCHAR sz1
[] = { 'a',0 };
5229 static const WCHAR sz2
[] = { 'b',0 };
5230 static const WCHAR sz1sz2
[] = { 'a','b',0 };
5231 static const WCHAR s1
[] = { 'a',0 };
5232 static const WCHAR s2
[] = { 'b',0 };
5233 static const WCHAR s1s2
[] = { 'a',0,'b',0 };
5235 BSTR str1
, str2
, res
;
5238 ret = VarBstrCat(NULL, NULL, NULL);
5241 /* Concatenation of two NULL strings works */
5242 ret
= VarBstrCat(NULL
, NULL
, &res
);
5243 ok(ret
== S_OK
, "VarBstrCat failed: %08x\n", ret
);
5244 ok(res
!= NULL
, "Expected a string\n");
5245 ok(SysStringLen(res
) == 0, "Expected a 0-length string\n");
5248 str1
= SysAllocString(sz1
);
5250 /* Concatenation with one NULL arg */
5251 ret
= VarBstrCat(NULL
, str1
, &res
);
5252 ok(ret
== S_OK
, "VarBstrCat failed: %08x\n", ret
);
5253 ok(res
!= NULL
, "Expected a string\n");
5254 ok(SysStringLen(res
) == SysStringLen(str1
), "Unexpected length\n");
5255 ok(!memcmp(res
, sz1
, SysStringLen(str1
)), "Unexpected value\n");
5257 ret
= VarBstrCat(str1
, NULL
, &res
);
5258 ok(ret
== S_OK
, "VarBstrCat failed: %08x\n", ret
);
5259 ok(res
!= NULL
, "Expected a string\n");
5260 ok(SysStringLen(res
) == SysStringLen(str1
), "Unexpected length\n");
5261 ok(!memcmp(res
, sz1
, SysStringLen(str1
)), "Unexpected value\n");
5264 /* Concatenation of two zero-terminated strings */
5265 str2
= SysAllocString(sz2
);
5266 ret
= VarBstrCat(str1
, str2
, &res
);
5267 ok(ret
== S_OK
, "VarBstrCat failed: %08x\n", ret
);
5268 ok(res
!= NULL
, "Expected a string\n");
5269 ok(SysStringLen(res
) == sizeof(sz1sz2
) / sizeof(WCHAR
) - 1,
5270 "Unexpected length\n");
5271 ok(!memcmp(res
, sz1sz2
, sizeof(sz1sz2
)), "Unexpected value\n");
5274 SysFreeString(str2
);
5275 SysFreeString(str1
);
5277 /* Concatenation of two strings with embedded NULLs */
5278 str1
= SysAllocStringLen(s1
, sizeof(s1
) / sizeof(WCHAR
));
5279 str2
= SysAllocStringLen(s2
, sizeof(s2
) / sizeof(WCHAR
));
5281 ret
= VarBstrCat(str1
, str2
, &res
);
5282 ok(ret
== S_OK
, "VarBstrCat failed: %08x\n", ret
);
5283 ok(res
!= NULL
, "Expected a string\n");
5284 ok(SysStringLen(res
) == sizeof(s1s2
) / sizeof(WCHAR
),
5285 "Unexpected length\n");
5286 ok(!memcmp(res
, s1s2
, sizeof(s1s2
)), "Unexpected value\n");
5289 SysFreeString(str2
);
5290 SysFreeString(str1
);
5295 static void test_IUnknownClear(void)
5299 DummyDispatch u
= { &DummyDispatch_VTable
, 1, VT_UI1
, FALSE
};
5300 IUnknown
* pu
= (IUnknown
*)&u
;
5302 /* Test that IUnknown_Release is called on by-value */
5303 V_VT(&v
) = VT_UNKNOWN
;
5304 V_UNKNOWN(&v
) = (IUnknown
*)&u
;
5305 hres
= VariantClear(&v
);
5306 ok(hres
== S_OK
&& u
.ref
== 0 && V_VT(&v
) == VT_EMPTY
,
5307 "clear unknown: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5308 S_OK
, 0, VT_EMPTY
, hres
, u
.ref
, V_VT(&v
));
5310 /* But not when clearing a by-reference*/
5312 V_VT(&v
) = VT_UNKNOWN
|VT_BYREF
;
5313 V_UNKNOWNREF(&v
) = &pu
;
5314 hres
= VariantClear(&v
);
5315 ok(hres
== S_OK
&& u
.ref
== 1 && V_VT(&v
) == VT_EMPTY
,
5316 "clear dispatch: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5317 S_OK
, 1, VT_EMPTY
, hres
, u
.ref
, V_VT(&v
));
5320 static void test_IUnknownCopy(void)
5323 VARIANTARG vSrc
, vDst
;
5324 DummyDispatch u
= { &DummyDispatch_VTable
, 1, VT_UI1
, FALSE
};
5325 IUnknown
* pu
= (IUnknown
*)&u
;
5327 /* AddRef is called on by-value copy */
5329 V_VT(&vSrc
) = VT_UNKNOWN
;
5330 V_UNKNOWN(&vSrc
) = pu
;
5331 hres
= VariantCopy(&vDst
, &vSrc
);
5332 ok(hres
== S_OK
&& u
.ref
== 2 && V_VT(&vDst
) == VT_UNKNOWN
,
5333 "copy unknown: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5334 S_OK
, 2, VT_EMPTY
, hres
, u
.ref
, V_VT(&vDst
));
5336 /* AddRef is skipped on copy of by-reference IDispatch */
5339 V_VT(&vSrc
) = VT_UNKNOWN
|VT_BYREF
;
5340 V_UNKNOWNREF(&vSrc
) = &pu
;
5341 hres
= VariantCopy(&vDst
, &vSrc
);
5342 ok(hres
== S_OK
&& u
.ref
== 1 && V_VT(&vDst
) == (VT_UNKNOWN
|VT_BYREF
),
5343 "copy unknown: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5344 S_OK
, 1, VT_DISPATCH
, hres
, u
.ref
, V_VT(&vDst
));
5346 /* AddRef is called copying by-reference IDispatch with indirection */
5349 V_VT(&vSrc
) = VT_UNKNOWN
|VT_BYREF
;
5350 V_UNKNOWNREF(&vSrc
) = &pu
;
5351 hres
= VariantCopyInd(&vDst
, &vSrc
);
5352 ok(hres
== S_OK
&& u
.ref
== 2 && V_VT(&vDst
) == VT_UNKNOWN
,
5353 "copy unknown: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5354 S_OK
, 2, VT_DISPATCH
, hres
, u
.ref
, V_VT(&vDst
));
5356 /* Indirection in place also calls AddRef */
5358 V_VT(&vSrc
) = VT_UNKNOWN
|VT_BYREF
;
5359 V_UNKNOWNREF(&vSrc
) = &pu
;
5360 hres
= VariantCopyInd(&vSrc
, &vSrc
);
5361 ok(hres
== S_OK
&& u
.ref
== 2 && V_VT(&vSrc
) == VT_UNKNOWN
,
5362 "copy unknown: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5363 S_OK
, 2, VT_DISPATCH
, hres
, u
.ref
, V_VT(&vSrc
));
5366 static void test_IUnknownChangeTypeEx(void)
5369 VARIANTARG vSrc
, vDst
;
5372 DummyDispatch u
= { &DummyDispatch_VTable
, 1, VT_UI1
, FALSE
};
5373 IUnknown
* pu
= (IUnknown
*)&u
;
5375 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
, SUBLANG_ENGLISH_US
), SORT_DEFAULT
);
5377 V_VT(&vSrc
) = VT_UNKNOWN
;
5378 V_UNKNOWN(&vSrc
) = pu
;
5380 /* =>IDispatch in place */
5381 hres
= VariantChangeTypeEx(&vSrc
, &vSrc
, lcid
, 0, VT_DISPATCH
);
5382 ok(hres
== S_OK
&& u
.ref
== 1 &&
5383 V_VT(&vSrc
) == VT_DISPATCH
&& V_DISPATCH(&vSrc
) == (IDispatch
*)pu
,
5384 "change unk(src=src): expected 0x%08x,%d,%d,%p, got 0x%08x,%d,%d,%p\n",
5385 S_OK
, 1, VT_DISPATCH
, pu
, hres
, u
.ref
, V_VT(&vSrc
), V_DISPATCH(&vSrc
));
5389 V_VT(&vSrc
) = VT_UNKNOWN
;
5390 V_UNKNOWN(&vSrc
) = (IUnknown
*)pu
;
5392 hres
= VariantChangeTypeEx(&vDst
, &vSrc
, lcid
, 0, VT_UNKNOWN
);
5393 /* Note vSrc is not cleared, as final refcount is 2 */
5394 ok(hres
== S_OK
&& u
.ref
== 2 &&
5395 V_VT(&vDst
) == VT_UNKNOWN
&& V_UNKNOWN(&vDst
) == (IUnknown
*)pu
,
5396 "change unk(src,dst): expected 0x%08x,%d,%d,%p, got 0x%08x,%d,%d,%p\n",
5397 S_OK
, 2, VT_UNKNOWN
, pu
, hres
, u
.ref
, V_VT(&vDst
), V_UNKNOWN(&vDst
));
5399 /* Can't change unknown to anything else */
5400 for (vt
= 0; vt
<= VT_BSTR_BLOB
; vt
++)
5402 HRESULT hExpected
= DISP_E_BADVARTYPE
;
5404 V_VT(&vSrc
) = VT_UNKNOWN
;
5405 V_UNKNOWN(&vSrc
) = (IUnknown
*)pu
;
5408 if (vt
== VT_UNKNOWN
|| vt
== VT_DISPATCH
|| vt
== VT_EMPTY
|| vt
== VT_NULL
)
5412 if (vt
== VT_I8
|| vt
== VT_UI8
)
5414 if (HAVE_OLEAUT32_I8
)
5415 hExpected
= DISP_E_TYPEMISMATCH
;
5417 else if (vt
== VT_RECORD
)
5419 if (HAVE_OLEAUT32_RECORD
)
5420 hExpected
= DISP_E_TYPEMISMATCH
;
5422 else if (vt
>= VT_I2
&& vt
<= VT_UINT
&& vt
!= (VARTYPE
)15)
5423 hExpected
= DISP_E_TYPEMISMATCH
;
5425 if (IS_ANCIENT
&& IS_MODERN_VTYPE(vt
))
5426 hExpected
= DISP_E_BADVARTYPE
;
5428 hres
= VariantChangeTypeEx(&vDst
, &vSrc
, lcid
, 0, vt
);
5429 ok(hres
== hExpected
,
5430 "change unk(badvar): vt %d expected 0x%08x, got 0x%08x\n",
5431 vt
, hExpected
, hres
);
5436 static void test_IDispatchClear(void)
5440 DummyDispatch d
= { &DummyDispatch_VTable
, 1, VT_UI1
, FALSE
};
5441 IDispatch
* pd
= (IDispatch
*)&d
;
5443 /* As per IUnknown */
5445 V_VT(&v
) = VT_DISPATCH
;
5446 V_DISPATCH(&v
) = pd
;
5447 hres
= VariantClear(&v
);
5448 ok(hres
== S_OK
&& d
.ref
== 0 && V_VT(&v
) == VT_EMPTY
,
5449 "clear dispatch: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5450 S_OK
, 0, VT_EMPTY
, hres
, d
.ref
, V_VT(&v
));
5453 V_VT(&v
) = VT_DISPATCH
|VT_BYREF
;
5454 V_DISPATCHREF(&v
) = &pd
;
5455 hres
= VariantClear(&v
);
5456 ok(hres
== S_OK
&& d
.ref
== 1 && V_VT(&v
) == VT_EMPTY
,
5457 "clear dispatch: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5458 S_OK
, 1, VT_EMPTY
, hres
, d
.ref
, V_VT(&v
));
5461 static void test_IDispatchCopy(void)
5464 VARIANTARG vSrc
, vDst
;
5465 DummyDispatch d
= { &DummyDispatch_VTable
, 1, VT_UI1
, FALSE
};
5466 IDispatch
* pd
= (IDispatch
*)&d
;
5468 /* As per IUnknown */
5471 V_VT(&vSrc
) = VT_DISPATCH
;
5472 V_DISPATCH(&vSrc
) = pd
;
5473 hres
= VariantCopy(&vDst
, &vSrc
);
5474 ok(hres
== S_OK
&& d
.ref
== 2 && V_VT(&vDst
) == VT_DISPATCH
,
5475 "copy dispatch: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5476 S_OK
, 2, VT_EMPTY
, hres
, d
.ref
, V_VT(&vDst
));
5480 V_VT(&vSrc
) = VT_DISPATCH
|VT_BYREF
;
5481 V_DISPATCHREF(&vSrc
) = &pd
;
5482 hres
= VariantCopy(&vDst
, &vSrc
);
5483 ok(hres
== S_OK
&& d
.ref
== 1 && V_VT(&vDst
) == (VT_DISPATCH
|VT_BYREF
),
5484 "copy dispatch: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5485 S_OK
, 1, VT_DISPATCH
, hres
, d
.ref
, V_VT(&vDst
));
5489 V_VT(&vSrc
) = VT_DISPATCH
|VT_BYREF
;
5490 V_DISPATCHREF(&vSrc
) = &pd
;
5491 hres
= VariantCopyInd(&vDst
, &vSrc
);
5492 ok(hres
== S_OK
&& d
.ref
== 2 && V_VT(&vDst
) == VT_DISPATCH
,
5493 "copy dispatch: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5494 S_OK
, 2, VT_DISPATCH
, hres
, d
.ref
, V_VT(&vDst
));
5497 V_VT(&vSrc
) = VT_DISPATCH
|VT_BYREF
;
5498 V_DISPATCHREF(&vSrc
) = &pd
;
5499 hres
= VariantCopyInd(&vSrc
, &vSrc
);
5500 ok(hres
== S_OK
&& d
.ref
== 2 && V_VT(&vSrc
) == VT_DISPATCH
,
5501 "copy dispatch: expected 0x%08x, %d, %d, got 0x%08x, %d, %d\n",
5502 S_OK
, 2, VT_DISPATCH
, hres
, d
.ref
, V_VT(&vSrc
));
5505 static void test_IDispatchChangeTypeEx(void)
5508 VARIANTARG vSrc
, vDst
;
5510 DummyDispatch d
= { &DummyDispatch_VTable
, 1, VT_UI1
, FALSE
};
5511 IDispatch
* pd
= (IDispatch
*)&d
;
5513 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
, SUBLANG_ENGLISH_US
), SORT_DEFAULT
);
5515 V_VT(&vSrc
) = VT_DISPATCH
;
5516 V_DISPATCH(&vSrc
) = pd
;
5518 /* =>IUnknown in place */
5519 hres
= VariantChangeTypeEx(&vSrc
, &vSrc
, lcid
, 0, VT_UNKNOWN
);
5520 ok(hres
== S_OK
&& d
.ref
== 1 &&
5521 V_VT(&vSrc
) == VT_UNKNOWN
&& V_UNKNOWN(&vSrc
) == (IUnknown
*)pd
,
5522 "change disp(src=src): expected 0x%08x,%d,%d,%p, got 0x%08x,%d,%d,%p\n",
5523 S_OK
, 1, VT_UNKNOWN
, pd
, hres
, d
.ref
, V_VT(&vSrc
), V_UNKNOWN(&vSrc
));
5527 V_VT(&vSrc
) = VT_DISPATCH
;
5528 V_DISPATCH(&vSrc
) = pd
;
5530 hres
= VariantChangeTypeEx(&vDst
, &vSrc
, lcid
, 0, VT_UNKNOWN
);
5531 /* Note vSrc is not cleared, as final refcount is 2 */
5532 ok(hres
== S_OK
&& d
.ref
== 2 &&
5533 V_VT(&vDst
) == VT_UNKNOWN
&& V_UNKNOWN(&vDst
) == (IUnknown
*)pd
,
5534 "change disp(src,dst): expected 0x%08x,%d,%d,%p, got 0x%08x,%d,%d,%p\n",
5535 S_OK
, 2, VT_UNKNOWN
, pd
, hres
, d
.ref
, V_VT(&vDst
), V_UNKNOWN(&vDst
));
5537 /* FIXME: Verify that VARIANT_NOVALUEPROP prevents conversion to integral
5538 * types. this requires that the xxxFromDisp tests work first.
5543 static void test_ErrorChangeTypeEx(void)
5546 VARIANTARG vSrc
, vDst
;
5550 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
, SUBLANG_ENGLISH_US
), SORT_DEFAULT
);
5552 for (vt
= 0; vt
<= VT_BSTR_BLOB
; vt
++)
5554 HRESULT hExpected
= DISP_E_BADVARTYPE
;
5556 V_VT(&vSrc
) = VT_ERROR
;
5559 hres
= VariantChangeTypeEx(&vDst
, &vSrc
, lcid
, 0, vt
);
5565 if (vt
== VT_I8
|| vt
== VT_UI8
)
5567 if (HAVE_OLEAUT32_I8
)
5568 hExpected
= DISP_E_TYPEMISMATCH
;
5570 else if (vt
== VT_RECORD
)
5572 if (HAVE_OLEAUT32_RECORD
)
5573 hExpected
= DISP_E_TYPEMISMATCH
;
5575 else if (vt
<= VT_UINT
&& vt
!= (VARTYPE
)15)
5576 hExpected
= DISP_E_TYPEMISMATCH
;
5578 if (IS_ANCIENT
&& IS_MODERN_VTYPE(vt
))
5579 hExpected
= DISP_E_BADVARTYPE
;
5581 ok(hres
== hExpected
,
5582 "change err: vt %d expected 0x%08x, got 0x%08x\n", vt
, hExpected
, hres
);
5587 static void test_EmptyChangeTypeEx(void)
5590 VARIANTARG vSrc
, vDst
;
5594 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
, SUBLANG_ENGLISH_US
), SORT_DEFAULT
);
5596 for (vt
= 0; vt
<= VT_BSTR_BLOB
; vt
++)
5598 HRESULT hExpected
= DISP_E_BADVARTYPE
;
5601 memset(&vDst
, 0, sizeof(vDst
));
5602 V_VT(&vDst
) = VT_EMPTY
;
5604 if (vt
== VT_I8
|| vt
== VT_UI8
)
5606 if (HAVE_OLEAUT32_I8
)
5609 else if (vt
== VT_RECORD
)
5611 if (HAVE_OLEAUT32_RECORD
)
5612 hExpected
= DISP_E_TYPEMISMATCH
;
5614 else if (vt
== VT_VARIANT
|| vt
== VT_DISPATCH
||
5615 vt
== VT_UNKNOWN
|| vt
== VT_ERROR
)
5617 hExpected
= DISP_E_TYPEMISMATCH
;
5619 else if (vt
<= VT_UINT
&& vt
!= (VARTYPE
)15)
5622 if (IS_ANCIENT
&& IS_MODERN_VTYPE(vt
))
5623 hExpected
= DISP_E_BADVARTYPE
;
5625 hres
= VariantChangeTypeEx(&vDst
, &vSrc
, lcid
, 0, vt
);
5627 ok(hres
== hExpected
&& (hres
!= S_OK
|| V_VT(&vDst
) == vt
),
5628 "change empty: vt %d expected 0x%08x, got 0x%08x, vt %d\n",
5629 vt
, hExpected
, hres
, V_VT(&vDst
));
5634 static void test_NullChangeTypeEx(void)
5637 VARIANTARG vSrc
, vDst
;
5641 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
, SUBLANG_ENGLISH_US
), SORT_DEFAULT
);
5643 for (vt
= 0; vt
<= VT_BSTR_BLOB
; vt
++)
5645 HRESULT hExpected
= DISP_E_BADVARTYPE
;
5648 V_VT(&vSrc
) = VT_NULL
;
5649 memset(&vDst
, 0, sizeof(vDst
));
5650 V_VT(&vDst
) = VT_EMPTY
;
5652 if (vt
== VT_I8
|| vt
== VT_UI8
)
5654 if (HAVE_OLEAUT32_I8
)
5655 hExpected
= DISP_E_TYPEMISMATCH
;
5657 else if (vt
== VT_RECORD
)
5659 if (HAVE_OLEAUT32_RECORD
)
5660 hExpected
= DISP_E_TYPEMISMATCH
;
5662 else if (vt
== VT_NULL
)
5666 else if (vt
== VT_VARIANT
|| vt
== VT_DISPATCH
||
5667 vt
== VT_UNKNOWN
|| vt
== VT_ERROR
||
5668 (vt
<= VT_UINT
&& vt
!= (VARTYPE
)15))
5669 hExpected
= DISP_E_TYPEMISMATCH
;
5671 if (IS_ANCIENT
&& IS_MODERN_VTYPE(vt
))
5672 hExpected
= DISP_E_BADVARTYPE
;
5674 hres
= VariantChangeTypeEx(&vDst
, &vSrc
, lcid
, 0, vt
);
5676 ok(hres
== hExpected
&& (hres
!= S_OK
|| V_VT(&vDst
) == vt
),
5677 "change null: vt %d expected 0x%08x, got 0x%08x, vt %d\n",
5678 vt
, hExpected
, hres
, V_VT(&vDst
));
5684 static void test_UintChangeTypeEx(void)
5687 VARIANTARG vSrc
, vDst
;
5690 lcid
= MAKELCID(MAKELANGID(LANG_ENGLISH
, SUBLANG_ENGLISH_US
), SORT_DEFAULT
);
5692 /* Converting a VT_UINT to a VT_INT does not check for overflow */
5693 V_VT(&vDst
) = VT_EMPTY
;
5694 V_VT(&vSrc
) = VT_UINT
;
5696 hres
= VariantChangeTypeEx(&vDst
, &vSrc
, lcid
, 0, VT_I4
);
5697 ok(hres
== S_OK
&& V_VT(&vDst
) == VT_I4
&& V_I4(&vDst
) == -1,
5698 "change uint: Expected %d,0x%08x,%d got %d,0x%08x,%d\n",
5699 VT_I4
, S_OK
, -1, V_VT(&vDst
), hres
, V_I4(&vDst
));
5702 #define NUM_CUST_ITEMS 16
5704 static void test_ClearCustData(void)
5706 WCHAR buff
[sizeof(CUSTDATAITEM
) * NUM_CUST_ITEMS
/ sizeof(WCHAR
)];
5710 CHECKPTR(ClearCustData
);
5712 memset(buff
, 0, sizeof(buff
));
5714 ci
.cCustData
= NUM_CUST_ITEMS
;
5715 /* This is a bit tricky. We use SysAllocStringByteLen to allocate the
5716 * array, since native uses an internal IMalloc interface for allocating
5717 * its memory, while Wine uses HeapAlloc(). Doing this ensures we allocate
5718 * using the correct function whether with native or builtin.
5720 ci
.prgCustData
= (LPCUSTDATAITEM
)SysAllocStringByteLen((LPCSTR
)buff
, sizeof(buff
));
5721 for (i
= 0; i
< NUM_CUST_ITEMS
; i
++)
5722 VariantInit(&ci
.prgCustData
[i
].varValue
);
5723 pClearCustData(&ci
);
5724 ok(!ci
.cCustData
&& !ci
.prgCustData
, "ClearCustData didn't clear fields!\n");
5727 static void test_NullByRef(void)
5734 V_VT(&v1
) = VT_BYREF
|VT_VARIANT
;
5737 hRes
= VariantChangeTypeEx(&v2
, &v1
, 0, 0, VT_I4
);
5738 ok(hRes
== DISP_E_TYPEMISMATCH
, "VariantChangeTypeEx should return DISP_E_TYPEMISMATCH\n");
5741 V_VT(&v1
) = VT_BYREF
|VT_VARIANT
;
5746 hRes
= VariantChangeTypeEx(&v2
, &v1
, 0, 0, VT_VARIANT
);
5747 ok(hRes
== DISP_E_TYPEMISMATCH
, "VariantChangeTypeEx should return DISP_E_TYPEMISMATCH\n");
5748 ok(V_VT(&v2
) == VT_I4
&& V_I4(&v2
) == 123, "VariantChangeTypeEx shouldn't change pvargDest\n");
5750 hRes
= VariantChangeTypeEx(&v2
, &v1
, 0, 0, VT_BYREF
|VT_I4
);
5751 ok(hRes
== DISP_E_TYPEMISMATCH
, "VariantChangeTypeEx should return DISP_E_TYPEMISMATCH\n");
5753 hRes
= VariantChangeTypeEx(&v2
, &v1
, 0, 0, 0x3847);
5754 ok(hRes
== DISP_E_BADVARTYPE
, "VariantChangeTypeEx should return DISP_E_BADVARTYPE\n");
5757 /* Dst Variant should remain unchanged if VariantChangeType cannot convert */
5758 static void test_ChangeType_keep_dst(void)
5762 static const WCHAR testW
[] = {'t','e','s','t',0};
5765 bstr
= SysAllocString(testW
);
5768 V_VT(&v1
) = VT_BSTR
;
5770 hres
= VariantChangeTypeEx(&v1
, &v1
, 0, 0, VT_INT
);
5771 ok(hres
== DISP_E_TYPEMISMATCH
, "VariantChangeTypeEx returns %08x\n", hres
);
5772 ok(V_VT(&v1
) == VT_BSTR
&& V_BSTR(&v1
) == bstr
, "VariantChangeTypeEx changed dst variant\n");
5775 hres
= VariantChangeTypeEx(&v2
, &v1
, 0, 0, VT_INT
);
5776 ok(hres
== DISP_E_TYPEMISMATCH
, "VariantChangeTypeEx returns %08x\n", hres
);
5777 ok(V_VT(&v2
) == VT_INT
&& V_INT(&v2
) == 4, "VariantChangeTypeEx changed dst variant\n");
5778 SysFreeString(bstr
);
5783 hOleaut32
= GetModuleHandleA("oleaut32.dll");
5785 trace("LCID's: System=0x%08x, User=0x%08x\n", GetSystemDefaultLCID(),
5786 GetUserDefaultLCID());
5791 test_VarI1FromUI1();
5792 test_VarI1FromUI2();
5793 test_VarI1FromUI4();
5794 test_VarI1FromUI8();
5795 test_VarI1FromBool();
5798 test_VarI1FromDate();
5800 test_VarI1FromDec();
5801 test_VarI1FromStr();
5802 test_VarUI1FromDisp();
5804 test_VarI1ChangeTypeEx();
5806 test_VarUI1FromI1();
5807 test_VarUI1FromI2();
5808 test_VarUI1FromI4();
5809 test_VarUI1FromI8();
5810 test_VarUI1FromUI2();
5811 test_VarUI1FromUI4();
5812 test_VarUI1FromUI8();
5813 test_VarUI1FromBool();
5814 test_VarUI1FromR4();
5815 test_VarUI1FromR8();
5816 test_VarUI1FromDate();
5817 test_VarUI1FromCy();
5818 test_VarUI1FromDec();
5819 test_VarUI1FromStr();
5821 test_VarUI1ChangeTypeEx();
5826 test_VarI2FromUI1();
5827 test_VarI2FromUI2();
5828 test_VarI2FromUI4();
5829 test_VarI2FromUI8();
5830 test_VarI2FromBool();
5833 test_VarI2FromDate();
5835 test_VarI2FromDec();
5836 test_VarI2FromStr();
5838 test_VarI2ChangeTypeEx();
5840 test_VarUI2FromI1();
5841 test_VarUI2FromI2();
5842 test_VarUI2FromI4();
5843 test_VarUI2FromI8();
5844 test_VarUI2FromUI1();
5845 test_VarUI2FromUI4();
5846 test_VarUI2FromUI8();
5847 test_VarUI2FromBool();
5848 test_VarUI2FromR4();
5849 test_VarUI2FromR8();
5850 test_VarUI2FromDate();
5851 test_VarUI2FromCy();
5852 test_VarUI2FromDec();
5853 test_VarUI2FromStr();
5855 test_VarUI2ChangeTypeEx();
5860 test_VarI4FromUI1();
5861 test_VarI4FromUI2();
5862 test_VarI4FromUI4();
5863 test_VarI4FromUI8();
5864 test_VarI4FromBool();
5867 test_VarI4FromDate();
5869 test_VarI4FromDec();
5870 test_VarI4FromStr();
5872 test_VarI4ChangeTypeEx();
5874 test_VarUI4FromI1();
5875 test_VarUI4FromI2();
5876 test_VarUI4FromUI2();
5877 test_VarUI4FromI8();
5878 test_VarUI4FromUI1();
5879 test_VarUI4FromI4();
5880 test_VarUI4FromUI8();
5881 test_VarUI4FromBool();
5882 test_VarUI4FromR4();
5883 test_VarUI4FromR8();
5884 test_VarUI4FromDate();
5885 test_VarUI4FromCy();
5886 test_VarUI4FromDec();
5887 test_VarUI4FromStr();
5889 test_VarUI4ChangeTypeEx();
5892 test_VarI8FromUI1();
5894 test_VarI8FromUI2();
5895 test_VarI8FromUI4();
5898 test_VarI8FromBool();
5899 test_VarI8FromUI8();
5901 test_VarI8FromDec();
5902 test_VarI8FromDate();
5903 test_VarI8FromStr();
5905 test_VarI8ChangeTypeEx();
5907 test_VarUI8FromI1();
5908 test_VarUI8FromUI1();
5909 test_VarUI8FromI2();
5910 test_VarUI8FromUI2();
5911 test_VarUI8FromUI4();
5912 test_VarUI8FromR4();
5913 test_VarUI8FromR8();
5914 test_VarUI8FromBool();
5915 test_VarUI8FromI8();
5916 test_VarUI8FromCy();
5917 test_VarUI8FromDec();
5918 test_VarUI8FromDate();
5919 test_VarUI8FromStr();
5921 test_VarUI8ChangeTypeEx();
5924 test_VarR4FromUI1();
5926 test_VarR4FromUI2();
5928 test_VarR4FromUI4();
5930 test_VarR4FromBool();
5933 test_VarR4FromUI8();
5934 test_VarR4FromDec();
5935 test_VarR4FromDate();
5936 test_VarR4FromStr();
5938 test_VarR4ChangeTypeEx();
5941 test_VarR8FromUI1();
5943 test_VarR8FromUI2();
5945 test_VarR8FromUI4();
5947 test_VarR8FromBool();
5950 test_VarR8FromUI8();
5951 test_VarR8FromDec();
5952 test_VarR8FromDate();
5953 test_VarR8FromStr();
5955 test_VarR8ChangeTypeEx();
5958 test_VarDateFromI1();
5959 test_VarDateFromUI1();
5960 test_VarDateFromI2();
5961 test_VarDateFromUI2();
5962 test_VarDateFromI4();
5963 test_VarDateFromUI4();
5964 test_VarDateFromR4();
5965 test_VarDateFromR8();
5966 test_VarDateFromBool();
5967 test_VarDateFromCy();
5968 test_VarDateFromI8();
5969 test_VarDateFromUI8();
5970 test_VarDateFromDec();
5971 test_VarDateFromStr();
5973 test_VarDateChangeTypeEx();
5976 test_VarCyFromUI1();
5978 test_VarCyFromUI2();
5980 test_VarCyFromUI4();
5983 test_VarCyFromBool();
5985 test_VarCyFromUI8();
5986 test_VarCyFromDec();
5987 test_VarCyFromDate();
6002 test_VarDecFromI1();
6003 test_VarDecFromI2();
6004 test_VarDecFromI4();
6005 test_VarDecFromI8();
6006 test_VarDecFromUI1();
6007 test_VarDecFromUI2();
6008 test_VarDecFromUI4();
6009 test_VarDecFromUI8();
6010 test_VarDecFromR4();
6011 test_VarDecFromR8();
6012 test_VarDecFromDate();
6013 test_VarDecFromStr();
6014 test_VarDecFromCy();
6015 test_VarDecFromDate();
6016 test_VarDecFromBool();
6026 test_VarBoolFromI1();
6027 test_VarBoolFromUI1();
6028 test_VarBoolFromI2();
6029 test_VarBoolFromUI2();
6030 test_VarBoolFromI4();
6031 test_VarBoolFromUI4();
6032 test_VarBoolFromR4();
6033 test_VarBoolFromR8();
6034 test_VarBoolFromCy();
6035 test_VarBoolFromI8();
6036 test_VarBoolFromUI8();
6037 test_VarBoolFromDec();
6038 test_VarBoolFromDate();
6039 test_VarBoolFromStr();
6041 test_VarBoolChangeTypeEx();
6043 test_VarBstrFromR4();
6044 test_VarBstrFromDate();
6045 test_VarBstrFromDec();
6047 test_SysStringLen();
6048 test_SysStringByteLen();
6049 test_SysAllocString();
6050 test_SysAllocStringLen();
6051 test_SysAllocStringByteLen();
6052 test_SysReAllocString();
6053 test_SysReAllocStringLen();
6057 test_IUnknownClear();
6058 test_IUnknownCopy();
6059 test_IUnknownChangeTypeEx();
6061 test_IDispatchClear();
6062 test_IDispatchCopy();
6063 test_IDispatchChangeTypeEx();
6065 test_ErrorChangeTypeEx();
6066 test_EmptyChangeTypeEx();
6067 test_NullChangeTypeEx();
6068 test_UintChangeTypeEx();
6070 test_ClearCustData();
6073 test_ChangeType_keep_dst();