Commit 2cfc711a authored by Michael Stefaniuc's avatar Michael Stefaniuc Committed by Alexandre Julliard

dmband: Merge the IClassFactory implementations.

parent faa05713
...@@ -26,92 +26,64 @@ static HINSTANCE instance; ...@@ -26,92 +26,64 @@ static HINSTANCE instance;
LONG DMBAND_refCount = 0; LONG DMBAND_refCount = 0;
typedef struct { typedef struct {
const IClassFactoryVtbl *lpVtbl; IClassFactory IClassFactory_iface;
HRESULT WINAPI (*fnCreateInstance)(REFIID riid, void **ppv, IUnknown *pUnkOuter);
} IClassFactoryImpl; } IClassFactoryImpl;
/****************************************************************** /******************************************************************
* DirectMusicBand ClassFactory * IClassFactory implementation
*/ */
static inline IClassFactoryImpl *impl_from_IClassFactory(IClassFactory *iface)
static HRESULT WINAPI BandCF_QueryInterface(LPCLASSFACTORY iface,REFIID riid,LPVOID *ppobj) { {
FIXME("- no interface IID: %s\n", debugstr_guid(riid)); return CONTAINING_RECORD(iface, IClassFactoryImpl, IClassFactory_iface);
if (ppobj == NULL) return E_POINTER;
return E_NOINTERFACE;
}
static ULONG WINAPI BandCF_AddRef(LPCLASSFACTORY iface) {
DMBAND_LockModule();
return 2; /* non-heap based object */
}
static ULONG WINAPI BandCF_Release(LPCLASSFACTORY iface) {
DMBAND_UnlockModule();
return 1; /* non-heap based object */
}
static HRESULT WINAPI BandCF_CreateInstance(LPCLASSFACTORY iface, LPUNKNOWN pOuter, REFIID riid, LPVOID *ppobj) {
TRACE ("(%p, %s, %p)\n", pOuter, debugstr_dmguid(riid), ppobj);
return DMUSIC_CreateDirectMusicBandImpl (riid, ppobj, pOuter);
} }
static HRESULT WINAPI BandCF_LockServer(LPCLASSFACTORY iface,BOOL dolock) { static HRESULT WINAPI ClassFactory_QueryInterface(IClassFactory *iface, REFIID riid, void **ppv)
TRACE("(%d)\n", dolock); {
if (ppv == NULL)
if (dolock) return E_POINTER;
DMBAND_LockModule();
else if (IsEqualGUID(&IID_IUnknown, riid))
DMBAND_UnlockModule(); TRACE("(%p)->(IID_IUnknown %p)\n", iface, ppv);
else if (IsEqualGUID(&IID_IClassFactory, riid))
TRACE("(%p)->(IID_IClassFactory %p)\n", iface, ppv);
else {
FIXME("(%p)->(%s %p)\n", iface, debugstr_guid(riid), ppv);
*ppv = NULL;
return E_NOINTERFACE;
}
*ppv = iface;
IClassFactory_AddRef(iface);
return S_OK; return S_OK;
} }
static const IClassFactoryVtbl BandCF_Vtbl = { static ULONG WINAPI ClassFactory_AddRef(IClassFactory *iface)
BandCF_QueryInterface, {
BandCF_AddRef,
BandCF_Release,
BandCF_CreateInstance,
BandCF_LockServer
};
static IClassFactoryImpl Band_CF = {&BandCF_Vtbl};
/******************************************************************
* DirectMusicBandTrack ClassFactory
*/
static HRESULT WINAPI BandTrackCF_QueryInterface(LPCLASSFACTORY iface,REFIID riid,LPVOID *ppobj) {
FIXME("- no interface IID: %s\n", debugstr_guid(riid));
if (ppobj == NULL) return E_POINTER;
return E_NOINTERFACE;
}
static ULONG WINAPI BandTrackCF_AddRef(LPCLASSFACTORY iface) {
DMBAND_LockModule(); DMBAND_LockModule();
return 2; /* non-heap based object */ return 2; /* non-heap based object */
} }
static ULONG WINAPI BandTrackCF_Release(LPCLASSFACTORY iface) { static ULONG WINAPI ClassFactory_Release(IClassFactory *iface)
{
DMBAND_UnlockModule(); DMBAND_UnlockModule();
return 1; /* non-heap based object */ return 1; /* non-heap based object */
} }
static HRESULT WINAPI BandTrackCF_CreateInstance(LPCLASSFACTORY iface, LPUNKNOWN pOuter, REFIID riid, LPVOID *ppobj) { static HRESULT WINAPI ClassFactory_CreateInstance(IClassFactory *iface, IUnknown *pUnkOuter,
TRACE ("(%p, %s, %p)\n", pOuter, debugstr_dmguid(riid), ppobj); REFIID riid, void **ppv)
{
IClassFactoryImpl *This = impl_from_IClassFactory(iface);
return DMUSIC_CreateDirectMusicBandTrack (riid, ppobj, pOuter); TRACE ("(%p, %s, %p)\n", pUnkOuter, debugstr_dmguid(riid), ppv);
return This->fnCreateInstance(riid, ppv, pUnkOuter);
} }
static HRESULT WINAPI BandTrackCF_LockServer(LPCLASSFACTORY iface,BOOL dolock) { static HRESULT WINAPI ClassFactory_LockServer(IClassFactory *iface, BOOL dolock)
{
TRACE("(%d)\n", dolock); TRACE("(%d)\n", dolock);
if (dolock) if (dolock)
...@@ -122,15 +94,16 @@ static HRESULT WINAPI BandTrackCF_LockServer(LPCLASSFACTORY iface,BOOL dolock) { ...@@ -122,15 +94,16 @@ static HRESULT WINAPI BandTrackCF_LockServer(LPCLASSFACTORY iface,BOOL dolock) {
return S_OK; return S_OK;
} }
static const IClassFactoryVtbl BandTrackCF_Vtbl = { static const IClassFactoryVtbl classfactory_vtbl = {
BandTrackCF_QueryInterface, ClassFactory_QueryInterface,
BandTrackCF_AddRef, ClassFactory_AddRef,
BandTrackCF_Release, ClassFactory_Release,
BandTrackCF_CreateInstance, ClassFactory_CreateInstance,
BandTrackCF_LockServer ClassFactory_LockServer
}; };
static IClassFactoryImpl BandTrack_CF = {&BandTrackCF_Vtbl}; static IClassFactoryImpl Band_CF = {{&classfactory_vtbl}, DMUSIC_CreateDirectMusicBandImpl};
static IClassFactoryImpl BandTrack_CF = {{&classfactory_vtbl}, DMUSIC_CreateDirectMusicBandTrack};
/****************************************************************** /******************************************************************
* DllMain * DllMain
......
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