@fedify/fedify 1.6.0-dev.812 → 1.6.0-dev.814
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm/deno.js +1 -2
- package/esm/federation/handler.js +3 -2
- package/esm/{deps/jsr.io/@std/http/1.0.16/_negotiation/media_type.js → federation/negotiation.js} +14 -62
- package/esm/nodeinfo/client.js +2 -2
- package/esm/nodeinfo/mod.js +1 -1
- package/esm/nodeinfo/semver.js +150 -0
- package/esm/nodeinfo/types.js +2 -2
- package/esm/vocab/vocab.js +176 -176
- package/package.json +1 -1
- package/types/deno.d.ts +0 -1
- package/types/federation/handler.d.ts.map +1 -1
- package/types/{deps/jsr.io/@std/http/1.0.16/_negotiation/common.d.ts → federation/negotiation.d.ts} +2 -3
- package/types/federation/negotiation.d.ts.map +1 -0
- package/types/nodeinfo/client.d.ts.map +1 -1
- package/types/nodeinfo/mod.d.ts +1 -1
- package/types/nodeinfo/mod.d.ts.map +1 -1
- package/types/nodeinfo/semver.d.ts +71 -0
- package/types/nodeinfo/semver.d.ts.map +1 -0
- package/types/nodeinfo/types.d.ts +1 -1
- package/types/nodeinfo/types.d.ts.map +1 -1
- package/esm/deps/jsr.io/@std/http/1.0.16/_negotiation/common.js +0 -40
- package/esm/deps/jsr.io/@std/http/1.0.16/_negotiation/encoding.js +0 -123
- package/esm/deps/jsr.io/@std/http/1.0.16/_negotiation/language.js +0 -113
- package/esm/deps/jsr.io/@std/http/1.0.16/negotiation.js +0 -37
- package/esm/deps/jsr.io/@std/semver/1.0.5/_constants.js +0 -28
- package/esm/deps/jsr.io/@std/semver/1.0.5/_shared.js +0 -162
- package/esm/deps/jsr.io/@std/semver/1.0.5/_test_comparator_set.js +0 -58
- package/esm/deps/jsr.io/@std/semver/1.0.5/can_parse.js +0 -27
- package/esm/deps/jsr.io/@std/semver/1.0.5/compare.js +0 -35
- package/esm/deps/jsr.io/@std/semver/1.0.5/difference.js +0 -41
- package/esm/deps/jsr.io/@std/semver/1.0.5/equals.js +0 -27
- package/esm/deps/jsr.io/@std/semver/1.0.5/format.js +0 -32
- package/esm/deps/jsr.io/@std/semver/1.0.5/format_range.js +0 -27
- package/esm/deps/jsr.io/@std/semver/1.0.5/greater_or_equal.js +0 -26
- package/esm/deps/jsr.io/@std/semver/1.0.5/greater_than.js +0 -28
- package/esm/deps/jsr.io/@std/semver/1.0.5/greater_than_range.js +0 -58
- package/esm/deps/jsr.io/@std/semver/1.0.5/increment.js +0 -176
- package/esm/deps/jsr.io/@std/semver/1.0.5/is_range.js +0 -38
- package/esm/deps/jsr.io/@std/semver/1.0.5/is_semver.js +0 -53
- package/esm/deps/jsr.io/@std/semver/1.0.5/less_or_equal.js +0 -26
- package/esm/deps/jsr.io/@std/semver/1.0.5/less_than.js +0 -26
- package/esm/deps/jsr.io/@std/semver/1.0.5/less_than_range.js +0 -58
- package/esm/deps/jsr.io/@std/semver/1.0.5/max_satisfying.js +0 -30
- package/esm/deps/jsr.io/@std/semver/1.0.5/min_satisfying.js +0 -30
- package/esm/deps/jsr.io/@std/semver/1.0.5/mod.js +0 -300
- package/esm/deps/jsr.io/@std/semver/1.0.5/not_equals.js +0 -25
- package/esm/deps/jsr.io/@std/semver/1.0.5/parse.js +0 -44
- package/esm/deps/jsr.io/@std/semver/1.0.5/parse_range.js +0 -358
- package/esm/deps/jsr.io/@std/semver/1.0.5/range_intersects.js +0 -89
- package/esm/deps/jsr.io/@std/semver/1.0.5/satisfies.js +0 -27
- package/esm/deps/jsr.io/@std/semver/1.0.5/try_parse.js +0 -27
- package/esm/deps/jsr.io/@std/semver/1.0.5/try_parse_range.js +0 -33
- package/esm/deps/jsr.io/@std/semver/1.0.5/types.js +0 -3
- package/types/deps/jsr.io/@std/http/1.0.16/_negotiation/common.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/http/1.0.16/_negotiation/encoding.d.ts +0 -34
- package/types/deps/jsr.io/@std/http/1.0.16/_negotiation/encoding.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/http/1.0.16/_negotiation/language.d.ts +0 -31
- package/types/deps/jsr.io/@std/http/1.0.16/_negotiation/language.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/http/1.0.16/_negotiation/media_type.d.ts +0 -31
- package/types/deps/jsr.io/@std/http/1.0.16/_negotiation/media_type.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/http/1.0.16/negotiation.d.ts +0 -148
- package/types/deps/jsr.io/@std/http/1.0.16/negotiation.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/_constants.d.ts +0 -12
- package/types/deps/jsr.io/@std/semver/1.0.5/_constants.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/_shared.d.ts +0 -44
- package/types/deps/jsr.io/@std/semver/1.0.5/_shared.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/_test_comparator_set.d.ts +0 -3
- package/types/deps/jsr.io/@std/semver/1.0.5/_test_comparator_set.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/can_parse.d.ts +0 -17
- package/types/deps/jsr.io/@std/semver/1.0.5/can_parse.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/compare.d.ts +0 -28
- package/types/deps/jsr.io/@std/semver/1.0.5/compare.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/difference.d.ts +0 -27
- package/types/deps/jsr.io/@std/semver/1.0.5/difference.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/equals.d.ts +0 -24
- package/types/deps/jsr.io/@std/semver/1.0.5/equals.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/format.d.ts +0 -22
- package/types/deps/jsr.io/@std/semver/1.0.5/format.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/format_range.d.ts +0 -18
- package/types/deps/jsr.io/@std/semver/1.0.5/format_range.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/greater_or_equal.d.ts +0 -25
- package/types/deps/jsr.io/@std/semver/1.0.5/greater_or_equal.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/greater_than.d.ts +0 -25
- package/types/deps/jsr.io/@std/semver/1.0.5/greater_than.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/greater_than_range.d.ts +0 -23
- package/types/deps/jsr.io/@std/semver/1.0.5/greater_than_range.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/increment.d.ts +0 -51
- package/types/deps/jsr.io/@std/semver/1.0.5/increment.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/is_range.d.ts +0 -23
- package/types/deps/jsr.io/@std/semver/1.0.5/is_range.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/is_semver.d.ts +0 -34
- package/types/deps/jsr.io/@std/semver/1.0.5/is_semver.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/less_or_equal.d.ts +0 -25
- package/types/deps/jsr.io/@std/semver/1.0.5/less_or_equal.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/less_than.d.ts +0 -25
- package/types/deps/jsr.io/@std/semver/1.0.5/less_than.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/less_than_range.d.ts +0 -23
- package/types/deps/jsr.io/@std/semver/1.0.5/less_than_range.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/max_satisfying.d.ts +0 -22
- package/types/deps/jsr.io/@std/semver/1.0.5/max_satisfying.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/min_satisfying.d.ts +0 -22
- package/types/deps/jsr.io/@std/semver/1.0.5/min_satisfying.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/mod.d.ts +0 -298
- package/types/deps/jsr.io/@std/semver/1.0.5/mod.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/not_equals.d.ts +0 -24
- package/types/deps/jsr.io/@std/semver/1.0.5/not_equals.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/parse.d.ts +0 -25
- package/types/deps/jsr.io/@std/semver/1.0.5/parse.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/parse_range.d.ts +0 -27
- package/types/deps/jsr.io/@std/semver/1.0.5/parse_range.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/range_intersects.d.ts +0 -25
- package/types/deps/jsr.io/@std/semver/1.0.5/range_intersects.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/satisfies.d.ts +0 -24
- package/types/deps/jsr.io/@std/semver/1.0.5/satisfies.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/try_parse.d.ts +0 -21
- package/types/deps/jsr.io/@std/semver/1.0.5/try_parse.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/try_parse_range.d.ts +0 -23
- package/types/deps/jsr.io/@std/semver/1.0.5/try_parse_range.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/semver/1.0.5/types.d.ts +0 -58
- package/types/deps/jsr.io/@std/semver/1.0.5/types.d.ts.map +0 -1
@@ -1,176 +0,0 @@
|
|
1
|
-
// Copyright 2018-2025 the Deno authors. MIT license.
|
2
|
-
// This module is browser compatible.
|
3
|
-
import { parseBuild } from "./_shared.js";
|
4
|
-
function bumpPrereleaseNumber(prerelease = []) {
|
5
|
-
const values = [...prerelease];
|
6
|
-
let index = values.length;
|
7
|
-
while (index >= 0) {
|
8
|
-
const value = values[index];
|
9
|
-
if (typeof value === "number") {
|
10
|
-
values[index] = value + 1;
|
11
|
-
break;
|
12
|
-
}
|
13
|
-
index -= 1;
|
14
|
-
}
|
15
|
-
// if no number was bumped
|
16
|
-
if (index === -1)
|
17
|
-
values.push(0);
|
18
|
-
return values;
|
19
|
-
}
|
20
|
-
function bumpPrerelease(prerelease = [], identifier) {
|
21
|
-
let values = bumpPrereleaseNumber(prerelease);
|
22
|
-
if (!identifier)
|
23
|
-
return values;
|
24
|
-
// 1.2.0-beta.1 bumps to 1.2.0-beta.2,
|
25
|
-
// 1.2.0-beta.foobar or 1.2.0-beta bumps to 1.2.0-beta.0
|
26
|
-
if (values[0] !== identifier || isNaN(values[1])) {
|
27
|
-
values = [identifier, 0];
|
28
|
-
}
|
29
|
-
return values;
|
30
|
-
}
|
31
|
-
/**
|
32
|
-
* Returns the new SemVer resulting from an increment by release type.
|
33
|
-
*
|
34
|
-
* `premajor`, `preminor` and `prepatch` will bump the version up to the next version,
|
35
|
-
* based on the type, and will also add prerelease metadata.
|
36
|
-
*
|
37
|
-
* If called from a non-prerelease version, the `prerelease` will work the same as
|
38
|
-
* `prepatch`. The patch version is incremented and then is made into a prerelease. If
|
39
|
-
* the input version is already a prerelease it will simply increment the prerelease
|
40
|
-
* metadata.
|
41
|
-
*
|
42
|
-
* If a prerelease identifier is specified without a number then a number will be added.
|
43
|
-
* For example `pre` will result in `pre.0`. If the existing version already has a
|
44
|
-
* prerelease with a number and its the same prerelease identifier then the number
|
45
|
-
* will be incremented. If the identifier differs from the new identifier then the new
|
46
|
-
* identifier is applied and the number is reset to `0`.
|
47
|
-
*
|
48
|
-
* If the input version has build metadata it will be preserved on the resulting version
|
49
|
-
* unless a new build parameter is specified. Specifying `""` will unset existing build
|
50
|
-
* metadata.
|
51
|
-
*
|
52
|
-
* @example Usage
|
53
|
-
* ```ts
|
54
|
-
* import { increment, parse } from "@std/semver";
|
55
|
-
* import { assertEquals } from "@std/assert";
|
56
|
-
*
|
57
|
-
* const version = parse("1.2.3");
|
58
|
-
* assertEquals(increment(version, "major"), parse("2.0.0"));
|
59
|
-
* assertEquals(increment(version, "minor"), parse("1.3.0"));
|
60
|
-
* assertEquals(increment(version, "patch"), parse("1.2.4"));
|
61
|
-
* assertEquals(increment(version, "prerelease"), parse("1.2.4-0"));
|
62
|
-
*
|
63
|
-
* const prerelease = parse("1.2.3-beta.0");
|
64
|
-
* assertEquals(increment(prerelease, "prerelease"), parse("1.2.3-beta.1"));
|
65
|
-
* ```
|
66
|
-
*
|
67
|
-
* @param version The version to increment
|
68
|
-
* @param release The type of increment to perform
|
69
|
-
* @param options Additional options
|
70
|
-
* @returns The new version
|
71
|
-
*/
|
72
|
-
export function increment(version, release, options = {}) {
|
73
|
-
const build = options.build !== undefined
|
74
|
-
? parseBuild(options.build)
|
75
|
-
: version.build ?? [];
|
76
|
-
switch (release) {
|
77
|
-
case "premajor":
|
78
|
-
return {
|
79
|
-
major: version.major + 1,
|
80
|
-
minor: 0,
|
81
|
-
patch: 0,
|
82
|
-
prerelease: bumpPrerelease(version.prerelease, options.prerelease),
|
83
|
-
build,
|
84
|
-
};
|
85
|
-
case "preminor":
|
86
|
-
return {
|
87
|
-
major: version.major,
|
88
|
-
minor: version.minor + 1,
|
89
|
-
patch: 0,
|
90
|
-
prerelease: bumpPrerelease(version.prerelease, options.prerelease),
|
91
|
-
build,
|
92
|
-
};
|
93
|
-
case "prepatch":
|
94
|
-
return {
|
95
|
-
major: version.major,
|
96
|
-
minor: version.minor,
|
97
|
-
patch: version.patch + 1,
|
98
|
-
prerelease: bumpPrerelease(version.prerelease, options.prerelease),
|
99
|
-
build,
|
100
|
-
};
|
101
|
-
case "prerelease": {
|
102
|
-
// If the input is a non-prerelease version, this acts the same as prepatch.
|
103
|
-
const isPrerelease = (version.prerelease ?? []).length === 0;
|
104
|
-
const patch = isPrerelease ? version.patch + 1 : version.patch;
|
105
|
-
return {
|
106
|
-
major: version.major,
|
107
|
-
minor: version.minor,
|
108
|
-
patch,
|
109
|
-
prerelease: bumpPrerelease(version.prerelease, options.prerelease),
|
110
|
-
build,
|
111
|
-
};
|
112
|
-
}
|
113
|
-
case "major": {
|
114
|
-
// If this is a pre-major version, bump up to the same major version. Otherwise increment major.
|
115
|
-
// 1.0.0-5 bumps to 1.0.0
|
116
|
-
// 1.1.0 bumps to 2.0.0
|
117
|
-
const isPrerelease = (version.prerelease ?? []).length === 0;
|
118
|
-
const major = isPrerelease || version.minor !== 0 || version.patch !== 0
|
119
|
-
? version.major + 1
|
120
|
-
: version.major;
|
121
|
-
return {
|
122
|
-
major,
|
123
|
-
minor: 0,
|
124
|
-
patch: 0,
|
125
|
-
prerelease: [],
|
126
|
-
build,
|
127
|
-
};
|
128
|
-
}
|
129
|
-
case "minor": {
|
130
|
-
// If this is a pre-minor version, bump up to the same minor version. Otherwise increment minor.
|
131
|
-
// 1.2.0-5 bumps to 1.2.0
|
132
|
-
// 1.2.1 bumps to 1.3.0
|
133
|
-
const isPrerelease = (version.prerelease ?? []).length === 0;
|
134
|
-
const minor = isPrerelease || version.patch !== 0
|
135
|
-
? version.minor + 1
|
136
|
-
: version.minor;
|
137
|
-
return {
|
138
|
-
major: version.major,
|
139
|
-
minor,
|
140
|
-
patch: 0,
|
141
|
-
prerelease: [],
|
142
|
-
build,
|
143
|
-
};
|
144
|
-
}
|
145
|
-
case "patch": {
|
146
|
-
// If this is not a pre-release version, it will increment the patch.
|
147
|
-
// If it is a pre-release it will bump up to the same patch version.
|
148
|
-
// 1.2.0-5 patches to 1.2.0
|
149
|
-
// 1.2.0 patches to 1.2.1
|
150
|
-
const isPrerelease = (version.prerelease ?? []).length === 0;
|
151
|
-
const patch = isPrerelease ? version.patch + 1 : version.patch;
|
152
|
-
return {
|
153
|
-
major: version.major,
|
154
|
-
minor: version.minor,
|
155
|
-
patch,
|
156
|
-
prerelease: [],
|
157
|
-
build,
|
158
|
-
};
|
159
|
-
}
|
160
|
-
case "pre": {
|
161
|
-
// 1.0.0 "pre" would become 1.0.0-0
|
162
|
-
// 1.0.0-0 would become 1.0.0-1
|
163
|
-
// 1.0.0-beta.0 would be come 1.0.0-beta.1
|
164
|
-
// switching the pre identifier resets the number to 0
|
165
|
-
return {
|
166
|
-
major: version.major,
|
167
|
-
minor: version.minor,
|
168
|
-
patch: version.patch,
|
169
|
-
prerelease: bumpPrerelease(version.prerelease, options.prerelease),
|
170
|
-
build,
|
171
|
-
};
|
172
|
-
}
|
173
|
-
default:
|
174
|
-
throw new TypeError(`Cannot increment version: invalid argument ${release}`);
|
175
|
-
}
|
176
|
-
}
|
@@ -1,38 +0,0 @@
|
|
1
|
-
import { OPERATORS } from "./_constants.js";
|
2
|
-
import { ALL } from "./_constants.js";
|
3
|
-
import { isSemVer } from "./is_semver.js";
|
4
|
-
function isComparator(value) {
|
5
|
-
if (value === null || value === undefined || Array.isArray(value) ||
|
6
|
-
typeof value !== "object")
|
7
|
-
return false;
|
8
|
-
if (value === ALL)
|
9
|
-
return true;
|
10
|
-
const { operator } = value;
|
11
|
-
return ((operator === undefined ||
|
12
|
-
OPERATORS.includes(operator)) &&
|
13
|
-
isSemVer(value));
|
14
|
-
}
|
15
|
-
/**
|
16
|
-
* Does a deep check on the object to determine if its a valid range.
|
17
|
-
*
|
18
|
-
* Objects with extra fields are still considered valid if they have at
|
19
|
-
* least the correct fields.
|
20
|
-
*
|
21
|
-
* Adds a type assertion if true.
|
22
|
-
*
|
23
|
-
* @example Usage
|
24
|
-
* ```ts
|
25
|
-
* import { isRange } from "@std/semver/is-range";
|
26
|
-
* import { assert } from "@std/assert";
|
27
|
-
*
|
28
|
-
* const range = [[{ major: 1, minor: 2, patch: 3 }]];
|
29
|
-
* assert(isRange(range));
|
30
|
-
* assert(!isRange({}));
|
31
|
-
* ```
|
32
|
-
* @param value The value to check if its a valid Range
|
33
|
-
* @returns True if its a valid Range otherwise false.
|
34
|
-
*/
|
35
|
-
export function isRange(value) {
|
36
|
-
return Array.isArray(value) &&
|
37
|
-
value.every((r) => Array.isArray(r) && r.every((c) => isComparator(c)));
|
38
|
-
}
|
@@ -1,53 +0,0 @@
|
|
1
|
-
// Copyright 2018-2025 the Deno authors. MIT license.
|
2
|
-
// This module is browser compatible.
|
3
|
-
import { ANY } from "./_constants.js";
|
4
|
-
import { isValidNumber, isValidString } from "./_shared.js";
|
5
|
-
/**
|
6
|
-
* Checks to see if value is a valid SemVer object. It does a check
|
7
|
-
* into each field including prerelease and build.
|
8
|
-
*
|
9
|
-
* Some invalid SemVer sentinels can still return true such as ANY and INVALID.
|
10
|
-
* An object which has the same value as a sentinel but isn't reference equal
|
11
|
-
* will still fail.
|
12
|
-
*
|
13
|
-
* Objects which are valid SemVer objects but have _extra_ fields are still
|
14
|
-
* considered SemVer objects and this will return true.
|
15
|
-
*
|
16
|
-
* A type assertion is added to the value.
|
17
|
-
*
|
18
|
-
* @example Usage
|
19
|
-
* ```ts
|
20
|
-
* import { isSemVer } from "@std/semver/is-semver";
|
21
|
-
* import { assert } from "@std/assert";
|
22
|
-
*
|
23
|
-
* const value = {
|
24
|
-
* major: 1,
|
25
|
-
* minor: 2,
|
26
|
-
* patch: 3,
|
27
|
-
* };
|
28
|
-
*
|
29
|
-
* assert(isSemVer(value));
|
30
|
-
* assert(!isSemVer({ major: 1, minor: 2 }));
|
31
|
-
* ```
|
32
|
-
*
|
33
|
-
* @param value The value to check to see if its a valid SemVer object
|
34
|
-
* @returns True if value is a valid SemVer otherwise false
|
35
|
-
*/
|
36
|
-
export function isSemVer(value) {
|
37
|
-
if (value === null || value === undefined)
|
38
|
-
return false;
|
39
|
-
if (Array.isArray(value))
|
40
|
-
return false;
|
41
|
-
if (typeof value !== "object")
|
42
|
-
return false;
|
43
|
-
if (value === ANY)
|
44
|
-
return true;
|
45
|
-
const { major, minor, patch, build = [], prerelease = [], } = value;
|
46
|
-
return (isValidNumber(major) &&
|
47
|
-
isValidNumber(minor) &&
|
48
|
-
isValidNumber(patch) &&
|
49
|
-
Array.isArray(prerelease) &&
|
50
|
-
prerelease.every((v) => isValidString(v) || isValidNumber(v)) &&
|
51
|
-
Array.isArray(build) &&
|
52
|
-
build.every(isValidString));
|
53
|
-
}
|
@@ -1,26 +0,0 @@
|
|
1
|
-
import { compare } from "./compare.js";
|
2
|
-
/**
|
3
|
-
* Less than or equal to comparison for two SemVers.
|
4
|
-
*
|
5
|
-
* This is equal to `compare(version1, version2) <= 0`.
|
6
|
-
*
|
7
|
-
* @example Usage
|
8
|
-
* ```ts
|
9
|
-
* import { parse, lessOrEqual } from "@std/semver";
|
10
|
-
* import { assert } from "@std/assert";
|
11
|
-
*
|
12
|
-
* const version1 = parse("1.2.3");
|
13
|
-
* const version2 = parse("1.2.4");
|
14
|
-
*
|
15
|
-
* assert(lessOrEqual(version1, version2));
|
16
|
-
* assert(!lessOrEqual(version2, version1));
|
17
|
-
* assert(lessOrEqual(version1, version1));
|
18
|
-
* ```
|
19
|
-
*
|
20
|
-
* @param version1 the first version to compare
|
21
|
-
* @param version2 the second version to compare
|
22
|
-
* @returns `true` if `version1` is less than or equal to `version2`, `false` otherwise
|
23
|
-
*/
|
24
|
-
export function lessOrEqual(version1, version2) {
|
25
|
-
return compare(version1, version2) <= 0;
|
26
|
-
}
|
@@ -1,26 +0,0 @@
|
|
1
|
-
import { compare } from "./compare.js";
|
2
|
-
/**
|
3
|
-
* Less than comparison for two SemVers.
|
4
|
-
*
|
5
|
-
* This is equal to `compare(version1, version2) < 0`.
|
6
|
-
*
|
7
|
-
* @example Usage
|
8
|
-
* ```ts
|
9
|
-
* import { parse, lessThan } from "@std/semver";
|
10
|
-
* import { assert } from "@std/assert";
|
11
|
-
*
|
12
|
-
* const version1 = parse("1.2.3");
|
13
|
-
* const version2 = parse("1.2.4");
|
14
|
-
*
|
15
|
-
* assert(lessThan(version1, version2));
|
16
|
-
* assert(!lessThan(version2, version1));
|
17
|
-
* assert(!lessThan(version1, version1));
|
18
|
-
* ```
|
19
|
-
*
|
20
|
-
* @param version1 the first version to compare
|
21
|
-
* @param version2 the second version to compare
|
22
|
-
* @returns `true` if `version1` is less than `version2`, `false` otherwise
|
23
|
-
*/
|
24
|
-
export function lessThan(version1, version2) {
|
25
|
-
return compare(version1, version2) < 0;
|
26
|
-
}
|
@@ -1,58 +0,0 @@
|
|
1
|
-
// Copyright 2018-2025 the Deno authors. MIT license.
|
2
|
-
// This module is browser compatible.
|
3
|
-
import { testComparatorSet } from "./_test_comparator_set.js";
|
4
|
-
import { isWildcardComparator } from "./_shared.js";
|
5
|
-
import { compare } from "./compare.js";
|
6
|
-
/**
|
7
|
-
* Check if the SemVer is less than the range.
|
8
|
-
*
|
9
|
-
* @example Usage
|
10
|
-
* ```ts
|
11
|
-
* import { parse, parseRange, lessThanRange } from "@std/semver";
|
12
|
-
* import { assert } from "@std/assert";
|
13
|
-
*
|
14
|
-
* const version1 = parse("1.2.3");
|
15
|
-
* const version2 = parse("1.0.0");
|
16
|
-
* const range = parseRange(">=1.2.3 <1.2.4");
|
17
|
-
*
|
18
|
-
* assert(!lessThanRange(version1, range));
|
19
|
-
* assert(lessThanRange(version2, range));
|
20
|
-
* ```
|
21
|
-
*
|
22
|
-
* @param version The version to check.
|
23
|
-
* @param range The range to check against.
|
24
|
-
* @returns `true` if the SemVer is less than the range, `false` otherwise.
|
25
|
-
*/
|
26
|
-
export function lessThanRange(version, range) {
|
27
|
-
return range.every((comparatorSet) => lessThanComparatorSet(version, comparatorSet));
|
28
|
-
}
|
29
|
-
function lessThanComparatorSet(version, comparatorSet) {
|
30
|
-
// If the comparator set contains wildcard, then the semver is not greater than the range.
|
31
|
-
if (comparatorSet.some(isWildcardComparator))
|
32
|
-
return false;
|
33
|
-
// If the SemVer satisfies the comparator set, then it's not less than the range.
|
34
|
-
if (testComparatorSet(version, comparatorSet))
|
35
|
-
return false;
|
36
|
-
// If the SemVer is greater than any of the comparator set, then it's not less than the range.
|
37
|
-
if (comparatorSet.some((comparator) => greaterThanComparator(version, comparator)))
|
38
|
-
return false;
|
39
|
-
return true;
|
40
|
-
}
|
41
|
-
function greaterThanComparator(version, comparator) {
|
42
|
-
const cmp = compare(version, comparator);
|
43
|
-
switch (comparator.operator) {
|
44
|
-
case "=":
|
45
|
-
case undefined:
|
46
|
-
return cmp > 0;
|
47
|
-
case "!=":
|
48
|
-
return false;
|
49
|
-
case ">":
|
50
|
-
return false;
|
51
|
-
case "<":
|
52
|
-
return cmp >= 0;
|
53
|
-
case ">=":
|
54
|
-
return false;
|
55
|
-
case "<=":
|
56
|
-
return cmp > 0;
|
57
|
-
}
|
58
|
-
}
|
@@ -1,30 +0,0 @@
|
|
1
|
-
import { satisfies } from "./satisfies.js";
|
2
|
-
import { greaterThan } from "./greater_than.js";
|
3
|
-
/**
|
4
|
-
* Returns the highest SemVer in the list that satisfies the range, or `undefined`
|
5
|
-
* if none of them do.
|
6
|
-
*
|
7
|
-
* @example Usage
|
8
|
-
* ```ts
|
9
|
-
* import { parse, parseRange, maxSatisfying } from "@std/semver";
|
10
|
-
* import { assertEquals } from "@std/assert";
|
11
|
-
*
|
12
|
-
* const versions = ["1.2.3", "1.2.4", "1.3.0", "2.0.0", "2.1.0"].map(parse);
|
13
|
-
* const range = parseRange(">=1.0.0 <2.0.0");
|
14
|
-
*
|
15
|
-
* assertEquals(maxSatisfying(versions, range), parse("1.3.0"));
|
16
|
-
* ```
|
17
|
-
*
|
18
|
-
* @param versions The versions to check.
|
19
|
-
* @param range The range of possible versions to compare to.
|
20
|
-
* @returns The highest version in versions that satisfies the range.
|
21
|
-
*/
|
22
|
-
export function maxSatisfying(versions, range) {
|
23
|
-
let max;
|
24
|
-
for (const version of versions) {
|
25
|
-
if (!satisfies(version, range))
|
26
|
-
continue;
|
27
|
-
max = max && greaterThan(max, version) ? max : version;
|
28
|
-
}
|
29
|
-
return max;
|
30
|
-
}
|
@@ -1,30 +0,0 @@
|
|
1
|
-
import { satisfies } from "./satisfies.js";
|
2
|
-
import { lessThan } from "./less_than.js";
|
3
|
-
/**
|
4
|
-
* Returns the lowest SemVer in the list that satisfies the range, or `undefined` if
|
5
|
-
* none of them do.
|
6
|
-
*
|
7
|
-
* @example Usage
|
8
|
-
* ```ts
|
9
|
-
* import { parse, parseRange, minSatisfying } from "@std/semver";
|
10
|
-
* import { assertEquals } from "@std/assert";
|
11
|
-
*
|
12
|
-
* const versions = ["0.2.0", "1.2.3", "1.3.0", "2.0.0", "2.1.0"].map(parse);
|
13
|
-
* const range = parseRange(">=1.0.0 <2.0.0");
|
14
|
-
*
|
15
|
-
* assertEquals(minSatisfying(versions, range), parse("1.2.3"));
|
16
|
-
* ```
|
17
|
-
*
|
18
|
-
* @param versions The versions to check.
|
19
|
-
* @param range The range of possible versions to compare to.
|
20
|
-
* @returns The lowest version in versions that satisfies the range.
|
21
|
-
*/
|
22
|
-
export function minSatisfying(versions, range) {
|
23
|
-
let min;
|
24
|
-
for (const version of versions) {
|
25
|
-
if (!satisfies(version, range))
|
26
|
-
continue;
|
27
|
-
min = min && lessThan(min, version) ? min : version;
|
28
|
-
}
|
29
|
-
return min;
|
30
|
-
}
|