aboutsummaryrefslogtreecommitdiff
path: root/src/install/semver.zig
diff options
context:
space:
mode:
authorGravatar Ai Hoshino <ambiguous404@gmail.com> 2023-08-31 09:49:09 +0800
committerGravatar GitHub <noreply@github.com> 2023-08-30 18:49:09 -0700
commit9334fbe9b4facdfa9057a25e88e998f1fd2e346a (patch)
treefb45c28d87d90898181ea511735571a693203cda /src/install/semver.zig
parent0a5d2a8195fbbaab7ff1f40ad54ba94726bcc104 (diff)
downloadbun-9334fbe9b4facdfa9057a25e88e998f1fd2e346a.tar.gz
bun-9334fbe9b4facdfa9057a25e88e998f1fd2e346a.tar.zst
bun-9334fbe9b4facdfa9057a25e88e998f1fd2e346a.zip
fix(install): resolve semver matching with pre-release tags. (#4412)
Close: #4398
Diffstat (limited to '')
-rw-r--r--src/install/semver.zig43
1 files changed, 37 insertions, 6 deletions
diff --git a/src/install/semver.zig b/src/install/semver.zig
index 04818cfd3..e773f005a 100644
--- a/src/install/semver.zig
+++ b/src/install/semver.zig
@@ -1266,7 +1266,7 @@ pub const Range = struct {
return lhs.op == rhs.op and lhs.version.eql(rhs.version);
}
- pub fn satisfies(this: Comparator, version: Version) bool {
+ pub fn satisfies(this: Comparator, version: Version, include_pre: bool) bool {
const order = version.orderWithoutTag(this.version);
return switch (order) {
@@ -1275,11 +1275,11 @@ pub const Range = struct {
else => false,
},
.gt => switch (this.op) {
- .gt, .gte => true,
+ .gt, .gte => if (!include_pre) false else true,
else => false,
},
.lt => switch (this.op) {
- .lt, .lte => true,
+ .lt, .lte => if (!include_pre) false else true,
else => false,
},
};
@@ -1287,15 +1287,46 @@ pub const Range = struct {
};
pub fn satisfies(this: Range, version: Version) bool {
- if (!this.hasLeft()) {
+ const has_left = this.hasLeft();
+ const has_right = this.hasRight();
+
+ if (!has_left) {
return true;
}
- if (!this.left.satisfies(version)) {
+ // When the boundaries of a range do not include a pre-release tag on either side,
+ // we should not consider that '7.0.0-rc2' < "7.0.0"
+ // ```
+ // > semver.satisfies("7.0.0-rc2", "<=7.0.0")
+ // false
+ // > semver.satisfies("7.0.0-rc2", ">=7.0.0")
+ // false
+ // > semver.satisfies("7.0.0-rc2", "<=7.0.0-rc2")
+ // true
+ // > semver.satisfies("7.0.0-rc2", ">=7.0.0-rc2")
+ // true
+ // ```
+ //
+ // - https://github.com/npm/node-semver#prerelease-tags
+ // - https://github.com/npm/node-semver/blob/cce61804ba6f997225a1267135c06676fe0524d2/classes/range.js#L505-L539
+ var include_pre = true;
+ if (version.tag.hasPre()) {
+ if (!has_right) {
+ if (!this.left.version.tag.hasPre()) {
+ include_pre = false;
+ }
+ } else {
+ if (!this.left.version.tag.hasPre() and !this.right.version.tag.hasPre()) {
+ include_pre = false;
+ }
+ }
+ }
+
+ if (!this.left.satisfies(version, include_pre)) {
return false;
}
- if (this.hasRight() and !this.right.satisfies(version)) {
+ if (has_right and !this.right.satisfies(version, include_pre)) {
return false;
}