msxml3: Support more node types in IXMLDOMDocument_createNode().
This commit is contained in:
parent
e2b727807d
commit
16d83dc7d4
|
@ -1342,11 +1342,11 @@ static HRESULT WINAPI domdoc_createNode(
|
||||||
{
|
{
|
||||||
domdoc *This = impl_from_IXMLDOMDocument2( iface );
|
domdoc *This = impl_from_IXMLDOMDocument2( iface );
|
||||||
DOMNodeType node_type;
|
DOMNodeType node_type;
|
||||||
xmlNodePtr xmlnode = NULL;
|
xmlNodePtr xmlnode;
|
||||||
xmlChar *xml_name;
|
xmlChar *xml_name;
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
|
|
||||||
TRACE("(%p)->(type,%s,%s,%p)\n", This, debugstr_w(name), debugstr_w(namespaceURI), node);
|
TRACE("(%p)->(%s,%s,%p)\n", This, debugstr_w(name), debugstr_w(namespaceURI), node);
|
||||||
|
|
||||||
if(!node) return E_INVALIDARG;
|
if(!node) return E_INVALIDARG;
|
||||||
|
|
||||||
|
@ -1354,8 +1354,7 @@ static HRESULT WINAPI domdoc_createNode(
|
||||||
FIXME("nodes with namespaces currently not supported.\n");
|
FIXME("nodes with namespaces currently not supported.\n");
|
||||||
|
|
||||||
hr = get_node_type(Type, &node_type);
|
hr = get_node_type(Type, &node_type);
|
||||||
if(FAILED(hr))
|
if(FAILED(hr)) return hr;
|
||||||
return hr;
|
|
||||||
|
|
||||||
TRACE("node_type %d\n", node_type);
|
TRACE("node_type %d\n", node_type);
|
||||||
|
|
||||||
|
@ -1365,30 +1364,49 @@ static HRESULT WINAPI domdoc_createNode(
|
||||||
{
|
{
|
||||||
case NODE_ELEMENT:
|
case NODE_ELEMENT:
|
||||||
xmlnode = xmlNewDocNode(get_doc(This), NULL, xml_name, NULL);
|
xmlnode = xmlNewDocNode(get_doc(This), NULL, xml_name, NULL);
|
||||||
*node = create_node(xmlnode);
|
|
||||||
TRACE("created %p\n", xmlnode);
|
|
||||||
break;
|
break;
|
||||||
case NODE_ATTRIBUTE:
|
case NODE_ATTRIBUTE:
|
||||||
xmlnode = (xmlNode *)xmlNewProp(NULL, xml_name, NULL);
|
xmlnode = (xmlNodePtr)xmlNewDocProp(get_doc(This), xml_name, NULL);
|
||||||
if(xmlnode)
|
|
||||||
{
|
|
||||||
xmlnode->doc = get_doc( This );
|
|
||||||
|
|
||||||
*node = (IXMLDOMNode*)create_attribute(xmlnode);
|
|
||||||
}
|
|
||||||
|
|
||||||
TRACE("created %p\n", xmlnode);
|
|
||||||
break;
|
break;
|
||||||
|
case NODE_TEXT:
|
||||||
|
xmlnode = (xmlNodePtr)xmlNewDocText(get_doc(This), NULL);
|
||||||
|
break;
|
||||||
|
case NODE_CDATA_SECTION:
|
||||||
|
xmlnode = xmlNewCDataBlock(get_doc(This), NULL, 0);
|
||||||
|
break;
|
||||||
|
case NODE_PROCESSING_INSTRUCTION:
|
||||||
|
#ifdef HAVE_XMLNEWDOCPI
|
||||||
|
xmlnode = xmlNewDocPI(get_doc(This), xml_name, NULL);
|
||||||
|
#else
|
||||||
|
FIXME("xmlNewDocPI() not supported, use libxml2 2.6.15 or greater\n");
|
||||||
|
xmlnode = NULL;
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case NODE_COMMENT:
|
||||||
|
xmlnode = xmlNewDocComment(get_doc(This), NULL);
|
||||||
|
break;
|
||||||
|
case NODE_DOCUMENT_FRAGMENT:
|
||||||
|
xmlnode = xmlNewDocFragment(get_doc(This));
|
||||||
|
break;
|
||||||
|
/* unsupported types */
|
||||||
|
case NODE_DOCUMENT:
|
||||||
|
case NODE_DOCUMENT_TYPE:
|
||||||
|
case NODE_ENTITY:
|
||||||
|
case NODE_NOTATION:
|
||||||
|
heap_free(xml_name);
|
||||||
|
return E_INVALIDARG;
|
||||||
default:
|
default:
|
||||||
FIXME("unhandled node type %d\n", node_type);
|
FIXME("unhandled node type %d\n", node_type);
|
||||||
|
xmlnode = NULL;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
*node = create_node(xmlnode);
|
||||||
heap_free(xml_name);
|
heap_free(xml_name);
|
||||||
|
|
||||||
if(xmlnode && *node)
|
if(*node)
|
||||||
{
|
{
|
||||||
|
TRACE("created node (%d, %p, %p)\n", node_type, *node, xmlnode);
|
||||||
xmldoc_add_orphan(xmlnode->doc, xmlnode);
|
xmldoc_add_orphan(xmlnode->doc, xmlnode);
|
||||||
return S_OK;
|
return S_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1752,6 +1752,9 @@ IXMLDOMNode *create_node( xmlNodePtr node )
|
||||||
case XML_DOCUMENT_NODE:
|
case XML_DOCUMENT_NODE:
|
||||||
pUnk = create_domdoc( node );
|
pUnk = create_domdoc( node );
|
||||||
break;
|
break;
|
||||||
|
case XML_DOCUMENT_FRAG_NODE:
|
||||||
|
pUnk = create_doc_fragment( node );
|
||||||
|
break;
|
||||||
default: {
|
default: {
|
||||||
xmlnode *new_node;
|
xmlnode *new_node;
|
||||||
|
|
||||||
|
|
|
@ -1657,6 +1657,35 @@ static void test_create(void)
|
||||||
if( r != S_OK )
|
if( r != S_OK )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
/* types not supported for creation */
|
||||||
|
V_VT(&var) = VT_I1;
|
||||||
|
V_I1(&var) = NODE_DOCUMENT;
|
||||||
|
node = (IXMLDOMNode*)0x1;
|
||||||
|
r = IXMLDOMDocument_createNode( doc, var, NULL, NULL, &node );
|
||||||
|
ok( r == E_INVALIDARG, "returns %08x\n", r );
|
||||||
|
ok( node == (void*)0x1, "expected same ptr, got %p\n", node);
|
||||||
|
|
||||||
|
V_VT(&var) = VT_I1;
|
||||||
|
V_I1(&var) = NODE_DOCUMENT_TYPE;
|
||||||
|
node = (IXMLDOMNode*)0x1;
|
||||||
|
r = IXMLDOMDocument_createNode( doc, var, NULL, NULL, &node );
|
||||||
|
ok( r == E_INVALIDARG, "returns %08x\n", r );
|
||||||
|
ok( node == (void*)0x1, "expected same ptr, got %p\n", node);
|
||||||
|
|
||||||
|
V_VT(&var) = VT_I1;
|
||||||
|
V_I1(&var) = NODE_ENTITY;
|
||||||
|
node = (IXMLDOMNode*)0x1;
|
||||||
|
r = IXMLDOMDocument_createNode( doc, var, NULL, NULL, &node );
|
||||||
|
ok( r == E_INVALIDARG, "returns %08x\n", r );
|
||||||
|
ok( node == (void*)0x1, "expected same ptr, got %p\n", node);
|
||||||
|
|
||||||
|
V_VT(&var) = VT_I1;
|
||||||
|
V_I1(&var) = NODE_NOTATION;
|
||||||
|
node = (IXMLDOMNode*)0x1;
|
||||||
|
r = IXMLDOMDocument_createNode( doc, var, NULL, NULL, &node );
|
||||||
|
ok( r == E_INVALIDARG, "returns %08x\n", r );
|
||||||
|
ok( node == (void*)0x1, "expected same ptr, got %p\n", node);
|
||||||
|
|
||||||
V_VT(&var) = VT_I1;
|
V_VT(&var) = VT_I1;
|
||||||
V_I1(&var) = NODE_ELEMENT;
|
V_I1(&var) = NODE_ELEMENT;
|
||||||
str = SysAllocString( szlc );
|
str = SysAllocString( szlc );
|
||||||
|
|
Loading…
Reference in New Issue