Michael Stefaniuc : explorerframe: COM cleanup for the IClassFactory iface.
Alexandre Julliard
julliard at winehq.org
Thu Jan 20 12:41:21 CST 2011
Module: wine
Branch: master
Commit: 4156a8045260bb2be8e7f2db91cabcf323e94a9c
URL: http://source.winehq.org/git/wine.git/?a=commit;h=4156a8045260bb2be8e7f2db91cabcf323e94a9c
Author: Michael Stefaniuc <mstefani at redhat.de>
Date: Thu Jan 20 01:59:16 2011 +0100
explorerframe: COM cleanup for the IClassFactory iface.
---
dlls/explorerframe/explorerframe_main.c | 24 ++++++++++++------------
1 files changed, 12 insertions(+), 12 deletions(-)
diff --git a/dlls/explorerframe/explorerframe_main.c b/dlls/explorerframe/explorerframe_main.c
index 365898f..a62d885 100644
--- a/dlls/explorerframe/explorerframe_main.c
+++ b/dlls/explorerframe/explorerframe_main.c
@@ -101,22 +101,22 @@ HRESULT WINAPI DllGetVersion(DLLVERSIONINFO *info)
/*************************************************************************
* Implement the ExplorerFrame class factory
- *
- * (Taken from shdocvw/factory.c; based on implementation in
- * ddraw/main.c)
*/
-#define FACTORY(x) ((IClassFactory*) &(x)->lpClassFactoryVtbl)
-
typedef struct
{
- const IClassFactoryVtbl *lpClassFactoryVtbl;
+ IClassFactory IClassFactory_iface;
HRESULT (*cf)(IUnknown*, REFIID, void**);
LONG ref;
} IClassFactoryImpl;
+static inline IClassFactoryImpl *impl_from_IClassFactory(IClassFactory *iface)
+{
+ return CONTAINING_RECORD(iface, IClassFactoryImpl, IClassFactory_iface);
+}
+
/*************************************************************************
- * EFCF_QueryInterface (IUnknown)
+ * EFCF_QueryInterface
*/
static HRESULT WINAPI EFCF_QueryInterface(IClassFactory* iface,
REFIID riid, void **ppobj)
@@ -140,7 +140,7 @@ static HRESULT WINAPI EFCF_QueryInterface(IClassFactory* iface,
}
/*************************************************************************
- * EFCF_AddRef (IUnknown)
+ * EFCF_AddRef
*/
static ULONG WINAPI EFCF_AddRef(IClassFactory *iface)
{
@@ -150,7 +150,7 @@ static ULONG WINAPI EFCF_AddRef(IClassFactory *iface)
}
/*************************************************************************
- * EFCF_Release (IUnknown)
+ * EFCF_Release
*/
static ULONG WINAPI EFCF_Release(IClassFactory *iface)
{
@@ -165,7 +165,7 @@ static ULONG WINAPI EFCF_Release(IClassFactory *iface)
static HRESULT WINAPI EFCF_CreateInstance(IClassFactory *iface, IUnknown *pOuter,
REFIID riid, void **ppobj)
{
- IClassFactoryImpl *This = (IClassFactoryImpl *)iface;
+ IClassFactoryImpl *This = impl_from_IClassFactory(iface);
return This->cf(pOuter, riid, ppobj);
}
@@ -198,12 +198,12 @@ static const IClassFactoryVtbl EFCF_Vtbl =
*/
HRESULT WINAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, void **ppv)
{
- static IClassFactoryImpl NSTCClassFactory = {&EFCF_Vtbl, NamespaceTreeControl_Constructor};
+ static IClassFactoryImpl NSTCClassFactory = {{&EFCF_Vtbl}, NamespaceTreeControl_Constructor};
TRACE("%s, %s, %p\n", debugstr_guid(rclsid), debugstr_guid(riid), ppv);
if(IsEqualGUID(&CLSID_NamespaceTreeControl, rclsid))
- return IClassFactory_QueryInterface(FACTORY(&NSTCClassFactory), riid, ppv);
+ return IClassFactory_QueryInterface(&NSTCClassFactory.IClassFactory_iface, riid, ppv);
return CLASS_E_CLASSNOTAVAILABLE;
}
More information about the wine-cvs
mailing list