diff --git a/HorseIsleServer/HISPd/Resources/DEBIAN/control b/HorseIsleServer/HISPd/Resources/DEBIAN/control index 2cf1360..8652f7b 100755 --- a/HorseIsleServer/HISPd/Resources/DEBIAN/control +++ b/HorseIsleServer/HISPd/Resources/DEBIAN/control @@ -1,7 +1,7 @@ -Package: hisp -Version: 1.7.128 -Depends: coreutils,systemd,mariadb-server,libsqlite3-dev,zlib1g-dev,libicu-dev,libkrb5-dev -Maintainer: Li -Homepage: https://islehorse.com -Architecture: amd64 -Description: Open Source Implementation of the server for flash game "Horse Isle". +Package: hisp +Version: 1.7.132 +Depends: coreutils,systemd,mariadb-server,libsqlite3-dev,zlib1g-dev,libicu-dev,libkrb5-dev +Maintainer: Li +Homepage: https://islehorse.com +Architecture: amd64 +Description: Open Source Implementation of the server for flash game "Horse Isle". diff --git a/HorseIsleServer/LibHISP/LibHISP.csproj b/HorseIsleServer/LibHISP/LibHISP.csproj index 1bd0724..1291cbe 100755 --- a/HorseIsleServer/LibHISP/LibHISP.csproj +++ b/HorseIsleServer/LibHISP/LibHISP.csproj @@ -272,6 +272,6 @@ - + diff --git a/HorseIsleServer/LibHISP/Properties/AssemblyInfo.cs b/HorseIsleServer/LibHISP/Properties/AssemblyInfo.cs index b9f78e7..d500a14 100755 --- a/HorseIsleServer/LibHISP/Properties/AssemblyInfo.cs +++ b/HorseIsleServer/LibHISP/Properties/AssemblyInfo.cs @@ -1,4 +1,4 @@ -using System.Reflection; +using System.Reflection; using System.Runtime.InteropServices; // General Information about an assembly is controlled through the following @@ -30,5 +30,14 @@ using System.Runtime.InteropServices; // // You can specify all the values or you can default the Build and Revision Numbers // by using the '*' as shown below: -[assembly: AssemblyVersion("1.7.128.0")] -[assembly: AssemblyFileVersion("1.7.128.0")] +[assembly: AssemblyVersion("1.7.132.0")] +[assembly: AssemblyFileVersion("1.7.132.0")] + + + + + + + + + diff --git a/HorseIsleServer/LibHISP/prebuild.csx b/HorseIsleServer/LibHISP/prebuild.csx new file mode 100644 index 0000000..6dcc796 --- /dev/null +++ b/HorseIsleServer/LibHISP/prebuild.csx @@ -0,0 +1,139 @@ +using System; +using System.Collections.Generic; +using System.Diagnostics; +using System.IO; +using System.Linq; +using System.Runtime.CompilerServices; + + +// Set Working Directory +private static string SOLUTION_DIR = Path.GetDirectoryName(Path.GetDirectoryName(GetSourceFile())); +Directory.SetCurrentDirectory(SOLUTION_DIR); + +private static string VERSIONING_FOLDER = Path.Combine("LibHISP", "Resources", "Versioning"); + +// Defaults (for if git isn't installed) +private static string COMMIT_HASH = "0000000000000000000000000000000000000000"; +private static string COMMIT_TAG = "v0.0.0"; +private static string COMMIT_BRANCH = "master"; + + +// Get Build Date +private static string COMMIT_DATE = DateTime.UtcNow.ToString("dd/MM/yyyyy"); +private static string COMMIT_TIME = DateTime.UtcNow.ToString("H:M:s"); + +// IDK how this works, found it on stackoverflow, but it returns the path to the prebuild.csx +private static string GetSourceFile([CallerFilePath] string file = "") +{ + return file; +} + +// Updates version inside a AssemblyInfo.cs file +private static void UpdateAsmInfo(string assemblyInfoFile) +{ + string assembly_version = DetermineAssemblyVersion(); + + Console.WriteLine("Updating Verson inside: " + assemblyInfoFile); + string[] lines = File.ReadAllLines(assemblyInfoFile); + for(int i = 0; i < lines.Length; i++) + { + if (lines[i].StartsWith("[assembly: AssemblyVersion(\"")) + { + lines[i] = "[assembly: AssemblyVersion(\"" + assembly_version + "\")]"; + } + + else if (lines[i].StartsWith("[assembly: AssemblyFileVersion(\"")) + { + lines[i] = "[assembly: AssemblyFileVersion(\"" + assembly_version + "\")]"; + } + } + + File.WriteAllLines(assemblyInfoFile, lines); +} + + +// Create "versioning" folder +public static void CreateVersioningFolder() +{ + if (!Directory.Exists(VERSIONING_FOLDER)) + { + Directory.CreateDirectory(VERSIONING_FOLDER); + } +} + +// Function for running a process +public static string StartProcess(string[] cmd) +{ + using (Process proc = new Process()) + { + proc.StartInfo.FileName = cmd[0]; + proc.StartInfo.RedirectStandardOutput = true; + proc.StartInfo.RedirectStandardError = true; + proc.StartInfo.UseShellExecute = false; + proc.StartInfo.CreateNoWindow = true; + proc.StartInfo.Arguments = String.Join(" ", cmd.Skip(1).ToArray()); + proc.Start(); + string output = proc.StandardOutput.ReadToEnd().Replace("\r", "").Replace("\n", ""); + return output; + } +} + +// Run git to determine version +private static void RunGit() +{ + try + { + COMMIT_HASH = StartProcess(new string[] { "git", "rev-parse", "--verify", "HEAD" }); + COMMIT_TAG = StartProcess(new string[] { "git", "describe", "--abbrev=0", "--tags" }); + COMMIT_TAG += "." + StartProcess(new string[] { "git", "rev-list", COMMIT_TAG + "..HEAD", "--count" }); + COMMIT_BRANCH = StartProcess(new string[] { "git", "branch", "--show-current" }); + } catch (Exception e) { Console.Error.WriteLine(e.Message); } +} + +// Write Resources to Versioning Folder +private static void WriteResources() +{ + File.WriteAllText(Path.Combine(VERSIONING_FOLDER, "GitCommit"), COMMIT_HASH); + File.WriteAllText(Path.Combine(VERSIONING_FOLDER, "GitTag" ), COMMIT_TAG); + File.WriteAllText(Path.Combine(VERSIONING_FOLDER, "GitBranch"), COMMIT_BRANCH); + File.WriteAllText(Path.Combine(VERSIONING_FOLDER, "BuildDate"), COMMIT_DATE); + File.WriteAllText(Path.Combine(VERSIONING_FOLDER, "BuildTime"), COMMIT_TIME); + +} + +// Find assembly version based on commit tag +private static string DetermineAssemblyVersion() +{ + List points = COMMIT_TAG.Replace("v", "").Split('.').ToList(); + while(points.Count < 4) + { + points.Add("0"); + } + return String.Join(".", points.ToArray()); +} + +private static void UpdateVersionInControlFile(string controlFile) +{ + Console.WriteLine("Updating Verson inside: " + controlFile); + string[] lines = File.ReadAllLines(controlFile); + for (int i = 0; i < lines.Length; i++) + { + if (lines[i].StartsWith("Version: ")) + { + lines[i] = "Version: " + COMMIT_TAG.Replace("v", ""); + } + } + File.WriteAllLines(controlFile, lines); +} + +CreateVersioningFolder(); +RunGit(); +WriteResources(); + +// Update AssemblyInfo.cs files +UpdateAsmInfo(Path.Combine("LibHISP", "Properties", "AssemblyInfo.cs")); +UpdateAsmInfo(Path.Combine("MPN00BS", "Properties", "AssemblyInfo.cs")); +UpdateAsmInfo(Path.Combine("HISPd", "Properties", "AssemblyInfo.cs")); + +// Update control file in dpkg. +UpdateVersionInControlFile(Path.Combine("HISPd", "Resources", "DEBIAN", "control")); \ No newline at end of file diff --git a/HorseIsleServer/LibHISP/prebuild.py b/HorseIsleServer/LibHISP/prebuild.py deleted file mode 100755 index 4d693ee..0000000 --- a/HorseIsleServer/LibHISP/prebuild.py +++ /dev/null @@ -1,80 +0,0 @@ -#!/usr/bin/python3 - -import os -import subprocess -import time -import datetime -import binascii - -os.chdir(os.path.dirname(os.path.dirname(os.path.realpath(__file__)))) - -# Updates version inside a AssemblyInfo.cs file -def update_asm_info(assemblyinfofile): - global commit_hash - global commit_tag - global commit_branch - global assembly_version - print("Updating Verson inside: "+assemblyinfofile) - lines = open(assemblyinfofile, "rb").readlines() - for i in range(0,len(lines)): - if lines[i].startswith(b"[assembly: AssemblyVersion(\""): - lines[i] = b"[assembly: AssemblyVersion(\""+bytes(assembly_version, "UTF-8")+b"\")]\r\n" - if lines[i].startswith(b"[assembly: AssemblyFileVersion(\""): - lines[i] = b"[assembly: AssemblyFileVersion(\""+bytes(assembly_version, "UTF-8")+b"\")]\r\n" - open(assemblyinfofile, "wb").writelines(lines) - - -# Create "versioning" folder -try: - versioning_folder = os.path.join("LibHISP", "Resources", "Versioning") - if not os.path.exists(versioning_folder): - os.mkdir(versioning_folder) -except FileExistsError: - pass - -# Defaults (for if git isn't installed) - -commit_hash = "0"*40 -commit_tag = "v0.0.0" -commit_branch = "master" - -# Run git to determine version info -try: - commit_hash = subprocess.run(['git', 'rev-parse', '--verify', 'HEAD'], stdout=subprocess.PIPE).stdout.replace(b"\r", b"").replace(b"\n", b"").decode("UTF-8") - commit_tag = subprocess.run(['git', 'describe', '--abbrev=0', '--tags'], stdout=subprocess.PIPE).stdout.replace(b"\r", b"").replace(b"\n", b"").decode("UTF-8") - commit_tag += "." + subprocess.run(['git', 'rev-list', commit_tag+'..HEAD', '--count'], stdout=subprocess.PIPE).stdout.replace(b"\r", b"").replace(b"\n", b"").decode("UTF-8") - commit_branch = subprocess.run(['git', 'branch', '--show-current'], stdout=subprocess.PIPE).stdout.replace(b"\r", b"").replace(b"\n", b"").decode("UTF-8") -except FileNotFoundError: - pass - -# Get current time and date of this build -commit_date = datetime.datetime.now().strftime("%d/%m/%Y") -commit_time = datetime.datetime.now().strftime("%H:%M:%S") - -# Write resources -open(os.path.join(versioning_folder, "GitCommit"), "w").write(commit_hash) -open(os.path.join(versioning_folder, "GitTag" ), "w").write(commit_tag) -open(os.path.join(versioning_folder, "GitBranch"), "w").write(commit_branch) -open(os.path.join(versioning_folder, "BuildDate"), "w").write(commit_date) -open(os.path.join(versioning_folder, "BuildTime"), "w").write(commit_time) - -# Get assembly version -points = commit_tag.replace("v", "").split(".") -while len(points) < 4: - points.append("0") -assembly_version = ".".join(points) - -# Update AssemblyInfo.cs files -update_asm_info(os.path.join("LibHISP", "Properties", "AssemblyInfo.cs")) -update_asm_info(os.path.join("MPN00BS", "Properties", "AssemblyInfo.cs")) -update_asm_info(os.path.join("HISPd" , "Properties", "AssemblyInfo.cs")) - -# Update control file in dpkg -control_file = os.path.join("HISPd", "Resources", "DEBIAN", "control") -print("Updating Verson inside: "+control_file) -lines = open(control_file, "rb").readlines() -for i in range(0,len(lines)): - if lines[i].startswith(b"Version: "): - lines[i] = b"Version: "+bytes(commit_tag.replace("v", ""), "UTF-8")+b"\n" -open(control_file, "wb").writelines(lines) - diff --git a/HorseIsleServer/MPN00BS/Properties/AssemblyInfo.cs b/HorseIsleServer/MPN00BS/Properties/AssemblyInfo.cs index 58c1bad..b78d4d2 100755 --- a/HorseIsleServer/MPN00BS/Properties/AssemblyInfo.cs +++ b/HorseIsleServer/MPN00BS/Properties/AssemblyInfo.cs @@ -1,4 +1,4 @@ -using System.Reflection; +using System.Reflection; using System.Runtime.InteropServices; // General Information about an assembly is controlled through the following @@ -30,5 +30,23 @@ using System.Runtime.InteropServices; // // You can specify all the values or you can default the Build and Revision Numbers // by using the '*' as shown below: -[assembly: AssemblyVersion("1.7.128.0")] -[assembly: AssemblyFileVersion("1.7.128.0")] +[assembly: AssemblyVersion("1.7.132.0")] + + + + + + + + + +[assembly: AssemblyFileVersion("1.7.132.0")] + + + + + + + + +