diff options
author | Bob Arnson <bob@firegiant.com> | 2022-01-29 23:44:11 -0500 |
---|---|---|
committer | Bob Arnson <github@bobs.org> | 2022-01-30 13:02:05 -0500 |
commit | 7ce477c6863c74ef0a50d117d8c28b2f19971b42 (patch) | |
tree | b953aae25a04d9ffbf0bd4609055087d96e760dc /src/ext | |
parent | 3c1b81ff55975adffdc76f1a184b0f264bd97cd6 (diff) | |
download | wix-7ce477c6863c74ef0a50d117d8c28b2f19971b42.tar.gz wix-7ce477c6863c74ef0a50d117d8c28b2f19971b42.tar.bz2 wix-7ce477c6863c74ef0a50d117d8c28b2f19971b42.zip |
Add compiler extension to handle platforms.
Custom actions to print EULA and validate install directories are
defined in WixUIExtension compiler extension, to handle
platform-specific custom actions referred to from `DoAction` control
events. This is the least-worst solution, given the `DoAction` approach
used in the WixUI authoring and anyone customizing a WixUI set.
Diffstat (limited to 'src/ext')
19 files changed, 238 insertions, 85 deletions
diff --git a/src/ext/UI/ca/uica.vcxproj b/src/ext/UI/ca/uica.vcxproj index e06b7572..27f0faa7 100644 --- a/src/ext/UI/ca/uica.vcxproj +++ b/src/ext/UI/ca/uica.vcxproj | |||
@@ -11,6 +11,22 @@ | |||
11 | <Configuration>Release</Configuration> | 11 | <Configuration>Release</Configuration> |
12 | <Platform>Win32</Platform> | 12 | <Platform>Win32</Platform> |
13 | </ProjectConfiguration> | 13 | </ProjectConfiguration> |
14 | <ProjectConfiguration Include="Debug|x64"> | ||
15 | <Configuration>Debug</Configuration> | ||
16 | <Platform>x64</Platform> | ||
17 | </ProjectConfiguration> | ||
18 | <ProjectConfiguration Include="Release|x64"> | ||
19 | <Configuration>Release</Configuration> | ||
20 | <Platform>x64</Platform> | ||
21 | </ProjectConfiguration> | ||
22 | <ProjectConfiguration Include="Debug|ARM64"> | ||
23 | <Configuration>Debug</Configuration> | ||
24 | <Platform>ARM64</Platform> | ||
25 | </ProjectConfiguration> | ||
26 | <ProjectConfiguration Include="Release|ARM64"> | ||
27 | <Configuration>Release</Configuration> | ||
28 | <Platform>ARM64</Platform> | ||
29 | </ProjectConfiguration> | ||
14 | </ItemGroup> | 30 | </ItemGroup> |
15 | 31 | ||
16 | <PropertyGroup Label="Globals"> | 32 | <PropertyGroup Label="Globals"> |
diff --git a/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Advanced/Package.wxs b/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Advanced/Package.wxs index 5ce4b00f..c22328e6 100644 --- a/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Advanced/Package.wxs +++ b/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Advanced/Package.wxs | |||
@@ -1,5 +1,5 @@ | |||
1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | 1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:ui="http://wixtoolset.org/schemas/v4/wxs/ui"> |
2 | <Package Name="MsiPackage" Language="1033" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="047730a5-30fe-4a62-a520-da9381b8226a" InstallerVersion="200"> | 2 | <Package Name="MsiPackage" Language="1033" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="047730a5-30fe-4a62-a520-da9381b8226a"> |
3 | <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." /> | 3 | <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." /> |
4 | 4 | ||
5 | <Feature Id="ProductFeature" Title="MsiPackage"> | 5 | <Feature Id="ProductFeature" Title="MsiPackage"> |
@@ -12,7 +12,7 @@ | |||
12 | </Component> | 12 | </Component> |
13 | </ComponentGroup> | 13 | </ComponentGroup> |
14 | 14 | ||
15 | <UIRef Id="WixUI_Advanced" /> | 15 | <ui:WixUI Id="WixUI_Advanced" /> |
16 | <Property Id="ApplicationFolderName" Value="MyProgram" /> | 16 | <Property Id="ApplicationFolderName" Value="MyProgram" /> |
17 | <Property Id="WixAppFolder" Value="WixPerMachineFolder" /> | 17 | <Property Id="WixAppFolder" Value="WixPerMachineFolder" /> |
18 | </Package> | 18 | </Package> |
diff --git a/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_FeatureTree/Package.wxs b/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_FeatureTree/Package.wxs index aff1c077..7c4db223 100644 --- a/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_FeatureTree/Package.wxs +++ b/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_FeatureTree/Package.wxs | |||
@@ -1,4 +1,4 @@ | |||
1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | 1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:ui="http://wixtoolset.org/schemas/v4/wxs/ui"> |
2 | <Package Name="MsiPackage" Language="1033" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="047730a5-30fe-4a62-a520-da9381b8226a" InstallerVersion="200"> | 2 | <Package Name="MsiPackage" Language="1033" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="047730a5-30fe-4a62-a520-da9381b8226a" InstallerVersion="200"> |
3 | <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." /> | 3 | <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." /> |
4 | 4 | ||
@@ -12,7 +12,7 @@ | |||
12 | </Component> | 12 | </Component> |
13 | </ComponentGroup> | 13 | </ComponentGroup> |
14 | 14 | ||
15 | <UIRef Id="WixUI_FeatureTree" /> | 15 | <ui:WixUI Id="WixUI_FeatureTree" /> |
16 | </Package> | 16 | </Package> |
17 | 17 | ||
18 | <Fragment> | 18 | <Fragment> |
diff --git a/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_InstallDir/Package.wxs b/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_InstallDir/Package.wxs index 7c2ceae0..b6f2344a 100644 --- a/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_InstallDir/Package.wxs +++ b/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_InstallDir/Package.wxs | |||
@@ -1,4 +1,4 @@ | |||
1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | 1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:ui="http://wixtoolset.org/schemas/v4/wxs/ui"> |
2 | <Package Name="MsiPackage" Language="1033" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="047730a5-30fe-4a62-a520-da9381b8226a" InstallerVersion="200"> | 2 | <Package Name="MsiPackage" Language="1033" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="047730a5-30fe-4a62-a520-da9381b8226a" InstallerVersion="200"> |
3 | <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." /> | 3 | <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." /> |
4 | 4 | ||
@@ -12,7 +12,7 @@ | |||
12 | </Component> | 12 | </Component> |
13 | </ComponentGroup> | 13 | </ComponentGroup> |
14 | 14 | ||
15 | <UIRef Id="WixUI_InstallDir" /> | 15 | <ui:WixUI Id="WixUI_InstallDir" /> |
16 | </Package> | 16 | </Package> |
17 | 17 | ||
18 | <Fragment> | 18 | <Fragment> |
diff --git a/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Minimal/Package.wxs b/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Minimal/Package.wxs index d2ff256c..962be579 100644 --- a/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Minimal/Package.wxs +++ b/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Minimal/Package.wxs | |||
@@ -1,4 +1,4 @@ | |||
1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | 1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:ui="http://wixtoolset.org/schemas/v4/wxs/ui"> |
2 | <Package Name="MsiPackage" Language="1033" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="047730a5-30fe-4a62-a520-da9381b8226a" InstallerVersion="200"> | 2 | <Package Name="MsiPackage" Language="1033" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="047730a5-30fe-4a62-a520-da9381b8226a" InstallerVersion="200"> |
3 | <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." /> | 3 | <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." /> |
4 | 4 | ||
@@ -12,7 +12,7 @@ | |||
12 | </Component> | 12 | </Component> |
13 | </ComponentGroup> | 13 | </ComponentGroup> |
14 | 14 | ||
15 | <UIRef Id="WixUI_Minimal" /> | 15 | <ui:WixUI Id="WixUI_Minimal" /> |
16 | </Package> | 16 | </Package> |
17 | 17 | ||
18 | <Fragment> | 18 | <Fragment> |
diff --git a/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Mondo/Package.wxs b/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Mondo/Package.wxs index 8d5a856a..9eca9790 100644 --- a/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Mondo/Package.wxs +++ b/src/ext/UI/test/WixToolsetTest.UI/TestData/WixUI_Mondo/Package.wxs | |||
@@ -1,4 +1,4 @@ | |||
1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | 1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:ui="http://wixtoolset.org/schemas/v4/wxs/ui"> |
2 | <Package Name="MsiPackage" Language="1033" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="047730a5-30fe-4a62-a520-da9381b8226a" InstallerVersion="200"> | 2 | <Package Name="MsiPackage" Language="1033" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="047730a5-30fe-4a62-a520-da9381b8226a" InstallerVersion="200"> |
3 | <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." /> | 3 | <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." /> |
4 | 4 | ||
@@ -12,7 +12,7 @@ | |||
12 | </Component> | 12 | </Component> |
13 | </ComponentGroup> | 13 | </ComponentGroup> |
14 | 14 | ||
15 | <UIRef Id="WixUI_Mondo" /> | 15 | <ui:WixUI Id="WixUI_Mondo" /> |
16 | </Package> | 16 | </Package> |
17 | 17 | ||
18 | <Fragment> | 18 | <Fragment> |
diff --git a/src/ext/UI/test/WixToolsetTest.UI/UIExtensionFixture.cs b/src/ext/UI/test/WixToolsetTest.UI/UIExtensionFixture.cs index 778bfb64..4ab7ec3f 100644 --- a/src/ext/UI/test/WixToolsetTest.UI/UIExtensionFixture.cs +++ b/src/ext/UI/test/WixToolsetTest.UI/UIExtensionFixture.cs | |||
@@ -7,8 +7,6 @@ namespace WixToolsetTest.UI | |||
7 | using System.Linq; | 7 | using System.Linq; |
8 | using WixBuildTools.TestSupport; | 8 | using WixBuildTools.TestSupport; |
9 | using WixToolset.Core.TestPackage; | 9 | using WixToolset.Core.TestPackage; |
10 | using WixToolset.Data; | ||
11 | using WixToolset.Data.Symbols; | ||
12 | using WixToolset.Data.WindowsInstaller; | 10 | using WixToolset.Data.WindowsInstaller; |
13 | using WixToolset.UI; | 11 | using WixToolset.UI; |
14 | using Xunit; | 12 | using Xunit; |
@@ -22,11 +20,48 @@ namespace WixToolsetTest.UI | |||
22 | var bindFolder = TestData.Get(@"TestData\data"); | 20 | var bindFolder = TestData.Get(@"TestData\data"); |
23 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); | 21 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); |
24 | 22 | ||
25 | var results = build.BuildAndQuery(Build, "Property"); | 23 | var results = build.BuildAndQuery(Build, "Dialog", "CustomAction"); |
26 | WixAssert.CompareLineByLine(new[] | 24 | Assert.Single(results, result => result.StartsWith("Dialog:AdvancedWelcomeEulaDlg\t")); |
27 | { | 25 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetDefaultPerMachineFolder\t")); |
28 | "Property:WixUI_Mode\tAdvanced", | 26 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetDefaultPerUserFolder\t")); |
29 | }, results.Where(s => s.StartsWith("Property:WixUI_Mode")).ToArray()); | 27 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetPerMachineFolder\t")); |
28 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetPerUserFolder\t")); | ||
29 | Assert.Single(results, result => result.StartsWith("CustomAction:WixUIPrintEula\t65\tWixUiCa_X86\t")); | ||
30 | Assert.Single(results, result => result.StartsWith("CustomAction:WixUIValidatePath\t65\tWixUiCa_X86\t")); | ||
31 | } | ||
32 | |||
33 | [Fact] | ||
34 | public void CanBuildUsingWixUIAdvancedX64() | ||
35 | { | ||
36 | var folder = TestData.Get(@"TestData\WixUI_Advanced"); | ||
37 | var bindFolder = TestData.Get(@"TestData\data"); | ||
38 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); | ||
39 | |||
40 | var results = build.BuildAndQuery(BuildX64, "Dialog", "CustomAction"); | ||
41 | Assert.Single(results, result => result.StartsWith("Dialog:AdvancedWelcomeEulaDlg\t")); | ||
42 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetDefaultPerMachineFolder\t")); | ||
43 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetDefaultPerUserFolder\t")); | ||
44 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetPerMachineFolder\t")); | ||
45 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetPerUserFolder\t")); | ||
46 | Assert.Single(results, result => result.StartsWith("CustomAction:WixUIPrintEula\t65\tWixUiCa_X64\t")); | ||
47 | Assert.Single(results, result => result.StartsWith("CustomAction:WixUIValidatePath\t65\tWixUiCa_X64\t")); | ||
48 | } | ||
49 | |||
50 | [Fact] | ||
51 | public void CanBuildUsingWixUIAdvancedARM64() | ||
52 | { | ||
53 | var folder = TestData.Get(@"TestData\WixUI_Advanced"); | ||
54 | var bindFolder = TestData.Get(@"TestData\data"); | ||
55 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); | ||
56 | |||
57 | var results = build.BuildAndQuery(BuildARM64, "Dialog", "CustomAction"); | ||
58 | Assert.Single(results, result => result.StartsWith("Dialog:AdvancedWelcomeEulaDlg\t")); | ||
59 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetDefaultPerMachineFolder\t")); | ||
60 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetDefaultPerUserFolder\t")); | ||
61 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetPerMachineFolder\t")); | ||
62 | Assert.Single(results, result => result.StartsWith("CustomAction:WixSetPerUserFolder\t")); | ||
63 | Assert.Single(results, result => result.StartsWith("CustomAction:WixUIPrintEula\t65\tWixUiCa_A64\t")); | ||
64 | Assert.Single(results, result => result.StartsWith("CustomAction:WixUIValidatePath\t65\tWixUiCa_A64\t")); | ||
30 | } | 65 | } |
31 | 66 | ||
32 | [Fact] | 67 | [Fact] |
@@ -36,11 +71,10 @@ namespace WixToolsetTest.UI | |||
36 | var bindFolder = TestData.Get(@"TestData\data"); | 71 | var bindFolder = TestData.Get(@"TestData\data"); |
37 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); | 72 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); |
38 | 73 | ||
39 | var results = build.BuildAndQuery(Build, "Property"); | 74 | var results = build.BuildAndQuery(Build, "Dialog", "CustomAction"); |
40 | WixAssert.CompareLineByLine(new[] | 75 | Assert.Single(results, result => result.StartsWith("Dialog:WelcomeDlg\t")); |
41 | { | 76 | Assert.Single(results, result => result.StartsWith("Dialog:CustomizeDlg\t")); |
42 | "Property:WixUI_Mode\tFeatureTree", | 77 | Assert.Empty(results.Where(result => result.StartsWith("Dialog:SetupTypeDlg\t"))); |
43 | }, results.Where(s => s.StartsWith("Property:WixUI_Mode")).ToArray()); | ||
44 | } | 78 | } |
45 | 79 | ||
46 | [Fact] | 80 | [Fact] |
@@ -50,11 +84,8 @@ namespace WixToolsetTest.UI | |||
50 | var bindFolder = TestData.Get(@"TestData\data"); | 84 | var bindFolder = TestData.Get(@"TestData\data"); |
51 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); | 85 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); |
52 | 86 | ||
53 | var results = build.BuildAndQuery(Build, "Property"); | 87 | var results = build.BuildAndQuery(Build, "Dialog", "CustomAction"); |
54 | WixAssert.CompareLineByLine(new[] | 88 | Assert.Single(results, result => result.StartsWith("Dialog:InstallDirDlg\t")); |
55 | { | ||
56 | "Property:WixUI_Mode\tInstallDir", | ||
57 | }, results.Where(s => s.StartsWith("Property:WixUI_Mode")).ToArray()); | ||
58 | } | 89 | } |
59 | 90 | ||
60 | [Fact] | 91 | [Fact] |
@@ -64,11 +95,8 @@ namespace WixToolsetTest.UI | |||
64 | var bindFolder = TestData.Get(@"TestData\data"); | 95 | var bindFolder = TestData.Get(@"TestData\data"); |
65 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); | 96 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); |
66 | 97 | ||
67 | var results = build.BuildAndQuery(Build, "Property"); | 98 | var results = build.BuildAndQuery(Build, "Dialog", "CustomAction"); |
68 | WixAssert.CompareLineByLine(new[] | 99 | Assert.Single(results, result => result.StartsWith("Dialog:WelcomeEulaDlg\t")); |
69 | { | ||
70 | "Property:WixUI_Mode\tMinimal", | ||
71 | }, results.Where(s => s.StartsWith("Property:WixUI_Mode")).ToArray()); | ||
72 | } | 100 | } |
73 | 101 | ||
74 | [Fact] | 102 | [Fact] |
@@ -92,10 +120,8 @@ namespace WixToolsetTest.UI | |||
92 | }); | 120 | }); |
93 | 121 | ||
94 | var wid = WindowsInstallerData.Load(Path.Combine(intermediateFolder, @"bin\test.wixpdb")); | 122 | var wid = WindowsInstallerData.Load(Path.Combine(intermediateFolder, @"bin\test.wixpdb")); |
95 | var propertyTable = wid.Tables["Property"]; | 123 | var dialogTable = wid.Tables["Dialog"]; |
96 | 124 | var dialogRow = dialogTable.Rows.Single(r => r.GetPrimaryKey() == "WelcomeEulaDlg"); | |
97 | var propertyRow = propertyTable.Rows.Single(r => r.GetPrimaryKey() == "WixUI_Mode"); | ||
98 | WixAssert.StringEqual("Minimal", propertyRow.FieldAsString(1)); | ||
99 | } | 125 | } |
100 | } | 126 | } |
101 | 127 | ||
@@ -106,11 +132,10 @@ namespace WixToolsetTest.UI | |||
106 | var bindFolder = TestData.Get(@"TestData\data"); | 132 | var bindFolder = TestData.Get(@"TestData\data"); |
107 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); | 133 | var build = new Builder(folder, typeof(UIExtensionFactory), new[] { bindFolder }); |
108 | 134 | ||
109 | var results = build.BuildAndQuery(Build, "Property"); | 135 | var results = build.BuildAndQuery(Build, "Dialog", "CustomAction"); |
110 | WixAssert.CompareLineByLine(new[] | 136 | Assert.Single(results, result => result.StartsWith("Dialog:WelcomeDlg\t")); |
111 | { | 137 | Assert.Single(results, result => result.StartsWith("Dialog:CustomizeDlg\t")); |
112 | "Property:WixUI_Mode\tMondo", | 138 | Assert.Single(results, result => result.StartsWith("Dialog:SetupTypeDlg\t")); |
113 | }, results.Where(s => s.StartsWith("Property:WixUI_Mode")).ToArray()); | ||
114 | } | 139 | } |
115 | 140 | ||
116 | [Fact] | 141 | [Fact] |
@@ -133,6 +158,18 @@ namespace WixToolsetTest.UI | |||
133 | .AssertSuccess(); | 158 | .AssertSuccess(); |
134 | } | 159 | } |
135 | 160 | ||
161 | private static void BuildX64(string[] args) | ||
162 | { | ||
163 | var result = WixRunner.Execute(args.Concat(new[] { "-arch", "x64" }).ToArray()) | ||
164 | .AssertSuccess(); | ||
165 | } | ||
166 | |||
167 | private static void BuildARM64(string[] args) | ||
168 | { | ||
169 | var result = WixRunner.Execute(args.Concat(new[] { "-arch", "arm64" }).ToArray()) | ||
170 | .AssertSuccess(); | ||
171 | } | ||
172 | |||
136 | private static void BuildInGerman(string[] args) | 173 | private static void BuildInGerman(string[] args) |
137 | { | 174 | { |
138 | var localizedArgs = args.Append("-culture").Append("de-DE").ToArray(); | 175 | var localizedArgs = args.Append("-culture").Append("de-DE").ToArray(); |
diff --git a/src/ext/UI/wixext/UICompiler.cs b/src/ext/UI/wixext/UICompiler.cs new file mode 100644 index 00000000..46b856c0 --- /dev/null +++ b/src/ext/UI/wixext/UICompiler.cs | |||
@@ -0,0 +1,118 @@ | |||
1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | ||
2 | |||
3 | namespace WixToolset.UI | ||
4 | { | ||
5 | using System; | ||
6 | using System.Collections.Generic; | ||
7 | using System.Xml.Linq; | ||
8 | using WixToolset.Data; | ||
9 | using WixToolset.Data.Symbols; | ||
10 | using WixToolset.Extensibility; | ||
11 | |||
12 | /// <summary> | ||
13 | /// The decompiler for the WiX Toolset UI Extension. | ||
14 | /// </summary> | ||
15 | public sealed class UICompiler : BaseCompilerExtension | ||
16 | { | ||
17 | public override XNamespace Namespace => "http://wixtoolset.org/schemas/v4/wxs/ui"; | ||
18 | |||
19 | /// <summary> | ||
20 | /// Processes an element for the Compiler. | ||
21 | /// </summary> | ||
22 | /// <param name="sourceLineNumbers">Source line number for the parent element.</param> | ||
23 | /// <param name="parentElement">Parent element of element to process.</param> | ||
24 | /// <param name="element">Element to process.</param> | ||
25 | /// <param name="contextValues">Extra information about the context in which this element is being parsed.</param> | ||
26 | public override void ParseElement(Intermediate intermediate, IntermediateSection section, XElement parentElement, XElement element, IDictionary<string, string> context) | ||
27 | { | ||
28 | switch (parentElement.Name.LocalName) | ||
29 | { | ||
30 | case "Fragment": | ||
31 | case "Module": | ||
32 | case "PatchFamily": | ||
33 | case "Package": | ||
34 | case "UI": | ||
35 | switch (element.Name.LocalName) | ||
36 | { | ||
37 | case "WixUI": | ||
38 | this.ParseWixUIElement(intermediate, section, element); | ||
39 | break; | ||
40 | default: | ||
41 | this.ParseHelper.UnexpectedElement(parentElement, element); | ||
42 | break; | ||
43 | } | ||
44 | break; | ||
45 | default: | ||
46 | this.ParseHelper.UnexpectedElement(parentElement, element); | ||
47 | break; | ||
48 | } | ||
49 | } | ||
50 | |||
51 | /// <summary> | ||
52 | /// Parses a WixUI element. | ||
53 | /// </summary> | ||
54 | private void ParseWixUIElement(Intermediate intermediate, IntermediateSection section, XElement element) | ||
55 | { | ||
56 | var sourceLineNumbers = this.ParseHelper.GetSourceLineNumbers(element); | ||
57 | string id = null; | ||
58 | |||
59 | foreach (var attrib in element.Attributes()) | ||
60 | { | ||
61 | if (String.IsNullOrEmpty(attrib.Name.NamespaceName) || this.Namespace == attrib.Name.Namespace) | ||
62 | { | ||
63 | switch (attrib.Name.LocalName) | ||
64 | { | ||
65 | case "Id": | ||
66 | id = this.ParseHelper.GetAttributeIdentifierValue(sourceLineNumbers, attrib); | ||
67 | break; | ||
68 | default: | ||
69 | this.ParseHelper.UnexpectedAttribute(element, attrib); | ||
70 | break; | ||
71 | } | ||
72 | } | ||
73 | else | ||
74 | { | ||
75 | this.ParseHelper.ParseExtensionAttribute(this.Context.Extensions, intermediate, section, element, attrib); | ||
76 | } | ||
77 | } | ||
78 | |||
79 | if (null == id) | ||
80 | { | ||
81 | this.Messaging.Write(ErrorMessages.ExpectedAttribute(sourceLineNumbers, element.Name.LocalName, "Id")); | ||
82 | } | ||
83 | else | ||
84 | { | ||
85 | this.ParseHelper.CreateSimpleReference(section, sourceLineNumbers, SymbolDefinitions.WixUI, id); | ||
86 | |||
87 | // Because these custom actions are "scheduled" via `DoAction` control events, we have to create the | ||
88 | // custom action definitions here, so the `DoAction` references are static and the targets are | ||
89 | // dynamically created to properly reflect the platform-specific DLL and avoid having duplicate ids | ||
90 | // in the UI .wixlib. | ||
91 | var platform = this.Context.Platform == Platform.ARM64 ? "A64" : this.Context.Platform.ToString(); | ||
92 | var source = $"WixUiCa_{platform}"; | ||
93 | |||
94 | section.AddSymbol(new CustomActionSymbol(sourceLineNumbers, new Identifier(AccessModifier.Global, "WixUIPrintEula")) | ||
95 | { | ||
96 | TargetType = CustomActionTargetType.Dll, | ||
97 | Target = "PrintEula", | ||
98 | SourceType = CustomActionSourceType.Binary, | ||
99 | Source = source, | ||
100 | IgnoreResult = true, | ||
101 | ExecutionType = CustomActionExecutionType.Immediate, | ||
102 | }); | ||
103 | |||
104 | section.AddSymbol(new CustomActionSymbol(sourceLineNumbers, new Identifier(AccessModifier.Global, "WixUIValidatePath")) | ||
105 | { | ||
106 | TargetType = CustomActionTargetType.Dll, | ||
107 | Target = "ValidatePath", | ||
108 | SourceType = CustomActionSourceType.Binary, | ||
109 | Source = source, | ||
110 | IgnoreResult = true, | ||
111 | ExecutionType = CustomActionExecutionType.Immediate, | ||
112 | }); | ||
113 | } | ||
114 | |||
115 | this.ParseHelper.ParseForExtensionElements(this.Context.Extensions, intermediate, section, element); | ||
116 | } | ||
117 | } | ||
118 | } | ||
diff --git a/src/ext/UI/wixext/UIExtensionFactory.cs b/src/ext/UI/wixext/UIExtensionFactory.cs index 141aa39f..a16a9899 100644 --- a/src/ext/UI/wixext/UIExtensionFactory.cs +++ b/src/ext/UI/wixext/UIExtensionFactory.cs | |||
@@ -11,6 +11,7 @@ namespace WixToolset.UI | |||
11 | protected override IReadOnlyCollection<Type> ExtensionTypes => new[] | 11 | protected override IReadOnlyCollection<Type> ExtensionTypes => new[] |
12 | { | 12 | { |
13 | typeof(UIExtensionData), | 13 | typeof(UIExtensionData), |
14 | typeof(UICompiler), | ||
14 | }; | 15 | }; |
15 | } | 16 | } |
16 | } | 17 | } |
diff --git a/src/ext/UI/wixlib/Common_Platform.wxi b/src/ext/UI/wixlib/Common_Platform.wxi index ffaa7114..0c03629c 100644 --- a/src/ext/UI/wixlib/Common_Platform.wxi +++ b/src/ext/UI/wixlib/Common_Platform.wxi | |||
@@ -2,18 +2,15 @@ | |||
2 | 2 | ||
3 | 3 | ||
4 | <Include xmlns="http://wixtoolset.org/schemas/v4/wxs"> | 4 | <Include xmlns="http://wixtoolset.org/schemas/v4/wxs"> |
5 | <?include caSuffix.wxi ?> | 5 | <?include ..\..\caDecor.wxi ?> |
6 | <Fragment> | ||
7 | <!-- print EULA functionality --> | ||
8 | <CustomAction Id="WixUIPrintEula$(var.Suffix)" DllEntry="PrintEula" Return="ignore" Execute="immediate" BinaryRef="WixUIWixca$(var.Suffix)" /> | ||
9 | </Fragment> | ||
10 | 6 | ||
11 | <Fragment> | 7 | <!-- |
12 | <!-- Validate install directory --> | 8 | Custom actions to print EULA amd validate install directories are defined |
13 | <CustomAction Id="WixUIValidatePath$(var.Suffix)" DllEntry="ValidatePath" Return="ignore" Execute="immediate" BinaryRef="WixUIWixca$(var.Suffix)" /> | 9 | in WixUIExtension compiler extension, to handle platform-specific custom |
14 | </Fragment> | 10 | actions referred to from `DoAction` control events. |
11 | --> | ||
15 | 12 | ||
16 | <Fragment> | 13 | <Fragment> |
17 | <Binary Id="WixUIWixca$(var.Suffix)" SourceFile="!(bindpath.$(var.platform))uica.dll" /> | 14 | <Binary Id="WixUiCa$(var.Suffix)" SourceFile="!(bindpath.$(var.platform))uica.dll" /> |
18 | </Fragment> | 15 | </Fragment> |
19 | </Include> | 16 | </Include> |
diff --git a/src/ext/UI/wixlib/Common_arm64.wxs b/src/ext/UI/wixlib/Common_arm64.wxs new file mode 100644 index 00000000..61dd5ddd --- /dev/null +++ b/src/ext/UI/wixlib/Common_arm64.wxs | |||
@@ -0,0 +1,7 @@ | |||
1 | <!-- Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. --> | ||
2 | |||
3 | |||
4 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | ||
5 | <?define platform=arm64 ?> | ||
6 | <?include Common_Platform.wxi ?> | ||
7 | </Wix> | ||
diff --git a/src/ext/UI/wixlib/Common_x64.wxs b/src/ext/UI/wixlib/Common_x64.wxs new file mode 100644 index 00000000..89204605 --- /dev/null +++ b/src/ext/UI/wixlib/Common_x64.wxs | |||
@@ -0,0 +1,7 @@ | |||
1 | <!-- Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. --> | ||
2 | |||
3 | |||
4 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | ||
5 | <?define platform=x64 ?> | ||
6 | <?include Common_Platform.wxi ?> | ||
7 | </Wix> | ||
diff --git a/src/ext/UI/wixlib/WixUI_Advanced.wxs b/src/ext/UI/wixlib/WixUI_Advanced.wxs index 7d1f4df0..2ea7a97d 100644 --- a/src/ext/UI/wixlib/WixUI_Advanced.wxs +++ b/src/ext/UI/wixlib/WixUI_Advanced.wxs | |||
@@ -53,7 +53,6 @@ Todo: | |||
53 | <TextStyle Id="WixUI_Font_Emphasized" FaceName="!(loc.Advanced_Font_FaceName)" Size="!(loc.Advanced_Font_Emphasized_Size)" Bold="yes" /> | 53 | <TextStyle Id="WixUI_Font_Emphasized" FaceName="!(loc.Advanced_Font_FaceName)" Size="!(loc.Advanced_Font_Emphasized_Size)" Bold="yes" /> |
54 | 54 | ||
55 | <Property Id="DefaultUIFont" Value="WixUI_Font_Normal" /> | 55 | <Property Id="DefaultUIFont" Value="WixUI_Font_Normal" /> |
56 | <Property Id="WixUI_Mode" Value="Advanced" /> | ||
57 | 56 | ||
58 | <DialogRef Id="BrowseDlg" /> | 57 | <DialogRef Id="BrowseDlg" /> |
59 | <DialogRef Id="DiskCostDlg" /> | 58 | <DialogRef Id="DiskCostDlg" /> |
diff --git a/src/ext/UI/wixlib/WixUI_FeatureTree.wxs b/src/ext/UI/wixlib/WixUI_FeatureTree.wxs index e999f2fe..6f36bdb8 100644 --- a/src/ext/UI/wixlib/WixUI_FeatureTree.wxs +++ b/src/ext/UI/wixlib/WixUI_FeatureTree.wxs | |||
@@ -29,7 +29,6 @@ Patch dialog sequence: | |||
29 | <TextStyle Id="WixUI_Font_Title" FaceName="Tahoma" Size="9" Bold="yes" /> | 29 | <TextStyle Id="WixUI_Font_Title" FaceName="Tahoma" Size="9" Bold="yes" /> |
30 | 30 | ||
31 | <Property Id="DefaultUIFont" Value="WixUI_Font_Normal" /> | 31 | <Property Id="DefaultUIFont" Value="WixUI_Font_Normal" /> |
32 | <Property Id="WixUI_Mode" Value="FeatureTree" /> | ||
33 | 32 | ||
34 | <DialogRef Id="ErrorDlg" /> | 33 | <DialogRef Id="ErrorDlg" /> |
35 | <DialogRef Id="FatalError" /> | 34 | <DialogRef Id="FatalError" /> |
diff --git a/src/ext/UI/wixlib/WixUI_InstallDir.wxs b/src/ext/UI/wixlib/WixUI_InstallDir.wxs index afe7820f..f8eb3b11 100644 --- a/src/ext/UI/wixlib/WixUI_InstallDir.wxs +++ b/src/ext/UI/wixlib/WixUI_InstallDir.wxs | |||
@@ -30,7 +30,6 @@ Patch dialog sequence: | |||
30 | <TextStyle Id="WixUI_Font_Title" FaceName="Tahoma" Size="9" Bold="yes" /> | 30 | <TextStyle Id="WixUI_Font_Title" FaceName="Tahoma" Size="9" Bold="yes" /> |
31 | 31 | ||
32 | <Property Id="DefaultUIFont" Value="WixUI_Font_Normal" /> | 32 | <Property Id="DefaultUIFont" Value="WixUI_Font_Normal" /> |
33 | <Property Id="WixUI_Mode" Value="InstallDir" /> | ||
34 | 33 | ||
35 | <DialogRef Id="BrowseDlg" /> | 34 | <DialogRef Id="BrowseDlg" /> |
36 | <DialogRef Id="DiskCostDlg" /> | 35 | <DialogRef Id="DiskCostDlg" /> |
diff --git a/src/ext/UI/wixlib/WixUI_Minimal.wxs b/src/ext/UI/wixlib/WixUI_Minimal.wxs index 08dba96d..8ac9751f 100644 --- a/src/ext/UI/wixlib/WixUI_Minimal.wxs +++ b/src/ext/UI/wixlib/WixUI_Minimal.wxs | |||
@@ -24,7 +24,6 @@ Patch dialog sequence: | |||
24 | <TextStyle Id="WixUI_Font_Title" FaceName="Tahoma" Size="9" Bold="yes" /> | 24 | <TextStyle Id="WixUI_Font_Title" FaceName="Tahoma" Size="9" Bold="yes" /> |
25 | 25 | ||
26 | <Property Id="DefaultUIFont" Value="WixUI_Font_Normal" /> | 26 | <Property Id="DefaultUIFont" Value="WixUI_Font_Normal" /> |
27 | <Property Id="WixUI_Mode" Value="Minimal" /> | ||
28 | 27 | ||
29 | <DialogRef Id="ErrorDlg" /> | 28 | <DialogRef Id="ErrorDlg" /> |
30 | <DialogRef Id="FatalError" /> | 29 | <DialogRef Id="FatalError" /> |
diff --git a/src/ext/UI/wixlib/WixUI_Mondo.wxs b/src/ext/UI/wixlib/WixUI_Mondo.wxs index 2d53b9dd..6a4b15b1 100644 --- a/src/ext/UI/wixlib/WixUI_Mondo.wxs +++ b/src/ext/UI/wixlib/WixUI_Mondo.wxs | |||
@@ -31,7 +31,6 @@ Patch dialog sequence: | |||
31 | <TextStyle Id="WixUI_Font_Title" FaceName="Tahoma" Size="9" Bold="yes" /> | 31 | <TextStyle Id="WixUI_Font_Title" FaceName="Tahoma" Size="9" Bold="yes" /> |
32 | 32 | ||
33 | <Property Id="DefaultUIFont" Value="WixUI_Font_Normal" /> | 33 | <Property Id="DefaultUIFont" Value="WixUI_Font_Normal" /> |
34 | <Property Id="WixUI_Mode" Value="Mondo" /> | ||
35 | 34 | ||
36 | <DialogRef Id="ErrorDlg" /> | 35 | <DialogRef Id="ErrorDlg" /> |
37 | <DialogRef Id="FatalError" /> | 36 | <DialogRef Id="FatalError" /> |
diff --git a/src/ext/UI/wixlib/caSuffix.wxi b/src/ext/UI/wixlib/caSuffix.wxi deleted file mode 100644 index 18436269..00000000 --- a/src/ext/UI/wixlib/caSuffix.wxi +++ /dev/null | |||
@@ -1,27 +0,0 @@ | |||
1 | <!-- Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. --> | ||
2 | |||
3 | <Include xmlns="http://wixtoolset.org/schemas/v4/wxs"> | ||
4 | <?ifndef platform ?> | ||
5 | <?error Required value "platform" not defined in include caSuffix.wxi ?> | ||
6 | <?endif?> | ||
7 | |||
8 | <?ifdef Suffix ?> | ||
9 | <?undef Suffix ?> | ||
10 | <?undef DeferredSuffix ?> | ||
11 | <?endif?> | ||
12 | |||
13 | <?if $(var.platform)="x86" ?> | ||
14 | <?define Suffix="" ?> | ||
15 | <?define DeferredSuffix="" ?> | ||
16 | <?endif?> | ||
17 | |||
18 | <?if $(var.platform)="x64" ?> | ||
19 | <?define Suffix="_x64" ?> | ||
20 | <?define DeferredSuffix="_64" ?> | ||
21 | <?endif?> | ||
22 | |||
23 | <?if $(var.platform)="arm" ?> | ||
24 | <?define Suffix="_ARM" ?> | ||
25 | <?define DeferredSuffix="_ARM" ?> | ||
26 | <?endif?> | ||
27 | </Include> | ||
diff --git a/src/ext/UI/wixlib/ui.wixproj b/src/ext/UI/wixlib/ui.wixproj index 2b335f01..ead77af4 100644 --- a/src/ext/UI/wixlib/ui.wixproj +++ b/src/ext/UI/wixlib/ui.wixproj | |||
@@ -27,7 +27,9 @@ | |||
27 | </ItemGroup> | 27 | </ItemGroup> |
28 | 28 | ||
29 | <ItemGroup> | 29 | <ItemGroup> |
30 | <ProjectReference Include="..\ca\uica.vcxproj" Properties="Platform=x86" ReferenceOutputAssembly="false" /> | 30 | <ProjectReference Include="..\ca\uica.vcxproj" Properties="Platform=x86" /> |
31 | <ProjectReference Include="..\ca\uica.vcxproj" Properties="Platform=x64" /> | ||
32 | <ProjectReference Include="..\ca\uica.vcxproj" Properties="Platform=ARM64" /> | ||
31 | </ItemGroup> | 33 | </ItemGroup> |
32 | 34 | ||
33 | <ItemGroup> | 35 | <ItemGroup> |