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
06afeec2
Commit
06afeec2
authored
Jul 22, 2010
by
Hans Leidekker
Committed by
Alexandre Julliard
Jul 22, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msi: Make sure properties are updated after applying a patch.
parent
1bf5e12e
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
73 additions
and
24 deletions
+73
-24
action.c
dlls/msi/action.c
+3
-0
msipriv.h
dlls/msi/msipriv.h
+1
-0
package.c
dlls/msi/package.c
+56
-23
patch.c
dlls/msi/tests/patch.c
+13
-1
No files found.
dlls/msi/action.c
View file @
06afeec2
...
@@ -7536,6 +7536,9 @@ UINT MSI_InstallPackage( MSIPACKAGE *package, LPCWSTR szPackagePath,
...
@@ -7536,6 +7536,9 @@ UINT MSI_InstallPackage( MSIPACKAGE *package, LPCWSTR szPackagePath,
/* properties may have been added by a transform */
/* properties may have been added by a transform */
msi_clone_properties
(
package
);
msi_clone_properties
(
package
);
msi_parse_command_line
(
package
,
szCommandLine
,
FALSE
);
msi_adjust_allusers_property
(
package
);
msi_set_context
(
package
);
msi_set_context
(
package
);
if
(
needs_ui_sequence
(
package
))
if
(
needs_ui_sequence
(
package
))
...
...
dlls/msi/msipriv.h
View file @
06afeec2
...
@@ -765,6 +765,7 @@ extern UINT msi_package_add_info(MSIPACKAGE *, DWORD, DWORD, LPCWSTR, LPWSTR);
...
@@ -765,6 +765,7 @@ extern UINT msi_package_add_info(MSIPACKAGE *, DWORD, DWORD, LPCWSTR, LPWSTR);
extern
UINT
msi_package_add_media_disk
(
MSIPACKAGE
*
,
DWORD
,
DWORD
,
DWORD
,
LPWSTR
,
LPWSTR
);
extern
UINT
msi_package_add_media_disk
(
MSIPACKAGE
*
,
DWORD
,
DWORD
,
DWORD
,
LPWSTR
,
LPWSTR
);
extern
UINT
msi_clone_properties
(
MSIPACKAGE
*
);
extern
UINT
msi_clone_properties
(
MSIPACKAGE
*
);
extern
UINT
msi_set_context
(
MSIPACKAGE
*
);
extern
UINT
msi_set_context
(
MSIPACKAGE
*
);
extern
void
msi_adjust_allusers_property
(
MSIPACKAGE
*
);
extern
UINT
MSI_GetFeatureCost
(
MSIPACKAGE
*
,
MSIFEATURE
*
,
MSICOSTTREE
,
INSTALLSTATE
,
LPINT
);
extern
UINT
MSI_GetFeatureCost
(
MSIPACKAGE
*
,
MSIFEATURE
*
,
MSICOSTTREE
,
INSTALLSTATE
,
LPINT
);
/* for deformating */
/* for deformating */
...
...
dlls/msi/package.c
View file @
06afeec2
...
@@ -324,57 +324,85 @@ static UINT create_temp_property_table(MSIPACKAGE *package)
...
@@ -324,57 +324,85 @@ static UINT create_temp_property_table(MSIPACKAGE *package)
UINT
msi_clone_properties
(
MSIPACKAGE
*
package
)
UINT
msi_clone_properties
(
MSIPACKAGE
*
package
)
{
{
MSIQUERY
*
view
=
NULL
;
MSIQUERY
*
view
_select
=
NULL
;
UINT
rc
;
UINT
rc
;
static
const
WCHAR
Query
[]
=
{
static
const
WCHAR
query_select
[]
=
{
'S'
,
'E'
,
'L'
,
'E'
,
'C'
,
'T'
,
' '
,
'*'
,
' '
,
'S'
,
'E'
,
'L'
,
'E'
,
'C'
,
'T'
,
' '
,
'*'
,
' '
,
'F'
,
'R'
,
'O'
,
'M'
,
' '
,
'`'
,
'P'
,
'r'
,
'o'
,
'p'
,
'e'
,
'r'
,
't'
,
'y'
,
'`'
,
0
};
'F'
,
'R'
,
'O'
,
'M'
,
' '
,
'`'
,
'P'
,
'r'
,
'o'
,
'p'
,
'e'
,
'r'
,
't'
,
'y'
,
'`'
,
0
};
static
const
WCHAR
I
nsert
[]
=
{
static
const
WCHAR
query_i
nsert
[]
=
{
'I'
,
'N'
,
'S'
,
'E'
,
'R'
,
'T'
,
' '
,
'i'
,
'n'
,
't'
,
'o'
,
' '
,
'I'
,
'N'
,
'S'
,
'E'
,
'R'
,
'T'
,
' '
,
'i'
,
'n'
,
't'
,
'o'
,
' '
,
'`'
,
'_'
,
'P'
,
'r'
,
'o'
,
'p'
,
'e'
,
'r'
,
't'
,
'y'
,
'`'
,
' '
,
'`'
,
'_'
,
'P'
,
'r'
,
'o'
,
'p'
,
'e'
,
'r'
,
't'
,
'y'
,
'`'
,
' '
,
'('
,
'`'
,
'_'
,
'P'
,
'r'
,
'o'
,
'p'
,
'e'
,
'r'
,
't'
,
'y'
,
'`'
,
','
,
'('
,
'`'
,
'_'
,
'P'
,
'r'
,
'o'
,
'p'
,
'e'
,
'r'
,
't'
,
'y'
,
'`'
,
','
,
'`'
,
'V'
,
'a'
,
'l'
,
'u'
,
'e'
,
'`'
,
')'
,
' '
,
'`'
,
'V'
,
'a'
,
'l'
,
'u'
,
'e'
,
'`'
,
')'
,
' '
,
'V'
,
'A'
,
'L'
,
'U'
,
'E'
,
'S'
,
' '
,
'('
,
'?'
,
','
,
'?'
,
')'
,
0
};
'V'
,
'A'
,
'L'
,
'U'
,
'E'
,
'S'
,
' '
,
'('
,
'?'
,
','
,
'?'
,
')'
,
0
};
static
const
WCHAR
query_update
[]
=
{
'U'
,
'P'
,
'D'
,
'A'
,
'T'
,
'E'
,
' '
,
'`'
,
'_'
,
'P'
,
'r'
,
'o'
,
'p'
,
'e'
,
'r'
,
't'
,
'y'
,
'`'
,
' '
,
'S'
,
'E'
,
'T'
,
' '
,
'`'
,
'V'
,
'a'
,
'l'
,
'u'
,
'e'
,
'`'
,
' '
,
'='
,
' '
,
'?'
,
' '
,
'W'
,
'H'
,
'E'
,
'R'
,
'E'
,
' '
,
'`'
,
'_'
,
'P'
,
'r'
,
'o'
,
'p'
,
'e'
,
'r'
,
't'
,
'y'
,
'`'
,
' '
,
'='
,
' '
,
'?'
,
0
};
/* clone the existing properties */
rc
=
MSI_DatabaseOpenViewW
(
package
->
db
,
query_select
,
&
view_select
);
rc
=
MSI_DatabaseOpenViewW
(
package
->
db
,
Query
,
&
view
);
if
(
rc
!=
ERROR_SUCCESS
)
if
(
rc
!=
ERROR_SUCCESS
)
return
rc
;
return
rc
;
rc
=
MSI_ViewExecute
(
view
,
0
);
rc
=
MSI_ViewExecute
(
view_select
,
0
);
if
(
rc
!=
ERROR_SUCCESS
)
if
(
rc
!=
ERROR_SUCCESS
)
{
{
MSI_ViewClose
(
view
);
MSI_ViewClose
(
view_select
);
msiobj_release
(
&
view
->
hdr
);
msiobj_release
(
&
view_select
->
hdr
);
return
rc
;
return
rc
;
}
}
while
(
1
)
while
(
1
)
{
{
MSI
RECORD
*
row
;
MSI
QUERY
*
view_insert
,
*
view_update
;
MSI
QUERY
*
view2
;
MSI
RECORD
*
rec_select
;
rc
=
MSI_ViewFetch
(
view
,
&
row
);
rc
=
MSI_ViewFetch
(
view_select
,
&
rec_select
);
if
(
rc
!=
ERROR_SUCCESS
)
if
(
rc
!=
ERROR_SUCCESS
)
break
;
break
;
rc
=
MSI_DatabaseOpenViewW
(
package
->
db
,
Insert
,
&
view2
);
rc
=
MSI_DatabaseOpenViewW
(
package
->
db
,
query_insert
,
&
view_insert
);
if
(
rc
!=
ERROR_SUCCESS
)
if
(
rc
!=
ERROR_SUCCESS
)
{
{
msiobj_release
(
&
row
->
hdr
);
msiobj_release
(
&
rec_select
->
hdr
);
continue
;
continue
;
}
}
MSI_ViewExecute
(
view2
,
row
);
rc
=
MSI_ViewExecute
(
view_insert
,
rec_select
);
MSI_ViewClose
(
view2
);
MSI_ViewClose
(
view_insert
);
msiobj_release
(
&
view2
->
hdr
);
msiobj_release
(
&
view_insert
->
hdr
);
msiobj_release
(
&
row
->
hdr
);
if
(
rc
!=
ERROR_SUCCESS
)
}
{
MSIRECORD
*
rec_update
;
MSI_ViewClose
(
view
);
TRACE
(
"insert failed, trying update
\n
"
);
msiobj_release
(
&
view
->
hdr
);
rc
=
MSI_DatabaseOpenViewW
(
package
->
db
,
query_update
,
&
view_update
);
if
(
rc
!=
ERROR_SUCCESS
)
{
WARN
(
"open view failed %u
\n
"
,
rc
);
msiobj_release
(
&
rec_select
->
hdr
);
continue
;
}
rec_update
=
MSI_CreateRecord
(
2
);
MSI_RecordCopyField
(
rec_select
,
1
,
rec_update
,
2
);
MSI_RecordCopyField
(
rec_select
,
2
,
rec_update
,
1
);
rc
=
MSI_ViewExecute
(
view_update
,
rec_update
);
if
(
rc
!=
ERROR_SUCCESS
)
WARN
(
"update failed %u
\n
"
,
rc
);
MSI_ViewClose
(
view_update
);
msiobj_release
(
&
view_update
->
hdr
);
msiobj_release
(
&
rec_update
->
hdr
);
}
msiobj_release
(
&
rec_select
->
hdr
);
}
MSI_ViewClose
(
view_select
);
msiobj_release
(
&
view_select
->
hdr
);
return
rc
;
return
rc
;
}
}
...
@@ -1014,7 +1042,7 @@ static UINT msi_load_admin_properties(MSIPACKAGE *package)
...
@@ -1014,7 +1042,7 @@ static UINT msi_load_admin_properties(MSIPACKAGE *package)
return
r
;
return
r
;
}
}
static
void
adjust_allusers_property
(
MSIPACKAGE
*
package
)
void
msi_
adjust_allusers_property
(
MSIPACKAGE
*
package
)
{
{
/* FIXME: this should depend on the user's privileges */
/* FIXME: this should depend on the user's privileges */
if
(
msi_get_property_int
(
package
->
db
,
szAllUsers
,
0
)
==
2
)
if
(
msi_get_property_int
(
package
->
db
,
szAllUsers
,
0
)
==
2
)
...
@@ -1046,6 +1074,7 @@ MSIPACKAGE *MSI_CreatePackage( MSIDATABASE *db, LPCWSTR base_url )
...
@@ -1046,6 +1074,7 @@ MSIPACKAGE *MSI_CreatePackage( MSIDATABASE *db, LPCWSTR base_url )
create_temp_property_table
(
package
);
create_temp_property_table
(
package
);
msi_clone_properties
(
package
);
msi_clone_properties
(
package
);
msi_adjust_allusers_property
(
package
);
package
->
ProductCode
=
msi_dup_property
(
package
->
db
,
szProductCode
);
package
->
ProductCode
=
msi_dup_property
(
package
->
db
,
szProductCode
);
package
->
script
=
msi_alloc_zero
(
sizeof
(
MSISCRIPT
)
);
package
->
script
=
msi_alloc_zero
(
sizeof
(
MSISCRIPT
)
);
...
@@ -1065,8 +1094,6 @@ MSIPACKAGE *MSI_CreatePackage( MSIDATABASE *db, LPCWSTR base_url )
...
@@ -1065,8 +1094,6 @@ MSIPACKAGE *MSI_CreatePackage( MSIDATABASE *db, LPCWSTR base_url )
if
(
package
->
WordCount
&
msidbSumInfoSourceTypeAdminImage
)
if
(
package
->
WordCount
&
msidbSumInfoSourceTypeAdminImage
)
msi_load_admin_properties
(
package
);
msi_load_admin_properties
(
package
);
adjust_allusers_property
(
package
);
}
}
return
package
;
return
package
;
...
@@ -1378,6 +1405,12 @@ UINT MSI_OpenPackageW(LPCWSTR szPackage, MSIPACKAGE **pPackage)
...
@@ -1378,6 +1405,12 @@ UINT MSI_OpenPackageW(LPCWSTR szPackage, MSIPACKAGE **pPackage)
index
++
;
index
++
;
}
}
if
(
index
)
{
msi_clone_properties
(
package
);
msi_adjust_allusers_property
(
package
);
}
*
pPackage
=
package
;
*
pPackage
=
package
;
return
ERROR_SUCCESS
;
return
ERROR_SUCCESS
;
}
}
...
...
dlls/msi/tests/patch.c
View file @
06afeec2
...
@@ -681,7 +681,7 @@ static void test_simple_patch( void )
...
@@ -681,7 +681,7 @@ static void test_simple_patch( void )
{
{
UINT
r
;
UINT
r
;
DWORD
size
;
DWORD
size
;
char
path
[
MAX_PATH
],
install_source
[
MAX_PATH
];
char
path
[
MAX_PATH
],
install_source
[
MAX_PATH
]
,
buffer
[
32
]
;
const
char
*
query
;
const
char
*
query
;
MSIHANDLE
hpackage
,
hdb
,
hview
,
hrec
;
MSIHANDLE
hpackage
,
hdb
,
hview
,
hrec
;
...
@@ -753,6 +753,12 @@ static void test_simple_patch( void )
...
@@ -753,6 +753,12 @@ static void test_simple_patch( void )
MsiViewClose
(
hview
);
MsiViewClose
(
hview
);
MsiCloseHandle
(
hview
);
MsiCloseHandle
(
hview
);
buffer
[
0
]
=
0
;
size
=
sizeof
(
buffer
);
r
=
MsiGetProperty
(
hpackage
,
"PATCHNEWSUMMARYSUBJECT"
,
buffer
,
&
size
);
ok
(
r
==
ERROR_SUCCESS
,
"expected ERROR_SUCCESS, got %u
\n
"
,
r
);
ok
(
!
strcmp
(
buffer
,
"Installer Database"
),
"expected
\'
Installer Database
\'
, got
\'
%s
\'\n
"
,
buffer
);
MsiCloseHandle
(
hdb
);
MsiCloseHandle
(
hdb
);
MsiCloseHandle
(
hpackage
);
MsiCloseHandle
(
hpackage
);
...
@@ -805,6 +811,12 @@ static void test_simple_patch( void )
...
@@ -805,6 +811,12 @@ static void test_simple_patch( void )
MsiViewClose
(
hview
);
MsiViewClose
(
hview
);
MsiCloseHandle
(
hview
);
MsiCloseHandle
(
hview
);
buffer
[
0
]
=
0
;
size
=
sizeof
(
buffer
);
r
=
MsiGetProperty
(
hpackage
,
"PATCHNEWSUMMARYSUBJECT"
,
buffer
,
&
size
);
ok
(
r
==
ERROR_SUCCESS
,
"expected ERROR_SUCCESS, got %u
\n
"
,
r
);
ok
(
!
strcmp
(
buffer
,
"Installation Database"
),
"expected
\'
Installation Database
\'
, got
\'
%s
\'\n
"
,
buffer
);
MsiCloseHandle
(
hdb
);
MsiCloseHandle
(
hdb
);
MsiCloseHandle
(
hpackage
);
MsiCloseHandle
(
hpackage
);
...
...
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