msxml3: Use an iface instead of a vtbl pointer in domimpl.
authorMichael Stefaniuc <mstefani@redhat.de>
Thu, 16 Dec 2010 00:04:11 +0000 (01:04 +0100)
committerAlexandre Julliard <julliard@winehq.org>
Thu, 16 Dec 2010 11:06:51 +0000 (12:06 +0100)
dlls/msxml3/domimpl.c

index 32a27bb9ae59d1b530435e3e958330393e13f6d7..5cc6bff7305a0d8ae6490642b1706095da654ac3 100644 (file)
@@ -39,13 +39,13 @@ WINE_DEFAULT_DEBUG_CHANNEL(msxml);
 
 typedef struct _domimpl
 {
-    const struct IXMLDOMImplementationVtbl *lpVtbl;
+    IXMLDOMImplementation IXMLDOMImplementation_iface;
     LONG ref;
 } domimpl;
 
 static inline domimpl *impl_from_IXMLDOMImplementation( IXMLDOMImplementation *iface )
 {
-    return (domimpl *)((char*)iface - FIELD_OFFSET(domimpl, lpVtbl));
+    return CONTAINING_RECORD(iface, domimpl, IXMLDOMImplementation_iface);
 }
 
 static HRESULT WINAPI dimimpl_QueryInterface(
@@ -164,8 +164,8 @@ static HRESULT WINAPI dimimpl_Invoke(
     hr = get_typeinfo(IXMLDOMImplementation_tid, &typeinfo);
     if(SUCCEEDED(hr))
     {
-        hr = ITypeInfo_Invoke(typeinfo, &(This->lpVtbl), dispIdMember, wFlags, pDispParams,
-                pVarResult, pExcepInfo, puArgErr);
+        hr = ITypeInfo_Invoke(typeinfo, &This->IXMLDOMImplementation_iface, dispIdMember, wFlags,
+                pDispParams, pVarResult, pExcepInfo, puArgErr);
         ITypeInfo_Release(typeinfo);
     }
 
@@ -220,10 +220,10 @@ IUnknown* create_doc_Implementation(void)
     if ( !This )
         return NULL;
 
-    This->lpVtbl = &dimimpl_vtbl;
+    This->IXMLDOMImplementation_iface.lpVtbl = &dimimpl_vtbl;
     This->ref = 1;
 
-    return (IUnknown*) &This->lpVtbl;
+    return (IUnknown*)&This->IXMLDOMImplementation_iface;
 }
 
 #endif