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
f80b5f6e
Commit
f80b5f6e
authored
Oct 16, 2008
by
James Hawkins
Committed by
Alexandre Julliard
Oct 17, 2008
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msi: All files are uncompressed in an administrative image.
parent
d318813a
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
90 additions
and
6 deletions
+90
-6
action.c
dlls/msi/action.c
+6
-2
install.c
dlls/msi/tests/install.c
+84
-4
No files found.
dlls/msi/action.c
View file @
f80b5f6e
...
...
@@ -1481,8 +1481,12 @@ static UINT load_file(MSIRECORD *row, LPVOID param)
/* if the compressed bits are not set in the file attributes,
* then read the information from the package word count property
*/
if
(
file
->
Attributes
&
(
msidbFileAttributesCompressed
|
msidbFileAttributesPatchAdded
))
if
(
package
->
WordCount
&
msidbSumInfoSourceTypeAdminImage
)
{
file
->
IsCompressed
=
FALSE
;
}
else
if
(
file
->
Attributes
&
(
msidbFileAttributesCompressed
|
msidbFileAttributesPatchAdded
))
{
file
->
IsCompressed
=
TRUE
;
}
...
...
dlls/msi/tests/install.c
View file @
f80b5f6e
...
...
@@ -768,6 +768,17 @@ static const CHAR mcomp_file_dat[] = "File\tComponent_\tFileName\tFileSize\tVers
"lithium
\t
lithium
\t
lithium
\t
0
\t\t\t
8192
\t
1
\n
"
"beryllium
\t
missingcomp
\t
beryllium
\t
0
\t\t\t
8192
\t
1"
;
static
const
CHAR
ai_file_dat
[]
=
"File
\t
Component_
\t
FileName
\t
FileSize
\t
Version
\t
Language
\t
Attributes
\t
Sequence
\n
"
"s72
\t
s72
\t
l255
\t
i4
\t
S72
\t
S20
\t
I2
\t
i2
\n
"
"File
\t
File
\n
"
"five.txt
\t
Five
\t
five.txt
\t
1000
\t\t\t
16384
\t
5
\n
"
"four.txt
\t
Four
\t
four.txt
\t
1000
\t\t\t
16384
\t
4
\n
"
"one.txt
\t
One
\t
one.txt
\t
1000
\t\t\t
16384
\t
1
\n
"
"three.txt
\t
Three
\t
three.txt
\t
1000
\t\t\t
16384
\t
3
\n
"
"two.txt
\t
Two
\t
two.txt
\t
1000
\t\t\t
16384
\t
2
\n
"
"file
\t
component
\t
filename
\t
100
\t\t\t
8192
\t
1
\n
"
"service_file
\t
service_comp
\t
service.exe
\t
100
\t\t\t
8192
\t
1"
;
typedef
struct
_msi_table
{
const
CHAR
*
filename
;
...
...
@@ -1166,6 +1177,18 @@ static const msi_table mcomp_tables[] =
ADD_TABLE
(
property
),
};
static
const
msi_table
ai_tables
[]
=
{
ADD_TABLE
(
component
),
ADD_TABLE
(
directory
),
ADD_TABLE
(
feature
),
ADD_TABLE
(
feature_comp
),
ADD_TABLE
(
ai_file
),
ADD_TABLE
(
install_exec_seq
),
ADD_TABLE
(
media
),
ADD_TABLE
(
property
)
};
/* cabinet definitions */
/* make the max size large so there is only one cab file */
...
...
@@ -1552,7 +1575,7 @@ static void write_file(const CHAR *filename, const char *data, int data_size)
CloseHandle
(
hf
);
}
static
void
write_msi_summary_info
(
MSIHANDLE
db
)
static
void
write_msi_summary_info
(
MSIHANDLE
db
,
INT
wordcount
)
{
MSIHANDLE
summary
;
UINT
r
;
...
...
@@ -1570,7 +1593,7 @@ static void write_msi_summary_info(MSIHANDLE db)
r
=
MsiSummaryInfoSetPropertyA
(
summary
,
PID_PAGECOUNT
,
VT_I4
,
100
,
NULL
,
NULL
);
ok
(
r
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %u
\n
"
,
r
);
r
=
MsiSummaryInfoSetPropertyA
(
summary
,
PID_WORDCOUNT
,
VT_I4
,
0
,
NULL
,
NULL
);
r
=
MsiSummaryInfoSetPropertyA
(
summary
,
PID_WORDCOUNT
,
VT_I4
,
wordcount
,
NULL
,
NULL
);
ok
(
r
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %u
\n
"
,
r
);
r
=
MsiSummaryInfoSetPropertyA
(
summary
,
PID_TITLE
,
VT_LPSTR
,
0
,
NULL
,
"MSITEST"
);
...
...
@@ -1583,7 +1606,11 @@ static void write_msi_summary_info(MSIHANDLE db)
MsiCloseHandle
(
summary
);
}
static
void
create_database
(
const
CHAR
*
name
,
const
msi_table
*
tables
,
int
num_tables
)
#define create_database(name, tables, num_tables) \
create_database_wordcount(name, tables, num_tables, 0);
static
void
create_database_wordcount
(
const
CHAR
*
name
,
const
msi_table
*
tables
,
int
num_tables
,
INT
wordcount
)
{
MSIHANDLE
db
;
UINT
r
;
...
...
@@ -1605,7 +1632,7 @@ static void create_database(const CHAR *name, const msi_table *tables, int num_t
DeleteFileA
(
table
->
filename
);
}
write_msi_summary_info
(
db
);
write_msi_summary_info
(
db
,
wordcount
);
r
=
MsiDatabaseCommit
(
db
);
ok
(
r
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %u
\n
"
,
r
);
...
...
@@ -5474,6 +5501,58 @@ static void test_sourcedirprop(void)
RemoveDirectory
(
"altsource"
);
}
static
void
test_adminimage
(
void
)
{
UINT
r
;
CreateDirectoryA
(
"msitest"
,
NULL
);
CreateDirectoryA
(
"msitest
\\
first"
,
NULL
);
CreateDirectoryA
(
"msitest
\\
second"
,
NULL
);
CreateDirectoryA
(
"msitest
\\
cabout"
,
NULL
);
CreateDirectoryA
(
"msitest
\\
cabout
\\
new"
,
NULL
);
create_file
(
"msitest
\\
one.txt"
,
100
);
create_file
(
"msitest
\\
first
\\
two.txt"
,
100
);
create_file
(
"msitest
\\
second
\\
three.txt"
,
100
);
create_file
(
"msitest
\\
cabout
\\
four.txt"
,
100
);
create_file
(
"msitest
\\
cabout
\\
new
\\
five.txt"
,
100
);
create_file
(
"msitest
\\
filename"
,
100
);
create_file
(
"msitest
\\
service.exe"
,
100
);
create_database_wordcount
(
msifile
,
ai_tables
,
sizeof
(
ai_tables
)
/
sizeof
(
msi_table
),
msidbSumInfoSourceTypeAdminImage
);
r
=
MsiInstallProductA
(
msifile
,
NULL
);
ok
(
r
==
ERROR_SUCCESS
,
"Expected ERROR_SUCCESS, got %u
\n
"
,
r
);
ok
(
delete_pf
(
"msitest
\\
cabout
\\
new
\\
five.txt"
,
TRUE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
cabout
\\
new"
,
FALSE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
cabout
\\
four.txt"
,
TRUE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
cabout"
,
FALSE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
changed
\\
three.txt"
,
TRUE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
changed"
,
FALSE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
first
\\
two.txt"
,
TRUE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
first"
,
FALSE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
one.txt"
,
TRUE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
filename"
,
TRUE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest
\\
service.exe"
,
TRUE
),
"File not installed
\n
"
);
ok
(
delete_pf
(
"msitest"
,
FALSE
),
"File not installed
\n
"
);
DeleteFileA
(
"msitest.msi"
);
DeleteFileA
(
"msitest
\\
cabout
\\
new
\\
five.txt"
);
DeleteFileA
(
"msitest
\\
cabout
\\
four.txt"
);
DeleteFileA
(
"msitest
\\
second
\\
three.txt"
);
DeleteFileA
(
"msitest
\\
first
\\
two.txt"
);
DeleteFileA
(
"msitest
\\
one.txt"
);
DeleteFileA
(
"msitest
\\
service.exe"
);
DeleteFileA
(
"msitest
\\
filename"
);
RemoveDirectoryA
(
"msitest
\\
cabout
\\
new"
);
RemoveDirectoryA
(
"msitest
\\
cabout"
);
RemoveDirectoryA
(
"msitest
\\
second"
);
RemoveDirectoryA
(
"msitest
\\
first"
);
RemoveDirectoryA
(
"msitest"
);
}
START_TEST
(
install
)
{
DWORD
len
;
...
...
@@ -5545,6 +5624,7 @@ START_TEST(install)
test_MsiConfigureProductEx
();
test_missingcomponent
();
test_sourcedirprop
();
test_adminimage
();
DeleteFileA
(
"msitest.log"
);
...
...
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