Add build scripts and fix errors on win/osx
This commit is contained in:
Родитель
638fbcd9dd
Коммит
faadac793a
|
@ -54,7 +54,6 @@
|
|||
<None Include="license.txt" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<PackageReference Include="System.Drawing.Common" Version="4.5.0" />
|
||||
<PackageReference Include="Avalonia" Version="0.6.2-build5873-beta" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
|
|
|
@ -17,47 +17,65 @@ namespace Avalonia
|
|||
|
||||
public static class SystemColors
|
||||
{
|
||||
public static IBrush ControlTextBrush { get; } = System.Drawing.SystemBrushes.ControlText.ToAvaloniaBrush();
|
||||
public static IBrush ControlDarkBrush { get; } = System.Drawing.SystemBrushes.ControlDark.ToAvaloniaBrush();
|
||||
public static IBrush HighlightBrush { get; } = System.Drawing.SystemBrushes.HighlightText.ToAvaloniaBrush();
|
||||
public static IBrush HighlightTextBrush { get; } = System.Drawing.SystemBrushes.HighlightText.ToAvaloniaBrush();
|
||||
public static IBrush WindowTextBrush { get; } = System.Drawing.SystemBrushes.WindowText.ToAvaloniaBrush();
|
||||
public static IBrush WindowBrush { get; } = System.Drawing.SystemBrushes.Window.ToAvaloniaBrush();
|
||||
public static IBrush GrayTextBrush { get; } = System.Drawing.SystemBrushes.GrayText.ToAvaloniaBrush();
|
||||
public static IBrush InfoTextBrush { get; } = System.Drawing.SystemBrushes.InfoText.ToAvaloniaBrush();
|
||||
public static IBrush InfoBrush { get; } = System.Drawing.SystemBrushes.Info.ToAvaloniaBrush();
|
||||
public static IBrush InactiveCaptionBrush { get; } = System.Drawing.SystemBrushes.InactiveCaption.ToAvaloniaBrush();
|
||||
public static IBrush InactiveCaptionTextBrush { get; } = System.Drawing.SystemBrushes.InactiveCaptionText.ToAvaloniaBrush();
|
||||
public static IBrush ControlTextBrush {get;} = new ImmutableSolidColorBrush(Color.FromUInt32(0xFF000000));
|
||||
public static IBrush ControlDarkBrush {get;} = new ImmutableSolidColorBrush(Color.FromUInt32(0xFFA0A0A0));
|
||||
public static IBrush HighlightBrush {get;} = new ImmutableSolidColorBrush(Color.FromUInt32(0xFFFFFFFF));
|
||||
public static IBrush HighlightTextBrush {get;} = new ImmutableSolidColorBrush(Color.FromUInt32(0xFFFFFFFF));
|
||||
public static IBrush WindowTextBrush {get;} = new ImmutableSolidColorBrush(Color.FromUInt32(0xFF000000));
|
||||
public static IBrush WindowBrush {get;} = new ImmutableSolidColorBrush(Color.FromUInt32(0xFFFFFFFF));
|
||||
public static IBrush GrayTextBrush {get;} = new ImmutableSolidColorBrush(Color.FromUInt32(0xFF6D6D6D));
|
||||
public static IBrush InfoTextBrush {get;} = new ImmutableSolidColorBrush(Color.FromUInt32(0xFF000000));
|
||||
public static IBrush InfoBrush {get;} = new ImmutableSolidColorBrush(Color.FromUInt32(0xFFFFFFE1));
|
||||
public static IBrush InactiveCaptionBrush {get;} = new ImmutableSolidColorBrush(Color.FromUInt32(0xFFBFCDDB));
|
||||
public static IBrush InactiveCaptionTextBrush {get;} = new ImmutableSolidColorBrush(Color.FromUInt32(0xFF000000));
|
||||
public static Color ControlLightColor {get;} = Color.FromUInt32(0xFFE3E3E3);
|
||||
public static Color ControlLightLightColor {get;} = Color.FromUInt32(0xFFFFFFFF);
|
||||
public static Color ControlDarkColor {get;} = Color.FromUInt32(0xFFA0A0A0);
|
||||
public static Color ControlDarkDarkColor {get;} = Color.FromUInt32(0xFF696969);
|
||||
public static Color HighlightColor {get;} = Color.FromUInt32(0xFF3399FF);
|
||||
|
||||
|
||||
public static Color ControlLightColor { get; } = System.Drawing.SystemColors.ControlLight.ToAvaloniaColor();
|
||||
public static Color ControlLightLightColor { get; } = System.Drawing.SystemColors.ControlLightLight.ToAvaloniaColor();
|
||||
public static Color ControlDarkColor { get; } = System.Drawing.SystemColors.ControlDark.ToAvaloniaColor();
|
||||
public static Color ControlDarkDarkColor { get; } = System.Drawing.SystemColors.ControlDarkDark.ToAvaloniaColor();
|
||||
public static Color HighlightColor { get; } = System.Drawing.SystemColors.Highlight.ToAvaloniaColor();
|
||||
// /// <summary>
|
||||
// /// pull out values from system.drawing
|
||||
// /// </summary>
|
||||
// /// <returns></returns>
|
||||
// public static string[] GetColors()
|
||||
// {
|
||||
// string ToString(object obj)
|
||||
// {
|
||||
// if(obj is ISolidColorBrush b)
|
||||
// {
|
||||
// return $"new ImmutableSolidColorBrush(Color.FromUInt32(0x{b.Color.ToUint32().ToString("X")}));;
|
||||
// }
|
||||
// else if(obj is Color c)
|
||||
// return $"Color.FromUInt32(0x{c.ToUint32().ToString("X")});;
|
||||
// else
|
||||
// return obj.ToString();
|
||||
// }
|
||||
// return Array.ConvertAll(typeof(SystemColors).GetProperties(), p => string.Format("{0} \{get;\} = {1}", p.Name, ToString(p.GetValue(null))));
|
||||
// }
|
||||
|
||||
public static Color ToAvaloniaColor(this System.Drawing.Color color)
|
||||
{
|
||||
return new Color(color.A, color.R, color.G, color.B);
|
||||
}
|
||||
|
||||
public static IBrush ToAvaloniaBrush(this System.Drawing.Brush brush)
|
||||
{
|
||||
if (brush is System.Drawing.SolidBrush solidbrush) {
|
||||
return new ImmutableSolidColorBrush(solidbrush.Color.ToAvaloniaColor());
|
||||
}
|
||||
else if(brush is System.Drawing.TextureBrush textureBrush) {
|
||||
using (var imageStream = new MemoryStream()) {
|
||||
var image = textureBrush.Image;
|
||||
image.Save(imageStream, System.Drawing.Imaging.ImageFormat.Bmp);
|
||||
//public static IBrush ToAvaloniaBrush(this System.Drawing.Brush brush)
|
||||
//{
|
||||
// if (brush is System.Drawing.SolidBrush solidbrush) {
|
||||
// return new ImmutableSolidColorBrush(solidbrush.Color.ToAvaloniaColor());
|
||||
// }
|
||||
// else if(brush is System.Drawing.TextureBrush textureBrush) {
|
||||
// using (var imageStream = new MemoryStream()) {
|
||||
// var image = textureBrush.Image;
|
||||
// image.Save(imageStream, System.Drawing.Imaging.ImageFormat.Bmp);
|
||||
|
||||
var avaloniaBitmap = new Bitmap(imageStream);
|
||||
return new ImageBrush(avaloniaBitmap);
|
||||
}
|
||||
// var avaloniaBitmap = new Bitmap(imageStream);
|
||||
// return new ImageBrush(avaloniaBitmap);
|
||||
// }
|
||||
|
||||
} else {
|
||||
throw new NotSupportedException();
|
||||
}
|
||||
}
|
||||
// } else {
|
||||
// throw new NotSupportedException();
|
||||
// }
|
||||
//}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
|
||||
<PropertyGroup>
|
||||
<OutputType>Exe</OutputType>
|
||||
<TargetFrameworks>netcoreapp2.1</TargetFrameworks>
|
||||
<TargetFramework>netcoreapp2.1</TargetFramework>
|
||||
|
||||
<TieredCompilations>true</TieredCompilations>
|
||||
<TargetLatestRuntimePatch>true</TargetLatestRuntimePatch>
|
||||
|
|
|
@ -1,21 +1,27 @@
|
|||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using System.Reflection;
|
||||
using Avalonia;
|
||||
using Avalonia.Logging.Serilog;
|
||||
|
||||
namespace AvaloniaILSpy
|
||||
{
|
||||
class Program
|
||||
{
|
||||
static void Main(string[] args)
|
||||
{
|
||||
AppBuilder.Configure<App>()
|
||||
.UsePlatformDetect()
|
||||
.LogToDebug()
|
||||
.Start<MainWindow>();
|
||||
}
|
||||
}
|
||||
class Program
|
||||
{
|
||||
static void Main(string[] args)
|
||||
{
|
||||
Directory.SetCurrentDirectory(Path.GetDirectoryName(Assembly.GetEntryAssembly().Location));
|
||||
|
||||
AppBuilder.Configure<App>()
|
||||
.UsePlatformDetect()
|
||||
#if DEBUG
|
||||
.LogToDebug()
|
||||
#endif
|
||||
.Start<MainWindow>();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -836,7 +836,7 @@ namespace AvaloniaILSpy.TextView
|
|||
throw ex;
|
||||
#else
|
||||
} catch (Exception ex) {
|
||||
tcs.SetException(ex);
|
||||
throw ex;
|
||||
#endif
|
||||
}
|
||||
});
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
# AvaloniaILSpy [![PayPal donate button](https://img.shields.io/badge/donate-paypal-blue.svg)](https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=HYERRCR8C7876&lc=US&item_name=AvaloniaILSpy&no_note=0¤cy_code=USD&bn=PP-DonationsBF:btn_donate_SM.gif:NonHosted)
|
||||
# AvaloniaILSpy [![appveyor](https://ci.appveyor.com/api/projects/status/github/jeffreye/AvaloniaILSpy?svg=true)](https://ci.appveyor.com/project/jeffreye/avaloniailspy) [![PayPal donate button](https://img.shields.io/badge/donate-paypal-blue.svg)](https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=HYERRCR8C7876&lc=US&item_name=AvaloniaILSpy&no_note=0¤cy_code=USD&bn=PP-DonationsBF:btn_donate_SM.gif:NonHosted)
|
||||
|
||||
This is a port of [ILSpy](https://github.com/icsharpcode/ILSpy)
|
||||
|
||||
|
|
|
@ -0,0 +1,14 @@
|
|||
os: Visual Studio 2017
|
||||
install:
|
||||
|
||||
before_build:
|
||||
- cmd: git submodule update --init --recursive
|
||||
|
||||
build_script:
|
||||
- cmd: dotnet --info
|
||||
- ps: .\build.ps1 -Platform "AnyCPU" -Configuration "Release"
|
||||
|
||||
test: off
|
||||
|
||||
artifacts:
|
||||
- path: artifacts/zips/*.zip
|
|
@ -0,0 +1,97 @@
|
|||
var target = Argument("target", "Default");
|
||||
var platform = Argument("platform", "AnyCPU");
|
||||
var configuration = Argument("configuration", "Release");
|
||||
|
||||
var editbin = @"C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Tools\MSVC\14.10.25017\bin\HostX86\x86\editbin.exe";
|
||||
|
||||
var artifactsDir = (DirectoryPath)Directory("./artifacts");
|
||||
var zipRootDir = artifactsDir.Combine("zips");
|
||||
|
||||
var fileZipSuffix = ".zip";
|
||||
|
||||
var netCoreAppsRoot= ".";
|
||||
var netCoreApp = "AvaloniaILSpy";
|
||||
|
||||
var buildDirs =
|
||||
GetDirectories($"{netCoreAppsRoot}/**/bin/**") +
|
||||
GetDirectories($"{netCoreAppsRoot}/**/obj/**") +
|
||||
GetDirectories($"{netCoreAppsRoot}/artifacts/**/zip/**");
|
||||
|
||||
var netCoreProject = new {
|
||||
Path = $"{netCoreAppsRoot}/{netCoreApp}",
|
||||
Name = netCoreApp,
|
||||
Framework = XmlPeek($"{netCoreAppsRoot}/{netCoreApp}/{netCoreApp}.csproj", "//*[local-name()='TargetFramework']/text()"),
|
||||
Runtimes = XmlPeek($"{netCoreAppsRoot}/{netCoreApp}/{netCoreApp}.csproj", "//*[local-name()='RuntimeIdentifiers']/text()").Split(';')
|
||||
};
|
||||
|
||||
|
||||
Task("Clean")
|
||||
.Does(()=>{
|
||||
CleanDirectories(buildDirs);
|
||||
});
|
||||
|
||||
Task("Restore-NetCore")
|
||||
.IsDependentOn("Clean")
|
||||
.Does(() =>
|
||||
{
|
||||
DotNetCoreRestore(netCoreProject.Path);
|
||||
});
|
||||
|
||||
Task("Build-NetCore")
|
||||
.IsDependentOn("Restore-NetCore")
|
||||
.Does(() =>
|
||||
{
|
||||
Information("Building: {0}", netCoreProject.Name);
|
||||
DotNetCoreBuild(netCoreProject.Path, new DotNetCoreBuildSettings {
|
||||
Configuration = configuration
|
||||
});
|
||||
});
|
||||
|
||||
Task("Publish-NetCore")
|
||||
.IsDependentOn("Restore-NetCore")
|
||||
.Does(() =>
|
||||
{
|
||||
foreach(var runtime in netCoreProject.Runtimes)
|
||||
{
|
||||
var outputDir = artifactsDir.Combine(runtime);
|
||||
|
||||
Information("Publishing: {0}, runtime: {1}", netCoreProject.Name, runtime);
|
||||
DotNetCorePublish(netCoreProject.Path, new DotNetCorePublishSettings {
|
||||
Framework = netCoreProject.Framework,
|
||||
Configuration = configuration,
|
||||
Runtime = runtime,
|
||||
OutputDirectory = outputDir.FullPath
|
||||
});
|
||||
|
||||
if (IsRunningOnWindows() && (runtime == "win7-x86" || runtime == "win7-x64"))
|
||||
{
|
||||
Information("Patching executable subsystem for: {0}, runtime: {1}", netCoreProject.Name, runtime);
|
||||
var targetExe = outputDir.CombineWithFilePath(netCoreProject.Name + ".exe");
|
||||
var exitCodeWithArgument = StartProcess(editbin, new ProcessSettings {
|
||||
Arguments = "/subsystem:windows " + targetExe.FullPath
|
||||
});
|
||||
Information("The editbin command exit code: {0}", exitCodeWithArgument);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
Task("Zip-NetCore")
|
||||
.IsDependentOn("Publish-NetCore")
|
||||
.Does(() =>
|
||||
{
|
||||
EnsureDirectoryExists(zipRootDir);
|
||||
foreach(var runtime in netCoreProject.Runtimes)
|
||||
{
|
||||
var workingDir = artifactsDir.Combine(runtime);
|
||||
Information("Zipping {0} artifacts to {1}", runtime, zipRootDir);
|
||||
Zip(workingDir.FullPath, zipRootDir.CombineWithFilePath(netCoreProject.Name + "-" + runtime + "-" + configuration + fileZipSuffix),
|
||||
GetFiles(workingDir.FullPath + "/*.*"));
|
||||
}
|
||||
});
|
||||
|
||||
Task("Default")
|
||||
.IsDependentOn("Restore-NetCore")
|
||||
.IsDependentOn("Publish-NetCore")
|
||||
.IsDependentOn("Zip-NetCore");
|
||||
|
||||
RunTarget(target);
|
|
@ -0,0 +1,236 @@
|
|||
##########################################################################
|
||||
# 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,
|
||||
[string]$Configuration,
|
||||
[ValidateSet("Quiet", "Minimal", "Normal", "Verbose", "Diagnostic")]
|
||||
[string]$Verbosity,
|
||||
[switch]$ShowDescription,
|
||||
[Alias("WhatIf", "Noop")]
|
||||
[switch]$DryRun,
|
||||
[switch]$Experimental,
|
||||
[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()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function GetProxyEnabledWebClient
|
||||
{
|
||||
$wc = New-Object System.Net.WebClient
|
||||
$proxy = [System.Net.WebRequest]::GetSystemWebProxy()
|
||||
$proxy.Credentials = [System.Net.CredentialCache]::DefaultCredentials
|
||||
$wc.Proxy = $proxy
|
||||
return $wc
|
||||
}
|
||||
|
||||
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"
|
||||
|
||||
# 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
|
||||
}
|
||||
|
||||
# Make sure that packages.config exist.
|
||||
if (!(Test-Path $PACKAGES_CONFIG)) {
|
||||
Write-Verbose -Message "Downloading packages.config..."
|
||||
try {
|
||||
$wc = GetProxyEnabledWebClient
|
||||
$wc.DownloadFile("https://cakebuild.net/download/bootstrapper/packages", $PACKAGES_CONFIG)
|
||||
} catch {
|
||||
Throw "Could not download packages.config."
|
||||
}
|
||||
}
|
||||
|
||||
# Try find NuGet.exe in path if not exists
|
||||
if (!(Test-Path $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
|
||||
}
|
||||
}
|
||||
|
||||
# Try download NuGet.exe if not exists
|
||||
if (!(Test-Path $NUGET_EXE)) {
|
||||
Write-Verbose -Message "Downloading NuGet.exe..."
|
||||
try {
|
||||
$wc = GetProxyEnabledWebClient
|
||||
$wc.DownloadFile($NUGET_URL, $NUGET_EXE)
|
||||
} catch {
|
||||
Throw "Could not download NuGet.exe."
|
||||
}
|
||||
}
|
||||
|
||||
# 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..."
|
||||
Get-ChildItem -Exclude packages.config,nuget.exe,Cake.Bakery |
|
||||
Remove-Item -Recurse
|
||||
}
|
||||
|
||||
Write-Verbose -Message "Restoring tools from NuGet..."
|
||||
$NuGetOutput = Invoke-Expression "&`"$NUGET_EXE`" install -ExcludeVersion -OutputDirectory `"$TOOLS_DIR`""
|
||||
|
||||
if ($LASTEXITCODE -ne 0) {
|
||||
Throw "An error occurred 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 occurred 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 occurred 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 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
|
||||
Write-Host "Running build script..."
|
||||
&$CAKE_EXE $cakeArguments
|
||||
exit $LASTEXITCODE
|
|
@ -0,0 +1,117 @@
|
|||
#!/usr/bin/env bash
|
||||
|
||||
##########################################################################
|
||||
# This is the Cake bootstrapper script for Linux and OS X.
|
||||
# This file was downloaded from https://github.com/cake-build/resources
|
||||
# Feel free to change this file to fit your needs.
|
||||
##########################################################################
|
||||
|
||||
# Define directories.
|
||||
SCRIPT_DIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
|
||||
TOOLS_DIR=$SCRIPT_DIR/tools
|
||||
ADDINS_DIR=$TOOLS_DIR/Addins
|
||||
MODULES_DIR=$TOOLS_DIR/Modules
|
||||
NUGET_EXE=$TOOLS_DIR/nuget.exe
|
||||
CAKE_EXE=$TOOLS_DIR/Cake/Cake.exe
|
||||
PACKAGES_CONFIG=$TOOLS_DIR/packages.config
|
||||
PACKAGES_CONFIG_MD5=$TOOLS_DIR/packages.config.md5sum
|
||||
ADDINS_PACKAGES_CONFIG=$ADDINS_DIR/packages.config
|
||||
MODULES_PACKAGES_CONFIG=$MODULES_DIR/packages.config
|
||||
|
||||
# Define md5sum or md5 depending on Linux/OSX
|
||||
MD5_EXE=
|
||||
if [[ "$(uname -s)" == "Darwin" ]]; then
|
||||
MD5_EXE="md5 -r"
|
||||
else
|
||||
MD5_EXE="md5sum"
|
||||
fi
|
||||
|
||||
# Define default arguments.
|
||||
SCRIPT="build.cake"
|
||||
CAKE_ARGUMENTS=()
|
||||
|
||||
# Parse arguments.
|
||||
for i in "$@"; do
|
||||
case $1 in
|
||||
-s|--script) SCRIPT="$2"; shift ;;
|
||||
--) shift; CAKE_ARGUMENTS+=("$@"); break ;;
|
||||
*) CAKE_ARGUMENTS+=("$1") ;;
|
||||
esac
|
||||
shift
|
||||
done
|
||||
|
||||
# Make sure the tools folder exist.
|
||||
if [ ! -d "$TOOLS_DIR" ]; then
|
||||
mkdir "$TOOLS_DIR"
|
||||
fi
|
||||
|
||||
# Make sure that packages.config exist.
|
||||
if [ ! -f "$TOOLS_DIR/packages.config" ]; then
|
||||
echo "Downloading packages.config..."
|
||||
curl -Lsfo "$TOOLS_DIR/packages.config" https://cakebuild.net/download/bootstrapper/packages
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "An error occurred while downloading packages.config."
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
||||
# Download NuGet if it does not exist.
|
||||
if [ ! -f "$NUGET_EXE" ]; then
|
||||
echo "Downloading NuGet..."
|
||||
curl -Lsfo "$NUGET_EXE" https://dist.nuget.org/win-x86-commandline/latest/nuget.exe
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "An error occurred while downloading nuget.exe."
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
||||
# Restore tools from NuGet.
|
||||
pushd "$TOOLS_DIR" >/dev/null
|
||||
if [ ! -f "$PACKAGES_CONFIG_MD5" ] || [ "$( cat "$PACKAGES_CONFIG_MD5" | sed 's/\r$//' )" != "$( $MD5_EXE "$PACKAGES_CONFIG" | awk '{ print $1 }' )" ]; then
|
||||
find . -type d ! -name . ! -name 'Cake.Bakery' | xargs rm -rf
|
||||
fi
|
||||
|
||||
mono "$NUGET_EXE" install -ExcludeVersion
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Could not restore NuGet tools."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
$MD5_EXE "$PACKAGES_CONFIG" | awk '{ print $1 }' >| "$PACKAGES_CONFIG_MD5"
|
||||
|
||||
popd >/dev/null
|
||||
|
||||
# Restore addins from NuGet.
|
||||
if [ -f "$ADDINS_PACKAGES_CONFIG" ]; then
|
||||
pushd "$ADDINS_DIR" >/dev/null
|
||||
|
||||
mono "$NUGET_EXE" install -ExcludeVersion
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Could not restore NuGet addins."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
popd >/dev/null
|
||||
fi
|
||||
|
||||
# Restore modules from NuGet.
|
||||
if [ -f "$MODULES_PACKAGES_CONFIG" ]; then
|
||||
pushd "$MODULES_DIR" >/dev/null
|
||||
|
||||
mono "$NUGET_EXE" install -ExcludeVersion
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Could not restore NuGet modules."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
popd >/dev/null
|
||||
fi
|
||||
|
||||
# Make sure that Cake has been installed.
|
||||
if [ ! -f "$CAKE_EXE" ]; then
|
||||
echo "Could not find Cake.exe at '$CAKE_EXE'."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Start Cake
|
||||
exec mono "$CAKE_EXE" $SCRIPT "${CAKE_ARGUMENTS[@]}"
|
|
@ -0,0 +1,15 @@
|
|||
; This is the default configuration file for Cake.
|
||||
; This file was downloaded from https://github.com/cake-build/resources
|
||||
|
||||
[Nuget]
|
||||
Source=https://api.nuget.org/v3/index.json
|
||||
UseInProcessClient=true
|
||||
LoadDependencies=false
|
||||
|
||||
[Paths]
|
||||
Tools=./tools
|
||||
Addins=./tools/Addins
|
||||
Modules=./tools/Modules
|
||||
|
||||
[Settings]
|
||||
SkipVerification=false
|
Загрузка…
Ссылка в новой задаче