syncpack 11.2.1 → 12.0.0-alpha.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 (274) hide show
  1. package/README.md +24 -26
  2. package/dist/bin-fix-mismatches/fix-mismatches.d.ts +15 -3
  3. package/dist/bin-fix-mismatches/fix-mismatches.js +124 -35
  4. package/dist/bin-fix-mismatches/index.js +12 -32
  5. package/dist/bin-format/format.d.ts +11 -3
  6. package/dist/bin-format/format.js +51 -61
  7. package/dist/bin-format/index.js +11 -31
  8. package/dist/bin-lint/index.js +8 -28
  9. package/dist/bin-lint/lint.d.ts +10 -3
  10. package/dist/bin-lint/lint.js +11 -35
  11. package/dist/bin-lint-semver-ranges/index.js +11 -39
  12. package/dist/bin-lint-semver-ranges/lint-semver-ranges.d.ts +15 -3
  13. package/dist/bin-lint-semver-ranges/lint-semver-ranges.js +93 -34
  14. package/dist/bin-list/index.js +11 -31
  15. package/dist/bin-list/list.d.ts +11 -3
  16. package/dist/bin-list/list.js +120 -34
  17. package/dist/bin-list-mismatches/index.js +11 -31
  18. package/dist/bin-list-mismatches/list-mismatches.d.ts +18 -3
  19. package/dist/bin-list-mismatches/list-mismatches.js +253 -34
  20. package/dist/bin-prompt/index.js +15 -31
  21. package/dist/bin-prompt/prompt.d.ts +10 -3
  22. package/dist/bin-prompt/prompt.js +87 -33
  23. package/dist/bin-set-semver-ranges/index.js +12 -40
  24. package/dist/bin-set-semver-ranges/set-semver-ranges.d.ts +10 -3
  25. package/dist/bin-set-semver-ranges/set-semver-ranges.js +54 -35
  26. package/dist/bin-update/effects.d.ts +45 -5
  27. package/dist/bin-update/effects.js +214 -128
  28. package/dist/bin-update/index.js +4 -27
  29. package/dist/bin-update/update.d.ts +5 -3
  30. package/dist/bin-update/update.js +56 -37
  31. package/dist/bin.js +0 -1
  32. package/dist/config/get-custom-types.d.ts +11 -1
  33. package/dist/config/get-custom-types.js +26 -21
  34. package/dist/config/get-enabled-types.d.ts +7 -8
  35. package/dist/config/get-enabled-types.js +63 -73
  36. package/dist/config/get-indent.js +1 -1
  37. package/dist/config/tag.d.ts +1 -1
  38. package/dist/config/tag.js +2 -25
  39. package/dist/config/types.d.ts +8 -9
  40. package/dist/constants.d.ts +2 -1
  41. package/dist/constants.js +2 -1
  42. package/dist/error-handlers/default-error-handlers.d.ts +25 -2
  43. package/dist/error-handlers/default-error-handlers.js +60 -36
  44. package/dist/get-context/index.d.ts +12 -6
  45. package/dist/get-context/index.js +13 -30
  46. package/dist/get-context/lib/key-by.d.ts +6 -0
  47. package/dist/get-context/lib/key-by.js +16 -0
  48. package/dist/get-instances/index.d.ts +14 -0
  49. package/dist/get-instances/index.js +46 -0
  50. package/dist/get-instances/instance.d.ts +25 -0
  51. package/dist/get-instances/instance.js +34 -0
  52. package/dist/get-package-json-files/get-file-paths.d.ts +6 -7
  53. package/dist/get-package-json-files/get-file-paths.js +10 -33
  54. package/dist/get-package-json-files/get-patterns/get-lerna-patterns.d.ts +3 -4
  55. package/dist/get-package-json-files/get-patterns/get-lerna-patterns.js +6 -32
  56. package/dist/get-package-json-files/get-patterns/get-pnpm-patterns.d.ts +3 -4
  57. package/dist/get-package-json-files/get-patterns/get-pnpm-patterns.js +6 -32
  58. package/dist/get-package-json-files/get-patterns/get-yarn-patterns.d.ts +3 -4
  59. package/dist/get-package-json-files/get-patterns/get-yarn-patterns.js +11 -40
  60. package/dist/get-package-json-files/get-patterns/index.d.ts +3 -5
  61. package/dist/get-package-json-files/get-patterns/index.js +6 -33
  62. package/dist/get-package-json-files/index.d.ts +6 -5
  63. package/dist/get-package-json-files/index.js +4 -28
  64. package/dist/get-package-json-files/package-json-file.d.ts +16 -16
  65. package/dist/get-package-json-files/package-json-file.js +21 -18
  66. package/dist/guards/can-add-to-group.d.ts +5 -4
  67. package/dist/guards/can-add-to-group.js +8 -4
  68. package/dist/guards/is-semver.d.ts +1 -1
  69. package/dist/guards/is-semver.js +1 -1
  70. package/dist/guards/is-valid-semver-range.d.ts +1 -1
  71. package/dist/guards/is-valid-semver-range.js +1 -1
  72. package/dist/io/ask-for-choice.d.ts +14 -0
  73. package/dist/io/ask-for-choice.js +21 -0
  74. package/dist/io/ask-for-input.d.ts +13 -0
  75. package/dist/io/ask-for-input.js +18 -0
  76. package/dist/io/exit-if-invalid.d.ts +4 -0
  77. package/dist/io/exit-if-invalid.js +13 -0
  78. package/dist/io/glob-sync.d.ts +11 -0
  79. package/dist/io/glob-sync.js +19 -0
  80. package/dist/io/index.d.ts +28 -0
  81. package/dist/{env/exit-if-invalid.js → io/index.js} +27 -9
  82. package/dist/io/read-config-file-sync.d.ts +7 -0
  83. package/dist/io/read-config-file-sync.js +26 -0
  84. package/dist/io/read-file-sync.d.ts +12 -0
  85. package/dist/io/read-file-sync.js +14 -0
  86. package/dist/io/read-json-file-sync.d.ts +30 -0
  87. package/dist/io/read-json-file-sync.js +25 -0
  88. package/dist/io/read-yaml-file-sync.d.ts +12 -0
  89. package/dist/io/read-yaml-file-sync.js +13 -0
  90. package/dist/io/write-file-sync.d.ts +12 -0
  91. package/dist/io/write-file-sync.js +15 -0
  92. package/dist/{env → io}/write-if-changed.d.ts +4 -4
  93. package/dist/io/write-if-changed.js +45 -0
  94. package/dist/lib/get-group-header.d.ts +10 -0
  95. package/dist/lib/get-group-header.js +31 -0
  96. package/dist/lib/get.d.ts +11 -0
  97. package/dist/lib/get.js +40 -0
  98. package/dist/lib/pad-start.d.ts +1 -0
  99. package/dist/lib/pad-start.js +7 -0
  100. package/dist/lib/ring-buffer.d.ts +10 -0
  101. package/dist/lib/ring-buffer.js +24 -0
  102. package/dist/lib/set-semver-range.d.ts +1 -1
  103. package/dist/lib/set-semver-range.js +7 -11
  104. package/dist/lib/with-logger.d.ts +2 -0
  105. package/dist/lib/with-logger.js +35 -0
  106. package/dist/option.d.ts +0 -1
  107. package/dist/option.js +0 -4
  108. package/dist/report.d.ts +166 -0
  109. package/dist/report.js +67 -0
  110. package/dist/schema.json +51 -20
  111. package/dist/semver-group/create-semver-groups.d.ts +4 -0
  112. package/dist/semver-group/create-semver-groups.js +77 -0
  113. package/dist/semver-group/disabled.d.ts +26 -0
  114. package/dist/semver-group/disabled.js +34 -0
  115. package/dist/semver-group/filtered-out.d.ts +27 -0
  116. package/dist/semver-group/filtered-out.js +40 -0
  117. package/dist/semver-group/ignored.d.ts +22 -0
  118. package/dist/semver-group/ignored.js +30 -0
  119. package/dist/semver-group/index.d.ts +22 -0
  120. package/dist/semver-group/index.js +10 -0
  121. package/dist/semver-group/with-range.d.ts +22 -0
  122. package/dist/semver-group/with-range.js +57 -0
  123. package/dist/specifier/alias.d.ts +15 -0
  124. package/dist/specifier/alias.js +22 -0
  125. package/dist/specifier/base.d.ts +39 -0
  126. package/dist/specifier/base.js +56 -0
  127. package/dist/specifier/delete.d.ts +15 -0
  128. package/dist/specifier/delete.js +18 -0
  129. package/dist/specifier/file.d.ts +6 -0
  130. package/dist/specifier/file.js +9 -0
  131. package/dist/specifier/hosted-git.d.ts +13 -0
  132. package/dist/specifier/hosted-git.js +24 -0
  133. package/dist/specifier/index.d.ts +27 -0
  134. package/dist/specifier/index.js +62 -0
  135. package/dist/specifier/lib/non-semver-error.d.ts +11 -0
  136. package/dist/specifier/lib/non-semver-error.js +10 -0
  137. package/dist/specifier/lib/parse-specifier.d.ts +14 -0
  138. package/dist/specifier/lib/parse-specifier.js +23 -0
  139. package/dist/specifier/lib/specific-registry-result.d.ts +9 -0
  140. package/dist/specifier/range.d.ts +18 -0
  141. package/dist/specifier/range.js +23 -0
  142. package/dist/specifier/tag.d.ts +9 -0
  143. package/dist/specifier/tag.js +12 -0
  144. package/dist/specifier/unsupported.d.ts +5 -0
  145. package/dist/specifier/unsupported.js +9 -0
  146. package/dist/specifier/url.d.ts +6 -0
  147. package/dist/specifier/url.js +9 -0
  148. package/dist/specifier/version.d.ts +18 -0
  149. package/dist/specifier/version.js +23 -0
  150. package/dist/specifier/workspace-protocol.d.ts +17 -0
  151. package/dist/specifier/workspace-protocol.js +35 -0
  152. package/dist/strategy/lib/get-non-empty-string-prop.d.ts +2 -2
  153. package/dist/strategy/lib/get-non-empty-string-prop.js +4 -5
  154. package/dist/strategy/name-and-version-props.d.ts +4 -4
  155. package/dist/strategy/name-and-version-props.js +36 -22
  156. package/dist/strategy/named-version-string.d.ts +4 -4
  157. package/dist/strategy/named-version-string.js +25 -25
  158. package/dist/strategy/unnamed-version-string.d.ts +4 -4
  159. package/dist/strategy/unnamed-version-string.js +23 -22
  160. package/dist/strategy/versions-by-name.d.ts +4 -4
  161. package/dist/strategy/versions-by-name.js +12 -12
  162. package/dist/version-group/banned.d.ts +17 -0
  163. package/dist/version-group/banned.js +32 -0
  164. package/dist/version-group/create-version-groups.d.ts +4 -0
  165. package/dist/version-group/create-version-groups.js +107 -0
  166. package/dist/version-group/filtered-out.d.ts +19 -0
  167. package/dist/version-group/filtered-out.js +34 -0
  168. package/dist/version-group/ignored.d.ts +17 -0
  169. package/dist/version-group/ignored.js +27 -0
  170. package/dist/version-group/index.d.ts +28 -0
  171. package/dist/version-group/index.js +10 -0
  172. package/dist/version-group/lib/get-highest-version.d.ts +6 -0
  173. package/dist/version-group/lib/get-highest-version.js +12 -0
  174. package/dist/version-group/lib/get-lowest-version.d.ts +6 -0
  175. package/dist/version-group/lib/get-lowest-version.js +12 -0
  176. package/dist/version-group/lib/get-preferred-version.d.ts +5 -0
  177. package/dist/{get-version-groups/lib/compare-semver.js → version-group/lib/get-preferred-version.js} +14 -2
  178. package/dist/version-group/lib/group-by.d.ts +5 -0
  179. package/dist/{get-version-groups → version-group}/lib/group-by.js +4 -0
  180. package/dist/version-group/pinned.d.ts +17 -0
  181. package/dist/version-group/pinned.js +30 -0
  182. package/dist/version-group/same-range.d.ts +19 -0
  183. package/dist/version-group/same-range.js +108 -0
  184. package/dist/version-group/snapped-to.d.ts +17 -0
  185. package/dist/version-group/snapped-to.js +83 -0
  186. package/dist/version-group/standard.d.ts +18 -0
  187. package/dist/version-group/standard.js +131 -0
  188. package/package.json +33 -33
  189. package/dist/bin-fix-mismatches/effects.d.ts +0 -2
  190. package/dist/bin-fix-mismatches/effects.js +0 -112
  191. package/dist/bin-format/format-cli.d.ts +0 -4
  192. package/dist/bin-format/format-cli.js +0 -42
  193. package/dist/bin-lint-semver-ranges/effects.d.ts +0 -2
  194. package/dist/bin-lint-semver-ranges/effects.js +0 -70
  195. package/dist/bin-list/effects.d.ts +0 -2
  196. package/dist/bin-list/effects.js +0 -114
  197. package/dist/bin-list-mismatches/effects.d.ts +0 -2
  198. package/dist/bin-list-mismatches/effects.js +0 -136
  199. package/dist/bin-prompt/effects.d.ts +0 -2
  200. package/dist/bin-prompt/effects.js +0 -110
  201. package/dist/bin-set-semver-ranges/effects.d.ts +0 -2
  202. package/dist/bin-set-semver-ranges/effects.js +0 -61
  203. package/dist/config/get-semver-range.d.ts +0 -3
  204. package/dist/config/get-semver-range.js +0 -12
  205. package/dist/create-program/effects.d.ts +0 -40
  206. package/dist/create-program/semver-ranges.d.ts +0 -7
  207. package/dist/create-program/semver-ranges.js +0 -55
  208. package/dist/create-program/versions.d.ts +0 -7
  209. package/dist/create-program/versions.js +0 -70
  210. package/dist/env/create-env.d.ts +0 -21
  211. package/dist/env/create-env.js +0 -81
  212. package/dist/env/default-env.d.ts +0 -18
  213. package/dist/env/default-env.js +0 -100
  214. package/dist/env/exit-if-invalid.d.ts +0 -4
  215. package/dist/env/tags.d.ts +0 -58
  216. package/dist/env/tags.js +0 -50
  217. package/dist/env/write-if-changed.js +0 -73
  218. package/dist/error-handlers/create-error-handlers.d.ts +0 -20
  219. package/dist/error-handlers/create-error-handlers.js +0 -60
  220. package/dist/get-package-json-files/get-patterns/read-json-safe.d.ts +0 -23
  221. package/dist/get-package-json-files/get-patterns/read-json-safe.js +0 -43
  222. package/dist/get-semver-groups/filtered-out.d.ts +0 -19
  223. package/dist/get-semver-groups/filtered-out.js +0 -55
  224. package/dist/get-semver-groups/ignored.d.ts +0 -17
  225. package/dist/get-semver-groups/ignored.js +0 -48
  226. package/dist/get-semver-groups/index.d.ts +0 -84
  227. package/dist/get-semver-groups/index.js +0 -139
  228. package/dist/get-semver-groups/with-range.d.ts +0 -18
  229. package/dist/get-semver-groups/with-range.js +0 -79
  230. package/dist/get-version-groups/banned.d.ts +0 -17
  231. package/dist/get-version-groups/banned.js +0 -50
  232. package/dist/get-version-groups/filtered-out.d.ts +0 -19
  233. package/dist/get-version-groups/filtered-out.js +0 -57
  234. package/dist/get-version-groups/ignored.d.ts +0 -17
  235. package/dist/get-version-groups/ignored.js +0 -50
  236. package/dist/get-version-groups/index.d.ts +0 -187
  237. package/dist/get-version-groups/index.js +0 -246
  238. package/dist/get-version-groups/lib/compare-semver.d.ts +0 -1
  239. package/dist/get-version-groups/lib/get-highest-version.d.ts +0 -2
  240. package/dist/get-version-groups/lib/get-highest-version.js +0 -13
  241. package/dist/get-version-groups/lib/get-lowest-version.d.ts +0 -2
  242. package/dist/get-version-groups/lib/get-lowest-version.js +0 -13
  243. package/dist/get-version-groups/lib/get-unique-specifiers.d.ts +0 -2
  244. package/dist/get-version-groups/lib/get-unique-specifiers.js +0 -11
  245. package/dist/get-version-groups/lib/group-by.d.ts +0 -1
  246. package/dist/get-version-groups/pinned.d.ts +0 -17
  247. package/dist/get-version-groups/pinned.js +0 -66
  248. package/dist/get-version-groups/same-range.d.ts +0 -17
  249. package/dist/get-version-groups/same-range.js +0 -73
  250. package/dist/get-version-groups/snapped-to.d.ts +0 -17
  251. package/dist/get-version-groups/snapped-to.js +0 -78
  252. package/dist/get-version-groups/standard.d.ts +0 -18
  253. package/dist/get-version-groups/standard.js +0 -109
  254. package/dist/guards/is-loose-semver.d.ts +0 -2
  255. package/dist/guards/is-loose-semver.js +0 -10
  256. package/dist/instance/create.d.ts +0 -4
  257. package/dist/instance/create.js +0 -142
  258. package/dist/instance/index.d.ts +0 -122
  259. package/dist/instance/index.js +0 -154
  260. package/dist/lib/$R.d.ts +0 -12
  261. package/dist/lib/$R.js +0 -34
  262. package/dist/lib/log-group-header.d.ts +0 -6
  263. package/dist/lib/log-group-header.js +0 -34
  264. package/dist/lib/log-verbose.d.ts +0 -1
  265. package/dist/lib/log-verbose.js +0 -24
  266. package/dist/lib/split-name-and-version.d.ts +0 -5
  267. package/dist/lib/split-name-and-version.js +0 -12
  268. /package/dist/{create-program/effects.js → specifier/lib/specific-registry-result.js} +0 -0
  269. /package/dist/{get-version-groups → version-group}/lib/clean.d.ts +0 -0
  270. /package/dist/{get-version-groups → version-group}/lib/clean.js +0 -0
  271. /package/dist/{get-version-groups → version-group}/lib/delete.d.ts +0 -0
  272. /package/dist/{get-version-groups → version-group}/lib/delete.js +0 -0
  273. /package/dist/{get-version-groups → version-group}/lib/get-range-score.d.ts +0 -0
  274. /package/dist/{get-version-groups → version-group}/lib/get-range-score.js +0 -0
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.readFileSync = exports.ReadFileError = void 0;
4
+ const effect_1 = require("effect");
5
+ class ReadFileError extends effect_1.Data.TaggedClass('ReadFileError') {
6
+ }
7
+ exports.ReadFileError = ReadFileError;
8
+ function readFileSync(io, filePath) {
9
+ return effect_1.Effect.try({
10
+ try: () => io.fs.readFileSync(filePath, { encoding: 'utf8' }),
11
+ catch: (err) => new ReadFileError({ filePath, error: String(err) }),
12
+ });
13
+ }
14
+ exports.readFileSync = readFileSync;
@@ -0,0 +1,30 @@
1
+ import { Data, Effect } from 'effect';
2
+ import type { Io } from '.';
3
+ import type { ReadFileError } from './read-file-sync';
4
+ declare const JsonParseError_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
5
+ readonly _tag: "JsonParseError";
6
+ }>;
7
+ export declare class JsonParseError extends JsonParseError_base<{
8
+ readonly error: unknown;
9
+ readonly filePath: string;
10
+ readonly json: string;
11
+ }> {
12
+ }
13
+ declare const JsonFile_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
14
+ readonly _tag: "JsonFile";
15
+ }>;
16
+ export declare class JsonFile<T> extends JsonFile_base<{
17
+ /** absolute path on disk to the directory of this file */
18
+ readonly dirPath: string;
19
+ /** absolute path on disk to this file */
20
+ readonly filePath: string;
21
+ /** relative path on disk to this file */
22
+ readonly shortPath: string;
23
+ /** parsed JSON contents of the file */
24
+ contents: T;
25
+ /** raw file contents of the file */
26
+ readonly json: string;
27
+ }> {
28
+ }
29
+ export declare function readJsonFileSync<T>(io: Io, filePath: string): Effect.Effect<never, ReadFileError | JsonParseError, JsonFile<T>>;
30
+ export {};
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.readJsonFileSync = exports.JsonFile = exports.JsonParseError = void 0;
4
+ const effect_1 = require("effect");
5
+ const path_1 = require("path");
6
+ const read_file_sync_1 = require("./read-file-sync");
7
+ class JsonParseError extends effect_1.Data.TaggedClass('JsonParseError') {
8
+ }
9
+ exports.JsonParseError = JsonParseError;
10
+ class JsonFile extends effect_1.Data.TaggedClass('JsonFile') {
11
+ }
12
+ exports.JsonFile = JsonFile;
13
+ function readJsonFileSync(io, filePath) {
14
+ return (0, effect_1.pipe)(effect_1.Effect.Do, effect_1.Effect.bind('json', () => (0, read_file_sync_1.readFileSync)(io, filePath)), effect_1.Effect.bind('contents', ({ json }) => effect_1.Effect.try({
15
+ try: () => JSON.parse(json),
16
+ catch: (error) => new JsonParseError({ error, filePath, json }),
17
+ })), effect_1.Effect.map(({ contents, json }) => new JsonFile({
18
+ contents,
19
+ dirPath: (0, path_1.dirname)(filePath),
20
+ filePath,
21
+ json,
22
+ shortPath: (0, path_1.relative)(io.process.cwd(), filePath),
23
+ })));
24
+ }
25
+ exports.readJsonFileSync = readJsonFileSync;
@@ -0,0 +1,12 @@
1
+ import { Data, Effect } from 'effect';
2
+ import type { Io } from '.';
3
+ declare const ReadYamlFileError_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
4
+ readonly _tag: "ReadYamlFileError";
5
+ }>;
6
+ declare class ReadYamlFileError extends ReadYamlFileError_base<{
7
+ readonly filePath: string;
8
+ readonly error: string;
9
+ }> {
10
+ }
11
+ export declare function readYamlFileSync<T = unknown>(io: Io, filePath: string): Effect.Effect<never, ReadYamlFileError, T>;
12
+ export {};
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.readYamlFileSync = void 0;
4
+ const effect_1 = require("effect");
5
+ class ReadYamlFileError extends effect_1.Data.TaggedClass('ReadYamlFileError') {
6
+ }
7
+ function readYamlFileSync(io, filePath) {
8
+ return effect_1.Effect.try({
9
+ try: () => io.readYamlFile.sync(filePath),
10
+ catch: (err) => new ReadYamlFileError({ filePath, error: String(err) }),
11
+ });
12
+ }
13
+ exports.readYamlFileSync = readYamlFileSync;
@@ -0,0 +1,12 @@
1
+ import { Data, Effect } from 'effect';
2
+ import type { Io } from '.';
3
+ declare const WriteFileError_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
4
+ readonly _tag: "WriteFileError";
5
+ }>;
6
+ export declare class WriteFileError extends WriteFileError_base<{
7
+ readonly filePath: string;
8
+ readonly error: string;
9
+ }> {
10
+ }
11
+ export declare function writeFileSync(filePath: string, contents: string): Effect.Effect<Io, WriteFileError, void>;
12
+ export {};
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.writeFileSync = exports.WriteFileError = void 0;
4
+ const effect_1 = require("effect");
5
+ const _1 = require(".");
6
+ class WriteFileError extends effect_1.Data.TaggedClass('WriteFileError') {
7
+ }
8
+ exports.WriteFileError = WriteFileError;
9
+ function writeFileSync(filePath, contents) {
10
+ return (0, effect_1.pipe)(_1.IoTag, effect_1.Effect.flatMap((io) => effect_1.Effect.try({
11
+ try: () => io.fs.writeFileSync(filePath, contents),
12
+ catch: (err) => new WriteFileError({ filePath, error: String(err) }),
13
+ })));
14
+ }
15
+ exports.writeFileSync = writeFileSync;
@@ -1,8 +1,8 @@
1
- import * as Effect from '@effect/io/Effect';
1
+ import { Effect } from 'effect';
2
+ import type { Io } from '.';
2
3
  import type { Ctx } from '../get-context';
3
- import { type Env } from './create-env';
4
- import type { WriteFileError } from './tags';
5
- export declare function writeIfChanged(ctx: Ctx): Effect.Effect<Env, WriteFileError, Ctx>;
4
+ import type { WriteFileError } from './write-file-sync';
5
+ export declare function writeIfChanged(ctx: Ctx): Effect.Effect<Io, WriteFileError, Ctx>;
6
6
  type Ending = '\n' | '\r' | '\r\n' | string;
7
7
  export declare const newlines: {
8
8
  detect(source: string): Ending;
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.newlines = exports.writeIfChanged = void 0;
7
+ const chalk_1 = __importDefault(require("chalk"));
8
+ const effect_1 = require("effect");
9
+ const os_1 = require("os");
10
+ const get_indent_1 = require("../config/get-indent");
11
+ const constants_1 = require("../constants");
12
+ const write_file_sync_1 = require("./write-file-sync");
13
+ function writeIfChanged(ctx) {
14
+ return (0, effect_1.pipe)(effect_1.Effect.all(ctx.packageJsonFiles.map((file) => (0, effect_1.pipe)(effect_1.Effect.Do, effect_1.Effect.bind('nextJson', () => toJson(file)), effect_1.Effect.bind('hasChanged', ({ nextJson }) => effect_1.Effect.succeed(file.jsonFile.json !== nextJson)), effect_1.Effect.flatMap(({ hasChanged, nextJson }) => hasChanged
15
+ ? (0, effect_1.pipe)((0, write_file_sync_1.writeFileSync)(file.jsonFile.filePath, nextJson), effect_1.Effect.flatMap(() => effect_1.Effect.logInfo((0, chalk_1.default) `{green ${constants_1.ICON.tick}} ${file.jsonFile.shortPath}`)))
16
+ : effect_1.Effect.logInfo((0, chalk_1.default) `{dim ${constants_1.ICON.skip} ${file.jsonFile.shortPath}}`))))), effect_1.Effect.map(() => ctx));
17
+ function toJson(file) {
18
+ const contents = file.jsonFile.contents;
19
+ const indent = (0, get_indent_1.getIndent)(ctx.config);
20
+ const EOL = exports.newlines.detect(file.jsonFile.json);
21
+ const source = `${JSON.stringify(contents, null, indent)}${EOL}`;
22
+ return effect_1.Effect.succeed(exports.newlines.fix(source, EOL));
23
+ }
24
+ }
25
+ exports.writeIfChanged = writeIfChanged;
26
+ const CR = '\r';
27
+ const CRLF = '\r\n';
28
+ const LF = '\n';
29
+ exports.newlines = {
30
+ detect(source) {
31
+ const cr = source.split(CR).length;
32
+ const lf = source.split(LF).length;
33
+ const crlf = source.split(CRLF).length;
34
+ if (cr + lf === 0)
35
+ return os_1.EOL;
36
+ if (crlf === cr && crlf === lf)
37
+ return CRLF;
38
+ if (cr > lf)
39
+ return CR;
40
+ return LF;
41
+ },
42
+ fix(source, lineEnding) {
43
+ return source.replace(/\r\n|\n|\r/g, lineEnding);
44
+ },
45
+ };
@@ -0,0 +1,10 @@
1
+ import type { SemverGroup } from '../semver-group';
2
+ import type { VersionGroup } from '../version-group';
3
+ export declare function getSemverGroupHeader(input: {
4
+ group: SemverGroup.Any;
5
+ index: number;
6
+ }): string;
7
+ export declare function getVersionGroupHeader(input: {
8
+ group: VersionGroup.Any;
9
+ index: number;
10
+ }): string;
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.getVersionGroupHeader = exports.getSemverGroupHeader = void 0;
7
+ const chalk_1 = __importDefault(require("chalk"));
8
+ function getSemverGroupHeader(input) {
9
+ return getGroupHeader(input.group.config.label || `Semver Group ${input.index + 1}`);
10
+ }
11
+ exports.getSemverGroupHeader = getSemverGroupHeader;
12
+ function getVersionGroupHeader(input) {
13
+ return getGroupHeader(input.group.config.label || `Version Group ${input.index + 1}`);
14
+ }
15
+ exports.getVersionGroupHeader = getVersionGroupHeader;
16
+ function getGroupHeader(label) {
17
+ const trimmed = label.trim();
18
+ const hasNewLines = trimmed.search(/[\r\n]/) !== -1;
19
+ const header = hasNewLines ? formatMultiLine(trimmed) : formatSingleLine(trimmed);
20
+ return chalk_1.default.blue(header);
21
+ }
22
+ function formatSingleLine(label) {
23
+ const leftSide = `= ${label} `;
24
+ const dividerWidth = 80 - leftSide.length;
25
+ const rightSide = dividerWidth > 0 ? '='.repeat(dividerWidth) : '';
26
+ return `${leftSide}${rightSide}`;
27
+ }
28
+ function formatMultiLine(label) {
29
+ const reindented = label.replace(/^\s+/gm, ' ');
30
+ return `= ${reindented}`;
31
+ }
@@ -0,0 +1,11 @@
1
+ import { Either } from 'effect';
2
+ export declare function get<T, P1 extends keyof NonNullable<T>>(obj: T, prop1: P1): Either.Either<Error, NonNullable<T>[P1]>;
3
+ export declare function get<T, P1 extends keyof NonNullable<T>, P2 extends keyof NonNullable<NonNullable<T>[P1]>>(obj: T, prop1: P1, prop2: P2): Either.Either<Error, NonNullable<NonNullable<T>[P1]>[P2]>;
4
+ export declare function get<T, P1 extends keyof NonNullable<T>, P2 extends keyof NonNullable<NonNullable<T>[P1]>, P3 extends keyof NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>>(obj: T, prop1: P1, prop2: P2, prop3: P3): Either.Either<Error, NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>;
5
+ export declare function get<T, P1 extends keyof NonNullable<T>, P2 extends keyof NonNullable<NonNullable<T>[P1]>, P3 extends keyof NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>, P4 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>>(obj: T, prop1: P1, prop2: P2, prop3: P3, prop4: P4): Either.Either<Error, NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>;
6
+ export declare function get<T, P1 extends keyof NonNullable<T>, P2 extends keyof NonNullable<NonNullable<T>[P1]>, P3 extends keyof NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>, P4 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>, P5 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>>(obj: T, prop1: P1, prop2: P2, prop3: P3, prop4: P4, prop5: P5): Either.Either<Error, NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>;
7
+ export declare function get<T, P1 extends keyof NonNullable<T>, P2 extends keyof NonNullable<NonNullable<T>[P1]>, P3 extends keyof NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>, P4 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>, P5 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>, P6 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>>(obj: T, prop1: P1, prop2: P2, prop3: P3, prop4: P4, prop5: P5, prop6: P6): Either.Either<Error, NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>[P6]>;
8
+ export declare function get<T, P1 extends keyof NonNullable<T>, P2 extends keyof NonNullable<NonNullable<T>[P1]>, P3 extends keyof NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>, P4 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>, P5 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>, P6 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>, P7 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>[P6]>>(obj: T, prop1: P1, prop2: P2, prop3: P3, prop4: P4, prop5: P5, prop6: P6, prop7: P7): Either.Either<Error, NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>[P6]>[P7]>;
9
+ export declare function get<T, P1 extends keyof NonNullable<T>, P2 extends keyof NonNullable<NonNullable<T>[P1]>, P3 extends keyof NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>, P4 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>, P5 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>, P6 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>, P7 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>[P6]>, P8 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>[P6]>[P7]>>(obj: T, prop1: P1, prop2: P2, prop3: P3, prop4: P4, prop5: P5, prop6: P6, prop7: P7, prop8: P8): Either.Either<Error, NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>[P6]>[P7]>[P8]>;
10
+ export declare function get<T, P1 extends keyof NonNullable<T>, P2 extends keyof NonNullable<NonNullable<T>[P1]>, P3 extends keyof NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>, P4 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>, P5 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>, P6 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>, P7 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>[P6]>, P8 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>[P6]>[P7]>, P9 extends keyof NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>[P6]>[P7]>[P8]>>(obj: T, prop1: P1, prop2: P2, prop3: P3, prop4: P4, prop5: P5, prop6: P6, prop7: P7, prop8: P8, prop9: P9): Either.Either<Error, NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<NonNullable<T>[P1]>[P2]>[P3]>[P4]>[P5]>[P6]>[P7]>[P8]>[P9]>;
11
+ export declare function get<T>(obj: T, ...props: any[]): Either.Either<Error, unknown>;
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.get = void 0;
4
+ const effect_1 = require("effect");
5
+ const is_function_1 = require("tightrope/guard/is-function");
6
+ const is_primitive_1 = require("tightrope/guard/is-primitive");
7
+ const is_readable_1 = require("tightrope/guard/is-readable");
8
+ function get(origin, ...props) {
9
+ return (0, is_readable_1.isReadable)(origin) ? props.reduce(getChild, origin) : ERR_UNREADABLE_ORIGIN(props, origin);
10
+ }
11
+ exports.get = get;
12
+ /** Used internally by get to retrieve a single child property from a parent object. */
13
+ function getChild(parent, prop) {
14
+ // quit if any ancestor was already not found
15
+ if (effect_1.Either.isEither(parent) && effect_1.Either.isLeft(parent))
16
+ return parent;
17
+ // ensure we have a plain value and not an Ok
18
+ const value = effect_1.Either.isEither(parent) && effect_1.Either.isRight(parent) ? effect_1.Either.getOrThrow(parent) : parent;
19
+ // quit if we can't read properties of value (eg value.likeThis)
20
+ if (!(0, is_readable_1.isReadable)(value))
21
+ return ERR_UNREADABLE_CHILD(prop, value);
22
+ // quit if value is object/array/function etc but the child is not found
23
+ if (!(0, is_primitive_1.isPrimitive)(value) && prop in value === false)
24
+ return ERR_NOT_FOUND(prop, value);
25
+ // quit if eg true.toFixed, 12.toUpperCase
26
+ if ((0, is_primitive_1.isPrimitive)(value) && value[prop] === undefined)
27
+ return ERR_NOT_FOUND(prop, value);
28
+ // the value is present, return it
29
+ const child = value[prop];
30
+ return effect_1.Either.right((0, is_function_1.isFunction)(child) ? child.bind(value) : child);
31
+ }
32
+ function ERR_UNREADABLE_CHILD(child, value) {
33
+ return effect_1.Either.left(new Error(`Cannot read "${child}" from unreadable value: ${value}`));
34
+ }
35
+ function ERR_NOT_FOUND(child, value) {
36
+ return effect_1.Either.left(new Error(`Property "${child}" not found on value: ${value}`));
37
+ }
38
+ function ERR_UNREADABLE_ORIGIN(props, origin) {
39
+ return effect_1.Either.left(new Error(`Cannot read "${props.join('.')}" from unreadable value: ${origin}`));
40
+ }
@@ -0,0 +1 @@
1
+ export declare function padStart(value: number): string;
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.padStart = void 0;
4
+ function padStart(value) {
5
+ return String(value).padStart(6, ' ');
6
+ }
7
+ exports.padStart = padStart;
@@ -0,0 +1,10 @@
1
+ /**
2
+ * An Array with a maximum size which, once reached, will replace the oldest
3
+ * item when a new one is added.
4
+ */
5
+ export declare class RingBuffer<T> extends Array {
6
+ cursor: number;
7
+ fixedLength: number;
8
+ constructor(fixedLength: number);
9
+ push(...values: T[]): number;
10
+ }
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RingBuffer = void 0;
4
+ /**
5
+ * An Array with a maximum size which, once reached, will replace the oldest
6
+ * item when a new one is added.
7
+ */
8
+ class RingBuffer extends Array {
9
+ cursor;
10
+ fixedLength;
11
+ constructor(fixedLength) {
12
+ super(fixedLength);
13
+ this.cursor = 0;
14
+ this.fixedLength = fixedLength;
15
+ }
16
+ push(...values) {
17
+ values.forEach((value) => {
18
+ this[this.cursor++] = value;
19
+ this.cursor %= this.length;
20
+ });
21
+ return this.length;
22
+ }
23
+ }
24
+ exports.RingBuffer = RingBuffer;
@@ -1,3 +1,3 @@
1
1
  import type { SemverRange } from '../config/types';
2
- export declare function getSemverRange(version: string): SemverRange;
2
+ /** @deprecated migrate to make better use of npm-package-arg */
3
3
  export declare function setSemverRange(semverRange: SemverRange, version: string): string;
@@ -1,24 +1,17 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.setSemverRange = exports.getSemverRange = void 0;
3
+ exports.setSemverRange = void 0;
4
+ const is_string_1 = require("tightrope/guard/is-string");
4
5
  const constants_1 = require("../constants");
5
- const is_loose_semver_1 = require("../guards/is-loose-semver");
6
6
  const is_semver_1 = require("../guards/is-semver");
7
7
  const is_valid_semver_range_1 = require("../guards/is-valid-semver-range");
8
- function getSemverRange(version) {
9
- if (version === '*')
10
- return version;
11
- const from1stNumber = version.search(/[0-9]/);
12
- const semverRange = version.slice(0, from1stNumber);
13
- return (0, is_valid_semver_range_1.isValidSemverRange)(semverRange) ? semverRange : '';
14
- }
15
- exports.getSemverRange = getSemverRange;
8
+ /** @deprecated migrate to make better use of npm-package-arg */
16
9
  function setSemverRange(semverRange, version) {
17
10
  if (!(0, is_semver_1.isSemver)(version) || !(0, is_valid_semver_range_1.isValidSemverRange)(semverRange))
18
11
  return version;
19
12
  if (semverRange === '*')
20
13
  return semverRange;
21
- const nextVersion = (0, is_loose_semver_1.isLooseSemver)(version) ? version.replace(/\.x/g, '.0') : version;
14
+ const nextVersion = isLooseSemver(version) ? version.replace(/\.x/g, '.0') : version;
22
15
  const from1stNumber = nextVersion.search(/[0-9]/);
23
16
  const from1stDot = nextVersion.indexOf('.');
24
17
  return semverRange === constants_1.RANGE.LOOSE
@@ -26,3 +19,6 @@ function setSemverRange(semverRange, version) {
26
19
  : `${semverRange}${nextVersion.slice(from1stNumber)}`;
27
20
  }
28
21
  exports.setSemverRange = setSemverRange;
22
+ function isLooseSemver(version) {
23
+ return (0, is_string_1.isString)(version) && (0, is_semver_1.isSemver)(version) && version.search(/\.x(\.|$)/) !== -1;
24
+ }
@@ -0,0 +1,2 @@
1
+ import { Effect } from 'effect';
2
+ export declare function withLogger(program: Effect.Effect<never, never, unknown>): Effect.Effect<never, never, unknown>;
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.withLogger = void 0;
7
+ const chalk_1 = __importDefault(require("chalk"));
8
+ const effect_1 = require("effect");
9
+ function withLogger(program) {
10
+ const logger = effect_1.Logger.make(({ logLevel, message }) => {
11
+ if (logLevel === effect_1.LogLevel.Info) {
12
+ globalThis.console.info(message);
13
+ }
14
+ else if (logLevel === effect_1.LogLevel.Debug) {
15
+ globalThis.console.info((0, chalk_1.default) `{magenta ? %s}`, message);
16
+ }
17
+ else if (logLevel === effect_1.LogLevel.Error) {
18
+ globalThis.console.error((0, chalk_1.default) `{red ! %s}`, message);
19
+ }
20
+ else if (logLevel === effect_1.LogLevel.Warning) {
21
+ globalThis.console.warn((0, chalk_1.default) `{yellow ! %s}`, message);
22
+ }
23
+ else {
24
+ globalThis.console.log((0, chalk_1.default) `{cyan [%s] %s}`, logLevel, message);
25
+ }
26
+ });
27
+ const layer = effect_1.Logger.replace(effect_1.Logger.defaultLogger, logger);
28
+ const logLevel = process.env.SYNCPACK_VERBOSE === 'true'
29
+ ? effect_1.LogLevel.Debug
30
+ : process.env.NODE_ENV === 'test'
31
+ ? effect_1.LogLevel.None
32
+ : effect_1.LogLevel.Info;
33
+ return effect_1.Effect.provide(effect_1.Logger.withMinimumLogLevel(program, logLevel), layer);
34
+ }
35
+ exports.withLogger = withLogger;
package/dist/option.d.ts CHANGED
@@ -2,7 +2,6 @@ export declare const option: {
2
2
  readonly config: readonly ["-c, --config <path>", "path to a syncpack config file"];
3
3
  readonly filter: readonly ["-f, --filter [pattern]", string];
4
4
  readonly indent: readonly ["-i, --indent [value]", "override indentation. defaults to \" \""];
5
- readonly semverRange: readonly ["-r, --semver-range <range>", "see supported ranges below. defaults to \"\""];
6
5
  readonly source: readonly ["-s, --source [pattern]", "glob pattern for package.json files to read from", typeof collect, string[]];
7
6
  readonly types: readonly ["-t, --types <names>", string];
8
7
  };
package/dist/option.js CHANGED
@@ -13,10 +13,6 @@ exports.option = {
13
13
  (0, chalk_1.default) `only include dependencies whose {yellow name} matches this regex`,
14
14
  ],
15
15
  indent: ['-i, --indent [value]', `override indentation. defaults to "${constants_1.DEFAULT_CONFIG.indent}"`],
16
- semverRange: [
17
- '-r, --semver-range <range>',
18
- `see supported ranges below. defaults to "${constants_1.DEFAULT_CONFIG.semverRange}"`,
19
- ],
20
16
  source: [
21
17
  '-s, --source [pattern]',
22
18
  'glob pattern for package.json files to read from',
@@ -0,0 +1,166 @@
1
+ import { Data } from 'effect';
2
+ import type { Union } from 'ts-toolbelt';
3
+ import type { Instance } from './get-instances/instance';
4
+ import type { Specifier } from './specifier';
5
+ export declare namespace Report {
6
+ export namespace Semver {
7
+ type Any = Union.Strict<Report.Semver.Invalid.Any | Report.Semver.Valid.Any>;
8
+ namespace Valid {
9
+ type Any = Union.Strict<Report.Disabled | Report.FilteredOut | Report.Ignored | Report.Valid>;
10
+ }
11
+ namespace Invalid {
12
+ type Any = Union.Strict<Report.Semver.Fixable.Any | Report.Semver.Unfixable.Any>;
13
+ }
14
+ namespace Fixable {
15
+ type Any = Report.SemverRangeMismatch;
16
+ }
17
+ namespace Unfixable {
18
+ type Any = Report.UnsupportedMismatch;
19
+ }
20
+ }
21
+ export namespace Version {
22
+ interface Group {
23
+ name: string;
24
+ reports: Report.Version.Any[];
25
+ }
26
+ type Any = Union.Strict<Report.Version.Invalid.Any | Report.Version.Valid.Any>;
27
+ namespace Valid {
28
+ type Any = Union.Strict<Report.Disabled | Report.FilteredOut | Report.Ignored | Report.Valid>;
29
+ }
30
+ namespace Invalid {
31
+ type Any = Union.Strict<Report.Version.Fixable.Any | Report.Version.Unfixable.Any>;
32
+ }
33
+ namespace Fixable {
34
+ type Any = Union.Strict<Report.Banned | Report.HighestSemverMismatch | Report.LocalPackageMismatch | Report.LowestSemverMismatch | Report.PinnedMismatch | Report.SemverRangeMismatch | Report.SnappedToMismatch>;
35
+ }
36
+ namespace Unfixable {
37
+ type Any = Union.Strict<Report.MissingLocalVersion | Report.MissingSnappedToMismatch | Report.UnsupportedMismatch | Report.SameRangeMismatch>;
38
+ }
39
+ }
40
+ const Disabled_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
41
+ readonly _tag: "Disabled";
42
+ }>;
43
+ /** Semver Groups are disabled by default */
44
+ export class Disabled extends Disabled_base<{
45
+ readonly instance: Instance;
46
+ }> {
47
+ }
48
+ const FilteredOut_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
49
+ readonly _tag: "FilteredOut";
50
+ }>;
51
+ /** Has a name which does not match the `--filter` RegExp */
52
+ export class FilteredOut extends FilteredOut_base<{
53
+ readonly instance: Instance;
54
+ }> {
55
+ }
56
+ const Ignored_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
57
+ readonly _tag: "Ignored";
58
+ }>;
59
+ /** Is in an ignored version group */
60
+ export class Ignored extends Ignored_base<{
61
+ readonly instance: Instance;
62
+ }> {
63
+ }
64
+ const Valid_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
65
+ readonly _tag: "Valid";
66
+ }>;
67
+ /** Version satisfies the rules of its version group */
68
+ export class Valid extends Valid_base<{
69
+ readonly specifier: Specifier.Any;
70
+ }> {
71
+ }
72
+ const Banned_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
73
+ readonly _tag: "Banned";
74
+ }>;
75
+ /** Must be removed */
76
+ export class Banned extends Banned_base<{
77
+ readonly fixable: Specifier.Any;
78
+ }> {
79
+ }
80
+ const HighestSemverMismatch_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
81
+ readonly _tag: "HighestSemverMismatch";
82
+ }>;
83
+ /** Version mismatches and should use a higher version found on another */
84
+ export class HighestSemverMismatch extends HighestSemverMismatch_base<{
85
+ readonly fixable: Specifier.Any;
86
+ }> {
87
+ }
88
+ const LocalPackageMismatch_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
89
+ readonly _tag: "LocalPackageMismatch";
90
+ }>;
91
+ /** Version mismatches the `.version` of the package developed in this repo */
92
+ export class LocalPackageMismatch extends LocalPackageMismatch_base<{
93
+ readonly fixable: Specifier.Any;
94
+ readonly localInstance: Instance;
95
+ }> {
96
+ }
97
+ const LowestSemverMismatch_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
98
+ readonly _tag: "LowestSemverMismatch";
99
+ }>;
100
+ /** Version mismatches and should use a lower version found on another */
101
+ export class LowestSemverMismatch extends LowestSemverMismatch_base<{
102
+ readonly fixable: Specifier.Any;
103
+ }> {
104
+ }
105
+ const PinnedMismatch_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
106
+ readonly _tag: "PinnedMismatch";
107
+ }>;
108
+ /** Version is not identical to the `pinVersion` of its Pinned version group */
109
+ export class PinnedMismatch extends PinnedMismatch_base<{
110
+ readonly fixable: Specifier.Any;
111
+ }> {
112
+ }
113
+ const SemverRangeMismatch_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
114
+ readonly _tag: "SemverRangeMismatch";
115
+ }>;
116
+ /** Version is identical but the semver range does not match its semver group */
117
+ export class SemverRangeMismatch extends SemverRangeMismatch_base<{
118
+ readonly fixable: Specifier.Any;
119
+ }> {
120
+ }
121
+ const SnappedToMismatch_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
122
+ readonly _tag: "SnappedToMismatch";
123
+ }>;
124
+ /** Version mismatches the version used by the packages in the `snapTo` array */
125
+ export class SnappedToMismatch extends SnappedToMismatch_base<{
126
+ readonly fixable: Specifier.Any;
127
+ readonly localInstance: Instance;
128
+ }> {
129
+ }
130
+ const MissingLocalVersion_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
131
+ readonly _tag: "MissingLocalVersion";
132
+ }>;
133
+ /** Dependency should match a local package.json which is missing a .version */
134
+ export class MissingLocalVersion extends MissingLocalVersion_base<{
135
+ readonly localInstance: Instance;
136
+ readonly unfixable: Instance;
137
+ }> {
138
+ }
139
+ const MissingSnappedToMismatch_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
140
+ readonly _tag: "MissingSnappedToMismatch";
141
+ }>;
142
+ /** Dependency is not present in any of the packages in the `snapTo` array */
143
+ export class MissingSnappedToMismatch extends MissingSnappedToMismatch_base<{
144
+ readonly unfixable: Instance;
145
+ }> {
146
+ }
147
+ const SameRangeMismatch_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
148
+ readonly _tag: "SameRangeMismatch";
149
+ }>;
150
+ /** Specifier does not cover the specifiers of every other instance in this group */
151
+ export class SameRangeMismatch extends SameRangeMismatch_base<{
152
+ readonly unfixable: Instance;
153
+ /** the raw specifiers which this instance's specifier did not cover */
154
+ readonly mismatches: string[];
155
+ }> {
156
+ }
157
+ const UnsupportedMismatch_base: new <A extends Record<string, any> = {}>(args: import("effect/Types").Equals<Omit<A, keyof import("effect/Equal").Equal>, {}> extends true ? void : { readonly [P in keyof A as P extends "_tag" | keyof import("effect/Equal").Equal ? never : P]: A[P]; }) => Data.Data<Readonly<A> & {
158
+ readonly _tag: "UnsupportedMismatch";
159
+ }>;
160
+ /** Version mismatches and is not semver, syncpack cannot guess what to do */
161
+ export class UnsupportedMismatch extends UnsupportedMismatch_base<{
162
+ readonly unfixable: Instance;
163
+ }> {
164
+ }
165
+ export {};
166
+ }