Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
0d78a883
Commit
0d78a883
authored
Nov 18, 2009
by
Piotr Caban
Committed by
Alexandre Julliard
Nov 18, 2009
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msxml3: Implemented xmlnode_get_nodeTypedValue date related data types handling.
parent
39f0504c
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
139 additions
and
0 deletions
+139
-0
node.c
dlls/msxml3/node.c
+67
-0
domdoc.c
dlls/msxml3/tests/domdoc.c
+72
-0
No files found.
dlls/msxml3/node.c
View file @
0d78a883
...
@@ -957,6 +957,73 @@ inline HRESULT VARIANT_from_xmlChar(xmlChar *str, VARIANT *v, BSTR type)
...
@@ -957,6 +957,73 @@ inline HRESULT VARIANT_from_xmlChar(xmlChar *str, VARIANT *v, BSTR type)
if
(
!
V_BSTR
(
v
))
if
(
!
V_BSTR
(
v
))
return
E_OUTOFMEMORY
;
return
E_OUTOFMEMORY
;
}
}
else
if
(
!
lstrcmpiW
(
type
,
szDateTime
)
||
!
lstrcmpiW
(
type
,
szDateTimeTZ
)
||
!
lstrcmpiW
(
type
,
szDate
)
||
!
lstrcmpiW
(
type
,
szTime
)
||
!
lstrcmpiW
(
type
,
szTimeTZ
))
{
VARIANT
src
;
WCHAR
*
p
,
*
e
;
SYSTEMTIME
st
;
DOUBLE
date
=
0
.
0
;
st
.
wYear
=
1899
;
st
.
wMonth
=
12
;
st
.
wDay
=
30
;
st
.
wDayOfWeek
=
st
.
wHour
=
st
.
wMinute
=
st
.
wSecond
=
st
.
wMilliseconds
=
0
;
V_VT
(
&
src
)
=
VT_BSTR
;
V_BSTR
(
&
src
)
=
bstr_from_xmlChar
(
str
);
if
(
!
V_BSTR
(
&
src
))
return
E_OUTOFMEMORY
;
p
=
V_BSTR
(
&
src
);
e
=
p
+
SysStringLen
(
V_BSTR
(
&
src
));
if
(
p
+
4
<
e
&&
*
(
p
+
4
)
==
'-'
)
/* parse date (yyyy-mm-dd) */
{
st
.
wYear
=
atoiW
(
p
);
st
.
wMonth
=
atoiW
(
p
+
5
);
st
.
wDay
=
atoiW
(
p
+
8
);
p
+=
10
;
if
(
*
p
==
'T'
)
p
++
;
}
if
(
p
+
2
<
e
&&
*
(
p
+
2
)
==
':'
)
/* parse time (hh:mm:ss.?) */
{
st
.
wHour
=
atoiW
(
p
);
st
.
wMinute
=
atoiW
(
p
+
3
);
st
.
wSecond
=
atoiW
(
p
+
6
);
p
+=
8
;
if
(
*
p
==
'.'
)
{
int
ms
;
p
++
;
ms
=
(
*
(
p
++
)
-
'0'
)
*
10
;
if
(
isdigitW
(
*
p
))
ms
+=
*
(
p
++
)
-
'0'
;
ms
*=
10
;
if
(
isdigitW
(
*
p
))
ms
+=
*
(
p
++
)
-
'0'
;
st
.
wMilliseconds
=
ms
;
while
(
isdigitW
(
*
p
))
p
++
;
}
}
SystemTimeToVariantTime
(
&
st
,
&
date
);
V_VT
(
v
)
=
VT_DATE
;
V_DATE
(
v
)
=
date
;
if
(
*
p
==
'+'
)
/* parse timezone offset (+hh:mm) */
V_DATE
(
v
)
+=
(
DOUBLE
)
atoiW
(
p
+
1
)
/
24
+
(
DOUBLE
)
atoiW
(
p
+
4
)
/
1440
;
else
if
(
*
p
==
'-'
)
/* parse timezone offset (-hh:mm) */
V_DATE
(
v
)
-=
(
DOUBLE
)
atoiW
(
p
+
1
)
/
24
+
(
DOUBLE
)
atoiW
(
p
+
4
)
/
1440
;
VariantClear
(
&
src
);
}
else
else
{
{
VARIANT
src
;
VARIANT
src
;
...
...
dlls/msxml3/tests/domdoc.c
View file @
0d78a883
...
@@ -156,6 +156,11 @@ static const CHAR szTypeValueXML[] =
...
@@ -156,6 +156,11 @@ static const CHAR szTypeValueXML[] =
" <int dt:dt=
\"
int
\"
>-13</int>
\n
"
" <int dt:dt=
\"
int
\"
>-13</int>
\n
"
" <fixed dt:dt=
\"
fixed.14.4
\"
>7322.9371</fixed>
\n
"
" <fixed dt:dt=
\"
fixed.14.4
\"
>7322.9371</fixed>
\n
"
" <bool dt:dt=
\"
boolean
\"
>1</bool>
\n
"
" <bool dt:dt=
\"
boolean
\"
>1</bool>
\n
"
" <datetime dt:dt=
\"
datetime
\"
>2009-11-18T03:21:33.12</datetime>
\n
"
" <datetimetz dt:dt=
\"
datetime.tz
\"
>2003-07-11T11:13:57+03:00</datetimetz>
\n
"
" <date dt:dt=
\"
date
\"
>3721-11-01</date>
\n
"
" <time dt:dt=
\"
time
\"
>13:57:12.31321</time>
\n
"
" <timetz dt:dt=
\"
time.tz
\"
>23:21:01.13+03:21</timetz>
\n
"
"</root>"
;
"</root>"
;
static
const
CHAR
szBasicTransformSSXMLPart1
[]
=
static
const
CHAR
szBasicTransformSSXMLPart1
[]
=
...
@@ -252,6 +257,8 @@ static WCHAR szStrangeChars[] = {'&','x',' ',0x2103, 0};
...
@@ -252,6 +257,8 @@ static WCHAR szStrangeChars[] = {'&','x',' ',0x2103, 0};
ok(r == (expect), #expr " returned %x, expected %x\n", r, expect); \
ok(r == (expect), #expr " returned %x, expected %x\n", r, expect); \
}
}
#define double_eq(x, y) ok((x)-(y)<=1e-14*(x) && (x)-(y)>=-1e-14*(x), "expected %.16g, got %.16g\n", x, y)
static
BSTR
alloc_str_from_narrow
(
const
char
*
str
)
static
BSTR
alloc_str_from_narrow
(
const
char
*
str
)
{
{
int
len
=
MultiByteToWideChar
(
CP_ACP
,
0
,
str
,
-
1
,
NULL
,
0
);
int
len
=
MultiByteToWideChar
(
CP_ACP
,
0
,
str
,
-
1
,
NULL
,
0
);
...
@@ -4087,6 +4094,71 @@ static void test_NodeTypeValue(void)
...
@@ -4087,6 +4094,71 @@ static void test_NodeTypeValue(void)
IXMLDOMNode_Release
(
pNode
);
IXMLDOMNode_Release
(
pNode
);
}
}
hr
=
IXMLDOMDocument2_selectSingleNode
(
doc
,
_bstr_
(
"root/datetime"
),
&
pNode
);
ok
(
hr
==
S_OK
,
"ret %08x
\n
"
,
hr
);
if
(
hr
==
S_OK
)
{
hr
=
IXMLDOMNode_get_nodeTypedValue
(
pNode
,
&
v
);
ok
(
hr
==
S_OK
,
"ret %08x
\n
"
,
hr
);
ok
(
V_VT
(
&
v
)
==
VT_DATE
,
"incorrect type
\n
"
);
double_eq
(
40135
.
13996666666
,
V_DATE
(
&
v
));
VariantClear
(
&
v
);
IXMLDOMNode_Release
(
pNode
);
}
hr
=
IXMLDOMDocument2_selectSingleNode
(
doc
,
_bstr_
(
"root/datetimetz"
),
&
pNode
);
ok
(
hr
==
S_OK
,
"ret %08x
\n
"
,
hr
);
if
(
hr
==
S_OK
)
{
hr
=
IXMLDOMNode_get_nodeTypedValue
(
pNode
,
&
v
);
ok
(
hr
==
S_OK
,
"ret %08x
\n
"
,
hr
);
ok
(
V_VT
(
&
v
)
==
VT_DATE
,
"incorrect type
\n
"
);
double_eq
(
37813
.
59302083334
,
V_DATE
(
&
v
));
VariantClear
(
&
v
);
IXMLDOMNode_Release
(
pNode
);
}
hr
=
IXMLDOMDocument2_selectSingleNode
(
doc
,
_bstr_
(
"root/date"
),
&
pNode
);
ok
(
hr
==
S_OK
,
"ret %08x
\n
"
,
hr
);
if
(
hr
==
S_OK
)
{
hr
=
IXMLDOMNode_get_nodeTypedValue
(
pNode
,
&
v
);
ok
(
hr
==
S_OK
,
"ret %08x
\n
"
,
hr
);
ok
(
V_VT
(
&
v
)
==
VT_DATE
,
"incorrect type
\n
"
);
double_eq
(
665413
.
0
,
V_DATE
(
&
v
));
VariantClear
(
&
v
);
IXMLDOMNode_Release
(
pNode
);
}
hr
=
IXMLDOMDocument2_selectSingleNode
(
doc
,
_bstr_
(
"root/time"
),
&
pNode
);
ok
(
hr
==
S_OK
,
"ret %08x
\n
"
,
hr
);
if
(
hr
==
S_OK
)
{
hr
=
IXMLDOMNode_get_nodeTypedValue
(
pNode
,
&
v
);
ok
(
hr
==
S_OK
,
"ret %08x
\n
"
,
hr
);
ok
(
V_VT
(
&
v
)
==
VT_DATE
,
"incorrect type
\n
"
);
double_eq
(
0
.
581392511574074
,
V_DATE
(
&
v
));
VariantClear
(
&
v
);
IXMLDOMNode_Release
(
pNode
);
}
hr
=
IXMLDOMDocument2_selectSingleNode
(
doc
,
_bstr_
(
"root/timetz"
),
&
pNode
);
ok
(
hr
==
S_OK
,
"ret %08x
\n
"
,
hr
);
if
(
hr
==
S_OK
)
{
hr
=
IXMLDOMNode_get_nodeTypedValue
(
pNode
,
&
v
);
ok
(
hr
==
S_OK
,
"ret %08x
\n
"
,
hr
);
ok
(
V_VT
(
&
v
)
==
VT_DATE
,
"incorrect type
\n
"
);
double_eq
(
1
.
112513078703703
,
V_DATE
(
&
v
));
VariantClear
(
&
v
);
IXMLDOMNode_Release
(
pNode
);
}
}
}
IXMLDOMDocument2_Release
(
doc
);
IXMLDOMDocument2_Release
(
doc
);
...
...
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