pstorec: Use an iface instead of a vtbl pointer in PStore_impl.

Michael Stefaniuc mstefani at redhat.de
Mon Nov 29 03:24:21 CST 2010


---
 dlls/pstorec/pstorec.c |   14 +++++++++-----
 1 files changed, 9 insertions(+), 5 deletions(-)

diff --git a/dlls/pstorec/pstorec.c b/dlls/pstorec/pstorec.c
index 493501f..8dc2bec 100644
--- a/dlls/pstorec/pstorec.c
+++ b/dlls/pstorec/pstorec.c
@@ -33,10 +33,14 @@ WINE_DEFAULT_DEBUG_CHANNEL(pstores);
 
 typedef struct
 {
-    const IPStoreVtbl *lpVtbl;
+    IPStore IPStore_iface;
     LONG ref;
 } PStore_impl;
 
+static inline PStore_impl *impl_from_IPStore(IPStore *iface){
+    return CONTAINING_RECORD(iface, PStore_impl, IPStore_iface);
+}
+
 BOOL WINAPI DllMain(HINSTANCE hinst, DWORD fdwReason, LPVOID fImpLoad)
 {
     TRACE("%p %x %p\n", hinst, fdwReason, fImpLoad);
@@ -62,7 +66,7 @@ static HRESULT WINAPI PStore_fnQueryInterface(
         REFIID riid,
         LPVOID *ppvObj)
 {
-    PStore_impl *This = (PStore_impl *)iface;
+    PStore_impl *This = impl_from_IPStore(iface);
 
     TRACE("%p %s\n",This,debugstr_guid(riid));
 
@@ -87,7 +91,7 @@ static HRESULT WINAPI PStore_fnQueryInterface(
  */
 static ULONG WINAPI PStore_fnAddRef(IPStore* iface)
 {
-    PStore_impl *This = (PStore_impl *)iface;
+    PStore_impl *This = impl_from_IPStore(iface);
 
     TRACE("%p %u\n", This, This->ref);
 
@@ -99,7 +103,7 @@ static ULONG WINAPI PStore_fnAddRef(IPStore* iface)
  */
 static ULONG WINAPI PStore_fnRelease(IPStore* iface)
 {
-    PStore_impl *This = (PStore_impl *)iface;
+    PStore_impl *This = impl_from_IPStore(iface);
     LONG ref;
 
     TRACE("%p %u\n", This, This->ref);
@@ -359,7 +363,7 @@ HRESULT WINAPI PStoreCreateInstance( IPStore** ppProvider,
     if( !ips )
         return E_OUTOFMEMORY;
 
-    ips->lpVtbl = &pstores_vtbl;
+    ips->IPStore_iface.lpVtbl = &pstores_vtbl;
     ips->ref = 1;
 
     *ppProvider = (IPStore*) ips;
-- 
1.7.2.3



More information about the wine-patches mailing list