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
d87b8b8e
Commit
d87b8b8e
authored
Oct 20, 2010
by
Adam Martinson
Committed by
Alexandre Julliard
Oct 21, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msxml3: Implement schema_cache_get_namespaceURI().
parent
491ec41f
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
165 additions
and
2 deletions
+165
-2
schema.c
dlls/msxml3/schema.c
+27
-2
schema.c
dlls/msxml3/tests/schema.c
+138
-0
No files found.
dlls/msxml3/schema.c
View file @
d87b8b8e
...
@@ -85,6 +85,12 @@ typedef struct _cache_entry
...
@@ -85,6 +85,12 @@ typedef struct _cache_entry
LONG
ref
;
LONG
ref
;
}
cache_entry
;
}
cache_entry
;
typedef
struct
_cache_index_data
{
LONG
index
;
BSTR
*
out
;
}
cache_index_data
;
static
LONG
cache_entry_add_ref
(
cache_entry
*
entry
)
static
LONG
cache_entry_add_ref
(
cache_entry
*
entry
)
{
{
LONG
ref
=
InterlockedIncrement
(
&
entry
->
ref
);
LONG
ref
=
InterlockedIncrement
(
&
entry
->
ref
);
...
@@ -468,10 +474,29 @@ static HRESULT WINAPI schema_cache_get_length(IXMLDOMSchemaCollection *iface, LO
...
@@ -468,10 +474,29 @@ static HRESULT WINAPI schema_cache_get_length(IXMLDOMSchemaCollection *iface, LO
return
S_OK
;
return
S_OK
;
}
}
static
void
cache_index
(
void
*
data
/* ignored */
,
void
*
index
,
xmlChar
*
name
)
{
cache_index_data
*
index_data
=
(
cache_index_data
*
)
index
;
if
(
index_data
->
index
--
==
0
)
*
index_data
->
out
=
bstr_from_xmlChar
(
name
);
}
static
HRESULT
WINAPI
schema_cache_get_namespaceURI
(
IXMLDOMSchemaCollection
*
iface
,
LONG
index
,
BSTR
*
len
)
static
HRESULT
WINAPI
schema_cache_get_namespaceURI
(
IXMLDOMSchemaCollection
*
iface
,
LONG
index
,
BSTR
*
len
)
{
{
FIXME
(
"stub
\n
"
);
schema_cache
*
This
=
impl_from_IXMLDOMSchemaCollection
(
iface
);
return
E_NOTIMPL
;
cache_index_data
data
=
{
index
,
len
};
TRACE
(
"(%p)->(%i, %p)
\n
"
,
This
,
index
,
len
);
if
(
!
len
)
return
E_POINTER
;
*
len
=
NULL
;
if
(
index
>=
xmlHashSize
(
This
->
cache
))
return
E_FAIL
;
xmlHashScan
(
This
->
cache
,
cache_index
,
&
data
);
return
S_OK
;
}
}
static
void
cache_copy
(
void
*
data
,
void
*
dest
,
xmlChar
*
name
)
static
void
cache_copy
(
void
*
data
,
void
*
dest
,
xmlChar
*
name
)
...
...
dlls/msxml3/tests/schema.c
View file @
d87b8b8e
...
@@ -530,6 +530,143 @@ static void test_length(void)
...
@@ -530,6 +530,143 @@ static void test_length(void)
free_bstrs
();
free_bstrs
();
}
}
static
void
test_collection_content
(
void
)
{
IXMLDOMDocument2
*
schema1
,
*
schema2
,
*
schema3
,
*
schema4
,
*
schema5
;
IXMLDOMSchemaCollection
*
cache1
,
*
cache2
;
VARIANT_BOOL
b
;
BSTR
bstr
;
BSTR
content
[
5
]
=
{
NULL
,
NULL
,
NULL
,
NULL
,
NULL
};
LONG
length
;
int
i
,
j
;
schema1
=
create_document_version
(
30
,
&
IID_IXMLDOMDocument2
);
schema2
=
create_document_version
(
30
,
&
IID_IXMLDOMDocument2
);
schema3
=
create_document_version
(
30
,
&
IID_IXMLDOMDocument2
);
cache1
=
create_cache_version
(
30
,
&
IID_IXMLDOMSchemaCollection
);
cache2
=
create_cache_version
(
40
,
&
IID_IXMLDOMSchemaCollection
);
if
(
!
schema1
||
!
schema2
||
!
schema3
||
!
cache1
)
{
if
(
schema1
)
IXMLDOMDocument2_Release
(
schema1
);
if
(
schema2
)
IXMLDOMDocument2_Release
(
schema2
);
if
(
schema3
)
IXMLDOMDocument2_Release
(
schema3
);
if
(
cache1
)
IXMLDOMSchemaCollection_Release
(
cache1
);
return
;
}
ole_check
(
IXMLDOMDocument2_loadXML
(
schema1
,
_bstr_
(
xdr_schema1_xml
),
&
b
));
ok
(
b
==
VARIANT_TRUE
,
"failed to load XML
\n
"
);
ole_check
(
IXMLDOMDocument2_loadXML
(
schema2
,
_bstr_
(
xdr_schema2_xml
),
&
b
));
ok
(
b
==
VARIANT_TRUE
,
"failed to load XML
\n
"
);
ole_check
(
IXMLDOMDocument2_loadXML
(
schema3
,
_bstr_
(
xdr_schema3_xml
),
&
b
));
ok
(
b
==
VARIANT_TRUE
,
"failed to load XML
\n
"
);
ole_check
(
IXMLDOMSchemaCollection_add
(
cache1
,
_bstr_
(
xdr_schema1_uri
),
_variantdoc_
(
schema1
)));
ole_check
(
IXMLDOMSchemaCollection_add
(
cache1
,
_bstr_
(
xdr_schema2_uri
),
_variantdoc_
(
schema2
)));
ole_check
(
IXMLDOMSchemaCollection_add
(
cache1
,
_bstr_
(
xdr_schema3_uri
),
_variantdoc_
(
schema3
)));
length
=
-
1
;
ole_check
(
IXMLDOMSchemaCollection_get_length
(
cache1
,
&
length
));
ok
(
length
==
3
,
"expected length 3, got %i
\n
"
,
length
);
IXMLDOMDocument2_Release
(
schema1
);
IXMLDOMDocument2_Release
(
schema2
);
IXMLDOMDocument2_Release
(
schema3
);
if
(
cache2
)
{
schema1
=
create_document_version
(
40
,
&
IID_IXMLDOMDocument2
);
schema2
=
create_document_version
(
40
,
&
IID_IXMLDOMDocument2
);
schema3
=
create_document_version
(
40
,
&
IID_IXMLDOMDocument2
);
schema4
=
create_document_version
(
40
,
&
IID_IXMLDOMDocument2
);
schema5
=
create_document_version
(
40
,
&
IID_IXMLDOMDocument2
);
ole_check
(
IXMLDOMDocument2_loadXML
(
schema1
,
_bstr_
(
xdr_schema1_xml
),
&
b
));
ok
(
b
==
VARIANT_TRUE
,
"failed to load XML
\n
"
);
ole_check
(
IXMLDOMDocument2_loadXML
(
schema2
,
_bstr_
(
xdr_schema2_xml
),
&
b
));
ok
(
b
==
VARIANT_TRUE
,
"failed to load XML
\n
"
);
ole_check
(
IXMLDOMDocument2_loadXML
(
schema3
,
_bstr_
(
xsd_schema1_xml
),
&
b
));
ok
(
b
==
VARIANT_TRUE
,
"failed to load XML
\n
"
);
ole_check
(
IXMLDOMDocument2_loadXML
(
schema4
,
_bstr_
(
xsd_schema2_xml
),
&
b
));
ok
(
b
==
VARIANT_TRUE
,
"failed to load XML
\n
"
);
ole_check
(
IXMLDOMDocument2_loadXML
(
schema5
,
_bstr_
(
xsd_schema3_xml
),
&
b
));
ok
(
b
==
VARIANT_TRUE
,
"failed to load XML
\n
"
);
/* combining XDR and XSD schemas in the same cache is fine */
ole_check
(
IXMLDOMSchemaCollection_add
(
cache2
,
_bstr_
(
xdr_schema1_uri
),
_variantdoc_
(
schema1
)));
ole_check
(
IXMLDOMSchemaCollection_add
(
cache2
,
_bstr_
(
xdr_schema2_uri
),
_variantdoc_
(
schema2
)));
ole_check
(
IXMLDOMSchemaCollection_add
(
cache2
,
_bstr_
(
xsd_schema1_uri
),
_variantdoc_
(
schema3
)));
ole_check
(
IXMLDOMSchemaCollection_add
(
cache2
,
_bstr_
(
xsd_schema2_uri
),
_variantdoc_
(
schema4
)));
ole_check
(
IXMLDOMSchemaCollection_add
(
cache2
,
_bstr_
(
xsd_schema3_uri
),
_variantdoc_
(
schema5
)));
length
=
-
1
;
ole_check
(
IXMLDOMSchemaCollection_get_length
(
cache2
,
&
length
));
ok
(
length
==
5
,
"expected length 5, got %i
\n
"
,
length
);
IXMLDOMDocument2_Release
(
schema1
);
IXMLDOMDocument2_Release
(
schema2
);
IXMLDOMDocument2_Release
(
schema3
);
IXMLDOMDocument2_Release
(
schema4
);
IXMLDOMDocument2_Release
(
schema5
);
}
bstr
=
NULL
;
/* error if index is out of range */
ole_expect
(
IXMLDOMSchemaCollection_get_namespaceURI
(
cache1
,
3
,
&
bstr
),
E_FAIL
);
if
(
bstr
)
SysFreeString
(
bstr
);
/* error if return pointer is NULL */
ole_expect
(
IXMLDOMSchemaCollection_get_namespaceURI
(
cache1
,
0
,
NULL
),
E_POINTER
);
/* pointer is checked first */
ole_expect
(
IXMLDOMSchemaCollection_get_namespaceURI
(
cache1
,
3
,
NULL
),
E_POINTER
);
for
(
i
=
0
;
i
<
3
;
++
i
)
{
bstr
=
NULL
;
ole_check
(
IXMLDOMSchemaCollection_get_namespaceURI
(
cache1
,
i
,
&
bstr
));
ok
(
bstr
!=
NULL
&&
*
bstr
,
"expected non-empty string
\n
"
);
content
[
i
]
=
bstr
;
for
(
j
=
0
;
j
<
i
;
++
j
)
ok
(
lstrcmpW
(
content
[
j
],
bstr
),
"got duplicate entry
\n
"
);
}
for
(
i
=
0
;
i
<
3
;
++
i
)
{
SysFreeString
(
content
[
i
]);
content
[
i
]
=
NULL
;
}
if
(
cache2
)
{
for
(
i
=
0
;
i
<
5
;
++
i
)
{
bstr
=
NULL
;
ole_check
(
IXMLDOMSchemaCollection_get_namespaceURI
(
cache2
,
i
,
&
bstr
));
ok
(
bstr
!=
NULL
&&
*
bstr
,
"expected non-empty string
\n
"
);
for
(
j
=
0
;
j
<
i
;
++
j
)
ok
(
lstrcmpW
(
content
[
j
],
bstr
),
"got duplicate entry
\n
"
);
content
[
i
]
=
bstr
;
}
for
(
i
=
0
;
i
<
5
;
++
i
)
{
SysFreeString
(
content
[
i
]);
content
[
i
]
=
NULL
;
}
}
IXMLDOMSchemaCollection_Release
(
cache1
);
if
(
cache2
)
IXMLDOMSchemaCollection_Release
(
cache2
);
free_bstrs
();
}
START_TEST
(
schema
)
START_TEST
(
schema
)
{
{
HRESULT
r
;
HRESULT
r
;
...
@@ -540,6 +677,7 @@ START_TEST(schema)
...
@@ -540,6 +677,7 @@ START_TEST(schema)
test_schema_refs
();
test_schema_refs
();
test_collection_refs
();
test_collection_refs
();
test_length
();
test_length
();
test_collection_content
();
CoUninitialize
();
CoUninitialize
();
}
}
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