semver 6.1.2 → 7.0.0

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.
Files changed (48) hide show
  1. package/CHANGELOG.md +27 -0
  2. package/README.md +83 -14
  3. package/bin/semver.js +173 -0
  4. package/classes/comparator.js +139 -0
  5. package/classes/index.js +5 -0
  6. package/classes/range.js +448 -0
  7. package/classes/semver.js +290 -0
  8. package/functions/clean.js +6 -0
  9. package/functions/cmp.js +48 -0
  10. package/functions/coerce.js +51 -0
  11. package/functions/compare-build.js +7 -0
  12. package/functions/compare-loose.js +3 -0
  13. package/functions/compare.js +5 -0
  14. package/functions/diff.js +25 -0
  15. package/functions/eq.js +3 -0
  16. package/functions/gt.js +3 -0
  17. package/functions/gte.js +3 -0
  18. package/functions/inc.js +15 -0
  19. package/functions/lt.js +3 -0
  20. package/functions/lte.js +3 -0
  21. package/functions/major.js +3 -0
  22. package/functions/minor.js +3 -0
  23. package/functions/neq.js +3 -0
  24. package/functions/parse.js +37 -0
  25. package/functions/patch.js +3 -0
  26. package/functions/prerelease.js +6 -0
  27. package/functions/rcompare.js +3 -0
  28. package/functions/rsort.js +3 -0
  29. package/functions/satisfies.js +10 -0
  30. package/functions/sort.js +3 -0
  31. package/functions/valid.js +6 -0
  32. package/index.js +64 -0
  33. package/internal/constants.js +17 -0
  34. package/internal/debug.js +9 -0
  35. package/internal/identifiers.js +23 -0
  36. package/internal/re.js +179 -0
  37. package/package.json +12 -6
  38. package/ranges/gtr.js +4 -0
  39. package/ranges/intersects.js +7 -0
  40. package/ranges/ltr.js +4 -0
  41. package/ranges/max-satisfying.js +25 -0
  42. package/ranges/min-satisfying.js +24 -0
  43. package/ranges/min-version.js +57 -0
  44. package/ranges/outside.js +80 -0
  45. package/ranges/to-comparators.js +8 -0
  46. package/ranges/valid.js +11 -0
  47. package/bin/semver +0 -160
  48. package/semver.js +0 -1552
@@ -0,0 +1,23 @@
1
+ const numeric = /^[0-9]+$/
2
+ const compareIdentifiers = (a, b) => {
3
+ const anum = numeric.test(a)
4
+ const bnum = numeric.test(b)
5
+
6
+ if (anum && bnum) {
7
+ a = +a
8
+ b = +b
9
+ }
10
+
11
+ return a === b ? 0
12
+ : (anum && !bnum) ? -1
13
+ : (bnum && !anum) ? 1
14
+ : a < b ? -1
15
+ : 1
16
+ }
17
+
18
+ const rcompareIdentifiers = (a, b) => compareIdentifiers(b, a)
19
+
20
+ module.exports = {
21
+ compareIdentifiers,
22
+ rcompareIdentifiers
23
+ }
package/internal/re.js ADDED
@@ -0,0 +1,179 @@
1
+ const { MAX_SAFE_COMPONENT_LENGTH } = require('./constants')
2
+ const debug = require('./debug')
3
+ exports = module.exports = {}
4
+
5
+ // The actual regexps go on exports.re
6
+ const re = exports.re = []
7
+ const src = exports.src = []
8
+ const t = exports.t = {}
9
+ let R = 0
10
+
11
+ const createToken = (name, value, isGlobal) => {
12
+ const index = R++
13
+ debug(index, value)
14
+ t[name] = index
15
+ src[index] = value
16
+ re[index] = new RegExp(value, isGlobal ? 'g' : undefined)
17
+ }
18
+
19
+ // The following Regular Expressions can be used for tokenizing,
20
+ // validating, and parsing SemVer version strings.
21
+
22
+ // ## Numeric Identifier
23
+ // A single `0`, or a non-zero digit followed by zero or more digits.
24
+
25
+ createToken('NUMERICIDENTIFIER', '0|[1-9]\\d*')
26
+ createToken('NUMERICIDENTIFIERLOOSE', '[0-9]+')
27
+
28
+ // ## Non-numeric Identifier
29
+ // Zero or more digits, followed by a letter or hyphen, and then zero or
30
+ // more letters, digits, or hyphens.
31
+
32
+ createToken('NONNUMERICIDENTIFIER', '\\d*[a-zA-Z-][a-zA-Z0-9-]*')
33
+
34
+ // ## Main Version
35
+ // Three dot-separated numeric identifiers.
36
+
37
+ createToken('MAINVERSION', `(${src[t.NUMERICIDENTIFIER]})\\.` +
38
+ `(${src[t.NUMERICIDENTIFIER]})\\.` +
39
+ `(${src[t.NUMERICIDENTIFIER]})`)
40
+
41
+ createToken('MAINVERSIONLOOSE', `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` +
42
+ `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` +
43
+ `(${src[t.NUMERICIDENTIFIERLOOSE]})`)
44
+
45
+ // ## Pre-release Version Identifier
46
+ // A numeric identifier, or a non-numeric identifier.
47
+
48
+ createToken('PRERELEASEIDENTIFIER', `(?:${src[t.NUMERICIDENTIFIER]
49
+ }|${src[t.NONNUMERICIDENTIFIER]})`)
50
+
51
+ createToken('PRERELEASEIDENTIFIERLOOSE', `(?:${src[t.NUMERICIDENTIFIERLOOSE]
52
+ }|${src[t.NONNUMERICIDENTIFIER]})`)
53
+
54
+ // ## Pre-release Version
55
+ // Hyphen, followed by one or more dot-separated pre-release version
56
+ // identifiers.
57
+
58
+ createToken('PRERELEASE', `(?:-(${src[t.PRERELEASEIDENTIFIER]
59
+ }(?:\\.${src[t.PRERELEASEIDENTIFIER]})*))`)
60
+
61
+ createToken('PRERELEASELOOSE', `(?:-?(${src[t.PRERELEASEIDENTIFIERLOOSE]
62
+ }(?:\\.${src[t.PRERELEASEIDENTIFIERLOOSE]})*))`)
63
+
64
+ // ## Build Metadata Identifier
65
+ // Any combination of digits, letters, or hyphens.
66
+
67
+ createToken('BUILDIDENTIFIER', '[0-9A-Za-z-]+')
68
+
69
+ // ## Build Metadata
70
+ // Plus sign, followed by one or more period-separated build metadata
71
+ // identifiers.
72
+
73
+ createToken('BUILD', `(?:\\+(${src[t.BUILDIDENTIFIER]
74
+ }(?:\\.${src[t.BUILDIDENTIFIER]})*))`)
75
+
76
+ // ## Full Version String
77
+ // A main version, followed optionally by a pre-release version and
78
+ // build metadata.
79
+
80
+ // Note that the only major, minor, patch, and pre-release sections of
81
+ // the version string are capturing groups. The build metadata is not a
82
+ // capturing group, because it should not ever be used in version
83
+ // comparison.
84
+
85
+ createToken('FULLPLAIN', `v?${src[t.MAINVERSION]
86
+ }${src[t.PRERELEASE]}?${
87
+ src[t.BUILD]}?`)
88
+
89
+ createToken('FULL', `^${src[t.FULLPLAIN]}$`)
90
+
91
+ // like full, but allows v1.2.3 and =1.2.3, which people do sometimes.
92
+ // also, 1.0.0alpha1 (prerelease without the hyphen) which is pretty
93
+ // common in the npm registry.
94
+ createToken('LOOSEPLAIN', `[v=\\s]*${src[t.MAINVERSIONLOOSE]
95
+ }${src[t.PRERELEASELOOSE]}?${
96
+ src[t.BUILD]}?`)
97
+
98
+ createToken('LOOSE', `^${src[t.LOOSEPLAIN]}$`)
99
+
100
+ createToken('GTLT', '((?:<|>)?=?)')
101
+
102
+ // Something like "2.*" or "1.2.x".
103
+ // Note that "x.x" is a valid xRange identifer, meaning "any version"
104
+ // Only the first item is strictly required.
105
+ createToken('XRANGEIDENTIFIERLOOSE', `${src[t.NUMERICIDENTIFIERLOOSE]}|x|X|\\*`)
106
+ createToken('XRANGEIDENTIFIER', `${src[t.NUMERICIDENTIFIER]}|x|X|\\*`)
107
+
108
+ createToken('XRANGEPLAIN', `[v=\\s]*(${src[t.XRANGEIDENTIFIER]})` +
109
+ `(?:\\.(${src[t.XRANGEIDENTIFIER]})` +
110
+ `(?:\\.(${src[t.XRANGEIDENTIFIER]})` +
111
+ `(?:${src[t.PRERELEASE]})?${
112
+ src[t.BUILD]}?` +
113
+ `)?)?`)
114
+
115
+ createToken('XRANGEPLAINLOOSE', `[v=\\s]*(${src[t.XRANGEIDENTIFIERLOOSE]})` +
116
+ `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` +
117
+ `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` +
118
+ `(?:${src[t.PRERELEASELOOSE]})?${
119
+ src[t.BUILD]}?` +
120
+ `)?)?`)
121
+
122
+ createToken('XRANGE', `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAIN]}$`)
123
+ createToken('XRANGELOOSE', `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAINLOOSE]}$`)
124
+
125
+ // Coercion.
126
+ // Extract anything that could conceivably be a part of a valid semver
127
+ createToken('COERCE', `${'(^|[^\\d])' +
128
+ '(\\d{1,'}${MAX_SAFE_COMPONENT_LENGTH}})` +
129
+ `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` +
130
+ `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` +
131
+ `(?:$|[^\\d])`)
132
+ createToken('COERCERTL', src[t.COERCE], true)
133
+
134
+ // Tilde ranges.
135
+ // Meaning is "reasonably at or greater than"
136
+ createToken('LONETILDE', '(?:~>?)')
137
+
138
+ createToken('TILDETRIM', `(\\s*)${src[t.LONETILDE]}\\s+`, true)
139
+ exports.tildeTrimReplace = '$1~'
140
+
141
+ createToken('TILDE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAIN]}$`)
142
+ createToken('TILDELOOSE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAINLOOSE]}$`)
143
+
144
+ // Caret ranges.
145
+ // Meaning is "at least and backwards compatible with"
146
+ createToken('LONECARET', '(?:\\^)')
147
+
148
+ createToken('CARETTRIM', `(\\s*)${src[t.LONECARET]}\\s+`, true)
149
+ exports.caretTrimReplace = '$1^'
150
+
151
+ createToken('CARET', `^${src[t.LONECARET]}${src[t.XRANGEPLAIN]}$`)
152
+ createToken('CARETLOOSE', `^${src[t.LONECARET]}${src[t.XRANGEPLAINLOOSE]}$`)
153
+
154
+ // A simple gt/lt/eq thing, or just "" to indicate "any version"
155
+ createToken('COMPARATORLOOSE', `^${src[t.GTLT]}\\s*(${src[t.LOOSEPLAIN]})$|^$`)
156
+ createToken('COMPARATOR', `^${src[t.GTLT]}\\s*(${src[t.FULLPLAIN]})$|^$`)
157
+
158
+ // An expression to strip any whitespace between the gtlt and the thing
159
+ // it modifies, so that `> 1.2.3` ==> `>1.2.3`
160
+ createToken('COMPARATORTRIM', `(\\s*)${src[t.GTLT]
161
+ }\\s*(${src[t.LOOSEPLAIN]}|${src[t.XRANGEPLAIN]})`, true)
162
+ exports.comparatorTrimReplace = '$1$2$3'
163
+
164
+ // Something like `1.2.3 - 1.2.4`
165
+ // Note that these all use the loose form, because they'll be
166
+ // checked against either the strict or loose comparator form
167
+ // later.
168
+ createToken('HYPHENRANGE', `^\\s*(${src[t.XRANGEPLAIN]})` +
169
+ `\\s+-\\s+` +
170
+ `(${src[t.XRANGEPLAIN]})` +
171
+ `\\s*$`)
172
+
173
+ createToken('HYPHENRANGELOOSE', `^\\s*(${src[t.XRANGEPLAINLOOSE]})` +
174
+ `\\s+-\\s+` +
175
+ `(${src[t.XRANGEPLAINLOOSE]})` +
176
+ `\\s*$`)
177
+
178
+ // Star ranges basically just allow anything at all.
179
+ createToken('STAR', '(<|>)?=?\\s*\\*')
package/package.json CHANGED
@@ -1,28 +1,34 @@
1
1
  {
2
2
  "name": "semver",
3
- "version": "6.1.2",
3
+ "version": "7.0.0",
4
4
  "description": "The semantic version parser used by npm.",
5
- "main": "semver.js",
5
+ "main": "index.js",
6
6
  "scripts": {
7
7
  "test": "tap",
8
+ "snap": "tap",
8
9
  "preversion": "npm test",
9
10
  "postversion": "npm publish",
10
11
  "postpublish": "git push origin --follow-tags"
11
12
  },
12
13
  "devDependencies": {
13
- "tap": "^14.1.6"
14
+ "tap": "^14.10.1"
14
15
  },
15
16
  "license": "ISC",
16
17
  "repository": "https://github.com/npm/node-semver",
17
18
  "bin": {
18
- "semver": "./bin/semver"
19
+ "semver": "./bin/semver.js"
19
20
  },
20
21
  "files": [
21
22
  "bin",
22
23
  "range.bnf",
23
- "semver.js"
24
+ "classes",
25
+ "functions",
26
+ "internal",
27
+ "ranges",
28
+ "index.js"
24
29
  ],
25
30
  "tap": {
26
- "check-coverage": true
31
+ "check-coverage": true,
32
+ "coverage-map": "map.js"
27
33
  }
28
34
  }
package/ranges/gtr.js ADDED
@@ -0,0 +1,4 @@
1
+ // Determine if version is greater than all the versions possible in the range.
2
+ const outside = require('./outside')
3
+ const gtr = (version, range, options) => outside(version, range, '>', options)
4
+ module.exports = gtr
@@ -0,0 +1,7 @@
1
+ const Range = require('../classes/range')
2
+ const intersects = (r1, r2, options) => {
3
+ r1 = new Range(r1, options)
4
+ r2 = new Range(r2, options)
5
+ return r1.intersects(r2)
6
+ }
7
+ module.exports = intersects
package/ranges/ltr.js ADDED
@@ -0,0 +1,4 @@
1
+ const outside = require('./outside')
2
+ // Determine if version is less than all the versions possible in the range
3
+ const ltr = (version, range, options) => outside(version, range, '<', options)
4
+ module.exports = ltr
@@ -0,0 +1,25 @@
1
+ const SemVer = require('../classes/semver')
2
+ const Range = require('../classes/range')
3
+
4
+ const maxSatisfying = (versions, range, options) => {
5
+ let max = null
6
+ let maxSV = null
7
+ let rangeObj = null
8
+ try {
9
+ rangeObj = new Range(range, options)
10
+ } catch (er) {
11
+ return null
12
+ }
13
+ versions.forEach((v) => {
14
+ if (rangeObj.test(v)) {
15
+ // satisfies(v, range, options)
16
+ if (!max || maxSV.compare(v) === -1) {
17
+ // compare(max, v, true)
18
+ max = v
19
+ maxSV = new SemVer(max, options)
20
+ }
21
+ }
22
+ })
23
+ return max
24
+ }
25
+ module.exports = maxSatisfying
@@ -0,0 +1,24 @@
1
+ const SemVer = require('../classes/semver')
2
+ const Range = require('../classes/range')
3
+ const minSatisfying = (versions, range, options) => {
4
+ let min = null
5
+ let minSV = null
6
+ let rangeObj = null
7
+ try {
8
+ rangeObj = new Range(range, options)
9
+ } catch (er) {
10
+ return null
11
+ }
12
+ versions.forEach((v) => {
13
+ if (rangeObj.test(v)) {
14
+ // satisfies(v, range, options)
15
+ if (!min || minSV.compare(v) === 1) {
16
+ // compare(min, v, true)
17
+ min = v
18
+ minSV = new SemVer(min, options)
19
+ }
20
+ }
21
+ })
22
+ return min
23
+ }
24
+ module.exports = minSatisfying
@@ -0,0 +1,57 @@
1
+ const SemVer = require('../classes/semver')
2
+ const Range = require('../classes/range')
3
+ const gt = require('../functions/gt')
4
+
5
+ const minVersion = (range, loose) => {
6
+ range = new Range(range, loose)
7
+
8
+ let minver = new SemVer('0.0.0')
9
+ if (range.test(minver)) {
10
+ return minver
11
+ }
12
+
13
+ minver = new SemVer('0.0.0-0')
14
+ if (range.test(minver)) {
15
+ return minver
16
+ }
17
+
18
+ minver = null
19
+ for (let i = 0; i < range.set.length; ++i) {
20
+ const comparators = range.set[i]
21
+
22
+ comparators.forEach((comparator) => {
23
+ // Clone to avoid manipulating the comparator's semver object.
24
+ const compver = new SemVer(comparator.semver.version)
25
+ switch (comparator.operator) {
26
+ case '>':
27
+ if (compver.prerelease.length === 0) {
28
+ compver.patch++
29
+ } else {
30
+ compver.prerelease.push(0)
31
+ }
32
+ compver.raw = compver.format()
33
+ /* fallthrough */
34
+ case '':
35
+ case '>=':
36
+ if (!minver || gt(minver, compver)) {
37
+ minver = compver
38
+ }
39
+ break
40
+ case '<':
41
+ case '<=':
42
+ /* Ignore maximum versions */
43
+ break
44
+ /* istanbul ignore next */
45
+ default:
46
+ throw new Error(`Unexpected operation: ${comparator.operator}`)
47
+ }
48
+ })
49
+ }
50
+
51
+ if (minver && range.test(minver)) {
52
+ return minver
53
+ }
54
+
55
+ return null
56
+ }
57
+ module.exports = minVersion
@@ -0,0 +1,80 @@
1
+ const SemVer = require('../classes/semver')
2
+ const Comparator = require('../classes/comparator')
3
+ const {ANY} = Comparator
4
+ const Range = require('../classes/range')
5
+ const satisfies = require('../functions/satisfies')
6
+ const gt = require('../functions/gt')
7
+ const lt = require('../functions/lt')
8
+ const lte = require('../functions/lte')
9
+ const gte = require('../functions/gte')
10
+
11
+ const outside = (version, range, hilo, options) => {
12
+ version = new SemVer(version, options)
13
+ range = new Range(range, options)
14
+
15
+ let gtfn, ltefn, ltfn, comp, ecomp
16
+ switch (hilo) {
17
+ case '>':
18
+ gtfn = gt
19
+ ltefn = lte
20
+ ltfn = lt
21
+ comp = '>'
22
+ ecomp = '>='
23
+ break
24
+ case '<':
25
+ gtfn = lt
26
+ ltefn = gte
27
+ ltfn = gt
28
+ comp = '<'
29
+ ecomp = '<='
30
+ break
31
+ default:
32
+ throw new TypeError('Must provide a hilo val of "<" or ">"')
33
+ }
34
+
35
+ // If it satisifes the range it is not outside
36
+ if (satisfies(version, range, options)) {
37
+ return false
38
+ }
39
+
40
+ // From now on, variable terms are as if we're in "gtr" mode.
41
+ // but note that everything is flipped for the "ltr" function.
42
+
43
+ for (let i = 0; i < range.set.length; ++i) {
44
+ const comparators = range.set[i]
45
+
46
+ let high = null
47
+ let low = null
48
+
49
+ comparators.forEach((comparator) => {
50
+ if (comparator.semver === ANY) {
51
+ comparator = new Comparator('>=0.0.0')
52
+ }
53
+ high = high || comparator
54
+ low = low || comparator
55
+ if (gtfn(comparator.semver, high.semver, options)) {
56
+ high = comparator
57
+ } else if (ltfn(comparator.semver, low.semver, options)) {
58
+ low = comparator
59
+ }
60
+ })
61
+
62
+ // If the edge version comparator has a operator then our version
63
+ // isn't outside it
64
+ if (high.operator === comp || high.operator === ecomp) {
65
+ return false
66
+ }
67
+
68
+ // If the lowest version comparator has an operator and our version
69
+ // is less than it then it isn't higher than the range
70
+ if ((!low.operator || low.operator === comp) &&
71
+ ltefn(version, low.semver)) {
72
+ return false
73
+ } else if (low.operator === ecomp && ltfn(version, low.semver)) {
74
+ return false
75
+ }
76
+ }
77
+ return true
78
+ }
79
+
80
+ module.exports = outside
@@ -0,0 +1,8 @@
1
+ const Range = require('../classes/range')
2
+
3
+ // Mostly just for testing and legacy API reasons
4
+ const toComparators = (range, options) =>
5
+ new Range(range, options).set
6
+ .map(comp => comp.map(c => c.value).join(' ').trim().split(' '))
7
+
8
+ module.exports = toComparators
@@ -0,0 +1,11 @@
1
+ const Range = require('../classes/range')
2
+ const validRange = (range, options) => {
3
+ try {
4
+ // Return '*' instead of '' so that truthiness works.
5
+ // This will throw if it's invalid anyway
6
+ return new Range(range, options).range || '*'
7
+ } catch (er) {
8
+ return null
9
+ }
10
+ }
11
+ module.exports = validRange
package/bin/semver DELETED
@@ -1,160 +0,0 @@
1
- #!/usr/bin/env node
2
- // Standalone semver comparison program.
3
- // Exits successfully and prints matching version(s) if
4
- // any supplied version is valid and passes all tests.
5
-
6
- var argv = process.argv.slice(2)
7
-
8
- var versions = []
9
-
10
- var range = []
11
-
12
- var inc = null
13
-
14
- var version = require('../package.json').version
15
-
16
- var loose = false
17
-
18
- var includePrerelease = false
19
-
20
- var coerce = false
21
-
22
- var identifier
23
-
24
- var semver = require('../semver')
25
-
26
- var reverse = false
27
-
28
- var options = {}
29
-
30
- main()
31
-
32
- function main () {
33
- if (!argv.length) return help()
34
- while (argv.length) {
35
- var a = argv.shift()
36
- var indexOfEqualSign = a.indexOf('=')
37
- if (indexOfEqualSign !== -1) {
38
- a = a.slice(0, indexOfEqualSign)
39
- argv.unshift(a.slice(indexOfEqualSign + 1))
40
- }
41
- switch (a) {
42
- case '-rv': case '-rev': case '--rev': case '--reverse':
43
- reverse = true
44
- break
45
- case '-l': case '--loose':
46
- loose = true
47
- break
48
- case '-p': case '--include-prerelease':
49
- includePrerelease = true
50
- break
51
- case '-v': case '--version':
52
- versions.push(argv.shift())
53
- break
54
- case '-i': case '--inc': case '--increment':
55
- switch (argv[0]) {
56
- case 'major': case 'minor': case 'patch': case 'prerelease':
57
- case 'premajor': case 'preminor': case 'prepatch':
58
- inc = argv.shift()
59
- break
60
- default:
61
- inc = 'patch'
62
- break
63
- }
64
- break
65
- case '--preid':
66
- identifier = argv.shift()
67
- break
68
- case '-r': case '--range':
69
- range.push(argv.shift())
70
- break
71
- case '-c': case '--coerce':
72
- coerce = true
73
- break
74
- case '-h': case '--help': case '-?':
75
- return help()
76
- default:
77
- versions.push(a)
78
- break
79
- }
80
- }
81
-
82
- var options = { loose: loose, includePrerelease: includePrerelease }
83
-
84
- versions = versions.map(function (v) {
85
- return coerce ? (semver.coerce(v) || { version: v }).version : v
86
- }).filter(function (v) {
87
- return semver.valid(v)
88
- })
89
- if (!versions.length) return fail()
90
- if (inc && (versions.length !== 1 || range.length)) { return failInc() }
91
-
92
- for (var i = 0, l = range.length; i < l; i++) {
93
- versions = versions.filter(function (v) {
94
- return semver.satisfies(v, range[i], options)
95
- })
96
- if (!versions.length) return fail()
97
- }
98
- return success(versions)
99
- }
100
-
101
- function failInc () {
102
- console.error('--inc can only be used on a single version with no range')
103
- fail()
104
- }
105
-
106
- function fail () { process.exit(1) }
107
-
108
- function success () {
109
- var compare = reverse ? 'rcompare' : 'compare'
110
- versions.sort(function (a, b) {
111
- return semver[compare](a, b, options)
112
- }).map(function (v) {
113
- return semver.clean(v, options)
114
- }).map(function (v) {
115
- return inc ? semver.inc(v, inc, options, identifier) : v
116
- }).forEach(function (v, i, _) { console.log(v) })
117
- }
118
-
119
- function help () {
120
- console.log(['SemVer ' + version,
121
- '',
122
- 'A JavaScript implementation of the https://semver.org/ specification',
123
- 'Copyright Isaac Z. Schlueter',
124
- '',
125
- 'Usage: semver [options] <version> [<version> [...]]',
126
- 'Prints valid versions sorted by SemVer precedence',
127
- '',
128
- 'Options:',
129
- '-r --range <range>',
130
- ' Print versions that match the specified range.',
131
- '',
132
- '-i --increment [<level>]',
133
- ' Increment a version by the specified level. Level can',
134
- ' be one of: major, minor, patch, premajor, preminor,',
135
- " prepatch, or prerelease. Default level is 'patch'.",
136
- ' Only one version may be specified.',
137
- '',
138
- '--preid <identifier>',
139
- ' Identifier to be used to prefix premajor, preminor,',
140
- ' prepatch or prerelease version increments.',
141
- '',
142
- '-l --loose',
143
- ' Interpret versions and ranges loosely',
144
- '',
145
- '-p --include-prerelease',
146
- ' Always include prerelease versions in range matching',
147
- '',
148
- '-c --coerce',
149
- ' Coerce a string into SemVer if possible',
150
- ' (does not imply --loose)',
151
- '',
152
- 'Program exits successfully if any valid version satisfies',
153
- 'all supplied ranges, and prints all satisfying versions.',
154
- '',
155
- 'If no satisfying versions are found, then exits failure.',
156
- '',
157
- 'Versions are printed in ascending order, so supplying',
158
- 'multiple versions to the utility will just sort them.'
159
- ].join('\n'))
160
- }