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
ddaba7a3
Commit
ddaba7a3
authored
Aug 26, 2015
by
Hans Leidekker
Committed by
Alexandre Julliard
Aug 26, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msi: Don't add the same environment string more than once.
parent
58bf3ca1
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
53 additions
and
28 deletions
+53
-28
action.c
dlls/msi/action.c
+46
-27
action.c
dlls/msi/tests/action.c
+7
-1
No files found.
dlls/msi/action.c
View file @
ddaba7a3
...
...
@@ -6922,13 +6922,13 @@ static UINT ITERATE_WriteEnvironmentString( MSIRECORD *rec, LPVOID param )
{
MSIPACKAGE
*
package
=
param
;
LPCWSTR
name
,
value
,
component
;
LPWSTR
data
=
NULL
,
newval
=
NULL
,
deformatted
=
NULL
,
ptr
;
DWORD
flags
,
type
,
size
;
WCHAR
*
data
=
NULL
,
*
newval
=
NULL
,
*
deformatted
=
NULL
,
*
p
,
*
q
;
DWORD
flags
,
type
,
size
,
len
,
len_value
=
0
;
UINT
res
;
HKEY
env
=
NULL
;
MSICOMPONENT
*
comp
;
MSIRECORD
*
uirow
;
int
action
=
0
;
int
action
=
0
,
found
=
0
;
component
=
MSI_RecordGetString
(
rec
,
4
);
comp
=
msi_get_loaded_component
(
package
,
component
);
...
...
@@ -6956,7 +6956,20 @@ static UINT ITERATE_WriteEnvironmentString( MSIRECORD *rec, LPVOID param )
goto
done
;
}
value
=
deformatted
;
if
((
value
=
deformatted
))
{
if
(
flags
&
ENV_MOD_PREFIX
)
{
p
=
strrchrW
(
value
,
';'
);
len_value
=
p
-
value
;
}
else
if
(
flags
&
ENV_MOD_APPEND
)
{
value
=
strchrW
(
value
,
';'
)
+
1
;
len_value
=
strlenW
(
value
);
}
else
len_value
=
strlenW
(
value
);
}
res
=
open_env_key
(
flags
,
&
env
);
if
(
res
!=
ERROR_SUCCESS
)
...
...
@@ -6982,10 +6995,6 @@ static UINT ITERATE_WriteEnvironmentString( MSIRECORD *rec, LPVOID param )
res
=
ERROR_SUCCESS
;
goto
done
;
}
/* If we are appending but the string was empty, strip ; */
if
((
flags
&
ENV_MOD_APPEND
)
&&
(
value
[
0
]
==
szSemiColon
[
0
]))
value
++
;
size
=
(
lstrlenW
(
value
)
+
1
)
*
sizeof
(
WCHAR
);
newval
=
strdupW
(
value
);
if
(
!
newval
)
...
...
@@ -7005,15 +7014,14 @@ static UINT ITERATE_WriteEnvironmentString( MSIRECORD *rec, LPVOID param )
goto
done
;
}
data
=
msi_alloc
(
size
);
if
(
!
data
)
if
(
!
(
p
=
q
=
data
=
msi_alloc
(
size
)))
{
msi_free
(
deformatted
);
RegCloseKey
(
env
);
return
ERROR_OUTOFMEMORY
;
}
res
=
RegQueryValueExW
(
env
,
name
,
NULL
,
&
type
,
(
LPVOID
)
data
,
&
size
);
res
=
RegQueryValueExW
(
env
,
name
,
NULL
,
&
type
,
(
BYTE
*
)
data
,
&
size
);
if
(
res
!=
ERROR_SUCCESS
)
goto
done
;
...
...
@@ -7026,20 +7034,28 @@ static UINT ITERATE_WriteEnvironmentString( MSIRECORD *rec, LPVOID param )
goto
done
;
}
size
=
(
lstrlenW
(
data
)
+
1
)
*
sizeof
(
WCHAR
);
if
(
flags
&
ENV_MOD_MASK
)
for
(;;)
{
while
(
*
q
&&
*
q
!=
';'
)
q
++
;
len
=
q
-
p
;
if
(
value
&&
len
==
len_value
&&
!
memcmp
(
value
,
p
,
len
*
sizeof
(
WCHAR
)
)
&&
(
!
p
[
len
]
||
p
[
len
]
==
';'
))
{
found
=
1
;
break
;
}
if
(
!*
q
)
break
;
p
=
++
q
;
}
if
(
found
)
{
DWORD
mod_size
;
int
multiplier
=
0
;
if
(
flags
&
ENV_MOD_APPEND
)
multiplier
++
;
if
(
flags
&
ENV_MOD_PREFIX
)
multiplier
++
;
mod_size
=
lstrlenW
(
value
)
*
multiplier
;
size
+=
mod_size
*
sizeof
(
WCHAR
);
TRACE
(
"string already set
\n
"
);
goto
done
;
}
newval
=
msi_alloc
(
size
);
ptr
=
newval
;
if
(
!
newval
)
size
=
(
len_value
+
1
+
strlenW
(
data
)
+
1
)
*
sizeof
(
WCHAR
);
if
(
!
(
p
=
newval
=
msi_alloc
(
size
)))
{
res
=
ERROR_OUTOFMEMORY
;
goto
done
;
...
...
@@ -7047,21 +7063,24 @@ static UINT ITERATE_WriteEnvironmentString( MSIRECORD *rec, LPVOID param )
if
(
flags
&
ENV_MOD_PREFIX
)
{
lstrcpyW
(
newval
,
value
);
ptr
=
newval
+
lstrlenW
(
value
);
memcpy
(
newval
,
value
,
len_value
*
sizeof
(
WCHAR
)
);
newval
[
len_value
]
=
';'
;
p
=
newval
+
len_value
+
1
;
action
|=
0x80000000
;
}
lstrcpyW
(
ptr
,
data
);
strcpyW
(
p
,
data
);
if
(
flags
&
ENV_MOD_APPEND
)
{
lstrcatW
(
newval
,
value
);
p
+=
strlenW
(
data
);
*
p
++
=
';'
;
memcpy
(
p
,
value
,
(
len_value
+
1
)
*
sizeof
(
WCHAR
)
);
action
|=
0x40000000
;
}
}
TRACE
(
"setting %s to %s
\n
"
,
debugstr_w
(
name
),
debugstr_w
(
newval
));
res
=
RegSetValueExW
(
env
,
name
,
0
,
type
,
(
LPVOID
)
newval
,
size
);
res
=
RegSetValueExW
(
env
,
name
,
0
,
type
,
(
BYTE
*
)
newval
,
size
);
if
(
res
)
{
WARN
(
"Failed to set %s to %s (%d)
\n
"
,
debugstr_w
(
name
),
debugstr_w
(
newval
),
res
);
...
...
dlls/msi/tests/action.c
View file @
ddaba7a3
...
...
@@ -218,7 +218,8 @@ static const char environment_dat[] =
"Var23
\t
+-MSITESTVAR19
\t
1
\t
One
\n
"
"Var24
\t
+-MSITESTVAR19
\t
[~]2
\t
One
\n
"
"Var25
\t
+-MSITESTVAR20
\t
1
\t
One
\n
"
"Var26
\t
+-MSITESTVAR20
\t
2[~]
\t
One
\n
"
;
"Var26
\t
+-MSITESTVAR20
\t
2[~]
\t
One
\n
"
"Var27
\t
+-MSITESTVAR21
\t
[~];1
\t
One
\n
"
;
static
const
char
service_install_dat
[]
=
"ServiceInstall
\t
Name
\t
DisplayName
\t
ServiceType
\t
StartType
\t
ErrorControl
\t
"
...
...
@@ -5145,6 +5146,7 @@ static void test_envvar(void)
"1;;2;;"
,
/* MSITESTVAR18 */
"1"
,
/* MSITESTVAR19 */
"1"
,
/* MSITESTVAR20 */
"1"
,
/* MSITESTVAR21 */
NULL
};
UINT
r
;
...
...
@@ -5172,6 +5174,9 @@ static void test_envvar(void)
res
=
RegSetValueExA
(
env
,
"MSITESTVAR2"
,
0
,
REG_SZ
,
(
const
BYTE
*
)
"0"
,
2
);
ok
(
res
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %d
\n
"
,
res
);
res
=
RegSetValueExA
(
env
,
"MSITESTVAR21"
,
0
,
REG_SZ
,
(
const
BYTE
*
)
"1"
,
2
);
ok
(
res
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %d
\n
"
,
res
);
MsiSetInternalUI
(
INSTALLUILEVEL_NONE
,
NULL
);
r
=
MsiInstallProductA
(
msifile
,
NULL
);
...
...
@@ -5264,6 +5269,7 @@ static void test_envvar(void)
error:
RegDeleteValueA
(
env
,
"MSITESTVAR1"
);
RegDeleteValueA
(
env
,
"MSITESTVAR2"
);
RegDeleteValueA
(
env
,
"MSITESTVAR21"
);
RegCloseKey
(
env
);
delete_test_files
();
...
...
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