@based/schema 5.0.0 → 5.0.2
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/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/parse/assert.d.ts +1 -1
- package/dist/parse/assert.js +1 -1
- package/dist/parse/index.js +4 -1
- package/dist/parse/semver/_constants.d.ts +12 -0
- package/dist/parse/semver/_constants.js +21 -0
- package/dist/parse/semver/_shared.d.ts +44 -0
- package/dist/parse/semver/_shared.js +165 -0
- package/dist/parse/semver/_test_comparator_set.d.ts +3 -0
- package/dist/parse/semver/_test_comparator_set.js +60 -0
- package/dist/parse/semver/can_parse.d.ts +17 -0
- package/dist/parse/semver/can_parse.js +28 -0
- package/dist/parse/semver/compare.d.ts +28 -0
- package/dist/parse/semver/compare.js +36 -0
- package/dist/parse/semver/difference.d.ts +27 -0
- package/dist/parse/semver/difference.js +41 -0
- package/dist/parse/semver/equals.d.ts +24 -0
- package/dist/parse/semver/equals.js +28 -0
- package/dist/parse/semver/format.d.ts +22 -0
- package/dist/parse/semver/format.js +33 -0
- package/dist/parse/semver/format_range.d.ts +18 -0
- package/dist/parse/semver/format_range.js +29 -0
- package/dist/parse/semver/greater_or_equal.d.ts +25 -0
- package/dist/parse/semver/greater_or_equal.js +27 -0
- package/dist/parse/semver/greater_than.d.ts +25 -0
- package/dist/parse/semver/greater_than.js +29 -0
- package/dist/parse/semver/greater_than_range.d.ts +23 -0
- package/dist/parse/semver/greater_than_range.js +59 -0
- package/dist/parse/semver/increment.d.ts +51 -0
- package/dist/parse/semver/increment.js +175 -0
- package/dist/parse/semver/is_range.d.ts +23 -0
- package/dist/parse/semver/is_range.js +39 -0
- package/dist/parse/semver/is_semver.d.ts +34 -0
- package/dist/parse/semver/is_semver.js +54 -0
- package/dist/parse/semver/less_or_equal.d.ts +25 -0
- package/dist/parse/semver/less_or_equal.js +27 -0
- package/dist/parse/semver/less_than.d.ts +25 -0
- package/dist/parse/semver/less_than.js +27 -0
- package/dist/parse/semver/less_than_range.d.ts +23 -0
- package/dist/parse/semver/less_than_range.js +59 -0
- package/dist/parse/semver/max_satisfying.d.ts +22 -0
- package/dist/parse/semver/max_satisfying.js +31 -0
- package/dist/parse/semver/min_satisfying.d.ts +22 -0
- package/dist/parse/semver/min_satisfying.js +31 -0
- package/dist/parse/semver/mod.d.ts +298 -0
- package/dist/parse/semver/mod.js +301 -0
- package/dist/parse/semver/not_equals.d.ts +24 -0
- package/dist/parse/semver/not_equals.js +26 -0
- package/dist/parse/semver/parse.d.ts +25 -0
- package/dist/parse/semver/parse.js +43 -0
- package/dist/parse/semver/parse_range.d.ts +27 -0
- package/dist/parse/semver/parse_range.js +361 -0
- package/dist/parse/semver/range_intersects.d.ts +25 -0
- package/dist/parse/semver/range_intersects.js +83 -0
- package/dist/parse/semver/satisfies.d.ts +24 -0
- package/dist/parse/semver/satisfies.js +28 -0
- package/dist/parse/semver/try_parse.d.ts +21 -0
- package/dist/parse/semver/try_parse.js +28 -0
- package/dist/parse/semver/try_parse_range.d.ts +23 -0
- package/dist/parse/semver/try_parse_range.js +34 -0
- package/dist/parse/semver/types.d.ts +58 -0
- package/dist/parse/semver/types.js +4 -0
- package/package.json +1 -2
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
package/dist/parse/assert.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { SemVer } from './semver/types.js';
|
|
2
2
|
export declare const expectVersion: (obj: any) => SemVer;
|
|
3
3
|
export declare const expectObject: (obj: any, msg?: string) => void;
|
|
4
4
|
export declare const expectArray: (obj: any) => void;
|
package/dist/parse/assert.js
CHANGED
package/dist/parse/index.js
CHANGED
|
@@ -4,7 +4,10 @@ import propParsers from './props.js';
|
|
|
4
4
|
import pc from 'picocolors';
|
|
5
5
|
import { expectArray, expectBoolean, expectFunction, expectObject, expectTimezoneName, expectVersion, } from './assert.js';
|
|
6
6
|
import { deepCopy } from '@based/utils';
|
|
7
|
-
import {
|
|
7
|
+
import { parse as parseVersion } from './semver/parse.js';
|
|
8
|
+
import { parseRange } from './semver/parse_range.js';
|
|
9
|
+
import { satisfies } from './semver/satisfies.js';
|
|
10
|
+
import { rangeIntersects } from './semver/range_intersects.js';
|
|
8
11
|
export { getPropType };
|
|
9
12
|
export class SchemaParser {
|
|
10
13
|
constructor(schema) {
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { Comparator, SemVer } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* ANY is a sentinel value used by some range calculations. It is not a valid
|
|
4
|
+
* SemVer object and should not be used directly.
|
|
5
|
+
*/
|
|
6
|
+
export declare const ANY: SemVer;
|
|
7
|
+
/**
|
|
8
|
+
* A comparator which will span all valid semantic versions
|
|
9
|
+
*/
|
|
10
|
+
export declare const ALL: Comparator;
|
|
11
|
+
export declare const OPERATORS: readonly [any, "=", "!=", ">", ">=", "<", "<="];
|
|
12
|
+
//# sourceMappingURL=_constants.d.ts.map
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
/**
|
|
3
|
+
* ANY is a sentinel value used by some range calculations. It is not a valid
|
|
4
|
+
* SemVer object and should not be used directly.
|
|
5
|
+
*/
|
|
6
|
+
export const ANY = {
|
|
7
|
+
major: Number.NaN,
|
|
8
|
+
minor: Number.NaN,
|
|
9
|
+
patch: Number.NaN,
|
|
10
|
+
prerelease: [],
|
|
11
|
+
build: [],
|
|
12
|
+
};
|
|
13
|
+
/**
|
|
14
|
+
* A comparator which will span all valid semantic versions
|
|
15
|
+
*/
|
|
16
|
+
export const ALL = {
|
|
17
|
+
operator: undefined,
|
|
18
|
+
...ANY,
|
|
19
|
+
};
|
|
20
|
+
export const OPERATORS = [undefined, '=', '!=', '>', '>=', '<', '<='];
|
|
21
|
+
//# sourceMappingURL=_constants.js.map
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import type { Comparator } from './types.js';
|
|
2
|
+
export declare function compareNumber(a: number, b: number): 1 | 0 | -1;
|
|
3
|
+
export declare function checkIdentifier(v1?: ReadonlyArray<string | number>, v2?: ReadonlyArray<string | number>): 1 | 0 | -1;
|
|
4
|
+
export declare function compareIdentifier(v1?: ReadonlyArray<string | number>, v2?: ReadonlyArray<string | number>): 1 | 0 | -1;
|
|
5
|
+
export declare const FULL_REGEXP: RegExp;
|
|
6
|
+
/**
|
|
7
|
+
* A version that can contain wildcards.
|
|
8
|
+
* @example "x", "1.x", "1.x.x", "1.2.x", "*", "1.*", "1.*.*", "1.2.*"
|
|
9
|
+
*/
|
|
10
|
+
export declare const XRANGE = "[v=\\s]*(?<major>0|[1-9]\\d*|x|X|\\*)(?:\\.(?<minor>0|[1-9]\\d*|x|X|\\*)(?:\\.(?<patch>0|[1-9]\\d*|x|X|\\*)(?:-(?<prerelease>(?:0|[1-9]\\d*|\\d*[a-zA-Z-][a-zA-Z0-9-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][a-zA-Z0-9-]*))*))?(?:\\+(?<buildmetadata>[0-9A-Za-z-]+(?:\\.[0-9A-Za-z-]+)*))?)?)?";
|
|
11
|
+
/**
|
|
12
|
+
* An operator (`~`, `~>`, `^`, `=`, `<`, `<=`, `>`, or `>=`), followed by an x-range.
|
|
13
|
+
* @example "~1.x.x", "^1.2.*", ">=1.2.3"
|
|
14
|
+
*/
|
|
15
|
+
export declare const OPERATOR_XRANGE_REGEXP: RegExp;
|
|
16
|
+
/**
|
|
17
|
+
* An empty string or a comparator (`=`, `<`, `<=`, `>`, or `>=`), followed by a version.
|
|
18
|
+
* @example ">1.2.3"
|
|
19
|
+
*/
|
|
20
|
+
export declare const COMPARATOR_REGEXP: RegExp;
|
|
21
|
+
/**
|
|
22
|
+
* Returns true if the value is a valid SemVer number.
|
|
23
|
+
*
|
|
24
|
+
* Must be a number. Must not be NaN. Can be positive or negative infinity.
|
|
25
|
+
* Can be between 0 and MAX_SAFE_INTEGER.
|
|
26
|
+
* @param value The value to check
|
|
27
|
+
* @returns True if its a valid semver number
|
|
28
|
+
*/
|
|
29
|
+
export declare function isValidNumber(value: unknown): value is number;
|
|
30
|
+
export declare const MAX_LENGTH = 256;
|
|
31
|
+
/**
|
|
32
|
+
* Returns true if the value is a valid semver pre-release or build identifier.
|
|
33
|
+
*
|
|
34
|
+
* Must be a string. Must be between 1 and 256 characters long. Must match
|
|
35
|
+
* the regular expression /[0-9A-Za-z-]+/.
|
|
36
|
+
* @param value The value to check
|
|
37
|
+
* @returns True if the value is a valid semver string.
|
|
38
|
+
*/
|
|
39
|
+
export declare function isValidString(value: unknown): value is string;
|
|
40
|
+
export declare function parsePrerelease(prerelease: string): (string | number)[];
|
|
41
|
+
export declare function parseBuild(buildmetadata: string): string[];
|
|
42
|
+
export declare function parseNumber(input: string, errorMessage: string): number;
|
|
43
|
+
export declare function isWildcardComparator(c: Comparator): boolean;
|
|
44
|
+
//# sourceMappingURL=_shared.d.ts.map
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
export function compareNumber(a, b) {
|
|
3
|
+
if (isNaN(a) || isNaN(b)) {
|
|
4
|
+
throw new Error('Cannot compare against non-numbers');
|
|
5
|
+
}
|
|
6
|
+
return a === b ? 0 : a < b ? -1 : 1;
|
|
7
|
+
}
|
|
8
|
+
export function checkIdentifier(v1 = [], v2 = []) {
|
|
9
|
+
// NOT having a prerelease is > having one
|
|
10
|
+
// But NOT having a build is < having one
|
|
11
|
+
if (v1.length && !v2.length)
|
|
12
|
+
return -1;
|
|
13
|
+
if (!v1.length && v2.length)
|
|
14
|
+
return 1;
|
|
15
|
+
return 0;
|
|
16
|
+
}
|
|
17
|
+
export function compareIdentifier(v1 = [], v2 = []) {
|
|
18
|
+
const length = Math.max(v1.length, v2.length);
|
|
19
|
+
for (let i = 0; i < length; i++) {
|
|
20
|
+
const a = v1[i];
|
|
21
|
+
const b = v2[i];
|
|
22
|
+
// same length is equal
|
|
23
|
+
if (a === undefined && b === undefined)
|
|
24
|
+
return 0;
|
|
25
|
+
// longer > shorter
|
|
26
|
+
if (b === undefined)
|
|
27
|
+
return 1;
|
|
28
|
+
// shorter < longer
|
|
29
|
+
if (a === undefined)
|
|
30
|
+
return -1;
|
|
31
|
+
// string > number
|
|
32
|
+
if (typeof a === 'string' && typeof b === 'number')
|
|
33
|
+
return 1;
|
|
34
|
+
// number < string
|
|
35
|
+
if (typeof a === 'number' && typeof b === 'string')
|
|
36
|
+
return -1;
|
|
37
|
+
if (a < b)
|
|
38
|
+
return -1;
|
|
39
|
+
if (a > b)
|
|
40
|
+
return 1;
|
|
41
|
+
// If they're equal, continue comparing segments.
|
|
42
|
+
}
|
|
43
|
+
return 0;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* A single `0`, or a non-zero digit followed by zero or more digits.
|
|
47
|
+
*/
|
|
48
|
+
const NUMERIC_IDENTIFIER = '0|[1-9]\\d*';
|
|
49
|
+
/**
|
|
50
|
+
* Zero or more digits, followed by a letter or hyphen, and then zero or more letters, digits, or hyphens.
|
|
51
|
+
*/
|
|
52
|
+
const NON_NUMERIC_IDENTIFIER = '\\d*[a-zA-Z-][a-zA-Z0-9-]*';
|
|
53
|
+
/**
|
|
54
|
+
* Three dot-separated numeric identifiers.
|
|
55
|
+
*/
|
|
56
|
+
const VERSION_CORE = `(?<major>${NUMERIC_IDENTIFIER})\\.(?<minor>${NUMERIC_IDENTIFIER})\\.(?<patch>${NUMERIC_IDENTIFIER})`;
|
|
57
|
+
/**
|
|
58
|
+
* A numeric identifier, or a non-numeric identifier.
|
|
59
|
+
*/
|
|
60
|
+
const PRERELEASE_IDENTIFIER = `(?:${NUMERIC_IDENTIFIER}|${NON_NUMERIC_IDENTIFIER})`;
|
|
61
|
+
/**
|
|
62
|
+
* A hyphen, followed by one or more dot-separated pre-release version identifiers.
|
|
63
|
+
* @example "-pre.release"
|
|
64
|
+
*/
|
|
65
|
+
const PRERELEASE = `(?:-(?<prerelease>${PRERELEASE_IDENTIFIER}(?:\\.${PRERELEASE_IDENTIFIER})*))`;
|
|
66
|
+
/**
|
|
67
|
+
* Any combination of digits, letters, or hyphens.
|
|
68
|
+
*/
|
|
69
|
+
const BUILD_IDENTIFIER = '[0-9A-Za-z-]+';
|
|
70
|
+
/**
|
|
71
|
+
* A plus sign, followed by one or more period-separated build metadata identifiers.
|
|
72
|
+
* @example "+build.meta"
|
|
73
|
+
*/
|
|
74
|
+
const BUILD = `(?:\\+(?<buildmetadata>${BUILD_IDENTIFIER}(?:\\.${BUILD_IDENTIFIER})*))`;
|
|
75
|
+
/**
|
|
76
|
+
* A version, followed optionally by a pre-release version and build metadata.
|
|
77
|
+
*/
|
|
78
|
+
const FULL_VERSION = `v?${VERSION_CORE}${PRERELEASE}?${BUILD}?`;
|
|
79
|
+
export const FULL_REGEXP = new RegExp(`^${FULL_VERSION}$`);
|
|
80
|
+
/**
|
|
81
|
+
* A comparator.
|
|
82
|
+
* @example `=`, `<`, `<=`, `>`, `>=`
|
|
83
|
+
*/
|
|
84
|
+
const COMPARATOR = '(?:<|>)?=?';
|
|
85
|
+
/**
|
|
86
|
+
* A wildcard identifier.
|
|
87
|
+
* @example "x", "X", "*"
|
|
88
|
+
*/
|
|
89
|
+
const WILDCARD_IDENTIFIER = `x|X|\\*`;
|
|
90
|
+
const XRANGE_IDENTIFIER = `${NUMERIC_IDENTIFIER}|${WILDCARD_IDENTIFIER}`;
|
|
91
|
+
/**
|
|
92
|
+
* A version that can contain wildcards.
|
|
93
|
+
* @example "x", "1.x", "1.x.x", "1.2.x", "*", "1.*", "1.*.*", "1.2.*"
|
|
94
|
+
*/
|
|
95
|
+
export const XRANGE = `[v=\\s]*(?<major>${XRANGE_IDENTIFIER})(?:\\.(?<minor>${XRANGE_IDENTIFIER})(?:\\.(?<patch>${XRANGE_IDENTIFIER})${PRERELEASE}?${BUILD}?)?)?`;
|
|
96
|
+
/**
|
|
97
|
+
* An operator (`~`, `~>`, `^`, `=`, `<`, `<=`, `>`, or `>=`), followed by an x-range.
|
|
98
|
+
* @example "~1.x.x", "^1.2.*", ">=1.2.3"
|
|
99
|
+
*/
|
|
100
|
+
export const OPERATOR_XRANGE_REGEXP = new RegExp(`^(?<operator>~>?|\\^|${COMPARATOR})\\s*${XRANGE}$`);
|
|
101
|
+
/**
|
|
102
|
+
* An empty string or a comparator (`=`, `<`, `<=`, `>`, or `>=`), followed by a version.
|
|
103
|
+
* @example ">1.2.3"
|
|
104
|
+
*/
|
|
105
|
+
export const COMPARATOR_REGEXP = new RegExp(`^(?<operator>${COMPARATOR})\\s*(${FULL_VERSION})$|^$`);
|
|
106
|
+
/**
|
|
107
|
+
* Returns true if the value is a valid SemVer number.
|
|
108
|
+
*
|
|
109
|
+
* Must be a number. Must not be NaN. Can be positive or negative infinity.
|
|
110
|
+
* Can be between 0 and MAX_SAFE_INTEGER.
|
|
111
|
+
* @param value The value to check
|
|
112
|
+
* @returns True if its a valid semver number
|
|
113
|
+
*/
|
|
114
|
+
export function isValidNumber(value) {
|
|
115
|
+
return (typeof value === 'number' &&
|
|
116
|
+
!Number.isNaN(value) &&
|
|
117
|
+
(!Number.isFinite(value) ||
|
|
118
|
+
(0 <= value && value <= Number.MAX_SAFE_INTEGER)));
|
|
119
|
+
}
|
|
120
|
+
export const MAX_LENGTH = 256;
|
|
121
|
+
/**
|
|
122
|
+
* Returns true if the value is a valid semver pre-release or build identifier.
|
|
123
|
+
*
|
|
124
|
+
* Must be a string. Must be between 1 and 256 characters long. Must match
|
|
125
|
+
* the regular expression /[0-9A-Za-z-]+/.
|
|
126
|
+
* @param value The value to check
|
|
127
|
+
* @returns True if the value is a valid semver string.
|
|
128
|
+
*/
|
|
129
|
+
export function isValidString(value) {
|
|
130
|
+
return (typeof value === 'string' &&
|
|
131
|
+
value.length > 0 &&
|
|
132
|
+
value.length <= MAX_LENGTH &&
|
|
133
|
+
/[0-9A-Za-z-]+/.test(value));
|
|
134
|
+
}
|
|
135
|
+
const NUMERIC_IDENTIFIER_REGEXP = new RegExp(`^${NUMERIC_IDENTIFIER}$`);
|
|
136
|
+
export function parsePrerelease(prerelease) {
|
|
137
|
+
return prerelease
|
|
138
|
+
.split('.')
|
|
139
|
+
.filter(Boolean)
|
|
140
|
+
.map((id) => {
|
|
141
|
+
if (NUMERIC_IDENTIFIER_REGEXP.test(id)) {
|
|
142
|
+
const number = Number(id);
|
|
143
|
+
if (isValidNumber(number))
|
|
144
|
+
return number;
|
|
145
|
+
}
|
|
146
|
+
return id;
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
export function parseBuild(buildmetadata) {
|
|
150
|
+
return buildmetadata.split('.').filter(Boolean);
|
|
151
|
+
}
|
|
152
|
+
export function parseNumber(input, errorMessage) {
|
|
153
|
+
const number = Number(input);
|
|
154
|
+
if (!isValidNumber(number))
|
|
155
|
+
throw new TypeError(errorMessage);
|
|
156
|
+
return number;
|
|
157
|
+
}
|
|
158
|
+
export function isWildcardComparator(c) {
|
|
159
|
+
return (Number.isNaN(c.major) &&
|
|
160
|
+
Number.isNaN(c.minor) &&
|
|
161
|
+
Number.isNaN(c.patch) &&
|
|
162
|
+
(c.prerelease === undefined || c.prerelease.length === 0) &&
|
|
163
|
+
(c.build === undefined || c.build.length === 0));
|
|
164
|
+
}
|
|
165
|
+
//# sourceMappingURL=_shared.js.map
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
import { isWildcardComparator } from './_shared.js';
|
|
3
|
+
import { compare } from './compare.js';
|
|
4
|
+
function testComparator(version, comparator) {
|
|
5
|
+
if (isWildcardComparator(comparator)) {
|
|
6
|
+
return true;
|
|
7
|
+
}
|
|
8
|
+
const cmp = compare(version, comparator);
|
|
9
|
+
switch (comparator.operator) {
|
|
10
|
+
case '=':
|
|
11
|
+
case undefined: {
|
|
12
|
+
return cmp === 0;
|
|
13
|
+
}
|
|
14
|
+
case '!=': {
|
|
15
|
+
return cmp !== 0;
|
|
16
|
+
}
|
|
17
|
+
case '>': {
|
|
18
|
+
return cmp > 0;
|
|
19
|
+
}
|
|
20
|
+
case '<': {
|
|
21
|
+
return cmp < 0;
|
|
22
|
+
}
|
|
23
|
+
case '>=': {
|
|
24
|
+
return cmp >= 0;
|
|
25
|
+
}
|
|
26
|
+
case '<=': {
|
|
27
|
+
return cmp <= 0;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
export function testComparatorSet(version, set) {
|
|
32
|
+
for (const comparator of set) {
|
|
33
|
+
if (!testComparator(version, comparator)) {
|
|
34
|
+
return false;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
if (version.prerelease && version.prerelease.length > 0) {
|
|
38
|
+
// Find the comparator that is allowed to have prereleases
|
|
39
|
+
// For example, ^1.2.3-pr.1 desugars to >=1.2.3-pr.1 <2.0.0
|
|
40
|
+
// That should allow `1.2.3-pr.2` to pass.
|
|
41
|
+
// However, `1.2.4-alpha.notready` should NOT be allowed,
|
|
42
|
+
// even though it's within the range set by the comparators.
|
|
43
|
+
for (const comparator of set) {
|
|
44
|
+
if (isWildcardComparator(comparator)) {
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
const { major, minor, patch, prerelease } = comparator;
|
|
48
|
+
if (prerelease && prerelease.length > 0) {
|
|
49
|
+
if (version.major === major &&
|
|
50
|
+
version.minor === minor &&
|
|
51
|
+
version.patch === patch) {
|
|
52
|
+
return true;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
return false;
|
|
57
|
+
}
|
|
58
|
+
return true;
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=_test_comparator_set.js.map
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Returns true if the string can be parsed as SemVer.
|
|
3
|
+
*
|
|
4
|
+
* @example Usage
|
|
5
|
+
* ```ts
|
|
6
|
+
* import { canParse } from "@std/semver/can-parse";
|
|
7
|
+
* import { assert, assertFalse } from "@std/assert";
|
|
8
|
+
*
|
|
9
|
+
* assert(canParse("1.2.3"));
|
|
10
|
+
* assertFalse(canParse("invalid"));
|
|
11
|
+
* ```
|
|
12
|
+
*
|
|
13
|
+
* @param value The version string to check
|
|
14
|
+
* @returns `true` if the string can be parsed as SemVer, `false` otherwise
|
|
15
|
+
*/
|
|
16
|
+
export declare function canParse(value: string): boolean;
|
|
17
|
+
//# sourceMappingURL=can_parse.d.ts.map
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { parse } from './parse.js';
|
|
4
|
+
/**
|
|
5
|
+
* Returns true if the string can be parsed as SemVer.
|
|
6
|
+
*
|
|
7
|
+
* @example Usage
|
|
8
|
+
* ```ts
|
|
9
|
+
* import { canParse } from "@std/semver/can-parse";
|
|
10
|
+
* import { assert, assertFalse } from "@std/assert";
|
|
11
|
+
*
|
|
12
|
+
* assert(canParse("1.2.3"));
|
|
13
|
+
* assertFalse(canParse("invalid"));
|
|
14
|
+
* ```
|
|
15
|
+
*
|
|
16
|
+
* @param value The version string to check
|
|
17
|
+
* @returns `true` if the string can be parsed as SemVer, `false` otherwise
|
|
18
|
+
*/
|
|
19
|
+
export function canParse(value) {
|
|
20
|
+
try {
|
|
21
|
+
parse(value);
|
|
22
|
+
return true;
|
|
23
|
+
}
|
|
24
|
+
catch {
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=can_parse.js.map
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { SemVer } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Compare two SemVers.
|
|
4
|
+
*
|
|
5
|
+
* Returns `0` if `version1` equals `version2`, or `1` if `version1` is greater, or `-1` if `version2` is
|
|
6
|
+
* greater.
|
|
7
|
+
*
|
|
8
|
+
* Sorts in ascending order if passed to {@linkcode Array.sort}.
|
|
9
|
+
*
|
|
10
|
+
* @example Usage
|
|
11
|
+
* ```ts
|
|
12
|
+
* import { parse, compare } from "@std/semver";
|
|
13
|
+
* import { assertEquals } from "@std/assert";
|
|
14
|
+
*
|
|
15
|
+
* const version1 = parse("1.2.3");
|
|
16
|
+
* const version2 = parse("1.2.4");
|
|
17
|
+
*
|
|
18
|
+
* assertEquals(compare(version1, version2), -1);
|
|
19
|
+
* assertEquals(compare(version2, version1), 1);
|
|
20
|
+
* assertEquals(compare(version1, version1), 0);
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* @param version1 The first SemVer to compare
|
|
24
|
+
* @param version2 The second SemVer to compare
|
|
25
|
+
* @returns `1` if `version1` is greater, `0` if equal, or `-1` if `version2` is greater
|
|
26
|
+
*/
|
|
27
|
+
export declare function compare(version1: SemVer, version2: SemVer): 1 | 0 | -1;
|
|
28
|
+
//# sourceMappingURL=compare.d.ts.map
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { checkIdentifier, compareIdentifier, compareNumber } from './_shared.js';
|
|
2
|
+
/**
|
|
3
|
+
* Compare two SemVers.
|
|
4
|
+
*
|
|
5
|
+
* Returns `0` if `version1` equals `version2`, or `1` if `version1` is greater, or `-1` if `version2` is
|
|
6
|
+
* greater.
|
|
7
|
+
*
|
|
8
|
+
* Sorts in ascending order if passed to {@linkcode Array.sort}.
|
|
9
|
+
*
|
|
10
|
+
* @example Usage
|
|
11
|
+
* ```ts
|
|
12
|
+
* import { parse, compare } from "@std/semver";
|
|
13
|
+
* import { assertEquals } from "@std/assert";
|
|
14
|
+
*
|
|
15
|
+
* const version1 = parse("1.2.3");
|
|
16
|
+
* const version2 = parse("1.2.4");
|
|
17
|
+
*
|
|
18
|
+
* assertEquals(compare(version1, version2), -1);
|
|
19
|
+
* assertEquals(compare(version2, version1), 1);
|
|
20
|
+
* assertEquals(compare(version1, version1), 0);
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* @param version1 The first SemVer to compare
|
|
24
|
+
* @param version2 The second SemVer to compare
|
|
25
|
+
* @returns `1` if `version1` is greater, `0` if equal, or `-1` if `version2` is greater
|
|
26
|
+
*/
|
|
27
|
+
export function compare(version1, version2) {
|
|
28
|
+
if (version1 === version2)
|
|
29
|
+
return 0;
|
|
30
|
+
return (compareNumber(version1.major, version2.major) ||
|
|
31
|
+
compareNumber(version1.minor, version2.minor) ||
|
|
32
|
+
compareNumber(version1.patch, version2.patch) ||
|
|
33
|
+
checkIdentifier(version1.prerelease, version2.prerelease) ||
|
|
34
|
+
compareIdentifier(version1.prerelease, version2.prerelease));
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=compare.js.map
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { ReleaseType, SemVer } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Returns difference between two SemVers by the release type,
|
|
4
|
+
* or `undefined` if the SemVers are the same.
|
|
5
|
+
*
|
|
6
|
+
* @example Usage
|
|
7
|
+
* ```ts
|
|
8
|
+
* import { parse, difference } from "@std/semver";
|
|
9
|
+
* import { assertEquals } from "@std/assert";
|
|
10
|
+
*
|
|
11
|
+
* const version1 = parse("1.2.3");
|
|
12
|
+
* const version2 = parse("1.2.4");
|
|
13
|
+
* const version3 = parse("1.3.0");
|
|
14
|
+
* const version4 = parse("2.0.0");
|
|
15
|
+
*
|
|
16
|
+
* assertEquals(difference(version1, version2), "patch");
|
|
17
|
+
* assertEquals(difference(version1, version3), "minor");
|
|
18
|
+
* assertEquals(difference(version1, version4), "major");
|
|
19
|
+
* assertEquals(difference(version1, version1), undefined);
|
|
20
|
+
* ```
|
|
21
|
+
*
|
|
22
|
+
* @param version1 The first SemVer to compare
|
|
23
|
+
* @param version2 The second SemVer to compare
|
|
24
|
+
* @returns The release type difference or `undefined` if the versions are the same
|
|
25
|
+
*/
|
|
26
|
+
export declare function difference(version1: SemVer, version2: SemVer): ReleaseType | undefined;
|
|
27
|
+
//# sourceMappingURL=difference.d.ts.map
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { compareIdentifier } from './_shared.js';
|
|
2
|
+
/**
|
|
3
|
+
* Returns difference between two SemVers by the release type,
|
|
4
|
+
* or `undefined` if the SemVers are the same.
|
|
5
|
+
*
|
|
6
|
+
* @example Usage
|
|
7
|
+
* ```ts
|
|
8
|
+
* import { parse, difference } from "@std/semver";
|
|
9
|
+
* import { assertEquals } from "@std/assert";
|
|
10
|
+
*
|
|
11
|
+
* const version1 = parse("1.2.3");
|
|
12
|
+
* const version2 = parse("1.2.4");
|
|
13
|
+
* const version3 = parse("1.3.0");
|
|
14
|
+
* const version4 = parse("2.0.0");
|
|
15
|
+
*
|
|
16
|
+
* assertEquals(difference(version1, version2), "patch");
|
|
17
|
+
* assertEquals(difference(version1, version3), "minor");
|
|
18
|
+
* assertEquals(difference(version1, version4), "major");
|
|
19
|
+
* assertEquals(difference(version1, version1), undefined);
|
|
20
|
+
* ```
|
|
21
|
+
*
|
|
22
|
+
* @param version1 The first SemVer to compare
|
|
23
|
+
* @param version2 The second SemVer to compare
|
|
24
|
+
* @returns The release type difference or `undefined` if the versions are the same
|
|
25
|
+
*/
|
|
26
|
+
export function difference(version1, version2) {
|
|
27
|
+
const hasPrerelease = version1.prerelease?.length || version2.prerelease?.length;
|
|
28
|
+
if (version1.major !== version2.major) {
|
|
29
|
+
return hasPrerelease ? 'premajor' : 'major';
|
|
30
|
+
}
|
|
31
|
+
if (version1.minor !== version2.minor) {
|
|
32
|
+
return hasPrerelease ? 'preminor' : 'minor';
|
|
33
|
+
}
|
|
34
|
+
if (version1.patch !== version2.patch) {
|
|
35
|
+
return hasPrerelease ? 'prepatch' : 'patch';
|
|
36
|
+
}
|
|
37
|
+
if (compareIdentifier(version1.prerelease, version2.prerelease) !== 0) {
|
|
38
|
+
return 'prerelease';
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=difference.js.map
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { SemVer } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Returns `true` if both SemVers are equivalent.
|
|
4
|
+
*
|
|
5
|
+
* This is equal to `compare(version1, version2) === 0`.
|
|
6
|
+
*
|
|
7
|
+
* @example Usage
|
|
8
|
+
* ```ts
|
|
9
|
+
* import { parse, equals } from "@std/semver";
|
|
10
|
+
* import { assert } from "@std/assert";
|
|
11
|
+
*
|
|
12
|
+
* const version1 = parse("1.2.3");
|
|
13
|
+
* const version2 = parse("1.2.3");
|
|
14
|
+
*
|
|
15
|
+
* assert(equals(version1, version2));
|
|
16
|
+
* assert(!equals(version1, parse("1.2.4")));
|
|
17
|
+
* ```
|
|
18
|
+
*
|
|
19
|
+
* @param version1 The first SemVer to compare
|
|
20
|
+
* @param version2 The second SemVer to compare
|
|
21
|
+
* @returns `true` if `version1` is equal to `version2`, `false` otherwise
|
|
22
|
+
*/
|
|
23
|
+
export declare function equals(version1: SemVer, version2: SemVer): boolean;
|
|
24
|
+
//# sourceMappingURL=equals.d.ts.map
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { compare } from './compare.js';
|
|
4
|
+
/**
|
|
5
|
+
* Returns `true` if both SemVers are equivalent.
|
|
6
|
+
*
|
|
7
|
+
* This is equal to `compare(version1, version2) === 0`.
|
|
8
|
+
*
|
|
9
|
+
* @example Usage
|
|
10
|
+
* ```ts
|
|
11
|
+
* import { parse, equals } from "@std/semver";
|
|
12
|
+
* import { assert } from "@std/assert";
|
|
13
|
+
*
|
|
14
|
+
* const version1 = parse("1.2.3");
|
|
15
|
+
* const version2 = parse("1.2.3");
|
|
16
|
+
*
|
|
17
|
+
* assert(equals(version1, version2));
|
|
18
|
+
* assert(!equals(version1, parse("1.2.4")));
|
|
19
|
+
* ```
|
|
20
|
+
*
|
|
21
|
+
* @param version1 The first SemVer to compare
|
|
22
|
+
* @param version2 The second SemVer to compare
|
|
23
|
+
* @returns `true` if `version1` is equal to `version2`, `false` otherwise
|
|
24
|
+
*/
|
|
25
|
+
export function equals(version1, version2) {
|
|
26
|
+
return compare(version1, version2) === 0;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=equals.js.map
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { SemVer } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Format a SemVer object into a string.
|
|
4
|
+
*
|
|
5
|
+
* @example Usage
|
|
6
|
+
* ```ts
|
|
7
|
+
* import { format } from "@std/semver/format";
|
|
8
|
+
* import { assertEquals } from "@std/assert";
|
|
9
|
+
*
|
|
10
|
+
* const semver = {
|
|
11
|
+
* major: 1,
|
|
12
|
+
* minor: 2,
|
|
13
|
+
* patch: 3,
|
|
14
|
+
* };
|
|
15
|
+
* assertEquals(format(semver), "1.2.3");
|
|
16
|
+
* ```
|
|
17
|
+
*
|
|
18
|
+
* @param version The SemVer to format
|
|
19
|
+
* @returns The string representation of a semantic version.
|
|
20
|
+
*/
|
|
21
|
+
export declare function format(version: SemVer): string;
|
|
22
|
+
//# sourceMappingURL=format.d.ts.map
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
function formatNumber(value) {
|
|
2
|
+
return value.toFixed(0);
|
|
3
|
+
}
|
|
4
|
+
/**
|
|
5
|
+
* Format a SemVer object into a string.
|
|
6
|
+
*
|
|
7
|
+
* @example Usage
|
|
8
|
+
* ```ts
|
|
9
|
+
* import { format } from "@std/semver/format";
|
|
10
|
+
* import { assertEquals } from "@std/assert";
|
|
11
|
+
*
|
|
12
|
+
* const semver = {
|
|
13
|
+
* major: 1,
|
|
14
|
+
* minor: 2,
|
|
15
|
+
* patch: 3,
|
|
16
|
+
* };
|
|
17
|
+
* assertEquals(format(semver), "1.2.3");
|
|
18
|
+
* ```
|
|
19
|
+
*
|
|
20
|
+
* @param version The SemVer to format
|
|
21
|
+
* @returns The string representation of a semantic version.
|
|
22
|
+
*/
|
|
23
|
+
export function format(version) {
|
|
24
|
+
const major = formatNumber(version.major);
|
|
25
|
+
const minor = formatNumber(version.minor);
|
|
26
|
+
const patch = formatNumber(version.patch);
|
|
27
|
+
const pre = version.prerelease?.join('.') ?? '';
|
|
28
|
+
const build = version.build?.join('.') ?? '';
|
|
29
|
+
const primary = `${major}.${minor}.${patch}`;
|
|
30
|
+
const release = [primary, pre].filter((v) => v).join('-');
|
|
31
|
+
return [release, build].filter((v) => v).join('+');
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=format.js.map
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { Range } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Formats the SemVerrange into a string.
|
|
4
|
+
*
|
|
5
|
+
* @example Usage
|
|
6
|
+
* ```ts
|
|
7
|
+
* import { formatRange, parseRange } from "@std/semver";
|
|
8
|
+
* import { assertEquals } from "@std/assert";
|
|
9
|
+
*
|
|
10
|
+
* const range = parseRange(">=1.2.3 <1.2.4");
|
|
11
|
+
* assertEquals(formatRange(range), ">=1.2.3 <1.2.4");
|
|
12
|
+
* ```
|
|
13
|
+
*
|
|
14
|
+
* @param range The range to format
|
|
15
|
+
* @returns A string representation of the SemVer range
|
|
16
|
+
*/
|
|
17
|
+
export declare function formatRange(range: Range): string;
|
|
18
|
+
//# sourceMappingURL=format_range.d.ts.map
|