winemenubuilder: Store menu paths in Unicode.

This commit is contained in:
Damjan Jovanovic 2010-04-30 13:41:40 +02:00 committed by Alexandre Julliard
parent 1434ef4e74
commit 21f75386ec
1 changed files with 45 additions and 16 deletions

View File

@ -883,11 +883,52 @@ static HKEY open_menus_reg_key(void)
static const WCHAR Software_Wine_FileOpenAssociationsW[] = { static const WCHAR Software_Wine_FileOpenAssociationsW[] = {
'S','o','f','t','w','a','r','e','\\','W','i','n','e','\\','M','e','n','u','F','i','l','e','s',0}; 'S','o','f','t','w','a','r','e','\\','W','i','n','e','\\','M','e','n','u','F','i','l','e','s',0};
HKEY assocKey; HKEY assocKey;
if (RegCreateKeyW(HKEY_CURRENT_USER, Software_Wine_FileOpenAssociationsW, &assocKey) == ERROR_SUCCESS) DWORD ret;
ret = RegCreateKeyW(HKEY_CURRENT_USER, Software_Wine_FileOpenAssociationsW, &assocKey);
if (ret == ERROR_SUCCESS)
return assocKey; return assocKey;
SetLastError(ret);
return NULL; return NULL;
} }
static DWORD register_menus_entry(const char *unix_file, const char *windows_file)
{
WCHAR *unix_fileW;
WCHAR *windows_fileW;
INT size;
DWORD ret;
size = MultiByteToWideChar(CP_UNIXCP, 0, unix_file, -1, NULL, 0);
unix_fileW = HeapAlloc(GetProcessHeap(), 0, size * sizeof(WCHAR));
if (unix_fileW)
{
MultiByteToWideChar(CP_UNIXCP, 0, unix_file, -1, unix_fileW, size);
size = MultiByteToWideChar(CP_UNIXCP, 0, windows_file, -1, NULL, 0);
windows_fileW = HeapAlloc(GetProcessHeap(), 0, size * sizeof(WCHAR));
if (windows_fileW)
{
HKEY hkey;
MultiByteToWideChar(CP_UNIXCP, 0, windows_file, -1, windows_fileW, size);
hkey = open_menus_reg_key();
if (hkey)
{
ret = RegSetValueExW(hkey, unix_fileW, 0, REG_SZ, (const BYTE*)windows_fileW,
(strlenW(windows_fileW) + 1) * sizeof(WCHAR));
RegCloseKey(hkey);
}
else
ret = GetLastError();
HeapFree(GetProcessHeap(), 0, windows_fileW);
}
else
ret = ERROR_NOT_ENOUGH_MEMORY;
HeapFree(GetProcessHeap(), 0, unix_fileW);
}
else
ret = ERROR_NOT_ENOUGH_MEMORY;
return ret;
}
static BOOL write_desktop_entry(const char *unix_link, const char *location, const char *linkname, static BOOL write_desktop_entry(const char *unix_link, const char *location, const char *linkname,
const char *path, const char *args, const char *descr, const char *path, const char *args, const char *descr,
const char *workdir, const char *icon) const char *workdir, const char *icon)
@ -919,13 +960,8 @@ static BOOL write_desktop_entry(const char *unix_link, const char *location, con
if (unix_link) if (unix_link)
{ {
HKEY hkey = open_menus_reg_key(); DWORD ret = register_menus_entry(location, unix_link);
if (hkey) if (ret != ERROR_SUCCESS)
{
RegSetValueExA(hkey, location, 0, REG_SZ, (const BYTE*) unix_link, lstrlenA(unix_link) + 1);
RegCloseKey(hkey);
}
else
return FALSE; return FALSE;
} }
@ -1057,14 +1093,7 @@ end:
remove(tempfilename); remove(tempfilename);
HeapFree(GetProcessHeap(), 0, tempfilename); HeapFree(GetProcessHeap(), 0, tempfilename);
if (ret) if (ret)
{ register_menus_entry(menuPath, unix_link);
HKEY hkey = open_menus_reg_key();
if (hkey)
{
RegSetValueExA(hkey, menuPath, 0, REG_SZ, (const BYTE*) unix_link, lstrlenA(unix_link) + 1);
RegCloseKey(hkey);
}
}
HeapFree(GetProcessHeap(), 0, name); HeapFree(GetProcessHeap(), 0, name);
HeapFree(GetProcessHeap(), 0, menuPath); HeapFree(GetProcessHeap(), 0, menuPath);
return ret; return ret;