Commit e803e634 authored by Michael Stefaniuc's avatar Michael Stefaniuc Committed by Alexandre Julliard

msxml3: Standardize the COM usage in xmlelem.c.

parent 0c5492aa
...@@ -45,7 +45,7 @@ static HRESULT XMLElementCollection_create( IUnknown *pUnkOuter, xmlNodePtr node ...@@ -45,7 +45,7 @@ static HRESULT XMLElementCollection_create( IUnknown *pUnkOuter, xmlNodePtr node
*/ */
typedef struct _xmlelem typedef struct _xmlelem
{ {
const IXMLElementVtbl *lpVtbl; IXMLElement IXMLElement_iface;
LONG ref; LONG ref;
xmlNodePtr node; xmlNodePtr node;
BOOL own; BOOL own;
...@@ -53,7 +53,7 @@ typedef struct _xmlelem ...@@ -53,7 +53,7 @@ typedef struct _xmlelem
static inline xmlelem *impl_from_IXMLElement(IXMLElement *iface) static inline xmlelem *impl_from_IXMLElement(IXMLElement *iface)
{ {
return (xmlelem *)((char*)iface - FIELD_OFFSET(xmlelem, lpVtbl)); return CONTAINING_RECORD(iface, xmlelem, IXMLElement_iface);
} }
static HRESULT WINAPI xmlelem_QueryInterface(IXMLElement *iface, REFIID riid, void** ppvObject) static HRESULT WINAPI xmlelem_QueryInterface(IXMLElement *iface, REFIID riid, void** ppvObject)
...@@ -165,7 +165,7 @@ static HRESULT WINAPI xmlelem_Invoke(IXMLElement *iface, DISPID dispIdMember, ...@@ -165,7 +165,7 @@ static HRESULT WINAPI xmlelem_Invoke(IXMLElement *iface, DISPID dispIdMember,
hr = get_typeinfo(IXMLElement_tid, &typeinfo); hr = get_typeinfo(IXMLElement_tid, &typeinfo);
if(SUCCEEDED(hr)) if(SUCCEEDED(hr))
{ {
hr = ITypeInfo_Invoke(typeinfo, &(This->lpVtbl), dispIdMember, wFlags, pDispParams, hr = ITypeInfo_Invoke(typeinfo, &This->IXMLElement_iface, dispIdMember, wFlags, pDispParams,
pVarResult, pExcepInfo, puArgErr); pVarResult, pExcepInfo, puArgErr);
ITypeInfo_Release(typeinfo); ITypeInfo_Release(typeinfo);
} }
...@@ -493,12 +493,12 @@ HRESULT XMLElement_create(IUnknown *pUnkOuter, xmlNodePtr node, LPVOID *ppObj, B ...@@ -493,12 +493,12 @@ HRESULT XMLElement_create(IUnknown *pUnkOuter, xmlNodePtr node, LPVOID *ppObj, B
if(!elem) if(!elem)
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
elem->lpVtbl = &xmlelem_vtbl; elem->IXMLElement_iface.lpVtbl = &xmlelem_vtbl;
elem->ref = 1; elem->ref = 1;
elem->node = node; elem->node = node;
elem->own = own; elem->own = own;
*ppObj = &elem->lpVtbl; *ppObj = &elem->IXMLElement_iface;
TRACE("returning iface %p\n", *ppObj); TRACE("returning iface %p\n", *ppObj);
return S_OK; return S_OK;
...@@ -509,8 +509,8 @@ HRESULT XMLElement_create(IUnknown *pUnkOuter, xmlNodePtr node, LPVOID *ppObj, B ...@@ -509,8 +509,8 @@ HRESULT XMLElement_create(IUnknown *pUnkOuter, xmlNodePtr node, LPVOID *ppObj, B
*/ */
typedef struct _xmlelem_collection typedef struct _xmlelem_collection
{ {
const IXMLElementCollectionVtbl *lpVtbl; IXMLElementCollection IXMLElementCollection_iface;
const IEnumVARIANTVtbl *lpvtblIEnumVARIANT; IEnumVARIANT IEnumVARIANT_iface;
LONG ref; LONG ref;
LONG length; LONG length;
xmlNodePtr node; xmlNodePtr node;
...@@ -534,12 +534,12 @@ static inline LONG xmlelem_collection_updatelength(xmlelem_collection *collectio ...@@ -534,12 +534,12 @@ static inline LONG xmlelem_collection_updatelength(xmlelem_collection *collectio
static inline xmlelem_collection *impl_from_IXMLElementCollection(IXMLElementCollection *iface) static inline xmlelem_collection *impl_from_IXMLElementCollection(IXMLElementCollection *iface)
{ {
return (xmlelem_collection *)((char*)iface - FIELD_OFFSET(xmlelem_collection, lpVtbl)); return CONTAINING_RECORD(iface, xmlelem_collection, IXMLElementCollection_iface);
} }
static inline xmlelem_collection *impl_from_IEnumVARIANT(IEnumVARIANT *iface) static inline xmlelem_collection *impl_from_IEnumVARIANT(IEnumVARIANT *iface)
{ {
return (xmlelem_collection *)((char*)iface - FIELD_OFFSET(xmlelem_collection, lpvtblIEnumVARIANT)); return CONTAINING_RECORD(iface, xmlelem_collection, IEnumVARIANT_iface);
} }
static HRESULT WINAPI xmlelem_collection_QueryInterface(IXMLElementCollection *iface, REFIID riid, void** ppvObject) static HRESULT WINAPI xmlelem_collection_QueryInterface(IXMLElementCollection *iface, REFIID riid, void** ppvObject)
...@@ -555,7 +555,7 @@ static HRESULT WINAPI xmlelem_collection_QueryInterface(IXMLElementCollection *i ...@@ -555,7 +555,7 @@ static HRESULT WINAPI xmlelem_collection_QueryInterface(IXMLElementCollection *i
} }
else if (IsEqualGUID(riid, &IID_IEnumVARIANT)) else if (IsEqualGUID(riid, &IID_IEnumVARIANT))
{ {
*ppvObject = &(This->lpvtblIEnumVARIANT); *ppvObject = &This->IEnumVARIANT_iface;
} }
else else
{ {
...@@ -797,15 +797,15 @@ static HRESULT XMLElementCollection_create(IUnknown *pUnkOuter, xmlNodePtr node, ...@@ -797,15 +797,15 @@ static HRESULT XMLElementCollection_create(IUnknown *pUnkOuter, xmlNodePtr node,
if(!collection) if(!collection)
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
collection->lpVtbl = &xmlelem_collection_vtbl; collection->IXMLElementCollection_iface.lpVtbl = &xmlelem_collection_vtbl;
collection->lpvtblIEnumVARIANT = &xmlelem_collection_IEnumVARIANTvtbl; collection->IEnumVARIANT_iface.lpVtbl = &xmlelem_collection_IEnumVARIANTvtbl;
collection->ref = 1; collection->ref = 1;
collection->length = 0; collection->length = 0;
collection->node = node; collection->node = node;
collection->current = node->children; collection->current = node->children;
xmlelem_collection_updatelength(collection); xmlelem_collection_updatelength(collection);
*ppObj = &collection->lpVtbl; *ppObj = &collection->IXMLElementCollection_iface;
TRACE("returning iface %p\n", *ppObj); TRACE("returning iface %p\n", *ppObj);
return S_OK; return S_OK;
......
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