From 061e7aad0fc1e3d11f985ea1f11aaaf760f1d2be Mon Sep 17 00:00:00 2001 From: IX-BOT <137874481+IX-BOT@users.noreply.github.com> Date: Mon, 27 Nov 2023 18:17:39 +0100 Subject: [PATCH] [BUG] ixc does not parse apax versions correctly when comparing dependencies in apax.yml and those installed in .apax folder (#266) * Create draft PR for #265 * add semantic comparision of apax packages - packages defined in apax.yml and .apax folder are now compared taking into accoun ^ and ~ * removes redownload flag when getting apax packages --------- Co-authored-by: PTKu Co-authored-by: Peter <61538034+PTKu@users.noreply.github.com> --- cake/Program.cs | 2 +- .../src/AXSharp.Compiler/AxProject.cs | 48 ++++++++++++++++++- 2 files changed, 47 insertions(+), 3 deletions(-) diff --git a/cake/Program.cs b/cake/Program.cs index 467983ea..eba17952 100644 --- a/cake/Program.cs +++ b/cake/Program.cs @@ -96,7 +96,7 @@ private static void ProvisionProjectWideTools(BuildContext context) context.ProcessRunner.Start(Helpers.GetApaxCommand(), new Cake.Core.IO.ProcessSettings() { - Arguments = $" install -r -c", + Arguments = $" install", WorkingDirectory = Path.Combine(context.ScrDir, "apax"), RedirectStandardOutput = false, RedirectStandardError = false, diff --git a/src/AXSharp.compiler/src/AXSharp.Compiler/AxProject.cs b/src/AXSharp.compiler/src/AXSharp.Compiler/AxProject.cs index 37740c80..508d5b5f 100644 --- a/src/AXSharp.compiler/src/AXSharp.Compiler/AxProject.cs +++ b/src/AXSharp.compiler/src/AXSharp.Compiler/AxProject.cs @@ -160,6 +160,50 @@ private static IEnumerable SearchForApaxFiles(string directory, int curr return apaxFilesList; } + static bool AreVersionsCompatible(string v1, string v2) + { + var versionA = ParseVersion(v1); + var versionB = ParseVersion(v2); + + if (v1.StartsWith("^") || v2.StartsWith("^")) + { + if (versionA.Major == 0 || versionB.Major == 0) + { + // Compare both major and minor for versions starting with 0 + return versionA.Major == versionB.Major && versionA.Minor == versionB.Minor; + } + else + { + // Compare only major for other versions + return versionA.Major == versionB.Major; + } + } + else if (v1.StartsWith("~") || v2.StartsWith("~")) + { + // Compare both major and minor for tilde versions + return versionA.Major == versionB.Major && versionA.Minor == versionB.Minor; + } + else + { + // Direct version comparison if no symbol is used + return versionA.Equals(versionB); + } + } + + static Version ParseVersion(string versionString) + { + // Check for caret or tilde and remove it + if (versionString.StartsWith("^") || versionString.StartsWith("~")) + { + versionString = versionString.Substring(1); + } + + // Parsing version string and creating a Version object + return Version.Parse(versionString); + } + + + private IEnumerable GetProjectDependencies() { var dependencies = ProjectInfo.Dependencies ?? new Dictionary(); @@ -184,7 +228,7 @@ private IEnumerable GetProjectDependencies() foreach (var dependency in dependencies) { var hasSuchProject = - nearByProjects.FirstOrDefault(p => p.Apax.Name == dependency.Key && p.Apax.Version == dependency.Value); + nearByProjects.FirstOrDefault(p => p.Apax.Name == dependency.Key && AreVersionsCompatible(p.Apax.Version, dependency.Value)); if (hasSuchProject != null) { var pathAXSharpConfig = @@ -199,7 +243,7 @@ private IEnumerable GetProjectDependencies() foreach (var dependency in dependencies) { var dependencyWithCompanion = installedDependencies - .FirstOrDefault(p => p.Apax != null && p.Apax.Name == dependency.Key && p.Apax.Version == dependency.Value); + .FirstOrDefault(p => p.Apax != null && p.Apax.Name == dependency.Key && AreVersionsCompatible(p.Apax.Version, dependency.Value)); if (dependencyWithCompanion?.Companion != null)