Commit 91513caa authored by Michael Karcher's avatar Michael Karcher Committed by Alexandre Julliard

msxml3: Handle all variant types in IXMLDOMDocument::createNode.

parent 27e9a983
...@@ -1110,13 +1110,19 @@ static HRESULT WINAPI domdoc_getElementsByTagName( ...@@ -1110,13 +1110,19 @@ static HRESULT WINAPI domdoc_getElementsByTagName(
return hr; return hr;
} }
static DOMNodeType get_node_type(VARIANT Type) static HRESULT get_node_type(VARIANT Type, DOMNodeType * type)
{ {
if(V_VT(&Type) == VT_I4) VARIANT tmp;
return V_I4(&Type); HRESULT hr;
VariantInit(&tmp);
hr = VariantChangeType(&tmp, &Type, 0, VT_I4);
if(FAILED(hr))
return E_INVALIDARG;
*type = V_I4(&tmp);
FIXME("Unsupported variant type %x\n", V_VT(&Type)); return S_OK;
return 0;
} }
static HRESULT WINAPI domdoc_createNode( static HRESULT WINAPI domdoc_createNode(
...@@ -1130,10 +1136,14 @@ static HRESULT WINAPI domdoc_createNode( ...@@ -1130,10 +1136,14 @@ static HRESULT WINAPI domdoc_createNode(
DOMNodeType node_type; DOMNodeType node_type;
xmlNodePtr xmlnode = NULL; xmlNodePtr xmlnode = NULL;
xmlChar *xml_name; xmlChar *xml_name;
HRESULT hr;
TRACE("(%p)->(type,%s,%s,%p)\n", This, debugstr_w(name), debugstr_w(namespaceURI), node); TRACE("(%p)->(type,%s,%s,%p)\n", This, debugstr_w(name), debugstr_w(namespaceURI), node);
node_type = get_node_type(Type); hr = get_node_type(Type, &node_type);
if(FAILED(hr))
return hr;
TRACE("node_type %d\n", node_type); TRACE("node_type %d\n", node_type);
xml_name = xmlChar_from_wchar((WCHAR*)name); xml_name = xmlChar_from_wchar((WCHAR*)name);
......
...@@ -1353,6 +1353,8 @@ static void test_refs(void) ...@@ -1353,6 +1353,8 @@ static void test_refs(void)
static void test_create(void) static void test_create(void)
{ {
static const WCHAR szOne[] = {'1',0};
static const WCHAR szOneGarbage[] = {'1','G','a','r','b','a','g','e',0};
HRESULT r; HRESULT r;
VARIANT var; VARIANT var;
BSTR str, name; BSTR str, name;
...@@ -1369,6 +1371,36 @@ static void test_create(void) ...@@ -1369,6 +1371,36 @@ static void test_create(void)
if( r != S_OK ) if( r != S_OK )
return; return;
V_VT(&var) = VT_I1;
V_I1(&var) = NODE_ELEMENT;
str = SysAllocString( szlc );
r = IXMLDOMDocument_createNode( doc, var, str, NULL, &node );
ok( r == S_OK, "returns %08x\n", r );
if( SUCCEEDED(r) ) IXMLDOMNode_Release( node );
V_VT(&var) = VT_R4;
V_R4(&var) = NODE_ELEMENT;
str = SysAllocString( szlc );
r = IXMLDOMDocument_createNode( doc, var, str, NULL, &node );
ok( r == S_OK, "returns %08x\n", r );
if( SUCCEEDED(r) ) IXMLDOMNode_Release( node );
V_VT(&var) = VT_BSTR;
V_BSTR(&var) = SysAllocString( szOne );
str = SysAllocString( szlc );
r = IXMLDOMDocument_createNode( doc, var, str, NULL, &node );
ok( r == S_OK, "returns %08x\n", r );
if( SUCCEEDED(r) ) IXMLDOMNode_Release( node );
VariantClear(&var);
V_VT(&var) = VT_BSTR;
V_BSTR(&var) = SysAllocString( szOneGarbage );
str = SysAllocString( szlc );
r = IXMLDOMDocument_createNode( doc, var, str, NULL, &node );
ok( r == E_INVALIDARG, "returns %08x\n", r );
if( SUCCEEDED(r) ) IXMLDOMNode_Release( node );
VariantClear(&var);
V_VT(&var) = VT_I4; V_VT(&var) = VT_I4;
V_I4(&var) = NODE_ELEMENT; V_I4(&var) = NODE_ELEMENT;
str = SysAllocString( szlc ); str = SysAllocString( szlc );
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment