keep-a-changelog 2.3.0 → 2.4.1

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 (207) hide show
  1. package/CHANGELOG.md +17 -2
  2. package/README.md +20 -6
  3. package/esm/_dnt.shims.js +0 -1
  4. package/esm/deps/deno.land/std@0.203.0/semver/_shared.d.ts +42 -0
  5. package/esm/deps/deno.land/std@0.203.0/semver/_shared.js +230 -0
  6. package/esm/deps/deno.land/std@0.203.0/semver/cmp.d.ts +9 -0
  7. package/esm/deps/deno.land/std@0.203.0/semver/cmp.js +35 -0
  8. package/esm/deps/deno.land/std@0.203.0/semver/comparator_format.d.ts +8 -0
  9. package/esm/deps/deno.land/std@0.203.0/semver/comparator_format.js +11 -0
  10. package/esm/deps/deno.land/std@0.203.0/semver/comparator_intersects.d.ts +8 -0
  11. package/esm/deps/deno.land/std@0.203.0/semver/comparator_intersects.js +45 -0
  12. package/esm/deps/deno.land/std@0.203.0/semver/comparator_max.d.ts +9 -0
  13. package/esm/deps/deno.land/std@0.203.0/semver/comparator_max.js +45 -0
  14. package/esm/deps/deno.land/std@0.203.0/semver/comparator_min.d.ts +8 -0
  15. package/esm/deps/deno.land/std@0.203.0/semver/comparator_min.js +32 -0
  16. package/esm/deps/deno.land/std@0.203.0/semver/compare.d.ts +10 -0
  17. package/esm/deps/deno.land/std@0.203.0/semver/compare.js +18 -0
  18. package/esm/deps/deno.land/std@0.203.0/semver/compare_build.d.ts +13 -0
  19. package/esm/deps/deno.land/std@0.203.0/semver/compare_build.js +23 -0
  20. package/esm/deps/deno.land/std@0.203.0/semver/constants.d.ts +42 -0
  21. package/esm/deps/deno.land/std@0.203.0/semver/constants.js +75 -0
  22. package/esm/deps/deno.land/std@0.203.0/semver/difference.d.ts +4 -0
  23. package/esm/deps/deno.land/std@0.203.0/semver/difference.js +26 -0
  24. package/esm/deps/deno.land/std@0.203.0/semver/eq.d.ts +4 -0
  25. package/esm/deps/deno.land/std@0.203.0/semver/eq.js +7 -0
  26. package/esm/deps/deno.land/std@0.203.0/semver/format.d.ts +12 -0
  27. package/esm/deps/deno.land/std@0.203.0/semver/format.js +54 -0
  28. package/esm/deps/deno.land/std@0.203.0/semver/gt.d.ts +3 -0
  29. package/esm/deps/deno.land/std@0.203.0/semver/gt.js +5 -0
  30. package/esm/deps/deno.land/std@0.203.0/semver/gte.d.ts +3 -0
  31. package/esm/deps/deno.land/std@0.203.0/semver/gte.js +5 -0
  32. package/esm/deps/deno.land/std@0.203.0/semver/gtr.d.ts +3 -0
  33. package/esm/deps/deno.land/std@0.203.0/semver/gtr.js +5 -0
  34. package/esm/deps/deno.land/std@0.203.0/semver/increment.d.ts +28 -0
  35. package/esm/deps/deno.land/std@0.203.0/semver/increment.js +207 -0
  36. package/esm/deps/deno.land/std@0.203.0/semver/is_semver.d.ts +17 -0
  37. package/esm/deps/deno.land/std@0.203.0/semver/is_semver.js +41 -0
  38. package/esm/deps/deno.land/std@0.203.0/semver/is_semver_comparator.d.ts +12 -0
  39. package/esm/deps/deno.land/std@0.203.0/semver/is_semver_comparator.js +31 -0
  40. package/esm/deps/deno.land/std@0.203.0/semver/is_semver_range.d.ts +12 -0
  41. package/esm/deps/deno.land/std@0.203.0/semver/is_semver_range.js +22 -0
  42. package/esm/deps/deno.land/std@0.203.0/semver/lt.d.ts +3 -0
  43. package/esm/deps/deno.land/std@0.203.0/semver/lt.js +5 -0
  44. package/esm/deps/deno.land/std@0.203.0/semver/lte.d.ts +3 -0
  45. package/esm/deps/deno.land/std@0.203.0/semver/lte.js +5 -0
  46. package/esm/deps/deno.land/std@0.203.0/semver/ltr.d.ts +3 -0
  47. package/esm/deps/deno.land/std@0.203.0/semver/ltr.js +5 -0
  48. package/esm/deps/deno.land/std@0.203.0/semver/max_satisfying.d.ts +9 -0
  49. package/esm/deps/deno.land/std@0.203.0/semver/max_satisfying.js +14 -0
  50. package/esm/deps/deno.land/std@0.203.0/semver/min_satisfying.d.ts +9 -0
  51. package/esm/deps/deno.land/std@0.203.0/semver/min_satisfying.js +14 -0
  52. package/esm/deps/deno.land/{std@0.173.0 → std@0.203.0}/semver/mod.d.ts +88 -176
  53. package/esm/deps/deno.land/std@0.203.0/semver/mod.js +313 -0
  54. package/esm/deps/deno.land/std@0.203.0/semver/neq.d.ts +3 -0
  55. package/esm/deps/deno.land/std@0.203.0/semver/neq.js +5 -0
  56. package/esm/deps/deno.land/std@0.203.0/semver/outside.d.ts +11 -0
  57. package/esm/deps/deno.land/std@0.203.0/semver/outside.js +67 -0
  58. package/esm/deps/deno.land/std@0.203.0/semver/parse.d.ts +8 -0
  59. package/esm/deps/deno.land/std@0.203.0/semver/parse.js +66 -0
  60. package/esm/deps/deno.land/std@0.203.0/semver/parse_comparator.d.ts +7 -0
  61. package/esm/deps/deno.land/std@0.203.0/semver/parse_comparator.js +28 -0
  62. package/esm/deps/deno.land/std@0.203.0/semver/parse_range.d.ts +7 -0
  63. package/esm/deps/deno.land/std@0.203.0/semver/parse_range.js +292 -0
  64. package/esm/deps/deno.land/std@0.203.0/semver/range_format.d.ts +8 -0
  65. package/esm/deps/deno.land/std@0.203.0/semver/range_format.js +11 -0
  66. package/esm/deps/deno.land/std@0.203.0/semver/range_intersects.d.ts +8 -0
  67. package/esm/deps/deno.land/std@0.203.0/semver/range_intersects.js +35 -0
  68. package/esm/deps/deno.land/std@0.203.0/semver/range_max.d.ts +7 -0
  69. package/esm/deps/deno.land/std@0.203.0/semver/range_max.js +15 -0
  70. package/esm/deps/deno.land/std@0.203.0/semver/range_min.d.ts +7 -0
  71. package/esm/deps/deno.land/std@0.203.0/semver/range_min.js +14 -0
  72. package/esm/deps/deno.land/std@0.203.0/semver/rcompare.d.ts +8 -0
  73. package/esm/deps/deno.land/std@0.203.0/semver/rcompare.js +10 -0
  74. package/esm/deps/deno.land/std@0.203.0/semver/rsort.d.ts +3 -0
  75. package/esm/deps/deno.land/std@0.203.0/semver/rsort.js +5 -0
  76. package/esm/deps/deno.land/std@0.203.0/semver/sort.d.ts +3 -0
  77. package/esm/deps/deno.land/std@0.203.0/semver/sort.js +5 -0
  78. package/esm/deps/deno.land/std@0.203.0/semver/test_comparator.d.ts +8 -0
  79. package/esm/deps/deno.land/std@0.203.0/semver/test_comparator.js +10 -0
  80. package/esm/deps/deno.land/std@0.203.0/semver/test_range.d.ts +8 -0
  81. package/esm/deps/deno.land/std@0.203.0/semver/test_range.js +16 -0
  82. package/esm/deps/deno.land/std@0.203.0/semver/types.d.ts +44 -0
  83. package/esm/deps/deno.land/std@0.203.0/semver/types.js +2 -0
  84. package/esm/src/Changelog.d.ts +4 -2
  85. package/esm/src/Changelog.js +25 -4
  86. package/esm/src/Release.d.ts +5 -4
  87. package/esm/src/Release.js +21 -22
  88. package/esm/src/deps.d.ts +2 -1
  89. package/esm/src/deps.js +1 -1
  90. package/esm/test/changelog.custom.type.md +2 -3
  91. package/esm/test/changelog.expected.linted.md +3 -4
  92. package/esm/test/changelog.expected.md +3 -4
  93. package/esm/test/changelog.md +3 -4
  94. package/esm/test/empty.expected.md +2 -2
  95. package/package.json +2 -2
  96. package/script/_dnt.shims.js +0 -1
  97. package/script/deps/deno.land/std@0.203.0/semver/_shared.d.ts +42 -0
  98. package/script/deps/deno.land/std@0.203.0/semver/_shared.js +248 -0
  99. package/script/deps/deno.land/std@0.203.0/semver/cmp.d.ts +9 -0
  100. package/script/deps/deno.land/std@0.203.0/semver/cmp.js +39 -0
  101. package/script/deps/deno.land/std@0.203.0/semver/comparator_format.d.ts +8 -0
  102. package/script/deps/deno.land/std@0.203.0/semver/comparator_format.js +15 -0
  103. package/script/deps/deno.land/std@0.203.0/semver/comparator_intersects.d.ts +8 -0
  104. package/script/deps/deno.land/std@0.203.0/semver/comparator_intersects.js +49 -0
  105. package/script/deps/deno.land/std@0.203.0/semver/comparator_max.d.ts +9 -0
  106. package/script/deps/deno.land/std@0.203.0/semver/comparator_max.js +49 -0
  107. package/script/deps/deno.land/std@0.203.0/semver/comparator_min.d.ts +8 -0
  108. package/script/deps/deno.land/std@0.203.0/semver/comparator_min.js +36 -0
  109. package/script/deps/deno.land/std@0.203.0/semver/compare.d.ts +10 -0
  110. package/script/deps/deno.land/std@0.203.0/semver/compare.js +22 -0
  111. package/script/deps/deno.land/std@0.203.0/semver/compare_build.d.ts +13 -0
  112. package/script/deps/deno.land/std@0.203.0/semver/compare_build.js +27 -0
  113. package/script/deps/deno.land/std@0.203.0/semver/constants.d.ts +42 -0
  114. package/script/deps/deno.land/std@0.203.0/semver/constants.js +78 -0
  115. package/script/deps/deno.land/std@0.203.0/semver/difference.d.ts +4 -0
  116. package/script/deps/deno.land/std@0.203.0/semver/difference.js +30 -0
  117. package/script/deps/deno.land/std@0.203.0/semver/eq.d.ts +4 -0
  118. package/script/deps/deno.land/std@0.203.0/semver/eq.js +11 -0
  119. package/script/deps/deno.land/std@0.203.0/semver/format.d.ts +12 -0
  120. package/script/deps/deno.land/std@0.203.0/semver/format.js +58 -0
  121. package/script/deps/deno.land/std@0.203.0/semver/gt.d.ts +3 -0
  122. package/script/deps/deno.land/std@0.203.0/semver/gt.js +9 -0
  123. package/script/deps/deno.land/std@0.203.0/semver/gte.d.ts +3 -0
  124. package/script/deps/deno.land/std@0.203.0/semver/gte.js +9 -0
  125. package/script/deps/deno.land/std@0.203.0/semver/gtr.d.ts +3 -0
  126. package/script/deps/deno.land/std@0.203.0/semver/gtr.js +9 -0
  127. package/script/deps/deno.land/std@0.203.0/semver/increment.d.ts +28 -0
  128. package/script/deps/deno.land/std@0.203.0/semver/increment.js +211 -0
  129. package/script/deps/deno.land/std@0.203.0/semver/is_semver.d.ts +17 -0
  130. package/script/deps/deno.land/std@0.203.0/semver/is_semver.js +45 -0
  131. package/script/deps/deno.land/std@0.203.0/semver/is_semver_comparator.d.ts +12 -0
  132. package/script/deps/deno.land/std@0.203.0/semver/is_semver_comparator.js +35 -0
  133. package/script/deps/deno.land/std@0.203.0/semver/is_semver_range.d.ts +12 -0
  134. package/script/deps/deno.land/std@0.203.0/semver/is_semver_range.js +26 -0
  135. package/script/deps/deno.land/std@0.203.0/semver/lt.d.ts +3 -0
  136. package/script/deps/deno.land/std@0.203.0/semver/lt.js +9 -0
  137. package/script/deps/deno.land/std@0.203.0/semver/lte.d.ts +3 -0
  138. package/script/deps/deno.land/std@0.203.0/semver/lte.js +9 -0
  139. package/script/deps/deno.land/std@0.203.0/semver/ltr.d.ts +3 -0
  140. package/script/deps/deno.land/std@0.203.0/semver/ltr.js +9 -0
  141. package/script/deps/deno.land/std@0.203.0/semver/max_satisfying.d.ts +9 -0
  142. package/script/deps/deno.land/std@0.203.0/semver/max_satisfying.js +18 -0
  143. package/script/deps/deno.land/std@0.203.0/semver/min_satisfying.d.ts +9 -0
  144. package/script/deps/deno.land/std@0.203.0/semver/min_satisfying.js +18 -0
  145. package/script/deps/deno.land/{std@0.173.0 → std@0.203.0}/semver/mod.d.ts +88 -176
  146. package/script/deps/deno.land/std@0.203.0/semver/mod.js +330 -0
  147. package/script/deps/deno.land/std@0.203.0/semver/neq.d.ts +3 -0
  148. package/script/deps/deno.land/std@0.203.0/semver/neq.js +9 -0
  149. package/script/deps/deno.land/std@0.203.0/semver/outside.d.ts +11 -0
  150. package/script/deps/deno.land/std@0.203.0/semver/outside.js +71 -0
  151. package/script/deps/deno.land/std@0.203.0/semver/parse.d.ts +8 -0
  152. package/script/deps/deno.land/std@0.203.0/semver/parse.js +70 -0
  153. package/script/deps/deno.land/std@0.203.0/semver/parse_comparator.d.ts +7 -0
  154. package/script/deps/deno.land/std@0.203.0/semver/parse_comparator.js +32 -0
  155. package/script/deps/deno.land/std@0.203.0/semver/parse_range.d.ts +7 -0
  156. package/script/deps/deno.land/std@0.203.0/semver/parse_range.js +296 -0
  157. package/script/deps/deno.land/std@0.203.0/semver/range_format.d.ts +8 -0
  158. package/script/deps/deno.land/std@0.203.0/semver/range_format.js +15 -0
  159. package/script/deps/deno.land/std@0.203.0/semver/range_intersects.d.ts +8 -0
  160. package/script/deps/deno.land/std@0.203.0/semver/range_intersects.js +39 -0
  161. package/script/deps/deno.land/std@0.203.0/semver/range_max.d.ts +7 -0
  162. package/script/deps/deno.land/std@0.203.0/semver/range_max.js +19 -0
  163. package/script/deps/deno.land/std@0.203.0/semver/range_min.d.ts +7 -0
  164. package/script/deps/deno.land/std@0.203.0/semver/range_min.js +18 -0
  165. package/script/deps/deno.land/std@0.203.0/semver/rcompare.d.ts +8 -0
  166. package/script/deps/deno.land/std@0.203.0/semver/rcompare.js +14 -0
  167. package/script/deps/deno.land/std@0.203.0/semver/rsort.d.ts +3 -0
  168. package/script/deps/deno.land/std@0.203.0/semver/rsort.js +9 -0
  169. package/script/deps/deno.land/std@0.203.0/semver/sort.d.ts +3 -0
  170. package/script/deps/deno.land/std@0.203.0/semver/sort.js +9 -0
  171. package/script/deps/deno.land/std@0.203.0/semver/test_comparator.d.ts +8 -0
  172. package/script/deps/deno.land/std@0.203.0/semver/test_comparator.js +14 -0
  173. package/script/deps/deno.land/std@0.203.0/semver/test_range.d.ts +8 -0
  174. package/script/deps/deno.land/std@0.203.0/semver/test_range.js +20 -0
  175. package/script/deps/deno.land/std@0.203.0/semver/types.d.ts +44 -0
  176. package/script/deps/deno.land/std@0.203.0/semver/types.js +3 -0
  177. package/script/src/Changelog.d.ts +4 -2
  178. package/script/src/Changelog.js +24 -3
  179. package/script/src/Release.d.ts +5 -4
  180. package/script/src/Release.js +20 -21
  181. package/script/src/deps.d.ts +2 -1
  182. package/script/src/deps.js +5 -6
  183. package/script/test/changelog.custom.type.md +2 -3
  184. package/script/test/changelog.expected.linted.md +3 -4
  185. package/script/test/changelog.expected.md +3 -4
  186. package/script/test/changelog.md +3 -4
  187. package/script/test/empty.expected.md +2 -2
  188. package/esm/_dnt.test_shims.d.ts +0 -5
  189. package/esm/deps/deno.land/std@0.133.0/fmt/colors.d.ts +0 -270
  190. package/esm/deps/deno.land/std@0.133.0/testing/_diff.d.ts +0 -23
  191. package/esm/deps/deno.land/std@0.133.0/testing/asserts.d.ts +0 -167
  192. package/esm/deps/deno.land/std@0.173.0/semver/mod.js +0 -1420
  193. package/esm/test/Change.test.d.ts +0 -1
  194. package/esm/test/deps.d.ts +0 -1
  195. package/esm/test/fixture/CustomRelease.d.ts +0 -8
  196. package/esm/test/parser.test.d.ts +0 -1
  197. package/esm/test/test.d.ts +0 -1
  198. package/script/_dnt.test_shims.d.ts +0 -5
  199. package/script/deps/deno.land/std@0.133.0/fmt/colors.d.ts +0 -270
  200. package/script/deps/deno.land/std@0.133.0/testing/_diff.d.ts +0 -23
  201. package/script/deps/deno.land/std@0.133.0/testing/asserts.d.ts +0 -167
  202. package/script/deps/deno.land/std@0.173.0/semver/mod.js +0 -1458
  203. package/script/test/Change.test.d.ts +0 -1
  204. package/script/test/deps.d.ts +0 -1
  205. package/script/test/fixture/CustomRelease.d.ts +0 -8
  206. package/script/test/parser.test.d.ts +0 -1
  207. package/script/test/test.d.ts +0 -1
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NONE = exports.ALL = exports.ANY = exports.INVALID = exports.MIN = exports.MAX = void 0;
4
+ /**
5
+ * MAX is a sentinel value used by some range calculations.
6
+ * It is equivalent to `∞.∞.∞`.
7
+ */
8
+ exports.MAX = {
9
+ major: Number.POSITIVE_INFINITY,
10
+ minor: Number.POSITIVE_INFINITY,
11
+ patch: Number.POSITIVE_INFINITY,
12
+ prerelease: [],
13
+ build: [],
14
+ };
15
+ /**
16
+ * The minimum valid SemVer object. Equivalent to `0.0.0`.
17
+ */
18
+ exports.MIN = {
19
+ major: 0,
20
+ minor: 0,
21
+ patch: 0,
22
+ prerelease: [],
23
+ build: [],
24
+ };
25
+ /**
26
+ * A sentinel value used to denote an invalid SemVer object
27
+ * which may be the result of impossible ranges or comparator operations.
28
+ * @example
29
+ * ```ts
30
+ * import { eq } from "https://deno.land/std@$STD_VERSION/semver/eq.ts";
31
+ * import { parse } from "https://deno.land/std@$STD_VERSION/semver/parse.ts";
32
+ * import { INVALID } from "https://deno.land/std@$STD_VERSION/semver/constants.ts"
33
+ * eq(parse("1.2.3"), INVALID);
34
+ * ```
35
+ */
36
+ exports.INVALID = {
37
+ major: Number.NEGATIVE_INFINITY,
38
+ minor: Number.POSITIVE_INFINITY,
39
+ patch: Number.POSITIVE_INFINITY,
40
+ prerelease: [],
41
+ build: [],
42
+ };
43
+ /**
44
+ * ANY is a sentinel value used by some range calculations. It is not a valid
45
+ * SemVer object and should not be used directly.
46
+ * @example
47
+ * ```ts
48
+ * import { eq } from "https://deno.land/std@$STD_VERSION/semver/eq.ts";
49
+ * import { parse } from "https://deno.land/std@$STD_VERSION/semver/parse.ts";
50
+ * import { ANY } from "https://deno.land/std@$STD_VERSION/semver/constants.ts"
51
+ * eq(parse("1.2.3"), ANY); // false
52
+ * ```
53
+ */
54
+ exports.ANY = {
55
+ major: Number.NaN,
56
+ minor: Number.NaN,
57
+ patch: Number.NaN,
58
+ prerelease: [],
59
+ build: [],
60
+ };
61
+ /**
62
+ * A comparator which will span all valid semantic versions
63
+ */
64
+ exports.ALL = {
65
+ operator: "",
66
+ semver: exports.ANY,
67
+ min: exports.MIN,
68
+ max: exports.MAX,
69
+ };
70
+ /**
71
+ * A comparator which will not span any semantic versions
72
+ */
73
+ exports.NONE = {
74
+ operator: "<",
75
+ semver: exports.MIN,
76
+ min: exports.MAX,
77
+ max: exports.MIN,
78
+ };
@@ -0,0 +1,4 @@
1
+ import type { ReleaseType, SemVer } from "./types.js";
2
+ /** Returns difference between two versions by the release type, or
3
+ * `undefined` if the versions are the same. */
4
+ export declare function difference(s0: SemVer, s1: SemVer): ReleaseType | undefined;
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.difference = void 0;
4
+ const eq_js_1 = require("./eq.js");
5
+ /** Returns difference between two versions by the release type, or
6
+ * `undefined` if the versions are the same. */
7
+ function difference(s0, s1) {
8
+ if ((0, eq_js_1.eq)(s0, s1)) {
9
+ return undefined;
10
+ }
11
+ else {
12
+ let prefix = "";
13
+ let defaultResult = undefined;
14
+ if (s0 && s1) {
15
+ if (s0.prerelease.length || s1.prerelease.length) {
16
+ prefix = "pre";
17
+ defaultResult = "prerelease";
18
+ }
19
+ for (const key in s0) {
20
+ if (key === "major" || key === "minor" || key === "patch") {
21
+ if (s0[key] !== s1[key]) {
22
+ return (prefix + key);
23
+ }
24
+ }
25
+ }
26
+ }
27
+ return defaultResult; // may be undefined
28
+ }
29
+ }
30
+ exports.difference = difference;
@@ -0,0 +1,4 @@
1
+ import type { SemVer } from "./types.js";
2
+ /** Returns `true` if they're logically equivalent, even if they're not the exact
3
+ * same version object. */
4
+ export declare function eq(s0: SemVer, s1: SemVer): boolean;
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.eq = void 0;
4
+ // Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
5
+ const compare_js_1 = require("./compare.js");
6
+ /** Returns `true` if they're logically equivalent, even if they're not the exact
7
+ * same version object. */
8
+ function eq(s0, s1) {
9
+ return (0, compare_js_1.compare)(s0, s1) === 0;
10
+ }
11
+ exports.eq = eq;
@@ -0,0 +1,12 @@
1
+ import type { FormatStyle, SemVer } from "./types.js";
2
+ /**
3
+ * Format a SemVer object into a string.
4
+ *
5
+ * If any number is NaN then NaN will be printed.
6
+ *
7
+ * If any number is positive or negative infinity then '∞' or '⧞' will be printed instead.
8
+ *
9
+ * @param semver The semantic version to format
10
+ * @returns The string representation of a semantic version.
11
+ */
12
+ export declare function format(semver: SemVer, style?: FormatStyle): string;
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.format = void 0;
4
+ // Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
5
+ const constants_js_1 = require("./constants.js");
6
+ function formatNumber(value) {
7
+ if (value === Number.POSITIVE_INFINITY) {
8
+ return "∞";
9
+ }
10
+ else if (value === Number.NEGATIVE_INFINITY) {
11
+ return "⧞";
12
+ }
13
+ else {
14
+ return value.toFixed(0);
15
+ }
16
+ }
17
+ /**
18
+ * Format a SemVer object into a string.
19
+ *
20
+ * If any number is NaN then NaN will be printed.
21
+ *
22
+ * If any number is positive or negative infinity then '∞' or '⧞' will be printed instead.
23
+ *
24
+ * @param semver The semantic version to format
25
+ * @returns The string representation of a semantic version.
26
+ */
27
+ function format(semver, style = "full") {
28
+ if (semver === constants_js_1.ANY) {
29
+ return "*";
30
+ }
31
+ const major = formatNumber(semver.major);
32
+ const minor = formatNumber(semver.minor);
33
+ const patch = formatNumber(semver.patch);
34
+ const pre = semver.prerelease.join(".");
35
+ const build = semver.build.join(".");
36
+ const primary = `${major}.${minor}.${patch}`;
37
+ const release = [primary, pre].filter((v) => v).join("-");
38
+ const full = [release, build].filter((v) => v).join("+");
39
+ switch (style) {
40
+ case "full":
41
+ return full;
42
+ case "release":
43
+ return release;
44
+ case "primary":
45
+ return primary;
46
+ case "build":
47
+ return build;
48
+ case "pre":
49
+ return pre;
50
+ case "patch":
51
+ return patch;
52
+ case "minor":
53
+ return minor;
54
+ case "major":
55
+ return major;
56
+ }
57
+ }
58
+ exports.format = format;
@@ -0,0 +1,3 @@
1
+ import type { SemVer } from "./types.js";
2
+ /** Greater than comparison */
3
+ export declare function gt(s0: SemVer, s1: SemVer): boolean;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.gt = void 0;
4
+ const compare_js_1 = require("./compare.js");
5
+ /** Greater than comparison */
6
+ function gt(s0, s1) {
7
+ return (0, compare_js_1.compare)(s0, s1) > 0;
8
+ }
9
+ exports.gt = gt;
@@ -0,0 +1,3 @@
1
+ import type { SemVer } from "./types.js";
2
+ /** Greater than or equal to comparison */
3
+ export declare function gte(s0: SemVer, s1: SemVer): boolean;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.gte = void 0;
4
+ const compare_js_1 = require("./compare.js");
5
+ /** Greater than or equal to comparison */
6
+ function gte(s0, s1) {
7
+ return (0, compare_js_1.compare)(s0, s1) >= 0;
8
+ }
9
+ exports.gte = gte;
@@ -0,0 +1,3 @@
1
+ import type { SemVer, SemVerRange } from "./types.js";
2
+ /** Checks to see if the version is greater than all possible versions of the range. */
3
+ export declare function gtr(version: SemVer, range: SemVerRange): boolean;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.gtr = void 0;
4
+ const outside_js_1 = require("./outside.js");
5
+ /** Checks to see if the version is greater than all possible versions of the range. */
6
+ function gtr(version, range) {
7
+ return (0, outside_js_1.outside)(version, range, ">");
8
+ }
9
+ exports.gtr = gtr;
@@ -0,0 +1,28 @@
1
+ import type { ReleaseType, SemVer } from "./types.js";
2
+ /**
3
+ * Returns the new version resulting from an increment by release type.
4
+ *
5
+ * `premajor`, `preminor` and `prepatch` will bump the version up to the next version,
6
+ * based on the type, and will also add prerelease metadata.
7
+ *
8
+ * If called from a non-prerelease version, the `prerelease` will work the same as
9
+ * `prepatch`. The patch version is incremented and then is made into a prerelease. If
10
+ * the input version is already a prerelease it will simply increment the prerelease
11
+ * metadata.
12
+ *
13
+ * If a prerelease identifier is specified without a number then a number will be added.
14
+ * For example `pre` will result in `pre.0`. If the existing version already has a
15
+ * prerelease with a number and its the same prerelease identifier then the number
16
+ * will be incremented. If the identifier differs from the new identifier then the new
17
+ * identifier is applied and the number is reset to `0`.
18
+ *
19
+ * If the input version has build metadata it will be preserved on the resulting version
20
+ * unless a new build parameter is specified. Specifying `""` will unset existing build
21
+ * metadata.
22
+ * @param version The version to increment
23
+ * @param release The type of increment to perform
24
+ * @param prerelease The pre-release metadata of the new version
25
+ * @param build The build metadata of the new version
26
+ * @returns
27
+ */
28
+ export declare function increment(version: SemVer, release: ReleaseType, prerelease?: string, build?: string): SemVer;
@@ -0,0 +1,211 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.increment = void 0;
4
+ function pre(prerelease, identifier) {
5
+ let values = [...prerelease];
6
+ // In reality this will either be 0, 1 or 2 entries.
7
+ let i = values.length;
8
+ while (--i >= 0) {
9
+ if (typeof values[i] === "number") {
10
+ // deno-fmt-ignore
11
+ values[i]++;
12
+ i = -2;
13
+ }
14
+ }
15
+ if (i === -1) {
16
+ // didn't increment anything
17
+ values.push(0);
18
+ }
19
+ if (identifier) {
20
+ // 1.2.0-beta.1 bumps to 1.2.0-beta.2,
21
+ // 1.2.0-beta.foobar or 1.2.0-beta bumps to 1.2.0-beta.0
22
+ if (values[0] === identifier) {
23
+ if (isNaN(values[1])) {
24
+ values = [identifier, 0];
25
+ }
26
+ }
27
+ else {
28
+ values = [identifier, 0];
29
+ }
30
+ }
31
+ return values;
32
+ }
33
+ function parseBuild(build, metadata) {
34
+ return metadata === undefined ? build : metadata.split(".").filter((m) => m);
35
+ }
36
+ /**
37
+ * Returns the new version resulting from an increment by release type.
38
+ *
39
+ * `premajor`, `preminor` and `prepatch` will bump the version up to the next version,
40
+ * based on the type, and will also add prerelease metadata.
41
+ *
42
+ * If called from a non-prerelease version, the `prerelease` will work the same as
43
+ * `prepatch`. The patch version is incremented and then is made into a prerelease. If
44
+ * the input version is already a prerelease it will simply increment the prerelease
45
+ * metadata.
46
+ *
47
+ * If a prerelease identifier is specified without a number then a number will be added.
48
+ * For example `pre` will result in `pre.0`. If the existing version already has a
49
+ * prerelease with a number and its the same prerelease identifier then the number
50
+ * will be incremented. If the identifier differs from the new identifier then the new
51
+ * identifier is applied and the number is reset to `0`.
52
+ *
53
+ * If the input version has build metadata it will be preserved on the resulting version
54
+ * unless a new build parameter is specified. Specifying `""` will unset existing build
55
+ * metadata.
56
+ * @param version The version to increment
57
+ * @param release The type of increment to perform
58
+ * @param prerelease The pre-release metadata of the new version
59
+ * @param build The build metadata of the new version
60
+ * @returns
61
+ */
62
+ function increment(version, release, prerelease, build) {
63
+ let result;
64
+ switch (release) {
65
+ case "premajor":
66
+ result = {
67
+ major: version.major + 1,
68
+ minor: 0,
69
+ patch: 0,
70
+ prerelease: pre(version.prerelease, prerelease),
71
+ build: parseBuild(version.build, build),
72
+ };
73
+ break;
74
+ case "preminor":
75
+ result = {
76
+ major: version.major,
77
+ minor: version.minor + 1,
78
+ patch: 0,
79
+ prerelease: pre(version.prerelease, prerelease),
80
+ build: parseBuild(version.build, build),
81
+ };
82
+ break;
83
+ case "prepatch":
84
+ result = {
85
+ major: version.major,
86
+ minor: version.minor,
87
+ patch: version.patch + 1,
88
+ prerelease: pre(version.prerelease, prerelease),
89
+ build: parseBuild(version.build, build),
90
+ };
91
+ break;
92
+ // If the input is a non-prerelease version, this acts the same as
93
+ // prepatch.
94
+ case "prerelease":
95
+ if (version.prerelease.length === 0) {
96
+ result = {
97
+ major: version.major,
98
+ minor: version.minor,
99
+ patch: version.patch + 1,
100
+ prerelease: pre(version.prerelease, prerelease),
101
+ build: parseBuild(version.build, build),
102
+ };
103
+ break;
104
+ }
105
+ else {
106
+ result = {
107
+ major: version.major,
108
+ minor: version.minor,
109
+ patch: version.patch,
110
+ prerelease: pre(version.prerelease, prerelease),
111
+ build: parseBuild(version.build, build),
112
+ };
113
+ break;
114
+ }
115
+ case "major":
116
+ // If this is a pre-major version, bump up to the same major version.
117
+ // Otherwise increment major.
118
+ // 1.0.0-5 bumps to 1.0.0
119
+ // 1.1.0 bumps to 2.0.0
120
+ if (version.minor !== 0 ||
121
+ version.patch !== 0 ||
122
+ version.prerelease.length === 0) {
123
+ result = {
124
+ major: version.major + 1,
125
+ minor: 0,
126
+ patch: 0,
127
+ prerelease: [],
128
+ build: parseBuild(version.build, build),
129
+ };
130
+ break;
131
+ }
132
+ else {
133
+ result = {
134
+ major: version.major,
135
+ minor: 0,
136
+ patch: 0,
137
+ prerelease: [],
138
+ build: parseBuild(version.build, build),
139
+ };
140
+ break;
141
+ }
142
+ case "minor":
143
+ // If this is a pre-minor version, bump up to the same minor version.
144
+ // Otherwise increment minor.
145
+ // 1.2.0-5 bumps to 1.2.0
146
+ // 1.2.1 bumps to 1.3.0
147
+ if (version.patch !== 0 ||
148
+ version.prerelease.length === 0) {
149
+ result = {
150
+ major: version.major,
151
+ minor: version.minor + 1,
152
+ patch: 0,
153
+ prerelease: [],
154
+ build: parseBuild(version.build, build),
155
+ };
156
+ break;
157
+ }
158
+ else {
159
+ result = {
160
+ major: version.major,
161
+ minor: version.minor,
162
+ patch: 0,
163
+ prerelease: [],
164
+ build: parseBuild(version.build, build),
165
+ };
166
+ break;
167
+ }
168
+ case "patch":
169
+ // If this is not a pre-release version, it will increment the patch.
170
+ // If it is a pre-release it will bump up to the same patch version.
171
+ // 1.2.0-5 patches to 1.2.0
172
+ // 1.2.0 patches to 1.2.1
173
+ if (version.prerelease.length === 0) {
174
+ result = {
175
+ major: version.major,
176
+ minor: version.minor,
177
+ patch: version.patch + 1,
178
+ prerelease: [],
179
+ build: parseBuild(version.build, build),
180
+ };
181
+ break;
182
+ }
183
+ else {
184
+ result = {
185
+ major: version.major,
186
+ minor: version.minor,
187
+ patch: version.patch,
188
+ prerelease: [],
189
+ build: parseBuild(version.build, build),
190
+ };
191
+ break;
192
+ }
193
+ // 1.0.0 "pre" would become 1.0.0-0
194
+ // 1.0.0-0 would become 1.0.0-1
195
+ // 1.0.0-beta.0 would be come 1.0.0-beta.1
196
+ // switching the pre identifier resets the number to 0
197
+ case "pre":
198
+ result = {
199
+ major: version.major,
200
+ minor: version.minor,
201
+ patch: version.patch,
202
+ prerelease: pre(version.prerelease, prerelease),
203
+ build: parseBuild(version.build, build),
204
+ };
205
+ break;
206
+ default:
207
+ throw new Error(`invalid increment argument: ${release}`);
208
+ }
209
+ return result;
210
+ }
211
+ exports.increment = increment;
@@ -0,0 +1,17 @@
1
+ import type { SemVer } from "./types.js";
2
+ /**
3
+ * Checks to see if value is a valid SemVer object. It does a check
4
+ * into each field including prerelease and build.
5
+ *
6
+ * Some invalid SemVer sentinels can still return true such as ANY and INVALID.
7
+ * An object which has the same value as a sentinel but isn't reference equal
8
+ * will still fail.
9
+ *
10
+ * Objects which are valid SemVer objects but have _extra_ fields are still
11
+ * considered SemVer objects and this will return true.
12
+ *
13
+ * A type assertion is added to the value.
14
+ * @param value The value to check to see if its a valid SemVer object
15
+ * @returns True if value is a valid SemVer otherwise false
16
+ */
17
+ export declare function isSemVer(value: unknown): value is SemVer;
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isSemVer = void 0;
4
+ // Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
5
+ const constants_js_1 = require("./constants.js");
6
+ const _shared_js_1 = require("./_shared.js");
7
+ /**
8
+ * Checks to see if value is a valid SemVer object. It does a check
9
+ * into each field including prerelease and build.
10
+ *
11
+ * Some invalid SemVer sentinels can still return true such as ANY and INVALID.
12
+ * An object which has the same value as a sentinel but isn't reference equal
13
+ * will still fail.
14
+ *
15
+ * Objects which are valid SemVer objects but have _extra_ fields are still
16
+ * considered SemVer objects and this will return true.
17
+ *
18
+ * A type assertion is added to the value.
19
+ * @param value The value to check to see if its a valid SemVer object
20
+ * @returns True if value is a valid SemVer otherwise false
21
+ */
22
+ function isSemVer(value) {
23
+ if (value === null || value === undefined)
24
+ return false;
25
+ if (Array.isArray(value))
26
+ return false;
27
+ if (typeof value !== "object")
28
+ return false;
29
+ if (value === constants_js_1.INVALID)
30
+ return true;
31
+ if (value === constants_js_1.ANY)
32
+ return true;
33
+ const { major, minor, patch, build, prerelease } = value;
34
+ const result = typeof major === "number" && (0, _shared_js_1.isValidNumber)(major) &&
35
+ typeof minor === "number" && (0, _shared_js_1.isValidNumber)(minor) &&
36
+ typeof patch === "number" && (0, _shared_js_1.isValidNumber)(patch) &&
37
+ Array.isArray(prerelease) &&
38
+ Array.isArray(build) &&
39
+ prerelease.every((v) => typeof v === "string" || typeof v === "number") &&
40
+ prerelease.filter((v) => typeof v === "string").every((v) => (0, _shared_js_1.isValidString)(v)) &&
41
+ prerelease.filter((v) => typeof v === "number").every((v) => (0, _shared_js_1.isValidNumber)(v)) &&
42
+ build.every((v) => typeof v === "string" && (0, _shared_js_1.isValidString)(v));
43
+ return result;
44
+ }
45
+ exports.isSemVer = isSemVer;
@@ -0,0 +1,12 @@
1
+ import type { SemVerComparator } from "./types.js";
2
+ /**
3
+ * Does a deep check on the value to see if it is a valid SemVerComparator object.
4
+ *
5
+ * Objects with extra fields are still considered valid if they have at
6
+ * least the correct fields.
7
+ *
8
+ * Adds a type assertion if true.
9
+ * @param value The value to check if its a SemVerComparator
10
+ * @returns True if the object is a SemVerComparator otherwise false
11
+ */
12
+ export declare function isSemVerComparator(value: unknown): value is SemVerComparator;
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isSemVerComparator = void 0;
4
+ // Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
5
+ const is_semver_js_1 = require("./is_semver.js");
6
+ const _shared_js_1 = require("./_shared.js");
7
+ const constants_js_1 = require("./constants.js");
8
+ /**
9
+ * Does a deep check on the value to see if it is a valid SemVerComparator object.
10
+ *
11
+ * Objects with extra fields are still considered valid if they have at
12
+ * least the correct fields.
13
+ *
14
+ * Adds a type assertion if true.
15
+ * @param value The value to check if its a SemVerComparator
16
+ * @returns True if the object is a SemVerComparator otherwise false
17
+ */
18
+ function isSemVerComparator(value) {
19
+ if (value === null || value === undefined)
20
+ return false;
21
+ if (value === constants_js_1.NONE)
22
+ return true;
23
+ if (value === constants_js_1.ALL)
24
+ return true;
25
+ if (Array.isArray(value))
26
+ return false;
27
+ if (typeof value !== "object")
28
+ return false;
29
+ const { operator, semver, min, max } = value;
30
+ return ((0, _shared_js_1.isValidOperator)(operator) &&
31
+ (0, is_semver_js_1.isSemVer)(semver) &&
32
+ (0, is_semver_js_1.isSemVer)(min) &&
33
+ (0, is_semver_js_1.isSemVer)(max));
34
+ }
35
+ exports.isSemVerComparator = isSemVerComparator;
@@ -0,0 +1,12 @@
1
+ import type { SemVerRange } from "./types.js";
2
+ /**
3
+ * Does a deep check on the object to determine if its a valid range.
4
+ *
5
+ * Objects with extra fields are still considered valid if they have at
6
+ * least the correct fields.
7
+ *
8
+ * Adds a type assertion if true.
9
+ * @param value The value to check if its a valid SemVerRange
10
+ * @returns True if its a valid SemVerRange otherwise false.
11
+ */
12
+ export declare function isSemVerRange(value: unknown): value is SemVerRange;
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isSemVerRange = void 0;
4
+ const is_semver_comparator_js_1 = require("./is_semver_comparator.js");
5
+ /**
6
+ * Does a deep check on the object to determine if its a valid range.
7
+ *
8
+ * Objects with extra fields are still considered valid if they have at
9
+ * least the correct fields.
10
+ *
11
+ * Adds a type assertion if true.
12
+ * @param value The value to check if its a valid SemVerRange
13
+ * @returns True if its a valid SemVerRange otherwise false.
14
+ */
15
+ function isSemVerRange(value) {
16
+ if (value === null || value === undefined)
17
+ return false;
18
+ if (Array.isArray(value))
19
+ return false;
20
+ if (typeof value !== "object")
21
+ return false;
22
+ const { ranges } = value;
23
+ return (Array.isArray(ranges),
24
+ ranges.every((r) => Array.isArray(r) && r.every((c) => (0, is_semver_comparator_js_1.isSemVerComparator)(c))));
25
+ }
26
+ exports.isSemVerRange = isSemVerRange;
@@ -0,0 +1,3 @@
1
+ import type { SemVer } from "./types.js";
2
+ /** Less than comparison */
3
+ export declare function lt(s0: SemVer, s1: SemVer): boolean;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.lt = void 0;
4
+ const compare_js_1 = require("./compare.js");
5
+ /** Less than comparison */
6
+ function lt(s0, s1) {
7
+ return (0, compare_js_1.compare)(s0, s1) < 0;
8
+ }
9
+ exports.lt = lt;
@@ -0,0 +1,3 @@
1
+ import type { SemVer } from "./types.js";
2
+ /** Less than or equal to comparison */
3
+ export declare function lte(s0: SemVer, s1: SemVer): boolean;