-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathBuild-Toolkit-Gallery.ps1
186 lines (139 loc) · 5.79 KB
/
Build-Toolkit-Gallery.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
<#
.SYNOPSIS
Builds the Toolkit Gallery with specified parameters. Primarily used by maintainers for local testing.
.DESCRIPTION
The Build-Toolkit-Gallery function is used to build the Community Toolkit Gallery app with customizable parameters. It allows you to specify the MultiTarget TFM, include heads, enable binlogs, additional msbuild properties, pick the components to build, and exclude specific components.
.PARAMETER MultiTargets
Specifies the MultiTarget TFM(s) to include for building the components. The default value is 'all'.
.PARAMETER ExcludeMultiTargets
Specifies the MultiTarget TFM(s) to exclude for building the components. The default value excludes targets that require additional tooling or workloads to build: 'wpf', 'linuxgtk', 'macos', 'ios', and 'android'. Run uno-check to install the required workloads.
.PARAMETER Heads
The heads to include in the build. Default is 'Uwp', 'Wasdk', 'Wasm'.
.PARAMETER ExcludeHeads
The heads to exclude from the build. Default is none.
.PARAMETER Components
The names of the components to build. Defaults to all components.
.PARAMETER ExcludeComponents
The names of the components to exclude from the build. Defaults to none.
.PARAMETER BinlogOutput
Specifies the output directory for binlogs. This parameter is optional, default is the current directory.
.PARAMETER EnableBinLogs
Enables the generation of binlogs by appending '/bl' to the msbuild command. Generated binlogs will match the csproj name. This parameter is optional. Use BinlogOutput to specify the output directory.
.PARAMETER WinUIMajorVersion
Specifies the WinUI major version to use when building an Uno head. Also decides the package id and dependency variant. The default value is '2'.
.PARAMETER AdditionalProperties
Additional msbuild properties to pass.
.PARAMETER Release
Specifies whether to build in Release configuration. Default is false.
.PARAMETER Verbose
Specifies whether to enable detailed msbuild verbosity. Default is false.
.NOTES
Author: Arlo Godfrey
Date: 2/19/2024
#>
Param (
[ValidateSet('all', 'wasm', 'uwp', 'wasdk', 'wpf', 'linuxgtk', 'macos', 'ios', 'android', 'netstandard')]
[Alias("mt")]
[string[]]$MultiTargets = @('uwp', 'wasdk', 'wasm'), # default settings
[ValidateSet('wasm', 'uwp', 'wasdk', 'wpf', 'linuxgtk', 'macos', 'ios', 'android', 'netstandard')]
[string[]]$ExcludeMultiTargets = @(), # default settings
[ValidateSet('all', 'Uwp', 'Wasdk', 'Wasm', 'Tests.Uwp', 'Tests.Wasdk')]
[string[]]$Heads = @('Uwp', 'Wasdk', 'Wasm'),
[ValidateSet('Uwp', 'Wasdk', 'Wasm', 'Tests.Uwp', 'Tests.Wasdk')]
[string[]]$ExcludeHeads,
[Alias("bl")]
[switch]$EnableBinLogs,
[Alias("blo")]
[string]$BinlogOutput,
[Alias("p")]
[hashtable]$AdditionalProperties,
[Alias("winui")]
[int]$WinUIMajorVersion = 2,
[Alias("c")]
[string[]]$Components = @("all"),
[string[]]$ExcludeComponents,
[switch]$Release,
[Alias("v")]
[switch]$Verbose
)
if ($null -eq $ExcludeMultiTargets)
{
$ExcludeMultiTargets = @()
}
# Both uwp and wasdk share a targetframework. Both cannot be enabled at once.
# If both are supplied, remove one based on WinUIMajorVersion.
if ($MultiTargets.Contains('uwp') -and $MultiTargets.Contains('wasdk'))
{
if ($WinUIMajorVersion -eq 2)
{
$ExcludeMultiTargets = $ExcludeMultiTargets + 'wasdk'
}
else
{
$ExcludeMultiTargets = $ExcludeMultiTargets + 'uwp'
}
}
if ($MultiTargets -eq 'all') {
$MultiTargets = @('wasm', 'uwp', 'wasdk', 'wpf', 'linuxgtk', 'macos', 'ios', 'android', 'netstandard')
}
if ($ExcludeMultiTargets) {
$MultiTargets = $MultiTargets | Where-Object { $_ -notin $ExcludeMultiTargets }
}
if ($ExcludeComponents) {
$Components = $Components | Where-Object { $_ -notin $ExcludeComponents }
}
# Certain ProjectReferences should always be generated (are required to build gallery) if csproj is available.
if ($Components -notcontains 'SettingsControls') {
$Components += 'SettingsControls'
}
if ($Components -notcontains 'Converters') {
$Components += 'Converters'
}
# Use the specified MultiTarget TFM and WinUI version
& $PSScriptRoot\MultiTarget\UseTargetFrameworks.ps1 $MultiTargets
& $PSScriptRoot\MultiTarget\UseUnoWinUI.ps1 $WinUIMajorVersion
# Generate gallery references to components
# Components built are selected via references from gallery head.
& $PSScriptRoot\MultiTarget\GenerateAllProjectReferences.ps1 -MultiTarget $MultiTargets -Components $Components
if ($Heads -eq 'all') {
$Heads = @('Uwp', 'Wasdk', 'Wasm', 'Tests.Uwp', 'Tests.Wasdk')
}
function Invoke-MSBuildWithBinlog {
param (
[string]$TargetHeadPath
)
# Reset build args to default
$msbuildArgs = @("-r", "-m", "-t:Clean,Build")
# Add additional properties to the msbuild arguments
if ($AdditionalProperties) {
foreach ($property in $AdditionalProperties.GetEnumerator()) {
$msbuildArgs += "/p:$($property.Name)=$($property.Value)"
}
}
# Handle binlog options
if ($EnableBinLogs) {
# Get binlog filename and output path
$csprojFileName = [System.IO.Path]::GetFileNameWithoutExtension($TargetHeadPath)
$defaultBinlogFilename = "$csprojFileName.msbuild.binlog"
$finalBinlogPath = $defaultBinlogFilename;
# Set default binlog output location if not provided
if ($BinlogOutput) {
$finalBinlogPath = "$BinlogOutput/$defaultBinlogFilename"
}
$msbuildArgs += "/bl:$finalBinlogPath"
}
if ($Release) {
$msbuildArgs += "/p:Configuration=Release"
}
if ($Verbose) {
$msbuildArgs += "/verbosity:detailed"
}
msbuild $msbuildArgs $TargetHeadPath
}
foreach ($head in $Heads) {
if ($ExcludeHeads -and $head -in $ExcludeHeads) {
continue
}
$targetHeadPath = Get-ChildItem "$PSScriptRoot/ProjectHeads/AllComponents/$head/*.csproj"
Invoke-MSBuildWithBinlog $targetHeadPath $EnableBinLogs $BinlogOutput
}