Fixed issues reported by winapi_check.
[wine/wine64.git] / dlls / dplayx / dpclassfactory.c
blob70b7f1372abf0e0dc60751ada3bf7055087a4825
2 #include "wine/obj_base.h"
3 #include "winerror.h"
4 #include "debugtools.h"
5 #include "dpinit.h"
7 DEFAULT_DEBUG_CHANNEL(dplay)
10 /*******************************************************************************
11 * DirectPlayLobby ClassFactory
14 typedef struct
16 /* IUnknown fields */
17 ICOM_VFIELD(IClassFactory);
18 DWORD ref;
19 } IClassFactoryImpl;
21 static HRESULT WINAPI
22 DP_and_DPL_QueryInterface(LPCLASSFACTORY iface,REFIID riid,LPVOID *ppobj) {
23 ICOM_THIS(IClassFactoryImpl,iface);
25 FIXME("(%p)->(%s,%p),stub!\n",This,debugstr_guid(riid),ppobj);
27 return E_NOINTERFACE;
30 static ULONG WINAPI
31 DP_and_DPL_AddRef(LPCLASSFACTORY iface) {
32 ICOM_THIS(IClassFactoryImpl,iface);
33 return ++(This->ref);
36 static ULONG WINAPI DP_and_DPL_Release(LPCLASSFACTORY iface) {
37 ICOM_THIS(IClassFactoryImpl,iface);
38 /* static class (reference starts @ 1), won't ever be freed */
39 return --(This->ref);
42 /* Not the most efficient implementation, but it's simple */
43 static HRESULT WINAPI DP_and_DPL_CreateInstance(
44 LPCLASSFACTORY iface,LPUNKNOWN pOuter,REFIID riid,LPVOID *ppobj
45 ) {
46 ICOM_THIS(IClassFactoryImpl,iface);
48 TRACE("(%p)->(%p,%s,%p)\n",This,pOuter,debugstr_guid(riid),ppobj);
50 /* FIXME: reuse already created DP/DPL object if present? */
51 if ( directPlayLobby_QueryInterface( riid, ppobj ) == S_OK )
53 return S_OK;
55 else if ( directPlay_QueryInterface( riid, ppobj ) == S_OK )
57 return S_OK;
60 return E_NOINTERFACE;
63 static HRESULT WINAPI DP_and_DPL_LockServer(LPCLASSFACTORY iface,BOOL dolock) {
64 ICOM_THIS(IClassFactoryImpl,iface);
65 FIXME("(%p)->(%d),stub!\n",This,dolock);
66 return S_OK;
69 static ICOM_VTABLE(IClassFactory) DP_and_DPL_Vtbl = {
70 ICOM_MSVTABLE_COMPAT_DummyRTTIVALUE
71 DP_and_DPL_QueryInterface,
72 DP_and_DPL_AddRef,
73 DP_and_DPL_Release,
74 DP_and_DPL_CreateInstance,
75 DP_and_DPL_LockServer
78 static IClassFactoryImpl DP_and_DPL_CF = {&DP_and_DPL_Vtbl, 1 };
81 /*******************************************************************************
82 * DPLAYX_DllGetClassObject [DPLAYX.?]
83 * Retrieves DP or DPL class object from a DLL object
85 * NOTES
86 * Docs say returns STDAPI
88 * PARAMS
89 * rclsid [I] CLSID for the class object
90 * riid [I] Reference to identifier of interface for class object
91 * ppv [O] Address of variable to receive interface pointer for riid
93 * RETURNS
94 * Success: S_OK
95 * Failure: CLASS_E_CLASSNOTAVAILABLE, E_OUTOFMEMORY, E_INVALIDARG,
96 * E_UNEXPECTED
98 DWORD WINAPI DPLAYX_DllGetClassObject(REFCLSID rclsid,REFIID riid,LPVOID *ppv)
100 TRACE("(%p,%p,%p)\n", debugstr_guid(rclsid), debugstr_guid(riid), ppv);
102 if ( IsEqualCLSID( riid, &IID_IClassFactory ) )
104 *ppv = (LPVOID)&DP_and_DPL_CF;
105 IClassFactory_AddRef( (IClassFactory*)*ppv );
107 return S_OK;
110 ERR("(%p,%p,%p): no interface found.\n", debugstr_guid(rclsid), debugstr_guid(riid), ppv);
111 return CLASS_E_CLASSNOTAVAILABLE;
114 /***********************************************************************
115 * DllCanUnloadNow (DPLAYX.@)
117 HRESULT WINAPI DPLAYX_DllCanUnloadNow(void)
119 FIXME("(void): stub\n");
121 return S_FALSE;