2022-04-18 19:36:09 -04:00
|
|
|
package funkin.util;
|
|
|
|
|
|
|
|
import thx.semver.Version;
|
|
|
|
import thx.semver.VersionRule;
|
|
|
|
|
|
|
|
/**
|
2023-11-07 04:04:22 -05:00
|
|
|
* Utility functions for operating on semantic versions.
|
|
|
|
*
|
2022-04-18 19:36:09 -04:00
|
|
|
* Remember, increment the patch version (1.0.x) if you make a bugfix,
|
|
|
|
* increment the minor version (1.x.0) if you make a new feature (but previous content is still compatible),
|
|
|
|
* and increment the major version (x.0.0) if you make a breaking change (e.g. new API or reorganized file format).
|
|
|
|
*/
|
|
|
|
class VersionUtil
|
|
|
|
{
|
2023-01-22 22:25:45 -05:00
|
|
|
/**
|
|
|
|
* Checks that a given verison number satisisfies a given version rule.
|
|
|
|
* Version rule can be complex, e.g. "1.0.x" or ">=1.0.0,<1.1.0", or anything NPM supports.
|
2024-03-16 22:20:22 -04:00
|
|
|
* @param version The semantic version to validate.
|
|
|
|
* @param versionRule The version rule to validate against.
|
|
|
|
* @return `true` if the version satisfies the rule, `false` otherwise.
|
2023-01-22 22:25:45 -05:00
|
|
|
*/
|
2023-08-22 04:27:30 -04:00
|
|
|
public static function validateVersion(version:thx.semver.Version, versionRule:thx.semver.VersionRule):Bool
|
2023-01-22 22:25:45 -05:00
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
2023-08-22 04:27:30 -04:00
|
|
|
return version.satisfies(versionRule);
|
2023-01-22 22:25:45 -05:00
|
|
|
}
|
|
|
|
catch (e)
|
|
|
|
{
|
|
|
|
trace('[VERSIONUTIL] Invalid semantic version: ${version}');
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2023-08-22 04:27:30 -04:00
|
|
|
|
2024-05-21 02:23:21 -04:00
|
|
|
public static function repairVersion(version:thx.semver.Version):thx.semver.Version
|
|
|
|
{
|
|
|
|
var versionData:thx.semver.Version.SemVer = version;
|
|
|
|
|
|
|
|
if (StructureUtil.isStructure(versionData.version))
|
|
|
|
{
|
|
|
|
// This is bad! versionData.version should be an array!
|
|
|
|
versionData.version = [versionData.version[0], versionData.version[1], versionData.version[2]];
|
|
|
|
|
|
|
|
var fixedVersion:thx.semver.Version = versionData;
|
|
|
|
return fixedVersion;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// No need for repair.
|
|
|
|
return version;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-08-22 04:27:30 -04:00
|
|
|
/**
|
|
|
|
* Checks that a given verison number satisisfies a given version rule.
|
|
|
|
* Version rule can be complex, e.g. "1.0.x" or ">=1.0.0,<1.1.0", or anything NPM supports.
|
2024-03-16 22:20:22 -04:00
|
|
|
* @param version The semantic version to validate.
|
|
|
|
* @param versionRule The version rule to validate against.
|
|
|
|
* @return `true` if the version satisfies the rule, `false` otherwise.
|
2023-08-22 04:27:30 -04:00
|
|
|
*/
|
|
|
|
public static function validateVersionStr(version:String, versionRule:String):Bool
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
var version:thx.semver.Version = version;
|
|
|
|
var versionRule:thx.semver.VersionRule = versionRule;
|
|
|
|
return version.satisfies(versionRule);
|
|
|
|
}
|
|
|
|
catch (e)
|
|
|
|
{
|
|
|
|
trace('[VERSIONUTIL] Invalid semantic version: ${version}');
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get and parse the semantic version from a JSON string.
|
|
|
|
* @param input The JSON string to parse.
|
|
|
|
* @return The semantic version, or null if it could not be parsed.
|
|
|
|
*/
|
2023-09-18 17:59:55 -04:00
|
|
|
public static function getVersionFromJSON(input:Null<String>):Null<thx.semver.Version>
|
2023-08-22 04:27:30 -04:00
|
|
|
{
|
2023-09-18 17:59:55 -04:00
|
|
|
if (input == null) return null;
|
2024-03-16 22:20:22 -04:00
|
|
|
var parsed:Dynamic = SerializerUtil.fromJSON(input);
|
2023-08-22 04:27:30 -04:00
|
|
|
if (parsed == null) return null;
|
|
|
|
if (parsed.version == null) return null;
|
|
|
|
var versionStr:String = parsed.version; // Dynamic -> String cast
|
|
|
|
var version:thx.semver.Version = versionStr; // Implicit, not explicit, cast.
|
|
|
|
return version;
|
|
|
|
}
|
2023-10-21 01:04:50 -04:00
|
|
|
|
2024-03-16 22:20:22 -04:00
|
|
|
/**
|
|
|
|
* Get and parse the semantic version from a JSON string.
|
|
|
|
* @param input The JSON string to parse.
|
|
|
|
* @return The semantic version, or null if it could not be parsed.
|
|
|
|
*/
|
2023-10-21 01:04:50 -04:00
|
|
|
public static function parseVersion(input:Dynamic):Null<thx.semver.Version>
|
|
|
|
{
|
|
|
|
if (input == null) return null;
|
|
|
|
|
|
|
|
if (Std.isOfType(input, String))
|
|
|
|
{
|
|
|
|
var inputStr:String = input;
|
|
|
|
var version:thx.semver.Version = inputStr;
|
|
|
|
return version;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
var semVer:thx.semver.Version.SemVer = input;
|
|
|
|
var version:thx.semver.Version = semVer;
|
|
|
|
return version;
|
|
|
|
}
|
|
|
|
}
|
2022-04-18 19:36:09 -04:00
|
|
|
}
|