Commit 83e91274 authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

msxml3: Get rid of node internal IUnknown.

parent 4ca6e39f
...@@ -93,7 +93,7 @@ static ULONG WINAPI domattr_Release( ...@@ -93,7 +93,7 @@ static ULONG WINAPI domattr_Release(
ref = InterlockedDecrement( &This->ref ); ref = InterlockedDecrement( &This->ref );
if ( ref == 0 ) if ( ref == 0 )
{ {
IXMLDOMNode_Release(IXMLDOMNode_from_impl(This->node)); destroy_xmlnode(This->node);
HeapFree( GetProcessHeap(), 0, This ); HeapFree( GetProcessHeap(), 0, This );
} }
......
...@@ -100,7 +100,7 @@ static ULONG WINAPI domcdata_Release( ...@@ -100,7 +100,7 @@ static ULONG WINAPI domcdata_Release(
ref = InterlockedDecrement( &This->ref ); ref = InterlockedDecrement( &This->ref );
if ( ref == 0 ) if ( ref == 0 )
{ {
IXMLDOMNode_Release(IXMLDOMNode_from_impl(This->node)); destroy_xmlnode(This->node);
HeapFree( GetProcessHeap(), 0, This ); HeapFree( GetProcessHeap(), 0, This );
} }
......
...@@ -94,7 +94,7 @@ static ULONG WINAPI domcomment_Release( ...@@ -94,7 +94,7 @@ static ULONG WINAPI domcomment_Release(
ref = InterlockedDecrement( &This->ref ); ref = InterlockedDecrement( &This->ref );
if ( ref == 0 ) if ( ref == 0 )
{ {
IXMLDOMNode_Release(IXMLDOMNode_from_impl(This->node)); destroy_xmlnode(This->node);
HeapFree( GetProcessHeap(), 0, This ); HeapFree( GetProcessHeap(), 0, This );
} }
......
...@@ -93,7 +93,7 @@ static ULONG WINAPI domfrag_Release( ...@@ -93,7 +93,7 @@ static ULONG WINAPI domfrag_Release(
ref = InterlockedDecrement( &This->ref ); ref = InterlockedDecrement( &This->ref );
if ( ref == 0 ) if ( ref == 0 )
{ {
IXMLDOMNode_Release(IXMLDOMNode_from_impl(This->node)); destroy_xmlnode(This->node);
HeapFree( GetProcessHeap(), 0, This ); HeapFree( GetProcessHeap(), 0, This );
} }
......
...@@ -509,7 +509,7 @@ static ULONG WINAPI domdoc_Release( ...@@ -509,7 +509,7 @@ static ULONG WINAPI domdoc_Release(
if (This->site) if (This->site)
IUnknown_Release( This->site ); IUnknown_Release( This->site );
IXMLDOMNode_Release(IXMLDOMNode_from_impl(This->node)); destroy_xmlnode(This->node);
if(This->schema) IXMLDOMSchemaCollection_Release( This->schema ); if(This->schema) IXMLDOMSchemaCollection_Release( This->schema );
if (This->stream) IStream_Release(This->stream); if (This->stream) IStream_Release(This->stream);
HeapFree( GetProcessHeap(), 0, This ); HeapFree( GetProcessHeap(), 0, This );
......
...@@ -108,7 +108,7 @@ static ULONG WINAPI domelem_Release( ...@@ -108,7 +108,7 @@ static ULONG WINAPI domelem_Release(
TRACE("(%p) ref=%d\n", This, ref); TRACE("(%p) ref=%d\n", This, ref);
if(!ref) { if(!ref) {
IXMLDOMNode_Release(IXMLDOMNode_from_impl(This->node)); destroy_xmlnode(This->node);
heap_free(This); heap_free(This);
} }
......
...@@ -93,7 +93,7 @@ static ULONG WINAPI entityref_Release( ...@@ -93,7 +93,7 @@ static ULONG WINAPI entityref_Release(
ref = InterlockedDecrement( &This->ref ); ref = InterlockedDecrement( &This->ref );
if ( ref == 0 ) if ( ref == 0 )
{ {
IXMLDOMNode_Release(IXMLDOMNode_from_impl(This->node)); destroy_xmlnode(This->node);
HeapFree( GetProcessHeap(), 0, This ); HeapFree( GetProcessHeap(), 0, This );
} }
......
...@@ -144,7 +144,6 @@ typedef struct _xmlnode ...@@ -144,7 +144,6 @@ typedef struct _xmlnode
{ {
DispatchEx dispex; DispatchEx dispex;
const struct IXMLDOMNodeVtbl *lpVtbl; const struct IXMLDOMNodeVtbl *lpVtbl;
const struct IUnknownVtbl *lpInternalUnkVtbl;
IUnknown *pUnkOuter; IUnknown *pUnkOuter;
LONG ref; LONG ref;
xmlNodePtr node; xmlNodePtr node;
...@@ -161,6 +160,7 @@ static inline IXMLDOMNode *IXMLDOMNode_from_impl(xmlnode *This) ...@@ -161,6 +160,7 @@ static inline IXMLDOMNode *IXMLDOMNode_from_impl(xmlnode *This)
} }
extern xmlnode *create_basic_node(xmlNodePtr,IUnknown*,dispex_static_data_t*); extern xmlnode *create_basic_node(xmlNodePtr,IUnknown*,dispex_static_data_t*);
extern void destroy_xmlnode(xmlnode*);
extern HRESULT DOMDocument_create_from_xmldoc(xmlDocPtr xmldoc, IXMLDOMDocument2 **document); extern HRESULT DOMDocument_create_from_xmldoc(xmlDocPtr xmldoc, IXMLDOMDocument2 **document);
......
...@@ -66,11 +66,6 @@ static const WCHAR szFloat[] = {'f','l','o','a','t',0}; ...@@ -66,11 +66,6 @@ static const WCHAR szFloat[] = {'f','l','o','a','t',0};
static const WCHAR szUUID[] = {'u','u','i','d',0}; static const WCHAR szUUID[] = {'u','u','i','d',0};
static const WCHAR szBinHex[] = {'b','i','n','.','h','e','x',0}; static const WCHAR szBinHex[] = {'b','i','n','.','h','e','x',0};
static inline xmlnode *impl_from_InternalUnknown( IUnknown *iface )
{
return (xmlnode *)((char*)iface - FIELD_OFFSET(xmlnode, lpInternalUnkVtbl));
}
xmlNodePtr xmlNodePtr_from_domnode( IXMLDOMNode *iface, xmlElementType type ) xmlNodePtr xmlNodePtr_from_domnode( IXMLDOMNode *iface, xmlElementType type )
{ {
xmlnode *This; xmlnode *This;
...@@ -91,23 +86,52 @@ static HRESULT WINAPI xmlnode_QueryInterface( ...@@ -91,23 +86,52 @@ static HRESULT WINAPI xmlnode_QueryInterface(
void** ppvObject ) void** ppvObject )
{ {
xmlnode *This = impl_from_IXMLDOMNode( iface ); xmlnode *This = impl_from_IXMLDOMNode( iface );
TRACE("%p %s %p\n", This, debugstr_guid(riid), ppvObject); TRACE("%p %s %p\n", This, debugstr_guid(riid), ppvObject);
if(This->pUnkOuter)
return IUnknown_QueryInterface(This->pUnkOuter, riid, ppvObject); return IUnknown_QueryInterface(This->pUnkOuter, riid, ppvObject);
if (IsEqualGUID(riid, &IID_IUnknown)) {
*ppvObject = iface;
}else if (IsEqualGUID( riid, &IID_IDispatch) ||
IsEqualGUID( riid, &IID_IXMLDOMNode)) {
*ppvObject = &This->lpVtbl;
}else {
FIXME("interface %s not implemented\n", debugstr_guid(riid));
*ppvObject = NULL;
return E_NOINTERFACE;
}
IUnknown_AddRef( (IUnknown*)*ppvObject );
return S_OK;
} }
static ULONG WINAPI xmlnode_AddRef( static ULONG WINAPI xmlnode_AddRef(
IXMLDOMNode *iface ) IXMLDOMNode *iface )
{ {
xmlnode *This = impl_from_IXMLDOMNode( iface ); xmlnode *This = impl_from_IXMLDOMNode( iface );
if(This->pUnkOuter)
return IUnknown_AddRef(This->pUnkOuter); return IUnknown_AddRef(This->pUnkOuter);
return InterlockedIncrement(&This->ref);
} }
static ULONG WINAPI xmlnode_Release( static ULONG WINAPI xmlnode_Release(
IXMLDOMNode *iface ) IXMLDOMNode *iface )
{ {
xmlnode *This = impl_from_IXMLDOMNode( iface ); xmlnode *This = impl_from_IXMLDOMNode( iface );
LONG ref;
if(This->pUnkOuter)
return IUnknown_Release(This->pUnkOuter); return IUnknown_Release(This->pUnkOuter);
ref = InterlockedDecrement( &This->ref );
if(!ref)
destroy_xmlnode(This);
return ref;
} }
static HRESULT WINAPI xmlnode_GetTypeInfoCount( static HRESULT WINAPI xmlnode_GetTypeInfoCount(
...@@ -1484,64 +1508,13 @@ static const struct IXMLDOMNodeVtbl xmlnode_vtbl = ...@@ -1484,64 +1508,13 @@ static const struct IXMLDOMNodeVtbl xmlnode_vtbl =
xmlnode_transformNodeToObject, xmlnode_transformNodeToObject,
}; };
static HRESULT WINAPI Internal_QueryInterface( void destroy_xmlnode(xmlnode *This)
IUnknown *iface,
REFIID riid,
void** ppvObject )
{ {
xmlnode *This = impl_from_InternalUnknown( iface ); if(This->node)
xmldoc_release(This->node->doc);
TRACE("%p %s %p\n", iface, debugstr_guid(riid), ppvObject);
if ( IsEqualGUID( riid, &IID_IUnknown ))
*ppvObject = iface;
else if ( IsEqualGUID( riid, &IID_IDispatch ) ||
IsEqualGUID( riid, &IID_IXMLDOMNode ) )
*ppvObject = &This->lpVtbl;
else
{
FIXME("interface %s not implemented\n", debugstr_guid(riid));
*ppvObject = NULL;
return E_NOINTERFACE;
}
IUnknown_AddRef( (IUnknown*)*ppvObject );
return S_OK;
}
static ULONG WINAPI Internal_AddRef(
IUnknown *iface )
{
xmlnode *This = impl_from_InternalUnknown( iface );
return InterlockedIncrement( &This->ref );
}
static ULONG WINAPI Internal_Release(
IUnknown *iface )
{
xmlnode *This = impl_from_InternalUnknown( iface );
ULONG ref;
ref = InterlockedDecrement( &This->ref );
if ( ref == 0 )
{
if( This->node )
xmldoc_release( This->node->doc );
HeapFree( GetProcessHeap(), 0, This ); HeapFree( GetProcessHeap(), 0, This );
}
return ref;
} }
static const struct IUnknownVtbl internal_unk_vtbl =
{
Internal_QueryInterface,
Internal_AddRef,
Internal_Release
};
xmlnode *create_basic_node( xmlNodePtr node, IUnknown *pUnkOuter, dispex_static_data_t *dispex_data ) xmlnode *create_basic_node( xmlNodePtr node, IUnknown *pUnkOuter, dispex_static_data_t *dispex_data )
{ {
xmlnode *This; xmlnode *This;
...@@ -1554,12 +1527,11 @@ xmlnode *create_basic_node( xmlNodePtr node, IUnknown *pUnkOuter, dispex_static_ ...@@ -1554,12 +1527,11 @@ xmlnode *create_basic_node( xmlNodePtr node, IUnknown *pUnkOuter, dispex_static_
xmldoc_add_ref( node->doc ); xmldoc_add_ref( node->doc );
This->lpVtbl = &xmlnode_vtbl; This->lpVtbl = &xmlnode_vtbl;
This->lpInternalUnkVtbl = &internal_unk_vtbl;
if(pUnkOuter) if(pUnkOuter)
This->pUnkOuter = pUnkOuter; /* Don't take a ref on outer Unknown */ This->pUnkOuter = pUnkOuter; /* Don't take a ref on outer Unknown */
else else
This->pUnkOuter = (IUnknown *)&This->lpInternalUnkVtbl; This->pUnkOuter = NULL;
if(dispex_data) if(dispex_data)
init_dispex(&This->dispex, This->pUnkOuter, dispex_data); init_dispex(&This->dispex, This->pUnkOuter, dispex_data);
...@@ -1602,7 +1574,7 @@ IXMLDOMNode *create_node( xmlNodePtr node ) ...@@ -1602,7 +1574,7 @@ IXMLDOMNode *create_node( xmlNodePtr node )
break; break;
default: default:
FIXME("only creating basic node for type %d\n", node->type); FIXME("only creating basic node for type %d\n", node->type);
pUnk = (IUnknown*)&create_basic_node( node, NULL, NULL )->lpInternalUnkVtbl; pUnk = (IUnknown*)&create_basic_node( node, NULL, NULL )->lpVtbl;
} }
hr = IUnknown_QueryInterface(pUnk, &IID_IXMLDOMNode, (LPVOID*)&ret); hr = IUnknown_QueryInterface(pUnk, &IID_IXMLDOMNode, (LPVOID*)&ret);
......
...@@ -93,7 +93,7 @@ static ULONG WINAPI dom_pi_Release( ...@@ -93,7 +93,7 @@ static ULONG WINAPI dom_pi_Release(
ref = InterlockedDecrement( &This->ref ); ref = InterlockedDecrement( &This->ref );
if ( ref == 0 ) if ( ref == 0 )
{ {
IXMLDOMNode_Release(IXMLDOMNode_from_impl(This->node)); destroy_xmlnode(This->node);
HeapFree( GetProcessHeap(), 0, This ); HeapFree( GetProcessHeap(), 0, This );
} }
......
...@@ -102,7 +102,7 @@ static ULONG WINAPI domtext_Release( ...@@ -102,7 +102,7 @@ static ULONG WINAPI domtext_Release(
ref = InterlockedDecrement( &This->ref ); ref = InterlockedDecrement( &This->ref );
if ( ref == 0 ) if ( ref == 0 )
{ {
IXMLDOMNode_Release(IXMLDOMNode_from_impl(This->node)); destroy_xmlnode(This->node);
HeapFree( GetProcessHeap(), 0, This ); HeapFree( GetProcessHeap(), 0, This );
} }
......
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