From 30577c253a7095184e00a4881c7d05d8a4cb5636 Mon Sep 17 00:00:00 2001 From: James Hawkins Date: Sat, 3 Feb 2007 22:54:42 -0600 Subject: [PATCH] msi: Allow uncompressed files before compressed files in the same media. --- dlls/msi/files.c | 7 ++++- dlls/msi/tests/install.c | 55 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 61 insertions(+), 1 deletion(-) diff --git a/dlls/msi/files.c b/dlls/msi/files.c index a4819fc1d1..9af403f101 100644 --- a/dlls/msi/files.c +++ b/dlls/msi/files.c @@ -64,6 +64,7 @@ struct media_info { LPWSTR cabinet; LPWSTR volume_label; BOOL is_continuous; + BOOL is_extracted; WCHAR source[MAX_PATH]; }; @@ -434,6 +435,9 @@ done: msi_free(cabinet); msi_free(cab_path); + if (ret) + mi->is_extracted = TRUE; + return ret; } @@ -715,7 +719,8 @@ UINT ACTION_InstallFiles(MSIPACKAGE *package) if (file->state != msifs_missing && file->state != msifs_overwrite) continue; - if (file->Sequence > mi->last_sequence || mi->is_continuous) + if (file->Sequence > mi->last_sequence || mi->is_continuous || + (file->IsCompressed && !mi->is_extracted)) { rc = ready_media(package, file, mi); if (rc != ERROR_SUCCESS) diff --git a/dlls/msi/tests/install.c b/dlls/msi/tests/install.c index 1c0fb6adcc..00b7763e2f 100644 --- a/dlls/msi/tests/install.c +++ b/dlls/msi/tests/install.c @@ -202,6 +202,18 @@ static const CHAR co2_media_dat[] = "DiskId\tLastSequence\tDiskPrompt\tCabinet\t "2\t12\t\ttest3.cab\tDISK3\t\n" "3\t2\t\ttest2.cab\tDISK2\t\n"; +static const CHAR mm_file_dat[] = "File\tComponent_\tFileName\tFileSize\tVersion\tLanguage\tAttributes\tSequence\n" + "s72\ts72\tl255\ti4\tS72\tS20\tI2\ti2\n" + "File\tFile\n" + "maximus\tmaximus\tmaximus\t500\t\t\t512\t1\n" + "augustus\taugustus\taugustus\t500\t\t\t512\t2\n" + "caesar\tcaesar\tcaesar\t500\t\t\t16384\t3"; + +static const CHAR mm_media_dat[] = "DiskId\tLastSequence\tDiskPrompt\tCabinet\tVolumeLabel\tSource\n" + "i2\ti4\tL64\tS255\tS32\tS72\n" + "Media\tDiskId\n" + "1\t3\t\ttest1.cab\tDISK1\t\n"; + typedef struct _msi_table { const CHAR *filename; @@ -262,6 +274,18 @@ static const msi_table co2_tables[] = ADD_TABLE(property), }; +static const msi_table mm_tables[] = +{ + ADD_TABLE(cc_component), + ADD_TABLE(directory), + ADD_TABLE(cc_feature), + ADD_TABLE(cc_feature_comp), + ADD_TABLE(mm_file), + ADD_TABLE(install_exec_seq), + ADD_TABLE(mm_media), + ADD_TABLE(property), +}; + /* cabinet definitions */ /* make the max size large so there is only one cab file */ @@ -967,6 +991,36 @@ static void test_caborder(void) DeleteFile(msifile); } +static void test_mixedmedia(void) +{ + UINT r; + + CreateDirectoryA("msitest", NULL); + create_file("msitest\\maximus", 500); + create_file("msitest\\augustus", 500); + create_file("caesar", 500); + + create_database(msifile, mm_tables, sizeof(mm_tables) / sizeof(msi_table)); + + MsiSetInternalUI(INSTALLUILEVEL_NONE, NULL); + + create_cab_file("test1.cab", MEDIA_SIZE, "caesar\0"); + + r = MsiInstallProductA(msifile, NULL); + ok(r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %u\n", r); + ok(delete_pf("msitest\\augustus", TRUE), "File not installed\n"); + ok(delete_pf("msitest\\caesar", TRUE), "File not installed\n"); + ok(delete_pf("msitest\\maximus", TRUE), "File not installed\n"); + ok(delete_pf("msitest", FALSE), "File not installed\n"); + + DeleteFile("maximus"); + DeleteFile("augustus"); + DeleteFile("caesar"); + RemoveDirectory("msitest"); + DeleteFile("test1.cab"); + DeleteFile(msifile); +} + START_TEST(install) { DWORD len; @@ -989,6 +1043,7 @@ START_TEST(install) test_packagecoltypes(); test_continuouscabs(); test_caborder(); + test_mixedmedia(); SetCurrentDirectoryA(prev_path); }