Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
d95ee19d
Commit
d95ee19d
authored
Dec 15, 2003
by
Jon Griffiths
Committed by
Alexandre Julliard
Dec 15, 2003
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use the SafeArray conversion functions when coercing arrays.
Simplify VariantChangeTypeEx. Replace calls to dump_Variant() with TRACE's.
parent
c2d6a6b4
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
73 additions
and
161 deletions
+73
-161
variant.c
dlls/oleaut32/variant.c
+73
-161
No files found.
dlls/oleaut32/variant.c
View file @
d95ee19d
...
@@ -41,7 +41,6 @@
...
@@ -41,7 +41,6 @@
#include "wine/debug.h"
#include "wine/debug.h"
#include "wine/unicode.h"
#include "wine/unicode.h"
#include "winerror.h"
#include "winerror.h"
#include "typelib.h"
#include "variant.h"
#include "variant.h"
WINE_DEFAULT_DEBUG_CHANNEL
(
ole
);
WINE_DEFAULT_DEBUG_CHANNEL
(
ole
);
...
@@ -79,13 +78,9 @@ const char* wine_vflags[16] =
...
@@ -79,13 +78,9 @@ const char* wine_vflags[16] =
"|VT_VECTOR|VT_ARRAY|VT_BYREF|VT_HARDTYPE"
,
"|VT_VECTOR|VT_ARRAY|VT_BYREF|VT_HARDTYPE"
,
};
};
/******************************************************************************
/* Convert a variant from one type to another */
* Coerce [INTERNAL]
static
inline
HRESULT
VARIANT_Coerce
(
VARIANTARG
*
pd
,
LCID
lcid
,
USHORT
wFlags
,
*
VARIANTARG
*
ps
,
VARTYPE
vt
)
* This function dispatches execution to the proper conversion API
* to do the necessary coercion.
*/
static
HRESULT
Coerce
(
VARIANTARG
*
pd
,
LCID
lcid
,
USHORT
wFlags
,
VARIANTARG
*
ps
,
VARTYPE
vt
)
{
{
HRESULT
res
=
DISP_E_TYPEMISMATCH
;
HRESULT
res
=
DISP_E_TYPEMISMATCH
;
VARTYPE
vtFrom
=
V_TYPE
(
ps
);
VARTYPE
vtFrom
=
V_TYPE
(
ps
);
...
@@ -520,11 +515,25 @@ static HRESULT Coerce(VARIANTARG* pd, LCID lcid, USHORT wFlags, VARIANTARG* ps,
...
@@ -520,11 +515,25 @@ static HRESULT Coerce(VARIANTARG* pd, LCID lcid, USHORT wFlags, VARIANTARG* ps,
case
VT_RECORD
:
case
VT_RECORD
:
break
;
break
;
}
}
return
res
;
return
res
;
}
}
/* Coerce to/from an array */
static
inline
HRESULT
VARIANT_CoerceArray
(
VARIANTARG
*
pd
,
VARIANTARG
*
ps
,
VARTYPE
vt
)
{
if
(
vt
==
VT_BSTR
&&
V_VT
(
ps
)
==
(
VT_ARRAY
|
VT_UI1
))
return
BstrFromVector
(
V_ARRAY
(
ps
),
&
V_BSTR
(
pd
));
if
(
V_VT
(
ps
)
==
VT_BSTR
&&
vt
==
(
VT_ARRAY
|
VT_UI1
))
return
VectorFromBstr
(
V_BSTR
(
ps
),
&
V_ARRAY
(
ps
));
if
(
V_VT
(
ps
)
==
vt
)
return
SafeArrayCopy
(
V_ARRAY
(
ps
),
&
V_ARRAY
(
pd
));
return
DISP_E_TYPEMISMATCH
;
}
/******************************************************************************
/******************************************************************************
* Check if a variants type is valid.
* Check if a variants type is valid.
*/
*/
...
@@ -893,50 +902,6 @@ VariantCopyInd_Return:
...
@@ -893,50 +902,6 @@ VariantCopyInd_Return:
}
}
/******************************************************************************
/******************************************************************************
* Coerces a full safearray. Not optimal code.
*/
static
HRESULT
coerce_array
(
VARIANTARG
*
src
,
VARIANTARG
*
dst
,
LCID
lcid
,
USHORT
wFlags
,
VARTYPE
vt
)
{
SAFEARRAY
*
sarr
=
V_ARRAY
(
src
);
HRESULT
hres
;
LPVOID
data
;
VARTYPE
vartype
;
SafeArrayGetVartype
(
sarr
,
&
vartype
);
switch
(
vt
)
{
case
VT_BSTR
:
if
(
sarr
->
cDims
!=
1
)
{
FIXME
(
"Can not coerce array with dim %d into BSTR
\n
"
,
sarr
->
cDims
);
return
E_FAIL
;
}
switch
(
V_VT
(
src
)
&
VT_TYPEMASK
)
{
case
VT_UI1
:
hres
=
SafeArrayAccessData
(
sarr
,
&
data
);
if
(
FAILED
(
hres
))
return
hres
;
/* Yes, just memcpied apparently. */
V_BSTR
(
dst
)
=
SysAllocStringByteLen
(
data
,
sarr
->
rgsabound
[
0
].
cElements
);
hres
=
SafeArrayUnaccessData
(
sarr
);
if
(
FAILED
(
hres
))
return
hres
;
break
;
default:
FIXME
(
"Cannot coerce array of %d into BSTR yet. Please report!
\n
"
,
V_VT
(
src
)
&
VT_TYPEMASK
);
return
E_FAIL
;
}
break
;
case
VT_SAFEARRAY
:
V_VT
(
dst
)
=
VT_SAFEARRAY
;
return
SafeArrayCopy
(
sarr
,
&
V_ARRAY
(
dst
));
default:
FIXME
(
"Cannot coerce array of vt 0x%x/0x%x into vt 0x%x yet. Please report/implement!
\n
"
,
vartype
,
V_VT
(
src
),
vt
);
return
E_FAIL
;
}
return
S_OK
;
}
/******************************************************************************
* VariantChangeType [OLEAUT32.12]
* VariantChangeType [OLEAUT32.12]
*
*
* Change the type of a variant.
* Change the type of a variant.
...
@@ -985,9 +950,6 @@ HRESULT WINAPI VariantChangeTypeEx(VARIANTARG* pvargDest, VARIANTARG* pvargSrc,
...
@@ -985,9 +950,6 @@ HRESULT WINAPI VariantChangeTypeEx(VARIANTARG* pvargDest, VARIANTARG* pvargSrc,
LCID
lcid
,
USHORT
wFlags
,
VARTYPE
vt
)
LCID
lcid
,
USHORT
wFlags
,
VARTYPE
vt
)
{
{
HRESULT
res
=
S_OK
;
HRESULT
res
=
S_OK
;
VARIANTARG
varg
;
V_VT
(
&
varg
)
=
VT_EMPTY
;
TRACE
(
"(%p->(%s%s),%p->(%s%s),0x%08lx,0x%04x,%s%s)
\n
"
,
pvargDest
,
TRACE
(
"(%p->(%s%s),%p->(%s%s),0x%08lx,0x%04x,%s%s)
\n
"
,
pvargDest
,
debugstr_VT
(
pvargDest
),
debugstr_VF
(
pvargDest
),
pvargSrc
,
debugstr_VT
(
pvargDest
),
debugstr_VF
(
pvargDest
),
pvargSrc
,
...
@@ -995,84 +957,42 @@ HRESULT WINAPI VariantChangeTypeEx(VARIANTARG* pvargDest, VARIANTARG* pvargSrc,
...
@@ -995,84 +957,42 @@ HRESULT WINAPI VariantChangeTypeEx(VARIANTARG* pvargDest, VARIANTARG* pvargSrc,
debugstr_vt
(
vt
),
debugstr_vf
(
vt
));
debugstr_vt
(
vt
),
debugstr_vf
(
vt
));
if
(
vt
==
VT_CLSID
)
if
(
vt
==
VT_CLSID
)
{
res
=
DISP_E_BADVARTYPE
;
res
=
DISP_E_BADVARTYPE
;
}
else
else
{
res
=
VARIANT_ValidateType
(
V_VT
(
pvargSrc
));
res
=
VARIANT_ValidateType
(
V_VT
(
pvargSrc
));
if
(
SUCCEEDED
(
res
)
)
if
(
SUCCEEDED
(
res
))
{
res
=
VARIANT_ValidateType
(
vt
);
res
=
VARIANT_ValidateType
(
vt
);
/* if we are doing an in-place conversion make a copy of the source.
if
(
SUCCEEDED
(
res
))
*/
if
(
SUCCEEDED
(
res
)
&&
pvargDest
==
pvargSrc
)
{
{
res
=
VariantCopy
(
&
varg
,
pvargSrc
);
VARIANTARG
vTmp
;
pvargSrc
=
&
varg
;
}
if
(
SUCCEEDED
(
res
)
)
V_VT
(
&
vTmp
)
=
VT_EMPTY
;
{
res
=
VariantCopyInd
(
&
vTmp
,
pvargSrc
);
/* free up the destination variant.
*/
res
=
VariantClear
(
pvargDest
);
}
if
(
SUCCEEDED
(
res
)
)
if
(
SUCCEEDED
(
res
))
{
if
(
V_VT
(
pvargSrc
)
&
VT_BYREF
)
{
{
/* Convert the source variant to a "byvalue" variant.
res
=
VariantClear
(
pvargDest
);
*/
VARIANTARG
Variant
;
if
((
V_VT
(
pvargSrc
)
&
0xf000
)
!=
VT_BYREF
)
{
if
(
SUCCEEDED
(
res
))
FIXME
(
"VT_TYPEMASK %s is unhandled.
\n
"
,
debugstr_VF
(
pvargSrc
));
return
E_FAIL
;
}
V_VT
(
&
Variant
)
=
VT_EMPTY
;
res
=
VariantCopyInd
(
&
Variant
,
pvargSrc
);
if
(
SUCCEEDED
(
res
)
)
{
{
res
=
Coerce
(
pvargDest
,
lcid
,
wFlags
,
&
Variant
,
vt
);
if
(
V_ISARRAY
(
&
vTmp
)
||
(
vt
&
VT_ARRAY
))
/* this should not fail.
res
=
VARIANT_CoerceArray
(
pvargDest
,
&
vTmp
,
vt
);
*/
VariantClear
(
&
Variant
);
}
}
else
else
{
res
=
VARIANT_Coerce
(
pvargDest
,
lcid
,
wFlags
,
&
vTmp
,
vt
);
if
(
V_VT
(
pvargSrc
)
&
VT_ARRAY
)
{
if
(
SUCCEEDED
(
res
))
if
((
V_VT
(
pvargSrc
)
&
0xf000
)
!=
VT_ARRAY
)
V_VT
(
pvargDest
)
=
vt
;
{
FIXME
(
"VT_TYPEMASK %s is unhandled in VT_ARRAY.
\n
"
,
debugstr_VF
(
pvargSrc
));
return
E_FAIL
;
}
}
V_VT
(
pvargDest
)
=
VT_ARRAY
|
vt
;
VariantClear
(
&
vTmp
);
res
=
coerce_array
(
pvargSrc
,
pvargDest
,
lcid
,
wFlags
,
vt
);
}
}
else
{
if
((
V_VT
(
pvargSrc
)
&
0xf000
))
{
FIXME
(
"VT_TYPEMASK %s is unhandled in normal case.
\n
"
,
debugstr_VF
(
pvargSrc
));
return
E_FAIL
;
}
/* Use the current "byvalue" source variant.
*/
res
=
Coerce
(
pvargDest
,
lcid
,
wFlags
,
pvargSrc
,
vt
);
}
}
}
}
}
}
VariantClear
(
&
varg
);
if
(
SUCCEEDED
(
res
)
)
V_VT
(
pvargDest
)
=
vt
;
TRACE
(
"returning 0x%08lx, %p->(%s%s)
\n
"
,
res
,
pvargDest
,
TRACE
(
"returning 0x%08lx, %p->(%s%s)
\n
"
,
res
,
pvargDest
,
debugstr_VT
(
pvargDest
),
debugstr_VF
(
pvargDest
));
debugstr_VT
(
pvargDest
),
debugstr_VF
(
pvargDest
));
return
res
;
return
res
;
...
@@ -2319,6 +2239,9 @@ VarNumFromParseNum_DecOverflow:
...
@@ -2319,6 +2239,9 @@ VarNumFromParseNum_DecOverflow:
*/
*/
HRESULT
WINAPI
VarCat
(
LPVARIANT
left
,
LPVARIANT
right
,
LPVARIANT
out
)
HRESULT
WINAPI
VarCat
(
LPVARIANT
left
,
LPVARIANT
right
,
LPVARIANT
out
)
{
{
TRACE
(
"(%p->(%s%s),%p->(%s%s),%p)
\n
"
,
left
,
debugstr_VT
(
left
),
debugstr_VF
(
left
),
right
,
debugstr_VT
(
right
),
debugstr_VF
(
right
),
out
);
/* Should we VariantClear out? */
/* Should we VariantClear out? */
/* Can we handle array, vector, by ref etc. */
/* Can we handle array, vector, by ref etc. */
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_NULL
&&
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_NULL
&&
...
@@ -2374,8 +2297,6 @@ HRESULT WINAPI VarCat(LPVARIANT left, LPVARIANT right, LPVARIANT out)
...
@@ -2374,8 +2297,6 @@ HRESULT WINAPI VarCat(LPVARIANT left, LPVARIANT right, LPVARIANT out)
*/
*/
HRESULT
WINAPI
VarCmp
(
LPVARIANT
left
,
LPVARIANT
right
,
LCID
lcid
,
DWORD
flags
)
HRESULT
WINAPI
VarCmp
(
LPVARIANT
left
,
LPVARIANT
right
,
LCID
lcid
,
DWORD
flags
)
{
{
BOOL
lOk
=
TRUE
;
BOOL
lOk
=
TRUE
;
BOOL
rOk
=
TRUE
;
BOOL
rOk
=
TRUE
;
LONGLONG
lVal
=
-
1
;
LONGLONG
lVal
=
-
1
;
...
@@ -2384,15 +2305,13 @@ HRESULT WINAPI VarCmp(LPVARIANT left, LPVARIANT right, LCID lcid, DWORD flags)
...
@@ -2384,15 +2305,13 @@ HRESULT WINAPI VarCmp(LPVARIANT left, LPVARIANT right, LCID lcid, DWORD flags)
DWORD
xmask
;
DWORD
xmask
;
HRESULT
rc
;
HRESULT
rc
;
TRACE
(
"(%p->(%s%s),%p->(%s%s),0x%08lx,0x%08lx)
\n
"
,
left
,
debugstr_VT
(
left
),
debugstr_VF
(
left
),
right
,
debugstr_VT
(
right
),
debugstr_VF
(
right
),
lcid
,
flags
);
VariantInit
(
&
lv
);
VariantInit
(
&
rv
);
VariantInit
(
&
lv
);
VariantInit
(
&
rv
);
V_VT
(
right
)
&=
~
0x8000
;
/* hack since we sometime get this flag. */
V_VT
(
right
)
&=
~
0x8000
;
/* hack since we sometime get this flag. */
V_VT
(
left
)
&=
~
0x8000
;
/* hack since we sometime get this flag. */
V_VT
(
left
)
&=
~
0x8000
;
/* hack since we sometime get this flag. */
TRACE
(
"Left Var:
\n
"
);
dump_Variant
(
left
);
TRACE
(
"Right Var:
\n
"
);
dump_Variant
(
right
);
/* If either are null, then return VARCMP_NULL */
/* If either are null, then return VARCMP_NULL */
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_NULL
||
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_NULL
||
(
V_VT
(
right
)
&
VT_TYPEMASK
)
==
VT_NULL
)
(
V_VT
(
right
)
&
VT_TYPEMASK
)
==
VT_NULL
)
...
@@ -2513,10 +2432,8 @@ HRESULT WINAPI VarAnd(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2513,10 +2432,8 @@ HRESULT WINAPI VarAnd(LPVARIANT left, LPVARIANT right, LPVARIANT result)
{
{
HRESULT
rc
=
E_FAIL
;
HRESULT
rc
=
E_FAIL
;
TRACE
(
"Left Var:
\n
"
);
TRACE
(
"(%p->(%s%s),%p->(%s%s),%p)
\n
"
,
left
,
debugstr_VT
(
left
),
dump_Variant
(
left
);
debugstr_VF
(
left
),
right
,
debugstr_VT
(
right
),
debugstr_VF
(
right
),
result
);
TRACE
(
"Right Var:
\n
"
);
dump_Variant
(
right
);
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_BOOL
&&
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_BOOL
&&
(
V_VT
(
right
)
&
VT_TYPEMASK
)
==
VT_BOOL
)
{
(
V_VT
(
right
)
&
VT_TYPEMASK
)
==
VT_BOOL
)
{
...
@@ -2582,8 +2499,8 @@ HRESULT WINAPI VarAnd(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2582,8 +2499,8 @@ HRESULT WINAPI VarAnd(LPVARIANT left, LPVARIANT right, LPVARIANT result)
}
}
}
}
TRACE
(
"r
c=%d, Result:
\n
"
,
(
int
)
rc
);
TRACE
(
"r
eturning 0x%8lx (%s%s),%ld
\n
"
,
rc
,
debugstr_VT
(
result
),
dump_Variant
(
result
);
debugstr_VF
(
result
),
V_VT
(
result
)
==
VT_I4
?
V_I4
(
result
)
:
V_I2
(
result
)
);
return
rc
;
return
rc
;
}
}
...
@@ -2602,10 +2519,8 @@ HRESULT WINAPI VarAdd(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2602,10 +2519,8 @@ HRESULT WINAPI VarAdd(LPVARIANT left, LPVARIANT right, LPVARIANT result)
{
{
HRESULT
rc
=
E_FAIL
;
HRESULT
rc
=
E_FAIL
;
TRACE
(
"Left Var:
\n
"
);
TRACE
(
"(%p->(%s%s),%p->(%s%s),%p)
\n
"
,
left
,
debugstr_VT
(
left
),
dump_Variant
(
left
);
debugstr_VF
(
left
),
right
,
debugstr_VT
(
right
),
debugstr_VF
(
right
),
result
);
TRACE
(
"Right Var:
\n
"
);
dump_Variant
(
right
);
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_EMPTY
)
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_EMPTY
)
return
VariantCopy
(
result
,
right
);
return
VariantCopy
(
result
,
right
);
...
@@ -2723,7 +2638,7 @@ HRESULT WINAPI VarAdd(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2723,7 +2638,7 @@ HRESULT WINAPI VarAdd(LPVARIANT left, LPVARIANT right, LPVARIANT result)
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_BSTR
&&
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_BSTR
&&
(
V_VT
(
right
)
&
VT_TYPEMASK
)
==
VT_BSTR
)
{
(
V_VT
(
right
)
&
VT_TYPEMASK
)
==
VT_BSTR
)
{
V_VT
(
result
)
=
VT_BSTR
;
V_VT
(
result
)
=
VT_BSTR
;
r
c
=
VarBstrCat
(
V_BSTR
(
left
),
V_BSTR
(
right
),
&
V_BSTR
(
result
));
r
eturn
VarBstrCat
(
V_BSTR
(
left
),
V_BSTR
(
right
),
&
V_BSTR
(
result
));
}
else
{
}
else
{
/* Integers */
/* Integers */
...
@@ -2780,8 +2695,8 @@ HRESULT WINAPI VarAdd(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2780,8 +2695,8 @@ HRESULT WINAPI VarAdd(LPVARIANT left, LPVARIANT right, LPVARIANT result)
}
}
}
}
TRACE
(
"r
c=%d, Result:
\n
"
,
(
int
)
rc
);
TRACE
(
"r
eturning 0x%8lx (%s%s),%ld
\n
"
,
rc
,
debugstr_VT
(
result
),
dump_Variant
(
result
);
debugstr_VF
(
result
),
V_VT
(
result
)
==
VT_I4
?
V_I4
(
result
)
:
V_I2
(
result
)
);
return
rc
;
return
rc
;
}
}
...
@@ -2796,8 +2711,8 @@ HRESULT WINAPI VarMul(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2796,8 +2711,8 @@ HRESULT WINAPI VarMul(LPVARIANT left, LPVARIANT right, LPVARIANT result)
VARIANT
lv
,
rv
;
VARIANT
lv
,
rv
;
BOOL
found
;
BOOL
found
;
TRACE
(
"
left: "
);
dump_Variant
(
left
);
TRACE
(
"
(%p->(%s%s),%p->(%s%s),%p)
\n
"
,
left
,
debugstr_VT
(
left
),
TRACE
(
"right: "
);
dump_Variant
(
righ
t
);
debugstr_VF
(
left
),
right
,
debugstr_VT
(
right
),
debugstr_VF
(
right
),
resul
t
);
VariantInit
(
&
lv
);
VariantInit
(
&
rv
);
VariantInit
(
&
lv
);
VariantInit
(
&
rv
);
lvt
=
V_VT
(
left
)
&
VT_TYPEMASK
;
lvt
=
V_VT
(
left
)
&
VT_TYPEMASK
;
...
@@ -2837,8 +2752,8 @@ HRESULT WINAPI VarMul(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2837,8 +2752,8 @@ HRESULT WINAPI VarMul(LPVARIANT left, LPVARIANT right, LPVARIANT result)
rc
=
S_OK
;
rc
=
S_OK
;
break
;
break
;
}
}
TRACE
(
"r
c=%d, Result:
\n
"
,
(
int
)
rc
);
TRACE
(
"r
eturning 0x%8lx (%s%s),%g
\n
"
,
rc
,
debugstr_VT
(
result
),
dump_Variant
(
result
);
debugstr_VF
(
result
),
V_VT
(
result
)
==
VT_R8
?
V_R8
(
result
)
:
(
double
)
V_I4
(
result
)
);
return
rc
;
return
rc
;
}
}
...
@@ -2853,8 +2768,8 @@ HRESULT WINAPI VarDiv(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2853,8 +2768,8 @@ HRESULT WINAPI VarDiv(LPVARIANT left, LPVARIANT right, LPVARIANT result)
VARIANT
lv
,
rv
;
VARIANT
lv
,
rv
;
BOOL
found
;
BOOL
found
;
TRACE
(
"
left: "
);
dump_Variant
(
left
);
TRACE
(
"
(%p->(%s%s),%p->(%s%s),%p)
\n
"
,
left
,
debugstr_VT
(
left
),
TRACE
(
"right: "
);
dump_Variant
(
righ
t
);
debugstr_VF
(
left
),
right
,
debugstr_VT
(
right
),
debugstr_VF
(
right
),
resul
t
);
VariantInit
(
&
lv
);
VariantInit
(
&
rv
);
VariantInit
(
&
lv
);
VariantInit
(
&
rv
);
lvt
=
V_VT
(
left
)
&
VT_TYPEMASK
;
lvt
=
V_VT
(
left
)
&
VT_TYPEMASK
;
...
@@ -2894,8 +2809,8 @@ HRESULT WINAPI VarDiv(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2894,8 +2809,8 @@ HRESULT WINAPI VarDiv(LPVARIANT left, LPVARIANT right, LPVARIANT result)
rc
=
S_OK
;
rc
=
S_OK
;
break
;
break
;
}
}
TRACE
(
"r
c=%d, Result:
\n
"
,
(
int
)
rc
);
TRACE
(
"r
eturning 0x%8lx (%s%s),%g
\n
"
,
rc
,
debugstr_VT
(
result
),
dump_Variant
(
result
);
debugstr_VF
(
result
),
V_VT
(
result
)
==
VT_R8
?
V_R8
(
result
)
:
(
double
)
V_I4
(
result
)
);
return
rc
;
return
rc
;
}
}
...
@@ -2910,8 +2825,8 @@ HRESULT WINAPI VarSub(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2910,8 +2825,8 @@ HRESULT WINAPI VarSub(LPVARIANT left, LPVARIANT right, LPVARIANT result)
VARIANT
lv
,
rv
;
VARIANT
lv
,
rv
;
BOOL
found
;
BOOL
found
;
TRACE
(
"
left: "
);
dump_Variant
(
left
);
TRACE
(
"
(%p->(%s%s),%p->(%s%s),%p)
\n
"
,
left
,
debugstr_VT
(
left
),
TRACE
(
"right: "
);
dump_Variant
(
righ
t
);
debugstr_VF
(
left
),
right
,
debugstr_VT
(
right
),
debugstr_VF
(
right
),
resul
t
);
VariantInit
(
&
lv
);
VariantInit
(
&
rv
);
VariantInit
(
&
lv
);
VariantInit
(
&
rv
);
lvt
=
V_VT
(
left
)
&
VT_TYPEMASK
;
lvt
=
V_VT
(
left
)
&
VT_TYPEMASK
;
...
@@ -2951,8 +2866,8 @@ HRESULT WINAPI VarSub(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2951,8 +2866,8 @@ HRESULT WINAPI VarSub(LPVARIANT left, LPVARIANT right, LPVARIANT result)
rc
=
S_OK
;
rc
=
S_OK
;
break
;
break
;
}
}
TRACE
(
"r
c=%d, Result:
\n
"
,
(
int
)
rc
);
TRACE
(
"r
eturning 0x%8lx (%s%s),%g
\n
"
,
rc
,
debugstr_VT
(
result
),
dump_Variant
(
result
);
debugstr_VF
(
result
),
V_VT
(
result
)
==
VT_R8
?
V_R8
(
result
)
:
(
double
)
V_I4
(
result
)
);
return
rc
;
return
rc
;
}
}
...
@@ -2964,10 +2879,8 @@ HRESULT WINAPI VarOr(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -2964,10 +2879,8 @@ HRESULT WINAPI VarOr(LPVARIANT left, LPVARIANT right, LPVARIANT result)
{
{
HRESULT
rc
=
E_FAIL
;
HRESULT
rc
=
E_FAIL
;
TRACE
(
"Left Var:
\n
"
);
TRACE
(
"(%p->(%s%s),%p->(%s%s),%p)
\n
"
,
left
,
debugstr_VT
(
left
),
dump_Variant
(
left
);
debugstr_VF
(
left
),
right
,
debugstr_VT
(
right
),
debugstr_VF
(
right
),
result
);
TRACE
(
"Right Var:
\n
"
);
dump_Variant
(
right
);
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_BOOL
&&
if
((
V_VT
(
left
)
&
VT_TYPEMASK
)
==
VT_BOOL
&&
(
V_VT
(
right
)
&
VT_TYPEMASK
)
==
VT_BOOL
)
{
(
V_VT
(
right
)
&
VT_TYPEMASK
)
==
VT_BOOL
)
{
...
@@ -3033,8 +2946,8 @@ HRESULT WINAPI VarOr(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -3033,8 +2946,8 @@ HRESULT WINAPI VarOr(LPVARIANT left, LPVARIANT right, LPVARIANT result)
}
}
}
}
TRACE
(
"r
c=%d, Result:
\n
"
,
(
int
)
rc
);
TRACE
(
"r
eturning 0x%8lx (%s%s),%ld
\n
"
,
rc
,
debugstr_VT
(
result
),
dump_Variant
(
result
);
debugstr_VF
(
result
),
V_VT
(
result
)
==
VT_I4
?
V_I4
(
result
)
:
V_I2
(
result
)
);
return
rc
;
return
rc
;
}
}
...
@@ -3226,9 +3139,11 @@ HRESULT WINAPI VarNot(LPVARIANT pVarIn, LPVARIANT pVarOut)
...
@@ -3226,9 +3139,11 @@ HRESULT WINAPI VarNot(LPVARIANT pVarIn, LPVARIANT pVarOut)
* VarMod [OLEAUT32.154]
* VarMod [OLEAUT32.154]
*
*
*/
*/
HRESULT
WINAPI
VarMod
(
LPVARIANT
left
,
LPVARIANT
right
,
LPVARIANT
resul
t
)
HRESULT
WINAPI
VarMod
(
LPVARIANT
pVarLeft
,
LPVARIANT
pVarRight
,
LPVARIANT
pVarOu
t
)
{
{
FIXME
(
"%p %p %p
\n
"
,
left
,
right
,
result
);
FIXME
(
"(%p->(%s%s),%p->(%s%s),%p)
\n
"
,
pVarLeft
,
debugstr_VT
(
pVarLeft
),
debugstr_VF
(
pVarLeft
),
pVarRight
,
debugstr_VT
(
pVarRight
),
debugstr_VF
(
pVarRight
),
pVarOut
);
return
E_FAIL
;
return
E_FAIL
;
}
}
...
@@ -3241,9 +3156,8 @@ HRESULT WINAPI VarPow(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -3241,9 +3156,8 @@ HRESULT WINAPI VarPow(LPVARIANT left, LPVARIANT right, LPVARIANT result)
HRESULT
hr
;
HRESULT
hr
;
VARIANT
dl
,
dr
;
VARIANT
dl
,
dr
;
TRACE
(
"(%p,%p,%p)
\n
"
,
left
,
right
,
result
);
TRACE
(
"(%p->(%s%s),%p->(%s%s),%p)
\n
"
,
left
,
debugstr_VT
(
left
),
debugstr_VF
(
left
),
TRACE
(
"left var:
\n
"
);
dump_Variant
(
left
);
right
,
debugstr_VT
(
right
),
debugstr_VF
(
right
),
result
);
TRACE
(
"right var:
\n
"
);
dump_Variant
(
right
);
hr
=
VariantChangeType
(
&
dl
,
left
,
0
,
VT_R8
);
hr
=
VariantChangeType
(
&
dl
,
left
,
0
,
VT_R8
);
if
(
!
SUCCEEDED
(
hr
))
{
if
(
!
SUCCEEDED
(
hr
))
{
...
@@ -3266,9 +3180,7 @@ HRESULT WINAPI VarPow(LPVARIANT left, LPVARIANT right, LPVARIANT result)
...
@@ -3266,9 +3180,7 @@ HRESULT WINAPI VarPow(LPVARIANT left, LPVARIANT right, LPVARIANT result)
*/
*/
HRESULT
WINAPI
VarInt
(
LPVARIANT
var
,
LPVARIANT
result
)
HRESULT
WINAPI
VarInt
(
LPVARIANT
var
,
LPVARIANT
result
)
{
{
TRACE
(
"(%p,%p)
\n
"
,
var
,
result
);
TRACE
(
"(%p->(%s%s),%p)
\n
"
,
var
,
debugstr_VT
(
var
),
debugstr_VF
(
var
),
result
);
TRACE
(
"Var:
\n
"
);
dump_Variant
(
var
);
switch
(
V_VT
(
var
))
{
switch
(
V_VT
(
var
))
{
case
VT_R4
:
case
VT_R4
:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment