msxml: text node implementation
Huw D M Davies
h.davies1 at physics.ox.ac.uk
Wed Jan 18 16:47:47 CST 2006
Huw Davies <huw at codeweavers.com>
msxml: text node implementation
diff --git a/dlls/msxml3/Makefile.in b/dlls/msxml3/Makefile.in
index a064746..f5f7785 100644
--- a/dlls/msxml3/Makefile.in
+++ b/dlls/msxml3/Makefile.in
@@ -17,7 +17,8 @@ C_SRCS = \
node.c \
nodelist.c \
nodemap.c \
- parseerror.c
+ parseerror.c \
+ text.c
SUBDIRS = tests
diff --git a/dlls/msxml3/msxml_private.h b/dlls/msxml3/msxml_private.h
index 88ba8f9..fc693ed 100644
--- a/dlls/msxml3/msxml_private.h
+++ b/dlls/msxml3/msxml_private.h
@@ -34,6 +34,7 @@ extern IXMLDOMNode *create_node( xm
extern IUnknown *create_basic_node( xmlNodePtr node, IUnknown *pUnkOuter );
extern IUnknown *create_attribute( xmlNodePtr attribute );
extern IUnknown *create_element( xmlNodePtr element );
+extern IUnknown *create_text( xmlNodePtr text );
extern IXMLDOMNodeList *create_nodelist( xmlNodePtr node );
extern IXMLDOMNamedNodeMap *create_nodemap( IXMLDOMNode *node );
extern IXMLDOMNodeList *create_filtered_nodelist( xmlNodePtr, const xmlChar * );
diff --git a/dlls/msxml3/node.c b/dlls/msxml3/node.c
index 0725cae..607056c 100644
--- a/dlls/msxml3/node.c
+++ b/dlls/msxml3/node.c
@@ -858,6 +858,9 @@ IXMLDOMNode *create_node( xmlNodePtr nod
case XML_ELEMENT_NODE:
pUnk = create_element( node );
break;
+ case XML_TEXT_NODE:
+ pUnk = create_text( node );
+ break;
case XML_DOCUMENT_NODE:
ERR("shouldn't be here!\n");
return NULL;
diff --git a/dlls/msxml3/text.c b/dlls/msxml3/text.c
new file mode 100644
index 0000000..17f3b43
--- /dev/null
+++ b/dlls/msxml3/text.c
@@ -0,0 +1,598 @@
+/*
+ * DOM text node implementation
+ *
+ * Copyright 2006 Huw Davies
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+#define COBJMACROS
+
+#include "config.h"
+
+#include <stdarg.h>
+#include "windef.h"
+#include "winbase.h"
+#include "winuser.h"
+#include "ole2.h"
+#include "msxml2.h"
+
+#include "msxml_private.h"
+
+#include "wine/debug.h"
+
+WINE_DEFAULT_DEBUG_CHANNEL(msxml);
+
+#ifdef HAVE_LIBXML2
+
+typedef struct _domtext
+{
+ const struct IXMLDOMTextVtbl *lpVtbl;
+ LONG ref;
+ IUnknown *node_unk;
+ IXMLDOMNode *node;
+} domtext;
+
+static inline domtext *impl_from_IXMLDOMText( IXMLDOMText *iface )
+{
+ return (domtext *)((char*)iface - FIELD_OFFSET(domtext, lpVtbl));
+}
+
+static inline xmlNodePtr get_text( domtext *This )
+{
+ return xmlNodePtr_from_domnode( This->node, XML_TEXT_NODE );
+}
+
+static HRESULT WINAPI domtext_QueryInterface(
+ IXMLDOMText *iface,
+ REFIID riid,
+ void** ppvObject )
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ TRACE("%p %s %p\n", This, debugstr_guid(riid), ppvObject);
+
+ if ( IsEqualGUID( riid, &IID_IXMLDOMText ) ||
+ IsEqualGUID( riid, &IID_IUnknown ) )
+ {
+ *ppvObject = iface;
+ }
+ else if ( IsEqualGUID( riid, &IID_IDispatch ) ||
+ IsEqualGUID( riid, &IID_IXMLDOMNode ) )
+ {
+ return IUnknown_QueryInterface(This->node_unk, riid, ppvObject);
+ }
+ else
+ {
+ FIXME("Unsupported inteferace %s\n", debugstr_guid(riid));
+ return E_NOINTERFACE;
+ }
+
+ IXMLDOMText_AddRef( iface );
+
+ return S_OK;
+}
+
+static ULONG WINAPI domtext_AddRef(
+ IXMLDOMText *iface )
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return InterlockedIncrement( &This->ref );
+}
+
+static ULONG WINAPI domtext_Release(
+ IXMLDOMText *iface )
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ ULONG ref;
+
+ ref = InterlockedDecrement( &This->ref );
+ if ( ref == 0 )
+ {
+ IUnknown_Release( This->node_unk );
+ HeapFree( GetProcessHeap(), 0, This );
+ }
+
+ return ref;
+}
+
+static HRESULT WINAPI domtext_GetTypeInfoCount(
+ IXMLDOMText *iface,
+ UINT* pctinfo )
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_GetTypeInfo(
+ IXMLDOMText *iface,
+ UINT iTInfo, LCID lcid,
+ ITypeInfo** ppTInfo )
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_GetIDsOfNames(
+ IXMLDOMText *iface,
+ REFIID riid, LPOLESTR* rgszNames,
+ UINT cNames, LCID lcid, DISPID* rgDispId )
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_Invoke(
+ IXMLDOMText *iface,
+ DISPID dispIdMember, REFIID riid, LCID lcid,
+ WORD wFlags, DISPPARAMS* pDispParams, VARIANT* pVarResult,
+ EXCEPINFO* pExcepInfo, UINT* puArgErr )
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_get_nodeName(
+ IXMLDOMText *iface,
+ BSTR* p )
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_nodeName( This->node, p );
+}
+
+static HRESULT WINAPI domtext_get_nodeValue(
+ IXMLDOMText *iface,
+ VARIANT* var1 )
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_nodeValue( This->node, var1 );
+}
+
+static HRESULT WINAPI domtext_put_nodeValue(
+ IXMLDOMText *iface,
+ VARIANT var1 )
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_put_nodeValue( This->node, var1 );
+}
+
+static HRESULT WINAPI domtext_get_nodeType(
+ IXMLDOMText *iface,
+ DOMNodeType* domNodeType )
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_nodeType( This->node, domNodeType );
+}
+
+static HRESULT WINAPI domtext_get_parentNode(
+ IXMLDOMText *iface,
+ IXMLDOMNode** parent )
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_parentNode( This->node, parent );
+}
+
+static HRESULT WINAPI domtext_get_childNodes(
+ IXMLDOMText *iface,
+ IXMLDOMNodeList** outList)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_childNodes( This->node, outList );
+}
+
+static HRESULT WINAPI domtext_get_firstChild(
+ IXMLDOMText *iface,
+ IXMLDOMNode** domNode)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_firstChild( This->node, domNode );
+}
+
+static HRESULT WINAPI domtext_get_lastChild(
+ IXMLDOMText *iface,
+ IXMLDOMNode** domNode)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_lastChild( This->node, domNode );
+}
+
+static HRESULT WINAPI domtext_get_previousSibling(
+ IXMLDOMText *iface,
+ IXMLDOMNode** domNode)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_previousSibling( This->node, domNode );
+}
+
+static HRESULT WINAPI domtext_get_nextSibling(
+ IXMLDOMText *iface,
+ IXMLDOMNode** domNode)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_nextSibling( This->node, domNode );
+}
+
+static HRESULT WINAPI domtext_get_attributes(
+ IXMLDOMText *iface,
+ IXMLDOMNamedNodeMap** attributeMap)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_attributes( This->node, attributeMap );
+}
+
+static HRESULT WINAPI domtext_insertBefore(
+ IXMLDOMText *iface,
+ IXMLDOMNode* newNode, VARIANT var1,
+ IXMLDOMNode** outOldNode)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_insertBefore( This->node, newNode, var1, outOldNode );
+}
+
+static HRESULT WINAPI domtext_replaceChild(
+ IXMLDOMText *iface,
+ IXMLDOMNode* newNode,
+ IXMLDOMNode* oldNode,
+ IXMLDOMNode** outOldNode)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_replaceChild( This->node, newNode, oldNode, outOldNode );
+}
+
+static HRESULT WINAPI domtext_removeChild(
+ IXMLDOMText *iface,
+ IXMLDOMNode* domNode, IXMLDOMNode** oldNode)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_removeChild( This->node, domNode, oldNode );
+}
+
+static HRESULT WINAPI domtext_appendChild(
+ IXMLDOMText *iface,
+ IXMLDOMNode* newNode, IXMLDOMNode** outNewNode)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_appendChild( This->node, newNode, outNewNode );
+}
+
+static HRESULT WINAPI domtext_hasChildNodes(
+ IXMLDOMText *iface,
+ VARIANT_BOOL* pbool)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_hasChildNodes( This->node, pbool );
+}
+
+static HRESULT WINAPI domtext_get_ownerDocument(
+ IXMLDOMText *iface,
+ IXMLDOMDocument** domDocument)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_ownerDocument( This->node, domDocument );
+}
+
+static HRESULT WINAPI domtext_cloneNode(
+ IXMLDOMText *iface,
+ VARIANT_BOOL pbool, IXMLDOMNode** outNode)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_cloneNode( This->node, pbool, outNode );
+}
+
+static HRESULT WINAPI domtext_get_nodeTypeString(
+ IXMLDOMText *iface,
+ BSTR* p)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_nodeTypeString( This->node, p );
+}
+
+static HRESULT WINAPI domtext_get_text(
+ IXMLDOMText *iface,
+ BSTR* p)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_text( This->node, p );
+}
+
+static HRESULT WINAPI domtext_put_text(
+ IXMLDOMText *iface,
+ BSTR p)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_put_text( This->node, p );
+}
+
+static HRESULT WINAPI domtext_get_specified(
+ IXMLDOMText *iface,
+ VARIANT_BOOL* pbool)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_specified( This->node, pbool );
+}
+
+static HRESULT WINAPI domtext_get_definition(
+ IXMLDOMText *iface,
+ IXMLDOMNode** domNode)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_definition( This->node, domNode );
+}
+
+static HRESULT WINAPI domtext_get_nodeTypedValue(
+ IXMLDOMText *iface,
+ VARIANT* var1)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_nodeTypedValue( This->node, var1 );
+}
+
+static HRESULT WINAPI domtext_put_nodeTypedValue(
+ IXMLDOMText *iface,
+ VARIANT var1)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_put_nodeTypedValue( This->node, var1 );
+}
+
+static HRESULT WINAPI domtext_get_dataType(
+ IXMLDOMText *iface,
+ VARIANT* var1)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_dataType( This->node, var1 );
+}
+
+static HRESULT WINAPI domtext_put_dataType(
+ IXMLDOMText *iface,
+ BSTR p)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_put_dataType( This->node, p );
+}
+
+static HRESULT WINAPI domtext_get_xml(
+ IXMLDOMText *iface,
+ BSTR* p)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_xml( This->node, p );
+}
+
+static HRESULT WINAPI domtext_transformNode(
+ IXMLDOMText *iface,
+ IXMLDOMNode* domNode, BSTR* p)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_transformNode( This->node, domNode, p );
+}
+
+static HRESULT WINAPI domtext_selectNodes(
+ IXMLDOMText *iface,
+ BSTR p, IXMLDOMNodeList** outList)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_selectNodes( This->node, p, outList );
+}
+
+static HRESULT WINAPI domtext_selectSingleNode(
+ IXMLDOMText *iface,
+ BSTR p, IXMLDOMNode** outNode)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_selectSingleNode( This->node, p, outNode );
+}
+
+static HRESULT WINAPI domtext_get_parsed(
+ IXMLDOMText *iface,
+ VARIANT_BOOL* pbool)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_parsed( This->node, pbool );
+}
+
+static HRESULT WINAPI domtext_get_namespaceURI(
+ IXMLDOMText *iface,
+ BSTR* p)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_namespaceURI( This->node, p );
+}
+
+static HRESULT WINAPI domtext_get_prefix(
+ IXMLDOMText *iface,
+ BSTR* p)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_prefix( This->node, p );
+}
+
+static HRESULT WINAPI domtext_get_baseName(
+ IXMLDOMText *iface,
+ BSTR* p)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_get_baseName( This->node, p );
+}
+
+static HRESULT WINAPI domtext_transformNodeToObject(
+ IXMLDOMText *iface,
+ IXMLDOMNode* domNode, VARIANT var1)
+{
+ domtext *This = impl_from_IXMLDOMText( iface );
+ return IXMLDOMNode_transformNodeToObject( This->node, domNode, var1 );
+}
+
+static HRESULT WINAPI domtext_get_data(
+ IXMLDOMText *iface,
+ BSTR *p)
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_put_data(
+ IXMLDOMText *iface,
+ BSTR data)
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_get_length(
+ IXMLDOMText *iface,
+ long *len)
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_substringData(
+ IXMLDOMText *iface,
+ long offset, long count, BSTR *p)
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_appendData(
+ IXMLDOMText *iface,
+ BSTR p)
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_insertData(
+ IXMLDOMText *iface,
+ long offset, BSTR p)
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_deleteData(
+ IXMLDOMText *iface,
+ long offset, long count)
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_replaceData(
+ IXMLDOMText *iface,
+ long offset, long count, BSTR p)
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI domtext_splitText(
+ IXMLDOMText *iface,
+ long offset, IXMLDOMText **txtNode)
+{
+ FIXME("\n");
+ return E_NOTIMPL;
+}
+
+
+static const struct IXMLDOMTextVtbl domtext_vtbl =
+{
+ domtext_QueryInterface,
+ domtext_AddRef,
+ domtext_Release,
+ domtext_GetTypeInfoCount,
+ domtext_GetTypeInfo,
+ domtext_GetIDsOfNames,
+ domtext_Invoke,
+ domtext_get_nodeName,
+ domtext_get_nodeValue,
+ domtext_put_nodeValue,
+ domtext_get_nodeType,
+ domtext_get_parentNode,
+ domtext_get_childNodes,
+ domtext_get_firstChild,
+ domtext_get_lastChild,
+ domtext_get_previousSibling,
+ domtext_get_nextSibling,
+ domtext_get_attributes,
+ domtext_insertBefore,
+ domtext_replaceChild,
+ domtext_removeChild,
+ domtext_appendChild,
+ domtext_hasChildNodes,
+ domtext_get_ownerDocument,
+ domtext_cloneNode,
+ domtext_get_nodeTypeString,
+ domtext_get_text,
+ domtext_put_text,
+ domtext_get_specified,
+ domtext_get_definition,
+ domtext_get_nodeTypedValue,
+ domtext_put_nodeTypedValue,
+ domtext_get_dataType,
+ domtext_put_dataType,
+ domtext_get_xml,
+ domtext_transformNode,
+ domtext_selectNodes,
+ domtext_selectSingleNode,
+ domtext_get_parsed,
+ domtext_get_namespaceURI,
+ domtext_get_prefix,
+ domtext_get_baseName,
+ domtext_transformNodeToObject,
+ domtext_get_data,
+ domtext_put_data,
+ domtext_get_length,
+ domtext_substringData,
+ domtext_appendData,
+ domtext_insertData,
+ domtext_deleteData,
+ domtext_replaceData,
+ domtext_splitText
+};
+
+IUnknown* create_text( xmlNodePtr text )
+{
+ domtext *This;
+ HRESULT hr;
+
+ This = HeapAlloc( GetProcessHeap(), 0, sizeof *This );
+ if ( !This )
+ return NULL;
+
+ This->lpVtbl = &domtext_vtbl;
+ This->ref = 1;
+
+ This->node_unk = create_basic_node( text, (IUnknown*)&This->lpVtbl );
+ if(!This->node_unk)
+ {
+ HeapFree(GetProcessHeap(), 0, This);
+ return NULL;
+ }
+
+ hr = IUnknown_QueryInterface(This->node_unk, &IID_IXMLDOMNode, (LPVOID*)&This->node);
+ if(FAILED(hr))
+ {
+ IUnknown_Release(This->node_unk);
+ HeapFree( GetProcessHeap(), 0, This );
+ return NULL;
+ }
+ /* The ref on This->node is actually looped back into this object, so release it */
+ IXMLDOMNode_Release(This->node);
+
+ return (IUnknown*) &This->lpVtbl;
+}
+
+#endif
More information about the wine-patches
mailing list