mirror of
https://github.com/ppy/osu.git
synced 2025-01-21 08:12:56 +08:00
Merge branch 'master' into fix-import-path-failures
This commit is contained in:
commit
e210435003
@ -2,11 +2,6 @@ clone_depth: 1
|
|||||||
version: '{branch}-{build}'
|
version: '{branch}-{build}'
|
||||||
image: Visual Studio 2017
|
image: Visual Studio 2017
|
||||||
configuration: Debug
|
configuration: Debug
|
||||||
cache:
|
|
||||||
- C:\ProgramData\chocolatey\bin -> appveyor.yml
|
|
||||||
- C:\ProgramData\chocolatey\lib -> appveyor.yml
|
|
||||||
- inspectcode -> appveyor.yml
|
|
||||||
- packages -> **\packages.config
|
|
||||||
install:
|
install:
|
||||||
- cmd: git submodule update --init --recursive --depth=5
|
- cmd: git submodule update --init --recursive --depth=5
|
||||||
- cmd: choco install resharper-clt -y
|
- cmd: choco install resharper-clt -y
|
||||||
|
@ -1,29 +1,24 @@
|
|||||||
branches:
|
|
||||||
only:
|
|
||||||
- release
|
|
||||||
skip_tags: true
|
|
||||||
skip_branch_with_pr: true
|
|
||||||
clone_depth: 1
|
clone_depth: 1
|
||||||
version: '{branch}-{build}'
|
version: '{build}'
|
||||||
|
skip_non_tags: true
|
||||||
image: Visual Studio 2017
|
image: Visual Studio 2017
|
||||||
configuration: Debug
|
|
||||||
cache:
|
|
||||||
- packages -> **\packages.config
|
|
||||||
install:
|
install:
|
||||||
- cmd: git submodule update --init --recursive --depth=5
|
- git clone https://github.com/ppy/osu-deploy
|
||||||
before_build:
|
before_build:
|
||||||
|
- ps: if($env:appveyor_repo_tag -eq 'True') { Update-AppveyorBuild -Version $env:appveyor_repo_tag_name }
|
||||||
|
- cmd: git submodule update --init --recursive --depth=5
|
||||||
- cmd: nuget restore -verbosity quiet
|
- cmd: nuget restore -verbosity quiet
|
||||||
build:
|
build_script:
|
||||||
project: osu.Desktop.Deploy/osu.Desktop.Deploy.csproj
|
|
||||||
verbosity: minimal
|
|
||||||
after_build:
|
|
||||||
- ps: iex ((New-Object Net.WebClient).DownloadString('https://raw.githubusercontent.com/appveyor/secure-file/master/install.ps1'))
|
- ps: iex ((New-Object Net.WebClient).DownloadString('https://raw.githubusercontent.com/appveyor/secure-file/master/install.ps1'))
|
||||||
- appveyor DownloadFile https://puu.sh/A6g5K/4d08705438.enc # signing certificate
|
- appveyor DownloadFile https://puu.sh/A6g5K/4d08705438.enc # signing certificate
|
||||||
- cmd: appveyor-tools\secure-file -decrypt 4d08705438.enc -secret %decode_secret% -out %HOMEPATH%\deanherbert.pfx
|
- cmd: appveyor-tools\secure-file -decrypt 4d08705438.enc -secret %decode_secret% -out %HOMEPATH%\deanherbert.pfx
|
||||||
- appveyor DownloadFile https://puu.sh/A6g75/fdc6f19b04.enc # deploy configuration
|
- appveyor DownloadFile https://puu.sh/A6g75/fdc6f19b04.enc # deploy configuration
|
||||||
- cmd: appveyor-tools\secure-file -decrypt fdc6f19b04.enc -secret %decode_secret% -out osu.Desktop.Deploy\bin\Debug\net471\osu.Desktop.Deploy.exe.config
|
- cd osu-deploy
|
||||||
- cd osu.Desktop.Deploy\bin\Debug\net471\
|
- nuget restore -verbosity quiet
|
||||||
- osu.Desktop.Deploy.exe %code_signing_password%
|
- msbuild osu.Desktop.Deploy.csproj
|
||||||
|
- cmd: ..\appveyor-tools\secure-file -decrypt ..\fdc6f19b04.enc -secret %decode_secret% -out bin\Debug\net471\osu.Desktop.Deploy.exe.config
|
||||||
|
- cd bin\Debug\net471\
|
||||||
|
- osu.Desktop.Deploy.exe %code_signing_password% %APPVEYOR_REPO_TAG_NAME%
|
||||||
environment:
|
environment:
|
||||||
TargetFramework: net471
|
TargetFramework: net471
|
||||||
decode_secret:
|
decode_secret:
|
||||||
@ -31,4 +26,7 @@ environment:
|
|||||||
code_signing_password:
|
code_signing_password:
|
||||||
secure: 34tLNqvjmmZEi97MLKfrnQ==
|
secure: 34tLNqvjmmZEi97MLKfrnQ==
|
||||||
artifacts:
|
artifacts:
|
||||||
- path: 'Releases\*'
|
- path: 'Releases\*'
|
||||||
|
deploy:
|
||||||
|
- provider: Environment
|
||||||
|
name: github
|
@ -1,21 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!--
|
|
||||||
Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
-->
|
|
||||||
<configuration>
|
|
||||||
<appSettings>
|
|
||||||
<add key="StagingFolder" value="Staging" />
|
|
||||||
<add key="ReleasesFolder" value="Releases" />
|
|
||||||
<add key="GitHubAccessToken" value="" />
|
|
||||||
<add key="GitHubUsername" value="ppy" />
|
|
||||||
<add key="GitHubRepoName" value="osu" />
|
|
||||||
<add key="ProjectName" value="osu.Desktop" />
|
|
||||||
<add key="NuSpecName" value="osu.Desktop\osu.nuspec" />
|
|
||||||
<add key="SolutionName" value="osu" />
|
|
||||||
<add key="TargetName" value="osu.Desktop" />
|
|
||||||
<add key="PackageName" value="osulazer" />
|
|
||||||
<add key="IconName" value="lazer.ico" />
|
|
||||||
<add key="CodeSigningCertificate" value="" />
|
|
||||||
</appSettings>
|
|
||||||
</configuration>
|
|
@ -1,16 +0,0 @@
|
|||||||
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using Newtonsoft.Json;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Deploy
|
|
||||||
{
|
|
||||||
public class GitHubObject
|
|
||||||
{
|
|
||||||
[JsonProperty(@"id")]
|
|
||||||
public int Id;
|
|
||||||
|
|
||||||
[JsonProperty(@"name")]
|
|
||||||
public string Name;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,28 +0,0 @@
|
|||||||
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using Newtonsoft.Json;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Deploy
|
|
||||||
{
|
|
||||||
public class GitHubRelease
|
|
||||||
{
|
|
||||||
[JsonProperty(@"id")]
|
|
||||||
public int Id;
|
|
||||||
|
|
||||||
[JsonProperty(@"tag_name")]
|
|
||||||
public string TagName => $"v{Name}";
|
|
||||||
|
|
||||||
[JsonProperty(@"name")]
|
|
||||||
public string Name;
|
|
||||||
|
|
||||||
[JsonProperty(@"draft")]
|
|
||||||
public bool Draft;
|
|
||||||
|
|
||||||
[JsonProperty(@"prerelease")]
|
|
||||||
public bool PreRelease;
|
|
||||||
|
|
||||||
[JsonProperty(@"upload_url")]
|
|
||||||
public string UploadUrl;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,471 +0,0 @@
|
|||||||
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Configuration;
|
|
||||||
using System.Diagnostics;
|
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Management.Automation;
|
|
||||||
using Newtonsoft.Json;
|
|
||||||
using osu.Framework.IO.Network;
|
|
||||||
using FileWebRequest = osu.Framework.IO.Network.FileWebRequest;
|
|
||||||
using WebRequest = osu.Framework.IO.Network.WebRequest;
|
|
||||||
|
|
||||||
namespace osu.Desktop.Deploy
|
|
||||||
{
|
|
||||||
internal static class Program
|
|
||||||
{
|
|
||||||
private static string packages => Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".nuget", "packages");
|
|
||||||
private static string nugetPath => Path.Combine(packages, @"nuget.commandline\4.5.1\tools\NuGet.exe");
|
|
||||||
private static string squirrelPath => Path.Combine(packages, @"squirrel.windows\1.8.0\tools\Squirrel.exe");
|
|
||||||
private const string msbuild_path = @"C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\MSBuild\15.0\Bin\MSBuild.exe";
|
|
||||||
|
|
||||||
public static string StagingFolder = ConfigurationManager.AppSettings["StagingFolder"];
|
|
||||||
public static string ReleasesFolder = ConfigurationManager.AppSettings["ReleasesFolder"];
|
|
||||||
public static string GitHubAccessToken = ConfigurationManager.AppSettings["GitHubAccessToken"];
|
|
||||||
public static string GitHubUsername = ConfigurationManager.AppSettings["GitHubUsername"];
|
|
||||||
public static string GitHubRepoName = ConfigurationManager.AppSettings["GitHubRepoName"];
|
|
||||||
public static string SolutionName = ConfigurationManager.AppSettings["SolutionName"];
|
|
||||||
public static string ProjectName = ConfigurationManager.AppSettings["ProjectName"];
|
|
||||||
public static string NuSpecName = ConfigurationManager.AppSettings["NuSpecName"];
|
|
||||||
public static string TargetNames = ConfigurationManager.AppSettings["TargetName"];
|
|
||||||
public static string PackageName = ConfigurationManager.AppSettings["PackageName"];
|
|
||||||
public static string IconName = ConfigurationManager.AppSettings["IconName"];
|
|
||||||
public static string CodeSigningCertificate = ConfigurationManager.AppSettings["CodeSigningCertificate"];
|
|
||||||
|
|
||||||
public static string GitHubApiEndpoint => $"https://api.github.com/repos/{GitHubUsername}/{GitHubRepoName}/releases";
|
|
||||||
public static string GitHubReleasePage => $"https://github.com/{GitHubUsername}/{GitHubRepoName}/releases";
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// How many previous build deltas we want to keep when publishing.
|
|
||||||
/// </summary>
|
|
||||||
private const int keep_delta_count = 4;
|
|
||||||
|
|
||||||
private static string codeSigningCmd => string.IsNullOrEmpty(codeSigningPassword) ? "" : $"-n \"/a /f {codeSigningCertPath} /p {codeSigningPassword} /t http://timestamp.comodoca.com/authenticode\"";
|
|
||||||
|
|
||||||
private static string homeDir => Environment.GetFolderPath(Environment.SpecialFolder.UserProfile);
|
|
||||||
private static string codeSigningCertPath => Path.Combine(homeDir, CodeSigningCertificate);
|
|
||||||
private static string solutionPath => Environment.CurrentDirectory;
|
|
||||||
private static string stagingPath => Path.Combine(solutionPath, StagingFolder);
|
|
||||||
private static string iconPath => Path.Combine(solutionPath, ProjectName, IconName);
|
|
||||||
|
|
||||||
private static string nupkgFilename(string ver) => $"{PackageName}.{ver}.nupkg";
|
|
||||||
private static string nupkgDistroFilename(string ver) => $"{PackageName}-{ver}-full.nupkg";
|
|
||||||
|
|
||||||
private static readonly Stopwatch sw = new Stopwatch();
|
|
||||||
|
|
||||||
private static string codeSigningPassword;
|
|
||||||
|
|
||||||
private static bool interactive;
|
|
||||||
|
|
||||||
public static void Main(string[] args)
|
|
||||||
{
|
|
||||||
interactive = args.Length == 0;
|
|
||||||
|
|
||||||
displayHeader();
|
|
||||||
|
|
||||||
findSolutionPath();
|
|
||||||
|
|
||||||
if (!Directory.Exists(ReleasesFolder))
|
|
||||||
{
|
|
||||||
write("WARNING: No release directory found. Make sure you want this!", ConsoleColor.Yellow);
|
|
||||||
Directory.CreateDirectory(ReleasesFolder);
|
|
||||||
}
|
|
||||||
|
|
||||||
checkGitHubReleases();
|
|
||||||
|
|
||||||
refreshDirectory(StagingFolder);
|
|
||||||
|
|
||||||
//increment build number until we have a unique one.
|
|
||||||
string verBase = DateTime.Now.ToString("yyyy.Mdd.");
|
|
||||||
int increment = 0;
|
|
||||||
while (Directory.GetFiles(ReleasesFolder, $"*{verBase}{increment}*").Any())
|
|
||||||
increment++;
|
|
||||||
|
|
||||||
string version = $"{verBase}{increment}";
|
|
||||||
|
|
||||||
Console.ForegroundColor = ConsoleColor.White;
|
|
||||||
Console.Write($"Ready to deploy {version}!");
|
|
||||||
pauseIfInteractive();
|
|
||||||
|
|
||||||
sw.Start();
|
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(CodeSigningCertificate))
|
|
||||||
{
|
|
||||||
Console.Write("Enter code signing password: ");
|
|
||||||
codeSigningPassword = args.Length > 0 ? args[0] : readLineMasked();
|
|
||||||
}
|
|
||||||
|
|
||||||
write("Updating AssemblyInfo...");
|
|
||||||
updateCsprojVersion(version);
|
|
||||||
updateAppveyorVersion(version);
|
|
||||||
|
|
||||||
write("Running build process...");
|
|
||||||
foreach (string targetName in TargetNames.Split(','))
|
|
||||||
runCommand(msbuild_path, $"/v:quiet /m /t:{targetName.Replace('.', '_')} /p:OutputPath={stagingPath};Targets=\"Clean;Build\";Configuration=Release {SolutionName}.sln");
|
|
||||||
|
|
||||||
write("Creating NuGet deployment package...");
|
|
||||||
runCommand(nugetPath, $"pack {NuSpecName} -Version {version} -Properties Configuration=Deploy -OutputDirectory {stagingPath} -BasePath {stagingPath}");
|
|
||||||
|
|
||||||
//prune once before checking for files so we can avoid erroring on files which aren't even needed for this build.
|
|
||||||
pruneReleases();
|
|
||||||
|
|
||||||
checkReleaseFiles();
|
|
||||||
|
|
||||||
write("Running squirrel build...");
|
|
||||||
runCommand(squirrelPath, $"--releasify {stagingPath}\\{nupkgFilename(version)} --framework-version=net471 --setupIcon {iconPath} --icon {iconPath} {codeSigningCmd} --no-msi");
|
|
||||||
|
|
||||||
//prune again to clean up before upload.
|
|
||||||
pruneReleases();
|
|
||||||
|
|
||||||
//rename setup to install.
|
|
||||||
File.Copy(Path.Combine(ReleasesFolder, "Setup.exe"), Path.Combine(ReleasesFolder, "install.exe"), true);
|
|
||||||
File.Delete(Path.Combine(ReleasesFolder, "Setup.exe"));
|
|
||||||
|
|
||||||
uploadBuild(version);
|
|
||||||
|
|
||||||
//reset assemblyinfo.
|
|
||||||
updateCsprojVersion("0.0.0");
|
|
||||||
|
|
||||||
write("Done!", ConsoleColor.White);
|
|
||||||
pauseIfInteractive();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void displayHeader()
|
|
||||||
{
|
|
||||||
Console.ForegroundColor = ConsoleColor.Red;
|
|
||||||
Console.WriteLine();
|
|
||||||
Console.WriteLine(" Please note that OSU! and PPY are registered trademarks and as such covered by trademark law.");
|
|
||||||
Console.WriteLine(" Do not distribute builds of this project publicly that make use of these.");
|
|
||||||
Console.ResetColor();
|
|
||||||
Console.WriteLine();
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Ensure we have all the files in the release directory which are expected to be there.
|
|
||||||
/// This should have been accounted for in earlier steps, and just serves as a verification step.
|
|
||||||
/// </summary>
|
|
||||||
private static void checkReleaseFiles()
|
|
||||||
{
|
|
||||||
if (!canGitHub) return;
|
|
||||||
|
|
||||||
var releaseLines = getReleaseLines();
|
|
||||||
|
|
||||||
//ensure we have all files necessary
|
|
||||||
foreach (var l in releaseLines)
|
|
||||||
if (!File.Exists(Path.Combine(ReleasesFolder, l.Filename)))
|
|
||||||
error($"Local file missing {l.Filename}");
|
|
||||||
}
|
|
||||||
|
|
||||||
private static IEnumerable<ReleaseLine> getReleaseLines() => File.ReadAllLines(Path.Combine(ReleasesFolder, "RELEASES")).Select(l => new ReleaseLine(l));
|
|
||||||
|
|
||||||
private static void pruneReleases()
|
|
||||||
{
|
|
||||||
if (!canGitHub) return;
|
|
||||||
|
|
||||||
write("Pruning RELEASES...");
|
|
||||||
|
|
||||||
var releaseLines = getReleaseLines().ToList();
|
|
||||||
|
|
||||||
var fulls = releaseLines.Where(l => l.Filename.Contains("-full")).Reverse().Skip(1);
|
|
||||||
|
|
||||||
//remove any FULL releases (except most recent)
|
|
||||||
foreach (var l in fulls)
|
|
||||||
{
|
|
||||||
write($"- Removing old release {l.Filename}", ConsoleColor.Yellow);
|
|
||||||
File.Delete(Path.Combine(ReleasesFolder, l.Filename));
|
|
||||||
releaseLines.Remove(l);
|
|
||||||
}
|
|
||||||
|
|
||||||
//remove excess deltas
|
|
||||||
var deltas = releaseLines.Where(l => l.Filename.Contains("-delta")).ToArray();
|
|
||||||
if (deltas.Length > keep_delta_count)
|
|
||||||
{
|
|
||||||
foreach (var l in deltas.Take(deltas.Length - keep_delta_count))
|
|
||||||
{
|
|
||||||
write($"- Removing old delta {l.Filename}", ConsoleColor.Yellow);
|
|
||||||
File.Delete(Path.Combine(ReleasesFolder, l.Filename));
|
|
||||||
releaseLines.Remove(l);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var lines = new List<string>();
|
|
||||||
releaseLines.ForEach(l => lines.Add(l.ToString()));
|
|
||||||
File.WriteAllLines(Path.Combine(ReleasesFolder, "RELEASES"), lines);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void uploadBuild(string version)
|
|
||||||
{
|
|
||||||
if (!canGitHub || string.IsNullOrEmpty(CodeSigningCertificate))
|
|
||||||
return;
|
|
||||||
|
|
||||||
write("Publishing to GitHub...");
|
|
||||||
|
|
||||||
write($"- Creating release {version}...", ConsoleColor.Yellow);
|
|
||||||
var req = new JsonWebRequest<GitHubRelease>($"{GitHubApiEndpoint}")
|
|
||||||
{
|
|
||||||
Method = HttpMethod.POST,
|
|
||||||
};
|
|
||||||
req.AddRaw(JsonConvert.SerializeObject(new GitHubRelease
|
|
||||||
{
|
|
||||||
Name = version,
|
|
||||||
Draft = true,
|
|
||||||
PreRelease = true
|
|
||||||
}));
|
|
||||||
req.AuthenticatedBlockingPerform();
|
|
||||||
|
|
||||||
var assetUploadUrl = req.ResponseObject.UploadUrl.Replace("{?name,label}", "?name={0}");
|
|
||||||
foreach (var a in Directory.GetFiles(ReleasesFolder).Reverse()) //reverse to upload RELEASES first.
|
|
||||||
{
|
|
||||||
write($"- Adding asset {a}...", ConsoleColor.Yellow);
|
|
||||||
var upload = new WebRequest(assetUploadUrl, Path.GetFileName(a))
|
|
||||||
{
|
|
||||||
Method = HttpMethod.POST,
|
|
||||||
Timeout = 240000,
|
|
||||||
ContentType = "application/octet-stream",
|
|
||||||
};
|
|
||||||
|
|
||||||
upload.AddRaw(File.ReadAllBytes(a));
|
|
||||||
upload.AuthenticatedBlockingPerform();
|
|
||||||
}
|
|
||||||
|
|
||||||
openGitHubReleasePage();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void openGitHubReleasePage() => Process.Start(GitHubReleasePage);
|
|
||||||
|
|
||||||
private static bool canGitHub => !string.IsNullOrEmpty(GitHubAccessToken);
|
|
||||||
|
|
||||||
private static void checkGitHubReleases()
|
|
||||||
{
|
|
||||||
if (!canGitHub) return;
|
|
||||||
|
|
||||||
write("Checking GitHub releases...");
|
|
||||||
var req = new JsonWebRequest<List<GitHubRelease>>($"{GitHubApiEndpoint}");
|
|
||||||
req.AuthenticatedBlockingPerform();
|
|
||||||
|
|
||||||
var lastRelease = req.ResponseObject.FirstOrDefault();
|
|
||||||
|
|
||||||
if (lastRelease == null)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (lastRelease.Draft)
|
|
||||||
{
|
|
||||||
openGitHubReleasePage();
|
|
||||||
error("There's a pending draft release! You probably don't want to push a build with this present.");
|
|
||||||
}
|
|
||||||
|
|
||||||
//there's a previous release for this project.
|
|
||||||
var assetReq = new JsonWebRequest<List<GitHubObject>>($"{GitHubApiEndpoint}/{lastRelease.Id}/assets");
|
|
||||||
assetReq.AuthenticatedBlockingPerform();
|
|
||||||
var assets = assetReq.ResponseObject;
|
|
||||||
|
|
||||||
//make sure our RELEASES file is the same as the last build on the server.
|
|
||||||
var releaseAsset = assets.FirstOrDefault(a => a.Name == "RELEASES");
|
|
||||||
|
|
||||||
//if we don't have a RELEASES asset then the previous release likely wasn't a Squirrel one.
|
|
||||||
if (releaseAsset == null) return;
|
|
||||||
|
|
||||||
write($"Last GitHub release was {lastRelease.Name}.");
|
|
||||||
|
|
||||||
bool requireDownload = false;
|
|
||||||
|
|
||||||
if (!File.Exists(Path.Combine(ReleasesFolder, nupkgDistroFilename(lastRelease.Name))))
|
|
||||||
{
|
|
||||||
write("Last version's package not found locally.", ConsoleColor.Red);
|
|
||||||
requireDownload = true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
var lastReleases = new RawFileWebRequest($"{GitHubApiEndpoint}/assets/{releaseAsset.Id}");
|
|
||||||
lastReleases.AuthenticatedBlockingPerform();
|
|
||||||
if (File.ReadAllText(Path.Combine(ReleasesFolder, "RELEASES")) != lastReleases.ResponseString)
|
|
||||||
{
|
|
||||||
write("Server's RELEASES differed from ours.", ConsoleColor.Red);
|
|
||||||
requireDownload = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!requireDownload) return;
|
|
||||||
|
|
||||||
write("Refreshing local releases directory...");
|
|
||||||
refreshDirectory(ReleasesFolder);
|
|
||||||
|
|
||||||
foreach (var a in assets)
|
|
||||||
{
|
|
||||||
if (a.Name.EndsWith(".exe")) continue;
|
|
||||||
|
|
||||||
write($"- Downloading {a.Name}...", ConsoleColor.Yellow);
|
|
||||||
new FileWebRequest(Path.Combine(ReleasesFolder, a.Name), $"{GitHubApiEndpoint}/assets/{a.Id}").AuthenticatedBlockingPerform();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void refreshDirectory(string directory)
|
|
||||||
{
|
|
||||||
if (Directory.Exists(directory))
|
|
||||||
Directory.Delete(directory, true);
|
|
||||||
Directory.CreateDirectory(directory);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void updateCsprojVersion(string version)
|
|
||||||
{
|
|
||||||
var toUpdate = new[] { "<Version>", "<FileVersion>" };
|
|
||||||
string file = Path.Combine(ProjectName, $"{ProjectName}.csproj");
|
|
||||||
|
|
||||||
var l1 = File.ReadAllLines(file);
|
|
||||||
List<string> l2 = new List<string>();
|
|
||||||
foreach (var l in l1)
|
|
||||||
{
|
|
||||||
string line = l;
|
|
||||||
|
|
||||||
foreach (var tag in toUpdate)
|
|
||||||
{
|
|
||||||
int startIndex = l.IndexOf(tag, StringComparison.InvariantCulture);
|
|
||||||
if (startIndex == -1)
|
|
||||||
continue;
|
|
||||||
startIndex += tag.Length;
|
|
||||||
|
|
||||||
int endIndex = l.IndexOf("<", startIndex, StringComparison.InvariantCulture);
|
|
||||||
line = $"{l.Substring(0, startIndex)}{version}{l.Substring(endIndex)}";
|
|
||||||
}
|
|
||||||
|
|
||||||
l2.Add(line);
|
|
||||||
}
|
|
||||||
|
|
||||||
File.WriteAllLines(file, l2);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Find the base path of the active solution (git checkout location)
|
|
||||||
/// </summary>
|
|
||||||
private static void findSolutionPath()
|
|
||||||
{
|
|
||||||
string path = Path.GetDirectoryName(Environment.CommandLine.Replace("\"", "").Trim());
|
|
||||||
|
|
||||||
if (string.IsNullOrEmpty(path))
|
|
||||||
path = Environment.CurrentDirectory;
|
|
||||||
|
|
||||||
while (!File.Exists(Path.Combine(path, $"{SolutionName}.sln")))
|
|
||||||
path = path.Remove(path.LastIndexOf(Path.DirectorySeparatorChar));
|
|
||||||
path += Path.DirectorySeparatorChar;
|
|
||||||
|
|
||||||
Environment.CurrentDirectory = path;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static bool runCommand(string command, string args)
|
|
||||||
{
|
|
||||||
var psi = new ProcessStartInfo(command, args)
|
|
||||||
{
|
|
||||||
WorkingDirectory = solutionPath,
|
|
||||||
CreateNoWindow = true,
|
|
||||||
RedirectStandardOutput = true,
|
|
||||||
RedirectStandardError = true,
|
|
||||||
UseShellExecute = false,
|
|
||||||
WindowStyle = ProcessWindowStyle.Hidden
|
|
||||||
};
|
|
||||||
|
|
||||||
Process p = Process.Start(psi);
|
|
||||||
if (p == null) return false;
|
|
||||||
|
|
||||||
string output = p.StandardOutput.ReadToEnd();
|
|
||||||
output += p.StandardError.ReadToEnd();
|
|
||||||
|
|
||||||
if (p.ExitCode == 0) return true;
|
|
||||||
|
|
||||||
write(output);
|
|
||||||
error($"Command {command} {args} failed!");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static string readLineMasked()
|
|
||||||
{
|
|
||||||
var fg = Console.ForegroundColor;
|
|
||||||
Console.ForegroundColor = Console.BackgroundColor;
|
|
||||||
var ret = Console.ReadLine();
|
|
||||||
Console.ForegroundColor = fg;
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void error(string message)
|
|
||||||
{
|
|
||||||
Console.ForegroundColor = ConsoleColor.Red;
|
|
||||||
Console.WriteLine($"FATAL ERROR: {message}");
|
|
||||||
|
|
||||||
pauseIfInteractive();
|
|
||||||
Environment.Exit(-1);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void pauseIfInteractive()
|
|
||||||
{
|
|
||||||
if (interactive)
|
|
||||||
Console.ReadLine();
|
|
||||||
else
|
|
||||||
Console.WriteLine();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static bool updateAppveyorVersion(string version)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
using (PowerShell ps = PowerShell.Create())
|
|
||||||
{
|
|
||||||
ps.AddScript($"Update-AppveyorBuild -Version \"{version}\"");
|
|
||||||
ps.Invoke();
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
// we don't have appveyor and don't care
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void write(string message, ConsoleColor col = ConsoleColor.Gray)
|
|
||||||
{
|
|
||||||
if (sw.ElapsedMilliseconds > 0)
|
|
||||||
{
|
|
||||||
Console.ForegroundColor = ConsoleColor.Green;
|
|
||||||
Console.Write(sw.ElapsedMilliseconds.ToString().PadRight(8));
|
|
||||||
}
|
|
||||||
Console.ForegroundColor = col;
|
|
||||||
Console.WriteLine(message);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void AuthenticatedBlockingPerform(this WebRequest r)
|
|
||||||
{
|
|
||||||
r.AddHeader("Authorization", $"token {GitHubAccessToken}");
|
|
||||||
r.Perform();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
internal class RawFileWebRequest : WebRequest
|
|
||||||
{
|
|
||||||
public RawFileWebRequest(string url) : base(url)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override string Accept => "application/octet-stream";
|
|
||||||
}
|
|
||||||
|
|
||||||
internal class ReleaseLine
|
|
||||||
{
|
|
||||||
public string Hash;
|
|
||||||
public string Filename;
|
|
||||||
public int Filesize;
|
|
||||||
|
|
||||||
public ReleaseLine(string line)
|
|
||||||
{
|
|
||||||
var split = line.Split(' ');
|
|
||||||
Hash = split[0];
|
|
||||||
Filename = split[1];
|
|
||||||
Filesize = int.Parse(split[2]);
|
|
||||||
}
|
|
||||||
|
|
||||||
public override string ToString() => $"{Hash} {Filename} {Filesize}";
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,17 +0,0 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk">
|
|
||||||
<Import Project="..\osu.Game.props" />
|
|
||||||
<PropertyGroup Label="Project">
|
|
||||||
<TargetFrameworks>net471</TargetFrameworks>
|
|
||||||
<OutputType>Exe</OutputType>
|
|
||||||
<PlatformTarget>AnyCPU</PlatformTarget>
|
|
||||||
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
|
|
||||||
</PropertyGroup>
|
|
||||||
<ItemGroup Label="Package References">
|
|
||||||
<PackageReference Include="NuGet.CommandLine" Version="4.5.1" />
|
|
||||||
<PackageReference Include="NUnit" Version="3.10.1" />
|
|
||||||
<PackageReference Include="ppy.osu.Framework" Version="2018.606.0" />
|
|
||||||
<PackageReference Include="squirrel.windows" Version="1.8.0" Condition="'$(TargetFramework)' == 'net471'" />
|
|
||||||
<PackageReference Include="System.Configuration.ConfigurationManager" Version="4.4.0" />
|
|
||||||
<PackageReference Include="System.Management.Automation.dll" Version="10.0.10586" />
|
|
||||||
</ItemGroup>
|
|
||||||
</Project>
|
|
4
osu.sln
4
osu.sln
@ -15,8 +15,6 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "osu.Game.Rulesets.Taiko", "
|
|||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "osu.Game.Rulesets.Mania", "osu.Game.Rulesets.Mania\osu.Game.Rulesets.Mania.csproj", "{48F4582B-7687-4621-9CBE-5C24197CB536}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "osu.Game.Rulesets.Mania", "osu.Game.Rulesets.Mania\osu.Game.Rulesets.Mania.csproj", "{48F4582B-7687-4621-9CBE-5C24197CB536}"
|
||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "osu.Desktop.Deploy", "osu.Desktop.Deploy\osu.Desktop.Deploy.csproj", "{BAEA2F74-0315-4667-84E0-ACAC0B4BF785}"
|
|
||||||
EndProject
|
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "osu.Game.Tests", "osu.Game.Tests\osu.Game.Tests.csproj", "{54377672-20B1-40AF-8087-5CF73BF3953A}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "osu.Game.Tests", "osu.Game.Tests\osu.Game.Tests.csproj", "{54377672-20B1-40AF-8087-5CF73BF3953A}"
|
||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "osu.Desktop", "osu.Desktop\osu.Desktop.csproj", "{419659FD-72EA-4678-9EB8-B22A746CED70}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "osu.Desktop", "osu.Desktop\osu.Desktop.csproj", "{419659FD-72EA-4678-9EB8-B22A746CED70}"
|
||||||
@ -59,8 +57,6 @@ Global
|
|||||||
{48F4582B-7687-4621-9CBE-5C24197CB536}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
{48F4582B-7687-4621-9CBE-5C24197CB536}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
{48F4582B-7687-4621-9CBE-5C24197CB536}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
{48F4582B-7687-4621-9CBE-5C24197CB536}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{48F4582B-7687-4621-9CBE-5C24197CB536}.Release|Any CPU.Build.0 = Release|Any CPU
|
{48F4582B-7687-4621-9CBE-5C24197CB536}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
{BAEA2F74-0315-4667-84E0-ACAC0B4BF785}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
|
||||||
{BAEA2F74-0315-4667-84E0-ACAC0B4BF785}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
|
||||||
{54377672-20B1-40AF-8087-5CF73BF3953A}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
{54377672-20B1-40AF-8087-5CF73BF3953A}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
{54377672-20B1-40AF-8087-5CF73BF3953A}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
{54377672-20B1-40AF-8087-5CF73BF3953A}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
{54377672-20B1-40AF-8087-5CF73BF3953A}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
{54377672-20B1-40AF-8087-5CF73BF3953A}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
Loading…
Reference in New Issue
Block a user