shlwapi: Handle URL_WININET_COMPATIBILITY flag in UrlCanonicalize.
[wine/multimedia.git] / dlls / userenv / userenv_main.c
blob59b3b1f95468fe1612ff346a29647fcf9853f002
1 /*
2 * Implementation of userenv.dll
4 * Copyright 2006 Mike McCormack for CodeWeavers
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
21 #include <stdarg.h>
23 #include "ntstatus.h"
24 #define WIN32_NO_STATUS
25 #include "windef.h"
26 #include "winbase.h"
27 #include "winreg.h"
28 #include "winternl.h"
29 #include "userenv.h"
31 #include "wine/debug.h"
33 WINE_DEFAULT_DEBUG_CHANNEL( userenv );
35 BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
37 TRACE("%p %d %p\n", hinstDLL, fdwReason, lpvReserved);
39 switch (fdwReason)
41 case DLL_WINE_PREATTACH:
42 return FALSE; /* prefer native version */
43 case DLL_PROCESS_ATTACH:
44 DisableThreadLibraryCalls(hinstDLL);
45 break;
46 case DLL_PROCESS_DETACH:
47 break;
49 return TRUE;
52 BOOL WINAPI CreateEnvironmentBlock( LPVOID* lpEnvironment,
53 HANDLE hToken, BOOL bInherit )
55 NTSTATUS r;
57 TRACE("%p %p %d\n", lpEnvironment, hToken, bInherit );
59 if (!lpEnvironment)
60 return FALSE;
62 r = RtlCreateEnvironment(bInherit, (WCHAR **)lpEnvironment);
63 if (r == STATUS_SUCCESS)
64 return TRUE;
65 return FALSE;
68 BOOL WINAPI DestroyEnvironmentBlock(LPVOID lpEnvironment)
70 NTSTATUS r;
72 TRACE("%p\n", lpEnvironment);
73 r = RtlDestroyEnvironment(lpEnvironment);
74 if (r == STATUS_SUCCESS)
75 return TRUE;
76 return FALSE;
79 BOOL WINAPI ExpandEnvironmentStringsForUserA( HANDLE hToken, LPCSTR lpSrc,
80 LPSTR lpDest, DWORD dwSize )
82 BOOL ret;
84 TRACE("%p %s %p %d\n", hToken, debugstr_a(lpSrc), lpDest, dwSize);
86 ret = ExpandEnvironmentStringsA( lpSrc, lpDest, dwSize );
87 TRACE("<- %s\n", debugstr_a(lpDest));
88 return ret;
91 BOOL WINAPI ExpandEnvironmentStringsForUserW( HANDLE hToken, LPCWSTR lpSrc,
92 LPWSTR lpDest, DWORD dwSize )
94 BOOL ret;
96 TRACE("%p %s %p %d\n", hToken, debugstr_w(lpSrc), lpDest, dwSize);
98 ret = ExpandEnvironmentStringsW( lpSrc, lpDest, dwSize );
99 TRACE("<- %s\n", debugstr_w(lpDest));
100 return ret;
103 BOOL WINAPI GetDefaultUserProfileDirectoryA( LPSTR lpProfileDir, LPDWORD lpcchSize )
105 FIXME("%p %p\n", lpProfileDir, lpcchSize );
106 return FALSE;
109 BOOL WINAPI GetDefaultUserProfileDirectoryW( LPWSTR lpProfileDir, LPDWORD lpcchSize )
111 FIXME("%p %p\n", lpProfileDir, lpcchSize );
112 return FALSE;
115 BOOL WINAPI GetUserProfileDirectoryA( HANDLE hToken, LPSTR lpProfileDir,
116 LPDWORD lpcchSize )
118 FIXME("%p %p %p\n", hToken, lpProfileDir, lpcchSize );
119 return FALSE;
122 BOOL WINAPI GetUserProfileDirectoryW( HANDLE hToken, LPWSTR lpProfileDir,
123 LPDWORD lpcchSize )
125 FIXME("%p %p %p\n", hToken, lpProfileDir, lpcchSize );
126 return FALSE;
129 static const char ProfileListA[] = "Software\\Microsoft\\Windows NT\\CurrentVersion\\ProfileList";
131 BOOL WINAPI GetProfilesDirectoryA( LPSTR lpProfilesDir, LPDWORD lpcchSize )
133 static const char ProfilesDirectory[] = "ProfilesDirectory";
134 LONG l;
135 HKEY key;
136 BOOL ret = FALSE;
137 DWORD len = 0, expanded_len;
138 LPSTR unexpanded_profiles_dir = NULL;
140 TRACE("%p %p\n", lpProfilesDir, lpcchSize );
142 if (!lpProfilesDir || !lpcchSize)
144 SetLastError(ERROR_INVALID_PARAMETER);
145 return FALSE;
148 l = RegOpenKeyExA(HKEY_LOCAL_MACHINE, ProfileListA, 0, KEY_READ, &key);
149 if (l)
151 SetLastError(l);
152 return FALSE;
154 l = RegQueryValueExA(key, ProfilesDirectory, NULL, NULL, NULL, &len);
155 if (l)
157 SetLastError(l);
158 goto end;
160 unexpanded_profiles_dir = HeapAlloc(GetProcessHeap(), 0, len);
161 if (!unexpanded_profiles_dir)
163 SetLastError(ERROR_OUTOFMEMORY);
164 goto end;
166 l = RegQueryValueExA(key, ProfilesDirectory, NULL, NULL,
167 (BYTE *)unexpanded_profiles_dir, &len);
168 if (l)
170 SetLastError(l);
171 goto end;
173 expanded_len = ExpandEnvironmentStringsA(unexpanded_profiles_dir, NULL, 0);
174 /* The returned length doesn't include the NULL terminator. */
175 if (*lpcchSize < expanded_len - 1)
177 *lpcchSize = expanded_len - 1;
178 SetLastError(ERROR_INSUFFICIENT_BUFFER);
179 goto end;
181 *lpcchSize = expanded_len - 1;
182 /* The return value is also the expected length. */
183 ret = ExpandEnvironmentStringsA(unexpanded_profiles_dir, lpProfilesDir,
184 expanded_len) - 1;
185 end:
186 HeapFree(GetProcessHeap(), 0, unexpanded_profiles_dir);
187 RegCloseKey(key);
188 return ret;
191 static const WCHAR ProfileListW[] = {'S','o','f','t','w','a','r','e','\\','M','i','c','r','o','s','o','f','t','\\','W','i','n','d','o','w','s',' ','N','T','\\','C','u','r','r','e','n','t','V','e','r','s','i','o','n','\\','P','r','o','f','i','l','e','L','i','s','t',0};
193 BOOL WINAPI GetProfilesDirectoryW( LPWSTR lpProfilesDir, LPDWORD lpcchSize )
195 static const WCHAR ProfilesDirectory[] = {'P','r','o','f','i','l','e','s','D','i','r','e','c','t','o','r','y',0};
196 LONG l;
197 HKEY key;
198 BOOL ret = FALSE;
199 DWORD len = 0, expanded_len;
200 LPWSTR unexpanded_profiles_dir = NULL;
202 TRACE("%p %p\n", lpProfilesDir, lpcchSize );
204 if (!lpProfilesDir || !lpcchSize)
206 SetLastError(ERROR_INVALID_PARAMETER);
207 return FALSE;
210 l = RegOpenKeyExW(HKEY_LOCAL_MACHINE, ProfileListW, 0, KEY_READ, &key);
211 if (l)
213 SetLastError(l);
214 return FALSE;
216 l = RegQueryValueExW(key, ProfilesDirectory, NULL, NULL, NULL, &len);
217 if (l)
219 SetLastError(l);
220 goto end;
222 unexpanded_profiles_dir = HeapAlloc(GetProcessHeap(), 0, len);
223 if (!unexpanded_profiles_dir)
225 SetLastError(ERROR_OUTOFMEMORY);
226 goto end;
228 l = RegQueryValueExW(key, ProfilesDirectory, NULL, NULL,
229 (BYTE *)unexpanded_profiles_dir, &len);
230 if (l)
232 SetLastError(l);
233 goto end;
235 expanded_len = ExpandEnvironmentStringsW(unexpanded_profiles_dir, NULL, 0);
236 /* The returned length doesn't include the NULL terminator. */
237 if (*lpcchSize < expanded_len - 1)
239 *lpcchSize = expanded_len - 1;
240 SetLastError(ERROR_INSUFFICIENT_BUFFER);
241 goto end;
243 *lpcchSize = expanded_len - 1;
244 /* The return value is also the expected length. */
245 ret = ExpandEnvironmentStringsW(unexpanded_profiles_dir, lpProfilesDir,
246 expanded_len) - 1;
247 end:
248 HeapFree(GetProcessHeap(), 0, unexpanded_profiles_dir);
249 RegCloseKey(key);
250 return ret;
253 BOOL WINAPI GetAllUsersProfileDirectoryA( LPSTR lpProfileDir, LPDWORD lpcchSize )
255 FIXME("%p %p\n", lpProfileDir, lpcchSize);
256 return FALSE;
259 BOOL WINAPI GetAllUsersProfileDirectoryW( LPWSTR lpProfileDir, LPDWORD lpcchSize )
261 FIXME("%p %p\n", lpProfileDir, lpcchSize);
262 return FALSE;
265 BOOL WINAPI GetProfileType( DWORD *pdwFlags )
267 FIXME("%p\n", pdwFlags );
268 *pdwFlags = 0;
269 return TRUE;
272 BOOL WINAPI LoadUserProfileA( HANDLE hToken, LPPROFILEINFOA lpProfileInfo )
274 FIXME("%p %p\n", hToken, lpProfileInfo );
275 lpProfileInfo->hProfile = HKEY_CURRENT_USER;
276 return TRUE;
279 BOOL WINAPI LoadUserProfileW( HANDLE hToken, LPPROFILEINFOW lpProfileInfo )
281 FIXME("%p %p\n", hToken, lpProfileInfo );
282 lpProfileInfo->hProfile = HKEY_CURRENT_USER;
283 return TRUE;
286 BOOL WINAPI RegisterGPNotification( HANDLE event, BOOL machine )
288 FIXME("%p %d\n", event, machine );
289 return TRUE;
292 BOOL WINAPI UnregisterGPNotification( HANDLE event )
294 FIXME("%p\n", event );
295 return TRUE;
298 BOOL WINAPI UnloadUserProfile( HANDLE hToken, HANDLE hProfile )
300 FIXME("(%p, %p): stub\n", hToken, hProfile);
301 return FALSE;
304 /******************************************************************************
305 * USERENV.138
307 * Create .lnk file
309 * PARAMETERS
310 * int csidl [in] well-known directory location to create link in
311 * LPCSTR lnk_dir [in] directory (relative to directory specified by csidl) to create link in
312 * LPCSTR lnk_filename [in] filename of the link file without .lnk extension
313 * LPCSTR lnk_target [in] file/directory pointed to by link
314 * LPCSTR lnk_iconfile [in] link icon resource filename
315 * DWORD lnk_iconid [in] link icon resource id in file referred by lnk_iconfile
316 * LPCSTR work_directory [in] link target's work directory
317 * WORD hotkey [in] link hotkey (virtual key id)
318 * DWORD win_state [in] initial window size (SW_SHOWMAXIMIZED to start maximized,
319 * SW_SHOWMINNOACTIVE to start minimized, everything else is default state)
320 * LPCSTR comment [in] comment - link's comment
321 * LPCSTR loc_filename_resfile [in] resource file which holds localized filename for this link file
322 * DWORD loc_filename_resid [in] resource id for this link file's localized filename
324 * RETURNS
325 * TRUE: Link file was successfully created
326 * FALSE: Link file was not created
328 BOOL WINAPI USERENV_138( int csidl, LPCSTR lnk_dir, LPCSTR lnk_filename,
329 LPCSTR lnk_target, LPCSTR lnk_iconfile, DWORD lnk_iconid,
330 LPCSTR work_directory, WORD hotkey, DWORD win_state, LPCSTR comment,
331 LPCSTR loc_filename_resfile, DWORD loc_filename_resid)
333 FIXME("(%d,%s,%s,%s,%s,%d,%s,0x%x,%d,%s,%s,%d) - stub\n", csidl, debugstr_a(lnk_dir),
334 debugstr_a(lnk_filename), debugstr_a(lnk_target), debugstr_a(lnk_iconfile),
335 lnk_iconid, debugstr_a(work_directory), hotkey, win_state,
336 debugstr_a(comment), debugstr_a(loc_filename_resfile), loc_filename_resid );
338 return FALSE;