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
98eafa87
Commit
98eafa87
authored
Apr 15, 2007
by
James Hawkins
Committed by
Alexandre Julliard
Apr 16, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msi: Add handling for the concurrent install custom action.
parent
6da8041d
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
102 additions
and
7 deletions
+102
-7
custom.c
dlls/msi/custom.c
+98
-0
install.c
dlls/msi/tests/install.c
+4
-7
No files found.
dlls/msi/custom.c
View file @
98eafa87
...
...
@@ -54,6 +54,8 @@ static UINT HANDLE_CustomType18(MSIPACKAGE *package, LPCWSTR source,
LPCWSTR
target
,
const
INT
type
,
LPCWSTR
action
);
static
UINT
HANDLE_CustomType19
(
MSIPACKAGE
*
package
,
LPCWSTR
source
,
LPCWSTR
target
,
const
INT
type
,
LPCWSTR
action
);
static
UINT
HANDLE_CustomType23
(
MSIPACKAGE
*
package
,
LPCWSTR
source
,
LPCWSTR
target
,
const
INT
type
,
LPCWSTR
action
);
static
UINT
HANDLE_CustomType50
(
MSIPACKAGE
*
package
,
LPCWSTR
source
,
LPCWSTR
target
,
const
INT
type
,
LPCWSTR
action
);
static
UINT
HANDLE_CustomType34
(
MSIPACKAGE
*
package
,
LPCWSTR
source
,
...
...
@@ -250,6 +252,10 @@ UINT ACTION_CustomAction(MSIPACKAGE *package,LPCWSTR action, BOOL execute)
case
17
:
rc
=
HANDLE_CustomType17
(
package
,
source
,
target
,
type
,
action
);
break
;
case
23
:
/* installs another package in the source tree */
deformat_string
(
package
,
target
,
&
deformated
);
rc
=
HANDLE_CustomType23
(
package
,
source
,
deformated
,
type
,
action
);
break
;
case
50
:
/*EXE file specified by a property value */
rc
=
HANDLE_CustomType50
(
package
,
source
,
target
,
type
,
action
);
break
;
...
...
@@ -548,6 +554,41 @@ static DWORD WINAPI DllThread( LPVOID arg )
return
rc
;
}
static
DWORD
WINAPI
ACTION_CAInstallPackage
(
const
GUID
*
guid
)
{
msi_custom_action_info
*
info
;
UINT
r
=
ERROR_FUNCTION_FAILED
;
INSTALLUILEVEL
old_level
;
info
=
find_action_by_guid
(
guid
);
if
(
!
info
)
{
ERR
(
"failed to find action %s
\n
"
,
debugstr_guid
(
guid
));
return
r
;
}
old_level
=
MsiSetInternalUI
(
INSTALLUILEVEL_BASIC
,
NULL
);
r
=
MsiInstallProductW
(
info
->
source
,
info
->
target
);
MsiSetInternalUI
(
old_level
,
NULL
);
return
r
;
}
static
DWORD
WINAPI
ConcurrentInstallThread
(
LPVOID
arg
)
{
LPGUID
guid
=
arg
;
DWORD
rc
;
TRACE
(
"concurrent installation (%x) started
\n
"
,
GetCurrentThreadId
());
rc
=
ACTION_CAInstallPackage
(
guid
);
TRACE
(
"concurrent installation (%x) returned %i
\n
"
,
GetCurrentThreadId
(),
rc
);
MsiCloseAllHandles
();
return
rc
;
}
static
msi_custom_action_info
*
do_msidbCustomActionTypeDll
(
MSIPACKAGE
*
package
,
INT
type
,
LPCWSTR
source
,
LPCWSTR
target
,
LPCWSTR
action
)
{
...
...
@@ -579,6 +620,63 @@ static msi_custom_action_info *do_msidbCustomActionTypeDll(
return
info
;
}
static
msi_custom_action_info
*
do_msidbCAConcurrentInstall
(
MSIPACKAGE
*
package
,
INT
type
,
LPCWSTR
source
,
LPCWSTR
target
,
LPCWSTR
action
)
{
msi_custom_action_info
*
info
;
info
=
msi_alloc
(
sizeof
*
info
);
if
(
!
info
)
return
NULL
;
msiobj_addref
(
&
package
->
hdr
);
info
->
package
=
package
;
info
->
type
=
type
;
info
->
target
=
strdupW
(
target
);
info
->
source
=
strdupW
(
source
);
info
->
action
=
strdupW
(
action
);
CoCreateGuid
(
&
info
->
guid
);
EnterCriticalSection
(
&
msi_custom_action_cs
);
list_add_tail
(
&
msi_pending_custom_actions
,
&
info
->
entry
);
LeaveCriticalSection
(
&
msi_custom_action_cs
);
info
->
handle
=
CreateThread
(
NULL
,
0
,
ConcurrentInstallThread
,
&
info
->
guid
,
0
,
NULL
);
if
(
!
info
->
handle
)
{
free_custom_action_data
(
info
);
return
NULL
;
}
return
info
;
}
static
UINT
HANDLE_CustomType23
(
MSIPACKAGE
*
package
,
LPCWSTR
source
,
LPCWSTR
target
,
const
INT
type
,
LPCWSTR
action
)
{
msi_custom_action_info
*
info
;
WCHAR
package_path
[
MAX_PATH
];
DWORD
size
;
static
const
WCHAR
backslash
[]
=
{
'\\'
,
0
};
MSI_GetPropertyW
(
package
,
cszSourceDir
,
package_path
,
&
size
);
lstrcatW
(
package_path
,
backslash
);
lstrcatW
(
package_path
,
source
);
if
(
GetFileAttributesW
(
package_path
)
==
INVALID_FILE_ATTRIBUTES
)
{
ERR
(
"Source package does not exist: %s
\n
"
,
debugstr_w
(
package_path
));
return
ERROR_FUNCTION_FAILED
;
}
TRACE
(
"Installing package %s concurrently
\n
"
,
debugstr_w
(
package_path
));
info
=
do_msidbCAConcurrentInstall
(
package
,
type
,
package_path
,
target
,
action
);
return
wait_thread_handle
(
info
);
}
static
UINT
HANDLE_CustomType1
(
MSIPACKAGE
*
package
,
LPCWSTR
source
,
LPCWSTR
target
,
const
INT
type
,
LPCWSTR
action
)
{
...
...
dlls/msi/tests/install.c
View file @
98eafa87
...
...
@@ -1417,13 +1417,10 @@ static void test_concurrentinstall(void)
MsiSetInternalUI
(
INSTALLUILEVEL_FULL
,
NULL
);
r
=
MsiInstallProductA
(
msifile
,
NULL
);
todo_wine
{
ok
(
r
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %u
\n
"
,
r
);
ok
(
delete_pf
(
"msitest
\\
maximus"
,
TRUE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
augustus"
,
TRUE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest"
,
FALSE
),
"File not installed
\n
"
);
}
ok
(
r
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %u
\n
"
,
r
);
ok
(
delete_pf
(
"msitest
\\
maximus"
,
TRUE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
augustus"
,
TRUE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest"
,
FALSE
),
"File not installed
\n
"
);
DeleteFile
(
msifile
);
}
...
...
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