Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
5779ce28
Commit
5779ce28
authored
May 15, 2012
by
Jacek Caban
Committed by
Alexandre Julliard
May 15, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
appwiz.cpl: Moved config_key value to addon_info_t.
parent
87538c62
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
49 additions
and
18 deletions
+49
-18
addons.c
dlls/appwiz.cpl/addons.c
+33
-18
appwiz.h
dlls/appwiz.cpl/appwiz.h
+16
-0
No files found.
dlls/appwiz.cpl/addons.c
View file @
5779ce28
...
@@ -69,6 +69,9 @@ typedef struct {
...
@@ -69,6 +69,9 @@ typedef struct {
const
char
*
file_name
;
const
char
*
file_name
;
const
char
*
subdir_name
;
const
char
*
subdir_name
;
const
char
*
sha
;
const
char
*
sha
;
const
char
*
config_key
;
const
char
*
url_config_key
;
const
char
*
dir_config_key
;
}
addon_info_t
;
}
addon_info_t
;
static
const
addon_info_t
addons_info
[]
=
{
static
const
addon_info_t
addons_info
[]
=
{
...
@@ -76,17 +79,13 @@ static const addon_info_t addons_info[] = {
...
@@ -76,17 +79,13 @@ static const addon_info_t addons_info[] = {
GECKO_VERSION
,
GECKO_VERSION
,
"wine_gecko-"
GECKO_VERSION
"-"
ARCH_STRING
".msi"
,
"wine_gecko-"
GECKO_VERSION
"-"
ARCH_STRING
".msi"
,
"gecko"
,
"gecko"
,
GECKO_SHA
GECKO_SHA
,
"MSHTML"
,
"GeckoUrl"
,
"GeckoCabDir"
}
}
};
};
static
const
addon_info_t
*
addon
=
&
addons_info
[
0
];
static
const
addon_info_t
*
addon
=
&
addons_info
[
0
];
static
const
WCHAR
mshtml_keyW
[]
=
{
'S'
,
'o'
,
'f'
,
't'
,
'w'
,
'a'
,
'r'
,
'e'
,
'\\'
,
'W'
,
'i'
,
'n'
,
'e'
,
'\\'
,
'M'
,
'S'
,
'H'
,
'T'
,
'M'
,
'L'
,
0
};
static
HWND
install_dialog
=
NULL
;
static
HWND
install_dialog
=
NULL
;
static
LPWSTR
url
=
NULL
;
static
LPWSTR
url
=
NULL
;
...
@@ -233,6 +232,23 @@ static BOOL install_from_unix_file(const char *dir, const char *subdir, const ch
...
@@ -233,6 +232,23 @@ static BOOL install_from_unix_file(const char *dir, const char *subdir, const ch
return
ret
;
return
ret
;
}
}
static
HKEY
open_config_key
(
void
)
{
HKEY
hkey
,
ret
;
DWORD
res
;
static
const
WCHAR
wine_keyW
[]
=
{
'S'
,
'o'
,
'f'
,
't'
,
'w'
,
'a'
,
'r'
,
'e'
,
'\\'
,
'W'
,
'i'
,
'n'
,
'e'
,
0
};
/* @@ Wine registry key: HKCU\Software\Wine\$config_key */
res
=
RegOpenKeyW
(
HKEY_CURRENT_USER
,
wine_keyW
,
&
hkey
);
if
(
res
!=
ERROR_SUCCESS
)
return
NULL
;
res
=
RegOpenKeyA
(
hkey
,
addon
->
config_key
,
&
ret
);
RegCloseKey
(
hkey
);
return
res
==
ERROR_SUCCESS
?
ret
:
NULL
;
}
static
BOOL
install_from_registered_dir
(
void
)
static
BOOL
install_from_registered_dir
(
void
)
{
{
char
*
package_dir
;
char
*
package_dir
;
...
@@ -240,16 +256,15 @@ static BOOL install_from_registered_dir(void)
...
@@ -240,16 +256,15 @@ static BOOL install_from_registered_dir(void)
DWORD
res
,
type
,
size
=
MAX_PATH
;
DWORD
res
,
type
,
size
=
MAX_PATH
;
BOOL
ret
;
BOOL
ret
;
/* @@ Wine registry key: HKCU\Software\Wine\MSHTML */
hkey
=
open_config_key
();
res
=
RegOpenKeyW
(
HKEY_CURRENT_USER
,
mshtml_keyW
,
&
hkey
);
if
(
!
hkey
)
if
(
res
!=
ERROR_SUCCESS
)
return
FALSE
;
return
FALSE
;
package_dir
=
heap_alloc
(
size
);
package_dir
=
heap_alloc
(
size
);
res
=
RegGetValueA
(
hkey
,
NULL
,
"GeckoCabDir"
,
RRF_RT_ANY
,
&
type
,
(
PBYTE
)
package_dir
,
&
size
);
res
=
RegGetValueA
(
hkey
,
NULL
,
addon
->
dir_config_key
,
RRF_RT_ANY
,
&
type
,
(
PBYTE
)
package_dir
,
&
size
);
if
(
res
==
ERROR_MORE_DATA
)
{
if
(
res
==
ERROR_MORE_DATA
)
{
package_dir
=
heap_realloc
(
package_dir
,
size
);
package_dir
=
heap_realloc
(
package_dir
,
size
);
res
=
RegGetValueA
(
hkey
,
NULL
,
"GeckoCabDir"
,
RRF_RT_ANY
,
&
type
,
(
PBYTE
)
package_dir
,
&
size
);
res
=
RegGetValueA
(
hkey
,
NULL
,
addon
->
dir_config_key
,
RRF_RT_ANY
,
&
type
,
(
PBYTE
)
package_dir
,
&
size
);
}
}
RegCloseKey
(
hkey
);
RegCloseKey
(
hkey
);
if
(
res
!=
ERROR_SUCCESS
||
(
type
!=
REG_SZ
&&
type
!=
REG_EXPAND_SZ
))
{
if
(
res
!=
ERROR_SUCCESS
||
(
type
!=
REG_SZ
&&
type
!=
REG_EXPAND_SZ
))
{
...
@@ -399,26 +414,26 @@ static IBindStatusCallback InstallCallback = { &InstallCallbackVtbl };
...
@@ -399,26 +414,26 @@ static IBindStatusCallback InstallCallback = { &InstallCallbackVtbl };
static
LPWSTR
get_url
(
void
)
static
LPWSTR
get_url
(
void
)
{
{
DWORD
size
=
INTERNET_MAX_URL_LENGTH
*
sizeof
(
WCHAR
);
WCHAR
*
url
,
*
config_key
;
HKEY
hkey
;
HKEY
hkey
;
DWORD
res
,
type
;
DWORD
res
,
type
;
DWORD
size
=
INTERNET_MAX_URL_LENGTH
*
sizeof
(
WCHAR
);
DWORD
returned_size
;
DWORD
returned_size
;
LPWSTR
url
;
static
const
WCHAR
wszGeckoUrl
[]
=
{
'G'
,
'e'
,
'c'
,
'k'
,
'o'
,
'U'
,
'r'
,
'l'
,
0
};
static
const
WCHAR
httpW
[]
=
{
'h'
,
't'
,
't'
,
'p'
};
static
const
WCHAR
httpW
[]
=
{
'h'
,
't'
,
't'
,
'p'
};
static
const
WCHAR
arch_formatW
[]
=
{
'?'
,
'a'
,
'r'
,
'c'
,
'h'
,
'='
};
static
const
WCHAR
arch_formatW
[]
=
{
'?'
,
'a'
,
'r'
,
'c'
,
'h'
,
'='
};
static
const
WCHAR
v_formatW
[]
=
{
'&'
,
'v'
,
'='
};
static
const
WCHAR
v_formatW
[]
=
{
'&'
,
'v'
,
'='
};
/* @@ Wine registry key: HKCU\Software\Wine\MSHTML */
hkey
=
open_config_key
();
res
=
RegOpenKeyW
(
HKEY_CURRENT_USER
,
mshtml_keyW
,
&
hkey
);
if
(
!
hkey
)
if
(
res
!=
ERROR_SUCCESS
)
return
NULL
;
return
NULL
;
url
=
heap_alloc
(
size
);
url
=
heap_alloc
(
size
);
returned_size
=
size
;
returned_size
=
size
;
res
=
RegQueryValueExW
(
hkey
,
wszGeckoUrl
,
NULL
,
&
type
,
(
LPBYTE
)
url
,
&
returned_size
);
config_key
=
heap_strdupAtoW
(
addon
->
url_config_key
);
res
=
RegQueryValueExW
(
hkey
,
config_key
,
NULL
,
&
type
,
(
LPBYTE
)
url
,
&
returned_size
);
heap_free
(
config_key
);
RegCloseKey
(
hkey
);
RegCloseKey
(
hkey
);
if
(
res
!=
ERROR_SUCCESS
||
type
!=
REG_SZ
)
{
if
(
res
!=
ERROR_SUCCESS
||
type
!=
REG_SZ
)
{
heap_free
(
url
);
heap_free
(
url
);
...
...
dlls/appwiz.cpl/appwiz.h
View file @
5779ce28
...
@@ -34,3 +34,19 @@ static inline BOOL heap_free(void *mem)
...
@@ -34,3 +34,19 @@ static inline BOOL heap_free(void *mem)
{
{
return
HeapFree
(
GetProcessHeap
(),
0
,
mem
);
return
HeapFree
(
GetProcessHeap
(),
0
,
mem
);
}
}
static
inline
WCHAR
*
heap_strdupAtoW
(
const
char
*
str
)
{
WCHAR
*
ret
=
NULL
;
if
(
str
)
{
size_t
len
;
len
=
MultiByteToWideChar
(
CP_ACP
,
0
,
str
,
-
1
,
NULL
,
0
);
ret
=
heap_alloc
(
len
*
sizeof
(
WCHAR
));
if
(
ret
)
MultiByteToWideChar
(
CP_ACP
,
0
,
str
,
-
1
,
ret
,
len
);
}
return
ret
;
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment