This repository has been archived by the owner on Jul 27, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 49
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' into issue-206
- Loading branch information
Showing
18 changed files
with
314 additions
and
97 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,55 +1,222 @@ | ||
########################################################################## | ||
# This is the Cake bootstrapper script for PowerShell. | ||
# This file was downloaded from https://github.com/cake-build/resources | ||
# Feel free to change this file to fit your needs. | ||
########################################################################## | ||
|
||
<# | ||
.SYNOPSIS | ||
This is a Powershell script to bootstrap a Cake build. | ||
.DESCRIPTION | ||
This Powershell script will download NuGet if missing, restore NuGet tools (including Cake) | ||
and execute your Cake build script with the parameters you provide. | ||
.PARAMETER Script | ||
The build script to execute. | ||
.PARAMETER Target | ||
The build script target to run. | ||
.PARAMETER Configuration | ||
The build configuration to use. | ||
.PARAMETER Verbosity | ||
Specifies the amount of information to be displayed. | ||
.PARAMETER ShowDescription | ||
Shows description about tasks. | ||
.PARAMETER DryRun | ||
Performs a dry run. | ||
.PARAMETER Experimental | ||
Uses the nightly builds of the Roslyn script engine. | ||
.PARAMETER Mono | ||
Uses the Mono Compiler rather than the Roslyn script engine. | ||
.PARAMETER SkipToolPackageRestore | ||
Skips restoring of packages. | ||
.PARAMETER ScriptArgs | ||
Remaining arguments are added here. | ||
.LINK | ||
https://cakebuild.net | ||
#> | ||
|
||
[CmdletBinding()] | ||
Param( | ||
[string]$Script = "build.cake", | ||
[string]$Target = "Default", | ||
[ValidateSet("Release", "Debug")] | ||
[string]$Configuration = "Release", | ||
[string]$Target, | ||
[string]$Configuration, | ||
[ValidateSet("Quiet", "Minimal", "Normal", "Verbose", "Diagnostic")] | ||
[string]$Verbosity = "Verbose", | ||
[string]$Verbosity, | ||
[switch]$ShowDescription, | ||
[Alias("WhatIf", "Noop")] | ||
[switch]$DryRun, | ||
[switch]$Experimental, | ||
[switch]$WhatIf | ||
[switch]$Mono, | ||
[switch]$SkipToolPackageRestore, | ||
[Parameter(Position=0,Mandatory=$false,ValueFromRemainingArguments=$true)] | ||
[string[]]$ScriptArgs | ||
) | ||
|
||
[Reflection.Assembly]::LoadWithPartialName("System.Security") | Out-Null | ||
function MD5HashFile([string] $filePath) | ||
{ | ||
if ([string]::IsNullOrEmpty($filePath) -or !(Test-Path $filePath -PathType Leaf)) | ||
{ | ||
return $null | ||
} | ||
|
||
[System.IO.Stream] $file = $null; | ||
[System.Security.Cryptography.MD5] $md5 = $null; | ||
try | ||
{ | ||
$md5 = [System.Security.Cryptography.MD5]::Create() | ||
$file = [System.IO.File]::OpenRead($filePath) | ||
return [System.BitConverter]::ToString($md5.ComputeHash($file)) | ||
} | ||
finally | ||
{ | ||
if ($file -ne $null) | ||
{ | ||
$file.Dispose() | ||
} | ||
} | ||
} | ||
|
||
Write-Host "Preparing to run build script..." | ||
|
||
if(!$PSScriptRoot){ | ||
$PSScriptRoot = Split-Path $MyInvocation.MyCommand.Path -Parent | ||
} | ||
|
||
$TOOLS_DIR = Join-Path $PSScriptRoot "tools" | ||
$ADDINS_DIR = Join-Path $TOOLS_DIR "Addins" | ||
$MODULES_DIR = Join-Path $TOOLS_DIR "Modules" | ||
$NUGET_EXE = Join-Path $TOOLS_DIR "nuget.exe" | ||
$CAKE_EXE = Join-Path $TOOLS_DIR "Cake/Cake.exe" | ||
$NUGET_URL = "https://dist.nuget.org/win-x86-commandline/latest/nuget.exe" | ||
$PACKAGES_CONFIG = Join-Path $TOOLS_DIR "packages.config" | ||
$PACKAGES_CONFIG_MD5 = Join-Path $TOOLS_DIR "packages.config.md5sum" | ||
$ADDINS_PACKAGES_CONFIG = Join-Path $ADDINS_DIR "packages.config" | ||
$MODULES_PACKAGES_CONFIG = Join-Path $MODULES_DIR "packages.config" | ||
|
||
# Should we use experimental build of Roslyn? | ||
$UseExperimental = ""; | ||
if($Experimental.IsPresent) { | ||
$UseExperimental = "-experimental" | ||
# Make sure tools folder exists | ||
if ((Test-Path $PSScriptRoot) -and !(Test-Path $TOOLS_DIR)) { | ||
Write-Verbose -Message "Creating tools directory..." | ||
New-Item -Path $TOOLS_DIR -Type directory | out-null | ||
} | ||
|
||
# Is this a dry run? | ||
$UseDryRun = ""; | ||
if($WhatIf.IsPresent) { | ||
$UseDryRun = "-dryrun" | ||
# Make sure that packages.config exist. | ||
if (!(Test-Path $PACKAGES_CONFIG)) { | ||
Write-Verbose -Message "Downloading packages.config..." | ||
try { (New-Object System.Net.WebClient).DownloadFile("https://cakebuild.net/download/bootstrapper/packages", $PACKAGES_CONFIG) } catch { | ||
Throw "Could not download packages.config." | ||
} | ||
} | ||
|
||
# Try download NuGet.exe if do not exist. | ||
# Try find NuGet.exe in path if not exists | ||
if (!(Test-Path $NUGET_EXE)) { | ||
Invoke-WebRequest -Uri http://nuget.org/nuget.exe -OutFile $NUGET_EXE | ||
Write-Verbose -Message "Trying to find nuget.exe in PATH..." | ||
$existingPaths = $Env:Path -Split ';' | Where-Object { (![string]::IsNullOrEmpty($_)) -and (Test-Path $_ -PathType Container) } | ||
$NUGET_EXE_IN_PATH = Get-ChildItem -Path $existingPaths -Filter "nuget.exe" | Select -First 1 | ||
if ($NUGET_EXE_IN_PATH -ne $null -and (Test-Path $NUGET_EXE_IN_PATH.FullName)) { | ||
Write-Verbose -Message "Found in PATH at $($NUGET_EXE_IN_PATH.FullName)." | ||
$NUGET_EXE = $NUGET_EXE_IN_PATH.FullName | ||
} | ||
} | ||
|
||
# Make sure NuGet exists where we expect it. | ||
# Try download NuGet.exe if not exists | ||
if (!(Test-Path $NUGET_EXE)) { | ||
Throw "Could not find NuGet.exe" | ||
Write-Verbose -Message "Downloading NuGet.exe..." | ||
try { | ||
(New-Object System.Net.WebClient).DownloadFile($NUGET_URL, $NUGET_EXE) | ||
} catch { | ||
Throw "Could not download NuGet.exe." | ||
} | ||
} | ||
|
||
# Restore tools from NuGet. | ||
Push-Location | ||
Set-Location $TOOLS_DIR | ||
Invoke-Expression "$NUGET_EXE install -ExcludeVersion" | ||
Pop-Location | ||
if ($LASTEXITCODE -ne 0) { | ||
exit $LASTEXITCODE | ||
# Save nuget.exe path to environment to be available to child processed | ||
$ENV:NUGET_EXE = $NUGET_EXE | ||
|
||
# Restore tools from NuGet? | ||
if(-Not $SkipToolPackageRestore.IsPresent) { | ||
Push-Location | ||
Set-Location $TOOLS_DIR | ||
|
||
# Check for changes in packages.config and remove installed tools if true. | ||
[string] $md5Hash = MD5HashFile($PACKAGES_CONFIG) | ||
if((!(Test-Path $PACKAGES_CONFIG_MD5)) -Or | ||
($md5Hash -ne (Get-Content $PACKAGES_CONFIG_MD5 ))) { | ||
Write-Verbose -Message "Missing or changed package.config hash..." | ||
Remove-Item * -Recurse -Exclude packages.config,nuget.exe | ||
} | ||
|
||
Write-Verbose -Message "Restoring tools from NuGet..." | ||
$NuGetOutput = Invoke-Expression "&`"$NUGET_EXE`" install -ExcludeVersion -OutputDirectory `"$TOOLS_DIR`"" | ||
|
||
if ($LASTEXITCODE -ne 0) { | ||
Throw "An error occured while restoring NuGet tools." | ||
} | ||
else | ||
{ | ||
$md5Hash | Out-File $PACKAGES_CONFIG_MD5 -Encoding "ASCII" | ||
} | ||
Write-Verbose -Message ($NuGetOutput | out-string) | ||
|
||
Pop-Location | ||
} | ||
|
||
# Restore addins from NuGet | ||
if (Test-Path $ADDINS_PACKAGES_CONFIG) { | ||
Push-Location | ||
Set-Location $ADDINS_DIR | ||
|
||
Write-Verbose -Message "Restoring addins from NuGet..." | ||
$NuGetOutput = Invoke-Expression "&`"$NUGET_EXE`" install -ExcludeVersion -OutputDirectory `"$ADDINS_DIR`"" | ||
|
||
if ($LASTEXITCODE -ne 0) { | ||
Throw "An error occured while restoring NuGet addins." | ||
} | ||
|
||
Write-Verbose -Message ($NuGetOutput | out-string) | ||
|
||
Pop-Location | ||
} | ||
|
||
# Restore modules from NuGet | ||
if (Test-Path $MODULES_PACKAGES_CONFIG) { | ||
Push-Location | ||
Set-Location $MODULES_DIR | ||
|
||
Write-Verbose -Message "Restoring modules from NuGet..." | ||
$NuGetOutput = Invoke-Expression "&`"$NUGET_EXE`" install -ExcludeVersion -OutputDirectory `"$MODULES_DIR`"" | ||
|
||
if ($LASTEXITCODE -ne 0) { | ||
Throw "An error occured while restoring NuGet modules." | ||
} | ||
|
||
Write-Verbose -Message ($NuGetOutput | out-string) | ||
|
||
Pop-Location | ||
} | ||
|
||
# Make sure that Cake has been installed. | ||
if (!(Test-Path $CAKE_EXE)) { | ||
Throw "Could not find Cake.exe" | ||
Throw "Could not find Cake.exe at $CAKE_EXE" | ||
} | ||
|
||
|
||
|
||
# Build Cake arguments | ||
$cakeArguments = @("$Script"); | ||
if ($Target) { $cakeArguments += "-target=$Target" } | ||
if ($Configuration) { $cakeArguments += "-configuration=$Configuration" } | ||
if ($Verbosity) { $cakeArguments += "-verbosity=$Verbosity" } | ||
if ($ShowDescription) { $cakeArguments += "-showdescription" } | ||
if ($DryRun) { $cakeArguments += "-dryrun" } | ||
if ($Experimental) { $cakeArguments += "-experimental" } | ||
if ($Mono) { $cakeArguments += "-mono" } | ||
$cakeArguments += $ScriptArgs | ||
|
||
# Start Cake | ||
Invoke-Expression "$CAKE_EXE `"$Script`" -target=`"$Target`" -configuration=`"$Configuration`" -verbosity=`"$Verbosity`" $UseDryRun $UseExperimental" | ||
Write-Host | ||
exit $LASTEXITCODE | ||
Write-Host "Running build script..." | ||
&$CAKE_EXE $cakeArguments | ||
exit $LASTEXITCODE |
Oops, something went wrong.