Classes
Comparator
Defined in: comparator.ts:123
Class used to parse the ||
separated portions
of a range, and evaluate versions against it.
This does most of the heavy lifting of range testing, and provides little affordance for improperly formatted strings. It should be considered an internal class, and usually not accessed directly.
Constructors
new Comparator()
Defined in: comparator.ts:160
Parameters
comp
string
includePrerelease
boolean
= false
Returns
Properties
includePrerelease
Defined in: comparator.ts:128
does this range include prereleases, even when they do not match the tuple in the comparator?
isAny
Defined in: comparator.ts:148
true if this comparator is a '*'
type of range.
Note that it still will not match versions with a prerelease value,
unless the tuple in the version matches the tuple provided to the
comparator, and the comparator version also has a prerelease value,
unless includePrerelease
is set.
isNone
Defined in: comparator.ts:139
true if this comparator can not match anything
raw
Defined in: comparator.ts:130
raw string used to create this comparator
tokens
Defined in: comparator.ts:132
tokens extracted from the raw string input
tuples
Defined in: comparator.ts:137
Either the any
comparator, the none
comparator, or an operator
and a ParsedXRange
Methods
test()
Defined in: comparator.ts:634
return true if the version is a match for this comparator
Parameters
v
Returns
boolean
toString()
Defined in: comparator.ts:151
the canonical strict simplified parsed form of this constructor
Returns
string
Range
Defined in: range.ts:11
A representation of a semver range, used to test versions.
Includes a set of comparators representing the ||
-separated
sections of the range string
Constructors
new Range()
Defined in: range.ts:36
Parameters
range
string
includePrerelease
boolean
= false
Returns
Properties
includePrerelease
Defined in: range.ts:31
true if all prerelease versions should be included
isAny
Defined in: range.ts:16
true if the range is *
isSingle
Defined in: range.ts:19
true if the range is a single semver version
raw
Defined in: range.ts:13
raw string used to create this Range
set
Defined in: range.ts:28
set of Comparator objects representing the ||
-separated sections
of the range. If at least one of these matches, then the version is a
match.
Methods
test()
Defined in: range.ts:67
test a Version against the range
Parameters
v
Returns
boolean
toString()
Defined in: range.ts:72
return the simplified canonical form of this range
Returns
string
Version
Defined in: version.ts:65
A parsed object representation of a SemVer version string
This is a bit less forgiving than node-semver, in that prerelease versions MUST start with ’-’. Otherwise, the allowed syntax is identical.
Constructors
new Version()
Defined in: version.ts:143
Parameters
version
string
major
number
minor
number
patch
number
prerelease
undefined
| string
build
undefined
| string
Returns
Properties
build?
Defined in: version.ts:87
List of '.'
-separated strings in the build
section.
This is undefined if the version does not have a build.
major
Defined in: version.ts:70
major version number
minor
Defined in: version.ts:72
minor version number
patch
Defined in: version.ts:74
patch version number
prerelease?
Defined in: version.ts:81
List of '.'
-separated strings and numbers indicating that this
version is a prerelease.
This is undefined if the version does not have a prerelease section.
raw
Defined in: version.ts:67
raw string provided to create this Version
Methods
compare()
Defined in: version.ts:194
Return 1 if this is > the provided version, -1 if we’re less, or 0 if they are equal.
No special handling for prerelease versions, this is just a precedence comparison.
This can be used to sort a list of versions by precedence:
Parameters
v
Returns
-1
| 0
| 1
equals()
Defined in: version.ts:255
true if these two versions have equal SemVer precedence
Parameters
v
Returns
boolean
greaterThan()
Defined in: version.ts:235
true if this version is > the argument
Parameters
v
Returns
boolean
greaterThanEqual()
Defined in: version.ts:240
true if this version is >= the argument
Parameters
v
Returns
boolean
inc()
Defined in: version.ts:327
Increment the version in place, in the manner specified.
Part behaviors:
-
'major'
If the version is aM.0.0-...
version with a prerelease, then simply drop the prerelease. Otherwise, set the minor and patch to 0, and increment the major. So1.0.0-beta
becomes1.0.0
, and1.2.3
becomes2.0.0
-
'minor'
If the version is aM.m.0-...
version with a prerelease, then simply drop the prerelease. Otherwise, set the patch to 0, and increment the minor. So1.2.0-beta
becomes1.2.0
, and1.2.3
becomes1.3.0
. -
'patch'
If the version has a prerelease, then simply drop the prerelease. Otherwise, increment the patch value. So1.2.3-beta
becomes1.2.3
and1.2.3
becomes1.2.4
. -
'premajor'
Set the patch and minor versions to0
, increment the major version, and add a prerelease, using the optional identifier. -
'preminor'
Set the patch version to0
, increment the minor version, and add a prerelease, using the optional identifier. -
'prepatch'
If a prerelease is already present, increment the patch version, otherwise leave it untouched, and add a prerelease, using the optional identifier. -
'prerelease'
If a prerelease version is present, then behave the same as'prepatch'
. Otherwise, add a prerelease, using the optional identifier. -
'pre'
This is mostly for use by the other prerelease incrementers.-
If a prerelease identifier is provided:
Update that named portion of the prerelease. For example,
inc('1.2.3-beta.4', 'pre', 'beta')
would result in1.2.3-beta.5
.If there is no prerelease identifier by that name, then replace the prerelease with
[name]
. Soinc('1.2.3-alpha.4', 'pre', 'beta')
would result in1.2.3-beta
.If the prerelease identifer is present, but has no numeric value following it, then add
0
. Soinc('1.2.3-beta', 'pre', 'beta')
would result in1.2.3-beta.0
. -
If no prerelease identifier is provided:
If there is no current prerelease, then set the prerelease to
0
. So,inc('1.2.3', 'pre')
becomes1.2.3-0
.If the last item in the prerelease is numeric, then increment it. So,
inc('1.2.3-beta.3', 'pre')
becomes1.2.3-beta.4
.
-
Parameters
part
prereleaseIdentifier?
string
Returns
lessThan()
Defined in: version.ts:245
true if this version is < the argument
Parameters
v
Returns
boolean
lessThanEqual()
Defined in: version.ts:250
true if this version is <= the argument
Parameters
v
Returns
boolean
rcompare()
Defined in: version.ts:230
The inverse of compare, for sorting version lists in reverse order
Parameters
v
Returns
number
satisfies()
Defined in: version.ts:269
true if this version satisfies the range
Parameters
r
Returns
boolean
toString()
Defined in: version.ts:90
Canonical strict form of this version
Returns
string
tupleEquals()
Defined in: version.ts:260
just compare the M.m.p parts of the version
Parameters
v
Returns
boolean
parse()
Defined in: version.ts:97
Generate a Version
object from a SemVer string
Parameters
version
string
Returns
Type Aliases
ComplexOperator
Defined in: comparator.ts:10
operators that are expanded to simpler forms
IncrementType
Defined in: version.ts:49
Types of incrementing supported by Version#inc
OVTuple
Defined in: comparator.ts:26
comparator expressed as a [operator,version] tuple
ParsedXMajor
Defined in: comparator.ts:85
a ParsedXRange that is just a *
ParsedXMinor
Defined in: comparator.ts:89
a ParsedXRange that is just a major version
ParsedXPatch
Defined in: comparator.ts:93
a ParsedXRange that is just a major and minor version
ParsedXRange
Defined in: comparator.ts:77
The result of parsing a version value that might be either a full
version like 1.2.3
or an X-Range like 1.2.x
ParsedXVersion
Defined in: comparator.ts:97
a ParsedXRange that is a full version
SimpleOperator
Defined in: comparator.ts:8
all comparators are expressed in terms of these operators
Functions
build()
Defined in: index.ts:415
extract the list of build identifiers, or undefined if the version
is invalid. If no build identifiers are present, returns []
.
Parameters
version
string
| Version
Returns
undefined
| string
[]
compare()
Defined in: index.ts:333
Same as sortMethod, but throws if either version is not valid. 1 if versionA is higher precedence than versionB -1 if versionA is lower precedence than versionB 0 if they have equal precedence
Parameters
versionA
string
| Version
versionB
string
| Version
Returns
-1
| 0
| 1
eq()
Defined in: index.ts:388
true if versionA is equal to versionB. throws on invalid values
Parameters
versionA
string
| Version
versionB
string
| Version
Returns
boolean
filter()
Defined in: index.ts:200
Filter a list of versions to find all that match a given range.
Type Parameters
• T extends string
| Version
= string
| Version
Parameters
list
T
[]
range
string
| Range
includePrerelease
boolean
= false
Returns
T
[]
filterMethod()
Defined in: index.ts:187
Method used by filter, for use in Array.filter
directly.
Usage:
Parameters
range
string
| Range
includePrerelease
boolean
= false
Returns
Function
Parameters
version
string
| Version
Returns
boolean
gt()
Defined in: index.ts:363
true if versionA is > versionB. throws on invalid values
Parameters
versionA
string
| Version
versionB
string
| Version
Returns
boolean
gte()
Defined in: index.ts:368
true if versionA is >= versionB. throws on invalid values
Parameters
versionA
string
| Version
versionB
string
| Version
Returns
boolean
highest()
Defined in: index.ts:211
Find the highest-precedence match for a range within a list of versions
Returns undefined
if no match was found.
Parameters
list
(string
| Version
)[]
range
string
| Range
includePrerelease
boolean
= false
Returns
undefined
| Version
inc()
Defined in: index.ts:81
Increment the specified part of the version, and return the resulting object. If a Version object is provided, it will be modified in-place.
See Version.inc for full description.
Parameters
version
string
| Version
part
prereleaseIdentifier?
string
Returns
lowest()
Defined in: index.ts:281
Find the lowest-precedence match for a range within a list of versions
Returns undefined
if no match was found.
Parameters
list
(string
| Version
)[]
range
string
| Range
includePrerelease
boolean
= false
Returns
undefined
| Version
lt()
Defined in: index.ts:373
true if versionA is < versionB. throws on invalid values
Parameters
versionA
string
| Version
versionB
string
| Version
Returns
boolean
lte()
Defined in: index.ts:378
true if versionA is <= versionB. throws on invalid values
Parameters
versionA
string
| Version
versionB
string
| Version
Returns
boolean
major()
Defined in: index.ts:394
extract the major version number, or undefined if invalid
Parameters
version
string
| Version
Returns
undefined
| number
minor()
Defined in: index.ts:397
extract the minor version number, or undefined if invalid
Parameters
version
string
| Version
Returns
undefined
| number
neq()
Defined in: index.ts:383
true if versionA is not equal to versionB. throws on invalid values
Parameters
versionA
string
| Version
versionB
string
| Version
Returns
boolean
parse()
Defined in: index.ts:10
Return the parsed version string, or undefined
if invalid
Parameters
version
string
| Version
Returns
undefined
| Version
parseRange()
Defined in: index.ts:20
Return the parsed version range, or undefined
if invalid
Parameters
range
string
| Range
includePrerelease
boolean
= false
Returns
undefined
| Range
patch()
Defined in: index.ts:400
extract the patch version number, or undefined if invalid
Parameters
version
string
| Version
Returns
undefined
| number
prerelease()
Defined in: index.ts:406
extract the list of prerelease identifiers, or undefined if the version
is invalid. If no prerelease identifiers are present, returns []
.
Parameters
version
string
| Version
Returns
undefined
| (string
| number
)[]
rcompare()
Defined in: index.ts:357
Inverse of compare
Same as rsortMethod, but throws if either version is not valid.
-1 if versionA is higher precedence than versionB 1 if versionA is lower precedence than versionB 0 if they have equal precedence
Parameters
versionA
string
| Version
versionB
string
| Version
Returns
-1
| 0
| 1
rsort()
Defined in: index.ts:144
Sort an array of version strings or objects in descending SemVer precedence order (ie, highest versions first).
Invalid version strings are sorted to the end of the array in ascending alphabetical order.
Note: when using this method, the list is cloned prior to sorting, to prevent surprising mutation. To sort the list in place, see rsortMethod.
Type Parameters
• T extends string
| Version
= string
| Version
Parameters
list
T
[]
Returns
T
[]
rsortedHighest()
Defined in: index.ts:261
Faster form of highest, for use when the list is sorted in reverse precedence order (higher-precedence versions first).
Note: This stops at the first match, and will produce incorrect results when the list is not properly sorted!
Parameters
list
(string
| Version
)[]
range
string
| Range
includePrerelease
boolean
= false
Returns
undefined
| Version
rsortedLowest()
Defined in: index.ts:320
Faster form of lowest, for use when the list is sorted in reverse precedence order (higher-precedence versions first).
Note: This stops at the first match, and will produce incorrect results when the list is not properly sorted!
Parameters
list
(string
| Version
)[]
range
string
| Range
includePrerelease
boolean
= false
Returns
undefined
| Version
rsortMethod()
Defined in: index.ts:161
The method used by rsort, exported for passing directly to
Array.sort
.
Usage:
Parameters
a
string
| Version
b
string
| Version
Returns
number
satisfies()
Defined in: index.ts:57
Return true if the version satisfies the range.
Parameters
version
string
| Version
range
string
| Range
includePrerelease
boolean
= false
Returns
boolean
sort()
Defined in: index.ts:129
Sort an array of version strings or objects in ascending SemVer precedence order (ie, lowest versions first).
Invalid version strings are sorted to the end of the array in ascending alphabetical order.
Note: when using this method, the list is cloned prior to sorting, to prevent surprising mutation. To sort the list in place, see sortMethod.
Type Parameters
• T extends string
| Version
= string
| Version
Parameters
list
T
[]
Returns
T
[]
sortedHighest()
Defined in: index.ts:236
Faster form of highest, for use when the list is sorted in precedence order (lower-precedence versions first).
Note: This stops at the first match, and will produce incorrect results when the list is not properly sorted!
Parameters
list
(string
| Version
)[]
range
string
| Range
includePrerelease
boolean
= false
Returns
undefined
| Version
sortedLowest()
Defined in: index.ts:306
Faster form of lowest, for use when the list is sorted in precedence order (lower-precedence versions first).
Note: This stops at the first match, and will produce incorrect results when the list is not properly sorted!
Parameters
list
(string
| Version
)[]
range
string
| Range
includePrerelease
boolean
= false
Returns
undefined
| Version
sortMethod()
Defined in: index.ts:104
The method used by sort, exported for passing directly to
Array.sort
.
Usage:
Parameters
a
string
| Version
b
string
| Version
Returns
number
stable()
Defined in: index.ts:422
return all versions that do not have any prerelease identifiers
Type Parameters
• T extends string
| Version
= string
| Version
Parameters
versions
T
[]
Returns
T
[]
valid()
Defined in: index.ts:42
return true if the version is valid
Note: do not use this if you intend to immediately parse the version if it’s
valid. Just use parse, and guard the possible undefined value, or
use Version.parse(..)
to throw on invalid values.
Parameters
version
string
| Version
Returns
boolean
validRange()
Defined in: index.ts:51
return true if the range is valid
Note: do not use this if you intend to immediately parse the range if it’s
valid. Just use parseRange, and guard the possible undefined value,
or use new Range(..)
to throw on invalid values.
Parameters
range
string
| Range
Returns
boolean