Release 1.3.7.
[wine/gsoc-2012-control.git] / dlls / msimtf / main.c
blob6b8957ba39180c0a296d007fb903a32dd3c7ee1e
1 /*
2 * Copyright 2007 Jacek Caban 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
19 #include "config.h"
21 #include <stdarg.h>
22 #include <stdio.h>
24 #define COBJMACROS
26 #include "windef.h"
27 #include "winbase.h"
28 #include "wingdi.h"
29 #include "winuser.h"
30 #include "winreg.h"
31 #include "advpub.h"
32 #include "ole2.h"
33 #include "dimm.h"
35 #include "wine/debug.h"
37 WINE_DEFAULT_DEBUG_CHANNEL(msimtf);
39 extern HRESULT ActiveIMMApp_Constructor(IUnknown *punkOuter, IUnknown **ppOut);
41 static HINSTANCE msimtf_instance;
43 /******************************************************************
44 * DllMain (msimtf.@)
46 BOOL WINAPI DllMain(HINSTANCE hInstDLL, DWORD fdwReason, LPVOID lpv)
48 switch(fdwReason)
50 case DLL_WINE_PREATTACH:
51 return FALSE; /* prefer native version */
52 case DLL_PROCESS_ATTACH:
53 msimtf_instance = hInstDLL;
54 DisableThreadLibraryCalls(hInstDLL);
55 break;
56 case DLL_PROCESS_DETACH:
57 break;
59 return TRUE;
62 typedef struct {
63 const IClassFactoryVtbl *lpClassFactoryVtbl;
65 HRESULT (*cf)(IUnknown*,IUnknown**);
66 } ClassFactory;
68 static HRESULT WINAPI ClassFactory_QueryInterface(IClassFactory *iface,
69 REFIID riid, void **ppv)
71 *ppv = NULL;
73 if(IsEqualGUID(&IID_IUnknown, riid)) {
74 TRACE("(IID_IUnknown %p)\n", ppv);
75 *ppv = iface;
76 }else if(IsEqualGUID(&IID_IClassFactory, riid)) {
77 TRACE("IID_IClassFactory %p)\n", ppv);
78 *ppv = iface;
81 if(*ppv) {
82 IUnknown_AddRef((IUnknown*)*ppv);
83 return S_OK;
86 FIXME("(%s %p)\n", debugstr_guid(riid), ppv);
87 return E_NOINTERFACE;
90 static ULONG WINAPI ClassFactory_AddRef(IClassFactory *iface)
92 return 2;
95 static ULONG WINAPI ClassFactory_Release(IClassFactory *iface)
97 return 1;
100 static HRESULT WINAPI ClassFactory_CreateInstance(IClassFactory *iface,
101 IUnknown *pOuter, REFIID riid, void **ppv)
103 ClassFactory *This = (ClassFactory*)iface;
104 HRESULT ret;
105 IUnknown *obj;
106 TRACE("(%p, %p, %s, %p)\n", iface, pOuter, debugstr_guid(riid), ppv);
108 ret = This->cf(pOuter, &obj);
109 if (FAILED(ret))
110 return ret;
112 ret = IUnknown_QueryInterface(obj,riid,ppv);
113 IUnknown_Release(obj);
114 return ret;
117 static HRESULT WINAPI ClassFactory_LockServer(IClassFactory *iface, BOOL dolock)
119 FIXME("(%d)\n", dolock);
120 return S_OK;
123 static const IClassFactoryVtbl ClassFactoryVtbl = {
124 ClassFactory_QueryInterface,
125 ClassFactory_AddRef,
126 ClassFactory_Release,
127 ClassFactory_CreateInstance,
128 ClassFactory_LockServer
131 /******************************************************************
132 * DllGetClassObject (msimtf.@)
134 HRESULT WINAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, LPVOID *ppv)
136 if(IsEqualGUID(&CLSID_CActiveIMM, rclsid)) {
137 static ClassFactory cf = {
138 &ClassFactoryVtbl,
139 ActiveIMMApp_Constructor,
142 return IClassFactory_QueryInterface((IClassFactory*)&cf, riid, ppv);
145 FIXME("(%s %s %p)\n", debugstr_guid(rclsid), debugstr_guid(riid), ppv);
146 return CLASS_E_CLASSNOTAVAILABLE;
149 /******************************************************************
150 * DllCanUnloadNow (msimtf.@)
152 HRESULT WINAPI DllCanUnloadNow(void)
154 return S_FALSE;
157 #define INF_SET_CLSID(clsid) \
158 do \
160 static CHAR name[] = "CLSID_" #clsid; \
162 pse[i].pszName = name; \
163 clsids[i++] = &CLSID_ ## clsid; \
164 } while (0)
166 static HRESULT register_server(BOOL doregister)
168 HRESULT hres;
169 HMODULE hAdvpack;
170 HRESULT (WINAPI *pRegInstall)(HMODULE hm, LPCSTR pszSection, const STRTABLEA* pstTable);
171 STRTABLEA strtable;
172 STRENTRYA pse[1];
173 static CLSID const *clsids[34];
174 unsigned int i = 0;
176 static const WCHAR wszAdvpack[] = {'a','d','v','p','a','c','k','.','d','l','l',0};
178 INF_SET_CLSID(CActiveIMM);
180 for(i = 0; i < sizeof(pse)/sizeof(pse[0]); i++) {
181 pse[i].pszValue = HeapAlloc(GetProcessHeap(), 0, 39);
182 sprintf(pse[i].pszValue, "{%08X-%04X-%04X-%02X%02X-%02X%02X%02X%02X%02X%02X}",
183 clsids[i]->Data1, clsids[i]->Data2, clsids[i]->Data3, clsids[i]->Data4[0],
184 clsids[i]->Data4[1], clsids[i]->Data4[2], clsids[i]->Data4[3], clsids[i]->Data4[4],
185 clsids[i]->Data4[5], clsids[i]->Data4[6], clsids[i]->Data4[7]);
188 strtable.cEntries = sizeof(pse)/sizeof(pse[0]);
189 strtable.pse = pse;
191 hAdvpack = LoadLibraryW(wszAdvpack);
192 pRegInstall = (void *)GetProcAddress(hAdvpack, "RegInstall");
194 hres = pRegInstall(msimtf_instance, doregister ? "RegisterDll" : "UnregisterDll", &strtable);
196 for(i=0; i < sizeof(pse)/sizeof(pse[0]); i++)
197 HeapFree(GetProcessHeap(), 0, pse[i].pszValue);
199 return hres;
202 #undef INF_SET_CLSID
204 /***********************************************************************
205 * DllRegisterServer (msimtf.@)
207 HRESULT WINAPI DllRegisterServer(void)
209 return register_server(TRUE);
212 /***********************************************************************
213 * DllUnregisterServer (msimtf.@)
215 HRESULT WINAPI DllUnregisterServer(void)
217 return register_server(FALSE);