rpcrt4/tests: Merge rpc_protseq.c into rpc.c.
[wine.git] / dlls / scrrun / scrrun.c
blob42b62b65148ccfca12cc9a12ad284dd4d991118c
1 /*
2 * Copyright 2011 Hans Leidekker for CodeWeavers
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
18 #define COBJMACROS
20 #include "config.h"
21 #include <stdarg.h>
23 #include "windef.h"
24 #include "winbase.h"
25 #include "ole2.h"
26 #include "olectl.h"
27 #include "rpcproxy.h"
29 #include <initguid.h>
30 #include "scrrun.h"
31 #include "scrrun_private.h"
33 #include "wine/debug.h"
35 WINE_DEFAULT_DEBUG_CHANNEL(scrrun);
37 static HINSTANCE scrrun_instance;
39 static inline struct provideclassinfo *impl_from_IProvideClassInfo(IProvideClassInfo *iface)
41 return CONTAINING_RECORD(iface, struct provideclassinfo, IProvideClassInfo_iface);
44 typedef HRESULT (*fnCreateInstance)(LPVOID *ppObj);
46 static HRESULT WINAPI scrruncf_QueryInterface(IClassFactory *iface, REFIID riid, LPVOID *ppv )
48 *ppv = NULL;
50 if(IsEqualGUID(&IID_IUnknown, riid)) {
51 TRACE("(%p)->(IID_IUnknown %p)\n", iface, ppv);
52 *ppv = iface;
53 }else if(IsEqualGUID(&IID_IClassFactory, riid)) {
54 TRACE("(%p)->(IID_IClassFactory %p)\n", iface, ppv);
55 *ppv = iface;
58 if(*ppv) {
59 IUnknown_AddRef((IUnknown*)*ppv);
60 return S_OK;
63 WARN("(%p)->(%s %p)\n", iface, debugstr_guid(riid), ppv);
64 return E_NOINTERFACE;
67 static ULONG WINAPI scrruncf_AddRef(IClassFactory *iface )
69 TRACE("(%p)\n", iface);
70 return 2;
73 static ULONG WINAPI scrruncf_Release(IClassFactory *iface )
75 TRACE("(%p)\n", iface);
76 return 1;
79 static HRESULT WINAPI scrruncf_LockServer(IClassFactory *iface, BOOL fLock)
81 TRACE("(%p)->(%x)\n", iface, fLock);
82 return S_OK;
85 static const struct IClassFactoryVtbl scrruncf_vtbl =
87 scrruncf_QueryInterface,
88 scrruncf_AddRef,
89 scrruncf_Release,
90 FileSystem_CreateInstance,
91 scrruncf_LockServer
94 static const struct IClassFactoryVtbl dictcf_vtbl =
96 scrruncf_QueryInterface,
97 scrruncf_AddRef,
98 scrruncf_Release,
99 Dictionary_CreateInstance,
100 scrruncf_LockServer
103 static IClassFactory FileSystemFactory = { &scrruncf_vtbl };
104 static IClassFactory DictionaryFactory = { &dictcf_vtbl };
106 static ITypeLib *typelib;
107 static ITypeInfo *typeinfos[LAST_tid];
109 static REFIID tid_ids[] = {
110 &IID_NULL,
111 &IID_IDictionary,
112 &IID_IDrive,
113 &IID_IDriveCollection,
114 &IID_IFile,
115 &IID_IFileCollection,
116 &IID_IFileSystem3,
117 &IID_IFolder,
118 &IID_IFolderCollection,
119 &IID_ITextStream
122 static HRESULT load_typelib(void)
124 HRESULT hres;
125 ITypeLib *tl;
127 if(typelib)
128 return S_OK;
130 hres = LoadRegTypeLib(&LIBID_Scripting, 1, 0, LOCALE_SYSTEM_DEFAULT, &tl);
131 if(FAILED(hres)) {
132 ERR("LoadRegTypeLib failed: %08x\n", hres);
133 return hres;
136 if(InterlockedCompareExchangePointer((void**)&typelib, tl, NULL))
137 ITypeLib_Release(tl);
138 return hres;
141 static HRESULT get_typeinfo_of_guid(const GUID *guid, ITypeInfo **tinfo)
143 HRESULT hres;
145 if(FAILED(hres = load_typelib()))
146 return hres;
148 return ITypeLib_GetTypeInfoOfGuid(typelib, guid, tinfo);
151 HRESULT get_typeinfo(tid_t tid, ITypeInfo **typeinfo)
153 HRESULT hres;
155 if (FAILED(hres = load_typelib()))
156 return hres;
158 if(!typeinfos[tid]) {
159 ITypeInfo *ti;
161 hres = ITypeLib_GetTypeInfoOfGuid(typelib, tid_ids[tid], &ti);
162 if(FAILED(hres)) {
163 ERR("GetTypeInfoOfGuid(%s) failed: %08x\n", debugstr_guid(tid_ids[tid]), hres);
164 return hres;
167 if(InterlockedCompareExchangePointer((void**)(typeinfos+tid), ti, NULL))
168 ITypeInfo_Release(ti);
171 *typeinfo = typeinfos[tid];
172 ITypeInfo_AddRef(typeinfos[tid]);
173 return S_OK;
176 static void release_typelib(void)
178 unsigned i;
180 if(!typelib)
181 return;
183 for(i=0; i < sizeof(typeinfos)/sizeof(*typeinfos); i++)
184 if(typeinfos[i])
185 ITypeInfo_Release(typeinfos[i]);
187 ITypeLib_Release(typelib);
190 static HRESULT WINAPI provideclassinfo_QueryInterface(IProvideClassInfo *iface, REFIID riid, void **obj)
192 struct provideclassinfo *This = impl_from_IProvideClassInfo(iface);
194 TRACE("(%p)->(%s %p)\n", This, debugstr_guid(riid), obj);
196 if (IsEqualIID(riid, &IID_IProvideClassInfo)) {
197 *obj = iface;
198 IProvideClassInfo_AddRef(iface);
199 return S_OK;
201 else
202 return IUnknown_QueryInterface(This->outer, riid, obj);
204 *obj = NULL;
205 WARN("interface %s not supported\n", debugstr_guid(riid));
206 return E_NOINTERFACE;
209 static ULONG WINAPI provideclassinfo_AddRef(IProvideClassInfo *iface)
211 struct provideclassinfo *This = impl_from_IProvideClassInfo(iface);
212 return IUnknown_AddRef(This->outer);
215 static ULONG WINAPI provideclassinfo_Release(IProvideClassInfo *iface)
217 struct provideclassinfo *This = impl_from_IProvideClassInfo(iface);
218 return IUnknown_Release(This->outer);
221 static HRESULT WINAPI provideclassinfo_GetClassInfo(IProvideClassInfo *iface, ITypeInfo **ti)
223 struct provideclassinfo *This = impl_from_IProvideClassInfo(iface);
225 TRACE("(%p)->(%p)\n", This, ti);
227 return get_typeinfo_of_guid(This->guid, ti);
230 static const IProvideClassInfoVtbl provideclassinfovtbl = {
231 provideclassinfo_QueryInterface,
232 provideclassinfo_AddRef,
233 provideclassinfo_Release,
234 provideclassinfo_GetClassInfo
237 void init_classinfo(const GUID *guid, IUnknown *outer, struct provideclassinfo *classinfo)
239 classinfo->IProvideClassInfo_iface.lpVtbl = &provideclassinfovtbl;
240 classinfo->outer = outer;
241 classinfo->guid = guid;
244 BOOL WINAPI DllMain( HINSTANCE hinst, DWORD reason, LPVOID reserved )
246 TRACE("%p, %u, %p\n", hinst, reason, reserved);
248 switch (reason)
250 case DLL_WINE_PREATTACH:
251 return FALSE; /* prefer native version */
252 case DLL_PROCESS_ATTACH:
253 DisableThreadLibraryCalls( hinst );
254 scrrun_instance = hinst;
255 break;
256 case DLL_PROCESS_DETACH:
257 if (reserved) break;
258 release_typelib();
259 break;
261 return TRUE;
264 /***********************************************************************
265 * DllRegisterServer (scrrun.@)
267 HRESULT WINAPI DllRegisterServer(void)
269 TRACE("()\n");
270 return __wine_register_resources(scrrun_instance);
273 /***********************************************************************
274 * DllUnregisterServer (scrrun.@)
276 HRESULT WINAPI DllUnregisterServer(void)
278 TRACE("()\n");
279 return __wine_unregister_resources(scrrun_instance);
282 /***********************************************************************
283 * DllGetClassObject (scrrun.@)
286 HRESULT WINAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, LPVOID* ppv)
288 if(IsEqualGUID(&CLSID_FileSystemObject, rclsid)) {
289 TRACE("(CLSID_FileSystemObject %s %p)\n", debugstr_guid(riid), ppv);
290 return IClassFactory_QueryInterface(&FileSystemFactory, riid, ppv);
292 else if(IsEqualGUID(&CLSID_Dictionary, rclsid)) {
293 TRACE("(CLSID_Dictionary %s %p)\n", debugstr_guid(riid), ppv);
294 return IClassFactory_QueryInterface(&DictionaryFactory, riid, ppv);
297 FIXME("%s %s %p\n", debugstr_guid(rclsid), debugstr_guid(riid), ppv);
298 return CLASS_E_CLASSNOTAVAILABLE;
301 /***********************************************************************
302 * DllCanUnloadNow (scrrun.@)
304 HRESULT WINAPI DllCanUnloadNow(void)
306 return S_FALSE;