Allow MsiViewExecute to be called twice on the same query.
[wine.git] / dlls / d3dxof / main.c
blobad987ea3bd429d476fd41fb4556f5ceb774e511a
1 /*
2 * DirectX Files Functions (D3DXOF.DLL)
4 * Copyright 2004 Christian Costa
6 * This file contains the (internal) driver registration functions,
7 * driver enumeration APIs and DirectDraw creation functions.
9 * This library is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU Lesser General Public
11 * License as published by the Free Software Foundation; either
12 * version 2.1 of the License, or (at your option) any later version.
14 * This library is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * Lesser General Public License for more details.
19 * You should have received a copy of the GNU Lesser General Public
20 * License along with this library; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
24 #include <stdarg.h>
25 #include <string.h>
27 #define COBJMACROS
28 #define COM_NO_WINDOWS_H
30 #include "windef.h"
31 #include "winbase.h"
32 #include "winuser.h"
33 #include "winreg.h"
34 #include "winerror.h"
36 #include "ole2.h"
37 #include "uuids.h"
39 #include "d3dxof_private.h"
40 #include "dxfile.h"
42 #include "wine/debug.h"
44 WINE_DEFAULT_DEBUG_CHANNEL(d3dxof);
46 static DWORD dll_ref = 0;
48 /* For the moment, do nothing here. */
49 BOOL WINAPI DllMain(HINSTANCE hInstDLL, DWORD fdwReason, LPVOID lpv)
51 switch(fdwReason) {
52 case DLL_PROCESS_ATTACH:
53 DisableThreadLibraryCalls(hInstDLL);
54 break;
55 case DLL_PROCESS_DETACH:
56 break;
58 return TRUE;
61 /******************************************************************************
62 * DirectX File ClassFactory
64 typedef struct {
65 IClassFactory ITF_IClassFactory;
67 DWORD ref;
68 HRESULT (*pfnCreateInstance)(IUnknown *pUnkOuter, LPVOID *ppObj);
69 } IClassFactoryImpl;
71 struct object_creation_info
73 const CLSID *clsid;
74 HRESULT (*pfnCreateInstance)(IUnknown *pUnkOuter, LPVOID *ppObj);
77 static const struct object_creation_info object_creation[] =
79 { &CLSID_CDirectXFile, IDirectXFileImpl_Create },
82 static HRESULT WINAPI XFCF_QueryInterface(LPCLASSFACTORY iface,REFIID riid, LPVOID *ppobj)
84 IClassFactoryImpl *This = (IClassFactoryImpl *)iface;
86 if (IsEqualGUID(riid, &IID_IUnknown)
87 || IsEqualGUID(riid, &IID_IClassFactory))
89 IClassFactory_AddRef(iface);
90 *ppobj = This;
91 return S_OK;
94 WARN("(%p)->(%s,%p),not found\n",This,debugstr_guid(riid),ppobj);
95 return E_NOINTERFACE;
98 static ULONG WINAPI XFCF_AddRef(LPCLASSFACTORY iface)
100 IClassFactoryImpl *This = (IClassFactoryImpl *)iface;
101 return InterlockedIncrement(&This->ref);
104 static ULONG WINAPI XFCF_Release(LPCLASSFACTORY iface)
106 IClassFactoryImpl *This = (IClassFactoryImpl *)iface;
108 ULONG ref = InterlockedDecrement(&This->ref);
110 if (ref == 0)
111 HeapFree(GetProcessHeap(), 0, This);
113 return ref;
116 static HRESULT WINAPI XFCF_CreateInstance(LPCLASSFACTORY iface, LPUNKNOWN pOuter, REFIID riid, LPVOID *ppobj)
118 IClassFactoryImpl *This = (IClassFactoryImpl *)iface;
119 HRESULT hres;
120 LPUNKNOWN punk;
122 TRACE("(%p)->(%p,%s,%p)\n",This,pOuter,debugstr_guid(riid),ppobj);
124 *ppobj = NULL;
125 hres = This->pfnCreateInstance(pOuter, (LPVOID *) &punk);
126 if (SUCCEEDED(hres)) {
127 hres = IUnknown_QueryInterface(punk, riid, ppobj);
128 IUnknown_Release(punk);
130 return hres;
133 static HRESULT WINAPI XFCF_LockServer(LPCLASSFACTORY iface, BOOL dolock)
135 IClassFactoryImpl *This = (IClassFactoryImpl *)iface;
136 FIXME("(%p)->(%d),stub!\n",This,dolock);
137 return S_OK;
140 static IClassFactoryVtbl XFCF_Vtbl =
142 XFCF_QueryInterface,
143 XFCF_AddRef,
144 XFCF_Release,
145 XFCF_CreateInstance,
146 XFCF_LockServer
149 /***********************************************************************
150 * DirectXFileCreate (D3DXOF.@)
152 HRESULT WINAPI DirectXFileCreate(LPDIRECTXFILE* lplpDirectXFile)
154 HRESULT hr;
156 TRACE("(%p)\n", lplpDirectXFile);
158 if (!lplpDirectXFile)
159 return DXFILEERR_BADVALUE;
161 hr = IDirectXFileImpl_Create(NULL, (LPVOID)lplpDirectXFile);
163 if (FAILED(hr))
164 return DXFILEERR_BADALLOC;
166 return S_OK;
169 /*******************************************************************************
170 * DllGetClassObject [D3DXOF.@]
171 * Retrieves class object from a DLL object
173 * NOTES
174 * Docs say returns STDAPI
176 * PARAMS
177 * rclsid [I] CLSID for the class object
178 * riid [I] Reference to identifier of interface for class object
179 * ppv [O] Address of variable to receive interface pointer for riid
181 * RETURNS
182 * Success: S_OK
183 * Failure: CLASS_E_CLASSNOTAVAILABLE, E_OUTOFMEMORY, E_INVALIDARG,
184 * E_UNEXPECTED
186 DWORD WINAPI D3DXOF_DllGetClassObject(REFCLSID rclsid, REFIID riid, LPVOID *ppv)
188 int i;
189 IClassFactoryImpl *factory;
191 TRACE("(%s,%s,%p)\n", debugstr_guid(rclsid), debugstr_guid(riid), ppv);
193 if ( !IsEqualGUID( &IID_IClassFactory, riid )
194 && ! IsEqualGUID( &IID_IUnknown, riid) )
195 return E_NOINTERFACE;
197 for (i=0; i < sizeof(object_creation)/sizeof(object_creation[0]); i++)
199 if (IsEqualGUID(object_creation[i].clsid, rclsid))
200 break;
203 if (i == sizeof(object_creation)/sizeof(object_creation[0]))
205 FIXME("%s: no class found.\n", debugstr_guid(rclsid));
206 return CLASS_E_CLASSNOTAVAILABLE;
209 factory = HeapAlloc(GetProcessHeap(), 0, sizeof(*factory));
210 if (factory == NULL) return E_OUTOFMEMORY;
212 factory->ITF_IClassFactory.lpVtbl = &XFCF_Vtbl;
213 factory->ref = 1;
215 factory->pfnCreateInstance = object_creation[i].pfnCreateInstance;
217 *ppv = &(factory->ITF_IClassFactory);
218 return S_OK;
221 /***********************************************************************
222 * DllCanUnloadNow (D3DXOF.@)
224 HRESULT WINAPI D3DXOF_DllCanUnloadNow(void)
226 return dll_ref != 0 ? S_FALSE : S_OK;