Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
e2dfb0af
Commit
e2dfb0af
authored
May 06, 2021
by
Hugh McMaster
Committed by
Alexandre Julliard
May 06, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
reg: Allow the 'reg_data' pointer to be NULL.
Signed-off-by:
Hugh McMaster
<
hugh.mcmaster@outlook.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
23e244fd
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
29 additions
and
23 deletions
+29
-23
add.c
programs/reg/add.c
+29
-23
No files found.
programs/reg/add.c
View file @
e2dfb0af
...
@@ -48,10 +48,10 @@ static inline BYTE hexchar_to_byte(WCHAR ch)
...
@@ -48,10 +48,10 @@ static inline BYTE hexchar_to_byte(WCHAR ch)
return
-
1
;
return
-
1
;
}
}
static
BYTE
*
get_regdata
(
const
WCHAR
*
data
,
DWORD
reg_type
,
WCHAR
separator
,
DWORD
*
size_bytes
)
static
BOOL
get_regdata
(
const
WCHAR
*
data
,
DWORD
reg_type
,
WCHAR
separator
,
BYTE
**
data_bytes
,
DWORD
*
size_bytes
)
{
{
static
const
WCHAR
empty
;
static
const
WCHAR
empty
;
LPBYTE
out_data
=
NULL
;
*
size_bytes
=
0
;
*
size_bytes
=
0
;
...
@@ -64,8 +64,8 @@ static BYTE *get_regdata(const WCHAR *data, DWORD reg_type, WCHAR separator, DWO
...
@@ -64,8 +64,8 @@ static BYTE *get_regdata(const WCHAR *data, DWORD reg_type, WCHAR separator, DWO
case
REG_EXPAND_SZ
:
case
REG_EXPAND_SZ
:
{
{
*
size_bytes
=
(
lstrlenW
(
data
)
+
1
)
*
sizeof
(
WCHAR
);
*
size_bytes
=
(
lstrlenW
(
data
)
+
1
)
*
sizeof
(
WCHAR
);
out_data
=
malloc
(
*
size_bytes
);
*
data_bytes
=
malloc
(
*
size_bytes
);
lstrcpyW
((
LPWSTR
)
out_data
,
data
);
lstrcpyW
((
WCHAR
*
)
*
data_bytes
,
data
);
break
;
break
;
}
}
case
REG_DWORD
:
case
REG_DWORD
:
...
@@ -77,41 +77,46 @@ static BYTE *get_regdata(const WCHAR *data, DWORD reg_type, WCHAR separator, DWO
...
@@ -77,41 +77,46 @@ static BYTE *get_regdata(const WCHAR *data, DWORD reg_type, WCHAR separator, DWO
val
=
wcstoul
(
data
,
&
rest
,
(
towlower
(
data
[
1
])
==
'x'
)
?
16
:
10
);
val
=
wcstoul
(
data
,
&
rest
,
(
towlower
(
data
[
1
])
==
'x'
)
?
16
:
10
);
if
(
*
rest
||
data
[
0
]
==
'-'
||
(
val
==
~
0u
&&
errno
==
ERANGE
))
{
if
(
*
rest
||
data
[
0
]
==
'-'
||
(
val
==
~
0u
&&
errno
==
ERANGE
))
{
output_message
(
STRING_MISSING_INTEGER
);
output_message
(
STRING_MISSING_INTEGER
);
break
;
return
FALSE
;
}
}
*
size_bytes
=
sizeof
(
DWORD
);
*
size_bytes
=
sizeof
(
DWORD
);
out_data
=
malloc
(
*
size_bytes
);
*
data_bytes
=
malloc
(
*
size_bytes
);
((
LPDWORD
)
out_data
)[
0
]
=
val
;
*
(
DWORD
*
)
*
data_bytes
=
val
;
break
;
break
;
}
}
case
REG_BINARY
:
case
REG_BINARY
:
{
{
BYTE
hex0
,
hex1
;
BYTE
hex0
,
hex1
,
*
ptr
;
int
i
=
0
,
destByteIndex
=
0
,
datalen
=
lstrlenW
(
data
);
int
i
=
0
,
destByteIndex
=
0
,
datalen
=
lstrlenW
(
data
);
*
size_bytes
=
((
datalen
+
datalen
%
2
)
/
2
)
*
sizeof
(
BYTE
);
*
size_bytes
=
((
datalen
+
datalen
%
2
)
/
2
)
*
sizeof
(
BYTE
);
out_data
=
malloc
(
*
size_bytes
);
*
data_bytes
=
malloc
(
*
size_bytes
);
if
(
datalen
%
2
)
if
(
datalen
%
2
)
{
{
hex1
=
hexchar_to_byte
(
data
[
i
++
]);
hex1
=
hexchar_to_byte
(
data
[
i
++
]);
if
(
hex1
==
0xFF
)
if
(
hex1
==
0xFF
)
goto
no_hex_data
;
goto
no_hex_data
;
out_data
[
destByteIndex
++
]
=
hex1
;
*
data_bytes
[
destByteIndex
++
]
=
hex1
;
}
}
for
(;
i
+
1
<
datalen
;
i
+=
2
)
ptr
=
*
data_bytes
;
for
(;
i
+
1
<
datalen
;
i
+=
2
)
{
{
hex0
=
hexchar_to_byte
(
data
[
i
]);
hex0
=
hexchar_to_byte
(
data
[
i
]);
hex1
=
hexchar_to_byte
(
data
[
i
+
1
]);
hex1
=
hexchar_to_byte
(
data
[
i
+
1
]);
if
(
hex0
==
0xFF
||
hex1
==
0xFF
)
if
(
hex0
==
0xFF
||
hex1
==
0xFF
)
goto
no_hex_data
;
goto
no_hex_data
;
out_data
[
destByteIndex
++
]
=
(
hex0
<<
4
)
|
hex1
;
ptr
[
destByteIndex
++
]
=
(
hex0
<<
4
)
|
hex1
;
}
}
break
;
break
;
no_hex_data:
no_hex_data:
/* cleanup, print error */
free
(
*
data_bytes
);
free
(
out_data
)
;
*
data_bytes
=
NULL
;
output_message
(
STRING_MISSING_HEXDATA
);
output_message
(
STRING_MISSING_HEXDATA
);
out_data
=
NULL
;
return
FALSE
;
break
;
}
}
case
REG_MULTI_SZ
:
case
REG_MULTI_SZ
:
{
{
...
@@ -134,20 +139,21 @@ static BYTE *get_regdata(const WCHAR *data, DWORD reg_type, WCHAR separator, DWO
...
@@ -134,20 +139,21 @@ static BYTE *get_regdata(const WCHAR *data, DWORD reg_type, WCHAR separator, DWO
{
{
free
(
buffer
);
free
(
buffer
);
output_message
(
STRING_INVALID_STRING
);
output_message
(
STRING_INVALID_STRING
);
return
NULL
;
return
FALSE
;
}
}
}
}
buffer
[
destindex
]
=
0
;
buffer
[
destindex
]
=
0
;
if
(
destindex
&&
buffer
[
destindex
-
1
])
if
(
destindex
&&
buffer
[
destindex
-
1
])
buffer
[
++
destindex
]
=
0
;
buffer
[
++
destindex
]
=
0
;
*
size_bytes
=
(
destindex
+
1
)
*
sizeof
(
WCHAR
);
*
size_bytes
=
(
destindex
+
1
)
*
sizeof
(
WCHAR
);
return
(
BYTE
*
)
buffer
;
*
data_bytes
=
(
BYTE
*
)
buffer
;
break
;
}
}
default:
default:
output_message
(
STRING_UNHANDLED_TYPE
,
reg_type
,
data
);
output_message
(
STRING_UNHANDLED_TYPE
,
reg_type
,
data
);
}
}
return
out_data
;
return
TRUE
;
}
}
static
int
run_add
(
HKEY
root
,
WCHAR
*
path
,
WCHAR
*
value_name
,
BOOL
value_empty
,
static
int
run_add
(
HKEY
root
,
WCHAR
*
path
,
WCHAR
*
value_name
,
BOOL
value_empty
,
...
@@ -194,7 +200,7 @@ static int run_add(HKEY root, WCHAR *path, WCHAR *value_name, BOOL value_empty,
...
@@ -194,7 +200,7 @@ static int run_add(HKEY root, WCHAR *path, WCHAR *value_name, BOOL value_empty,
return
1
;
return
1
;
}
}
if
(
!
(
reg_data
=
get_regdata
(
data
,
data_type
,
separator
,
&
data_size
)
))
if
(
!
get_regdata
(
data
,
data_type
,
separator
,
&
reg_data
,
&
data_size
))
{
{
RegCloseKey
(
hkey
);
RegCloseKey
(
hkey
);
return
1
;
return
1
;
...
...
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