@monorepolint/rules 0.5.0-alpha.10 → 0.5.0-alpha.106

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 (156) hide show
  1. package/.turbo/turbo-clean.log +4 -0
  2. package/.turbo/turbo-compile-typescript.log +4 -0
  3. package/.turbo/turbo-lint.log +110 -0
  4. package/.turbo/turbo-test.log +638 -0
  5. package/.turbo/turbo-transpile-typescript.log +14 -0
  6. package/build/js/index.js +1417 -0
  7. package/build/js/index.js.map +1 -0
  8. package/build/tsconfig.tsbuildinfo +1 -0
  9. package/{lib/__tests__/utils.d.ts → build/types/__tests__/alphabeticalScripts.spec.d.ts} +2 -2
  10. package/build/types/__tests__/alphabeticalScripts.spec.d.ts.map +1 -0
  11. package/build/types/__tests__/bannedDependencies.spec.d.ts +2 -0
  12. package/build/types/__tests__/bannedDependencies.spec.d.ts.map +1 -0
  13. package/build/types/__tests__/consistentDependencies.spec.d.ts.map +1 -0
  14. package/build/types/__tests__/consistentVersions.spec.d.ts +8 -0
  15. package/build/types/__tests__/consistentVersions.spec.d.ts.map +1 -0
  16. package/build/types/__tests__/fileContents.spec.d.ts +8 -0
  17. package/build/types/__tests__/fileContents.spec.d.ts.map +1 -0
  18. package/build/types/__tests__/mustSatisfyPeerDependencies.spec.d.ts +8 -0
  19. package/build/types/__tests__/mustSatisfyPeerDependencies.spec.d.ts.map +1 -0
  20. package/build/types/__tests__/nestedWorkspaces.spec.d.ts +2 -0
  21. package/build/types/__tests__/nestedWorkspaces.spec.d.ts.map +1 -0
  22. package/build/types/__tests__/packageEntry.spec.d.ts.map +1 -0
  23. package/build/types/__tests__/packageOrder.spec.d.ts.map +1 -0
  24. package/build/types/__tests__/packageScript.spec.d.ts.map +1 -0
  25. package/build/types/__tests__/requireDependency.spec.d.ts +2 -0
  26. package/build/types/__tests__/requireDependency.spec.d.ts.map +1 -0
  27. package/build/types/__tests__/utils.d.ts +81 -0
  28. package/build/types/__tests__/utils.d.ts.map +1 -0
  29. package/build/types/alphabeticalDependencies.d.ts +9 -0
  30. package/build/types/alphabeticalDependencies.d.ts.map +1 -0
  31. package/build/types/alphabeticalScripts.d.ts +9 -0
  32. package/build/types/alphabeticalScripts.d.ts.map +1 -0
  33. package/build/types/bannedDependencies.d.ts +66 -0
  34. package/build/types/bannedDependencies.d.ts.map +1 -0
  35. package/build/types/consistentDependencies.d.ts +18 -0
  36. package/build/types/consistentDependencies.d.ts.map +1 -0
  37. package/build/types/consistentVersions.d.ts +21 -0
  38. package/build/types/consistentVersions.d.ts.map +1 -0
  39. package/build/types/fileContents.d.ts +39 -0
  40. package/build/types/fileContents.d.ts.map +1 -0
  41. package/build/types/index.d.ts +20 -0
  42. package/build/types/index.d.ts.map +1 -0
  43. package/build/types/mustSatisfyPeerDependencies.d.ts +427 -0
  44. package/build/types/mustSatisfyPeerDependencies.d.ts.map +1 -0
  45. package/build/types/nestedWorkspaces.d.ts +10 -0
  46. package/build/types/nestedWorkspaces.d.ts.map +1 -0
  47. package/build/types/packageEntry.d.ts +54 -0
  48. package/build/types/packageEntry.d.ts.map +1 -0
  49. package/build/types/packageOrder.d.ts +13 -0
  50. package/build/types/packageOrder.d.ts.map +1 -0
  51. package/build/types/packageScript.d.ts +37 -0
  52. package/build/types/packageScript.d.ts.map +1 -0
  53. package/build/types/public/util.d.ts +2 -0
  54. package/build/types/public/util.d.ts.map +1 -0
  55. package/build/types/requireDependency.d.ts +35 -0
  56. package/build/types/requireDependency.d.ts.map +1 -0
  57. package/build/types/standardTsconfig.d.ts +53 -0
  58. package/build/types/standardTsconfig.d.ts.map +1 -0
  59. package/build/types/util/checkAlpha.d.ts +10 -0
  60. package/build/types/util/checkAlpha.d.ts.map +1 -0
  61. package/build/types/util/makeDirectory.d.ts +8 -0
  62. package/build/types/util/makeDirectory.d.ts.map +1 -0
  63. package/build/types/util/makeRule.d.ts +13 -0
  64. package/build/types/util/makeRule.d.ts.map +1 -0
  65. package/build/types/util/packageDependencyGraphService.d.ts +37 -0
  66. package/build/types/util/packageDependencyGraphService.d.ts.map +1 -0
  67. package/package.json +45 -20
  68. package/src/__tests__/alphabeticalScripts.spec.ts +76 -0
  69. package/src/__tests__/bannedDependencies.spec.ts +189 -0
  70. package/src/__tests__/consistentDependencies.spec.ts +42 -28
  71. package/src/__tests__/consistentVersions.spec.ts +224 -0
  72. package/src/__tests__/fileContents.spec.ts +79 -0
  73. package/src/__tests__/mustSatisfyPeerDependencies.spec.ts +1189 -0
  74. package/src/__tests__/nestedWorkspaces.spec.ts +153 -0
  75. package/src/__tests__/packageEntry.spec.ts +127 -49
  76. package/src/__tests__/packageOrder.spec.ts +68 -53
  77. package/src/__tests__/packageScript.spec.ts +124 -98
  78. package/src/__tests__/requireDependency.spec.ts +152 -0
  79. package/src/__tests__/utils.ts +115 -11
  80. package/src/alphabeticalDependencies.ts +6 -50
  81. package/src/alphabeticalScripts.ts +19 -0
  82. package/src/bannedDependencies.ts +134 -45
  83. package/src/consistentDependencies.ts +39 -16
  84. package/src/consistentVersions.ts +141 -0
  85. package/src/fileContents.ts +39 -35
  86. package/src/index.ts +13 -8
  87. package/src/mustSatisfyPeerDependencies.ts +744 -0
  88. package/src/nestedWorkspaces.ts +60 -0
  89. package/src/packageEntry.ts +71 -27
  90. package/src/packageOrder.ts +15 -12
  91. package/src/packageScript.ts +14 -18
  92. package/src/public/util.ts +1 -0
  93. package/src/requireDependency.ts +71 -0
  94. package/src/standardTsconfig.ts +49 -26
  95. package/src/util/checkAlpha.ts +59 -0
  96. package/src/util/makeDirectory.ts +24 -0
  97. package/src/util/makeRule.ts +29 -0
  98. package/src/util/packageDependencyGraphService.ts +114 -0
  99. package/tsconfig.json +10 -2
  100. package/lib/__tests__/consistentDependencies.spec.d.ts.map +0 -1
  101. package/lib/__tests__/consistentDependencies.spec.js +0 -108
  102. package/lib/__tests__/consistentDependencies.spec.js.map +0 -1
  103. package/lib/__tests__/packageEntry.spec.d.ts.map +0 -1
  104. package/lib/__tests__/packageEntry.spec.js +0 -99
  105. package/lib/__tests__/packageEntry.spec.js.map +0 -1
  106. package/lib/__tests__/packageOrder.spec.d.ts.map +0 -1
  107. package/lib/__tests__/packageOrder.spec.js +0 -115
  108. package/lib/__tests__/packageOrder.spec.js.map +0 -1
  109. package/lib/__tests__/packageScript.spec.d.ts.map +0 -1
  110. package/lib/__tests__/packageScript.spec.js +0 -172
  111. package/lib/__tests__/packageScript.spec.js.map +0 -1
  112. package/lib/__tests__/utils.d.ts.map +0 -1
  113. package/lib/__tests__/utils.js +0 -23
  114. package/lib/__tests__/utils.js.map +0 -1
  115. package/lib/alphabeticalDependencies.d.ts +0 -10
  116. package/lib/alphabeticalDependencies.d.ts.map +0 -1
  117. package/lib/alphabeticalDependencies.js +0 -56
  118. package/lib/alphabeticalDependencies.js.map +0 -1
  119. package/lib/bannedDependencies.d.ts +0 -15
  120. package/lib/bannedDependencies.d.ts.map +0 -1
  121. package/lib/bannedDependencies.js +0 -57
  122. package/lib/bannedDependencies.js.map +0 -1
  123. package/lib/consistentDependencies.d.ts +0 -10
  124. package/lib/consistentDependencies.d.ts.map +0 -1
  125. package/lib/consistentDependencies.js +0 -57
  126. package/lib/consistentDependencies.js.map +0 -1
  127. package/lib/fileContents.d.ts +0 -25
  128. package/lib/fileContents.d.ts.map +0 -1
  129. package/lib/fileContents.js +0 -77
  130. package/lib/fileContents.js.map +0 -1
  131. package/lib/index.d.ts +0 -15
  132. package/lib/index.d.ts.map +0 -1
  133. package/lib/index.js +0 -25
  134. package/lib/index.js.map +0 -1
  135. package/lib/packageEntry.d.ts +0 -16
  136. package/lib/packageEntry.d.ts.map +0 -1
  137. package/lib/packageEntry.js +0 -40
  138. package/lib/packageEntry.js.map +0 -1
  139. package/lib/packageOrder.d.ts +0 -12
  140. package/lib/packageOrder.d.ts.map +0 -1
  141. package/lib/packageOrder.js +0 -103
  142. package/lib/packageOrder.js.map +0 -1
  143. package/lib/packageScript.d.ts +0 -25
  144. package/lib/packageScript.d.ts.map +0 -1
  145. package/lib/packageScript.js +0 -89
  146. package/lib/packageScript.js.map +0 -1
  147. package/lib/standardTsconfig.d.ts +0 -33
  148. package/lib/standardTsconfig.d.ts.map +0 -1
  149. package/lib/standardTsconfig.js +0 -98
  150. package/lib/standardTsconfig.js.map +0 -1
  151. package/tsconfig.tsbuildinfo +0 -2439
  152. /package/{lib → build/types}/__tests__/consistentDependencies.spec.d.ts +0 -0
  153. /package/{lib → build/types}/__tests__/packageEntry.spec.d.ts +0 -0
  154. /package/{lib → build/types}/__tests__/packageOrder.spec.d.ts +0 -0
  155. /package/{lib → build/types}/__tests__/packageScript.spec.d.ts +0 -0
  156. /package/{jest.config.js → jest.config.cjs} +0 -0
@@ -0,0 +1,1417 @@
1
+ // src/alphabeticalDependencies.ts
2
+ import * as r from "runtypes";
3
+
4
+ // src/util/checkAlpha.ts
5
+ import { diff } from "jest-diff";
6
+ function checkAlpha(context, block) {
7
+ const packageJson = context.getPackageJson();
8
+ const packagePath = context.getPackageJsonPath();
9
+ const blockToSort = packageJson[block];
10
+ if (blockToSort === void 0) {
11
+ return;
12
+ }
13
+ const actualOrder = Object.keys(blockToSort);
14
+ const expectedOrder = actualOrder.slice().sort();
15
+ if (!arrayOrderCompare(actualOrder, expectedOrder)) {
16
+ context.addError({
17
+ file: packagePath,
18
+ message: createIncorrectOrderErrorMessage(block, packageJson.name),
19
+ longMessage: diff(expectedOrder, actualOrder, { expand: true }),
20
+ fixer: () => {
21
+ const expectedDependencies = {};
22
+ expectedOrder.forEach((dep) => {
23
+ expectedDependencies[dep] = blockToSort[dep];
24
+ });
25
+ const newPackageJson = { ...packageJson };
26
+ newPackageJson[block] = expectedDependencies;
27
+ context.host.writeJson(packagePath, newPackageJson);
28
+ }
29
+ });
30
+ }
31
+ }
32
+ function arrayOrderCompare(a, b) {
33
+ for (let index = 0; index < a.length; index++) {
34
+ if (a[index] !== b[index]) {
35
+ return false;
36
+ }
37
+ }
38
+ return true;
39
+ }
40
+ function createIncorrectOrderErrorMessage(block, packageName) {
41
+ return `Incorrect order of ${block} in ${packageName}'s package.json`;
42
+ }
43
+
44
+ // src/util/makeRule.ts
45
+ var globalId = 0;
46
+ function makeRule({
47
+ name,
48
+ check,
49
+ optionsRuntype,
50
+ printStats
51
+ }) {
52
+ return function(ruleEntry) {
53
+ const id = `${name} :: ${globalId++}`;
54
+ return {
55
+ id,
56
+ check: (context) => check(context, ruleEntry.options, { id }),
57
+ name,
58
+ optionsRuntype,
59
+ ruleEntry,
60
+ printStats
61
+ };
62
+ };
63
+ }
64
+
65
+ // src/alphabeticalDependencies.ts
66
+ var Options = r.Undefined;
67
+ var alphabeticalDependencies = makeRule({
68
+ name: "alphabeticalDependencies",
69
+ check: (context) => {
70
+ checkAlpha(context, "dependencies");
71
+ checkAlpha(context, "devDependencies");
72
+ checkAlpha(context, "peerDependencies");
73
+ },
74
+ optionsRuntype: Options
75
+ });
76
+
77
+ // src/alphabeticalScripts.ts
78
+ import * as r2 from "runtypes";
79
+ var Options2 = r2.Undefined;
80
+ var alphabeticalScripts = makeRule({
81
+ name: "alphabeticalScripts",
82
+ check: (context) => {
83
+ checkAlpha(context, "scripts");
84
+ },
85
+ optionsRuntype: Options2
86
+ });
87
+
88
+ // src/bannedDependencies.ts
89
+ import { matchesAnyGlob } from "@monorepolint/utils";
90
+ import { AggregateTiming } from "@monorepolint/utils";
91
+ import * as path2 from "node:path";
92
+ import * as r3 from "runtypes";
93
+
94
+ // src/util/packageDependencyGraphService.ts
95
+ import * as path from "node:path";
96
+ import resolvePackagePath from "resolve-package-path";
97
+ var PackageDependencyGraphService = class {
98
+ buildDependencyGraph(startPackageJsonPath, host, maxDepth) {
99
+ const nodes = /* @__PURE__ */ new Map();
100
+ const visit = (packageJsonPath, currentDepth) => {
101
+ if (nodes.has(packageJsonPath)) {
102
+ return nodes.get(packageJsonPath);
103
+ }
104
+ const packageJson = host.readJson(packageJsonPath);
105
+ const node = {
106
+ packageJson,
107
+ dependencies: /* @__PURE__ */ new Map(),
108
+ paths: {
109
+ packageJsonPath,
110
+ rootDirectory: path.dirname(packageJsonPath)
111
+ }
112
+ };
113
+ nodes.set(packageJsonPath, node);
114
+ const nextDepth = currentDepth + 1;
115
+ if (maxDepth == null || nextDepth <= maxDepth) {
116
+ const dependencies = packageJson.dependencies != null ? Object.keys(packageJson.dependencies) : [];
117
+ for (const dependency of dependencies) {
118
+ const dependencyPackageJsonPath = resolvePackagePath(dependency, node.paths.rootDirectory);
119
+ if (dependencyPackageJsonPath == null) {
120
+ throw new Error(`Could not resolve ${dependency} from ${node.paths.rootDirectory}`);
121
+ }
122
+ node.dependencies.set(dependency, visit(dependencyPackageJsonPath, nextDepth));
123
+ }
124
+ }
125
+ return node;
126
+ };
127
+ return visit(startPackageJsonPath, 0);
128
+ }
129
+ *traverse(root, opts = { traverseAllPaths: false }) {
130
+ const visited = /* @__PURE__ */ new Set();
131
+ function* visit(node, importPath = []) {
132
+ if (!opts.traverseAllPaths && visited.has(node)) {
133
+ return;
134
+ }
135
+ if (importPath.indexOf(node) !== -1) {
136
+ return;
137
+ }
138
+ visited.add(node);
139
+ importPath = [...importPath, node];
140
+ yield { ...node, importPath };
141
+ for (const dependency of node.dependencies.values()) {
142
+ yield* visit(dependency, importPath);
143
+ }
144
+ }
145
+ yield* visit(root);
146
+ }
147
+ };
148
+
149
+ // src/bannedDependencies.ts
150
+ var bannedDepGlobsField = r3.Union(
151
+ r3.Array(r3.String),
152
+ r3.Record({
153
+ glob: r3.Array(r3.String).optional(),
154
+ exact: r3.Array(r3.String).optional()
155
+ })
156
+ );
157
+ var Options3 = r3.Union(
158
+ r3.Record({
159
+ bannedDependencies: bannedDepGlobsField,
160
+ bannedTransitiveDependencies: r3.Undefined.optional()
161
+ }),
162
+ r3.Record({
163
+ bannedDependencies: bannedDepGlobsField.optional(),
164
+ bannedTransitiveDependencies: r3.Array(r3.String)
165
+ }),
166
+ r3.Record({
167
+ bannedDependencies: bannedDepGlobsField.optional(),
168
+ bannedTransitiveDependencies: r3.Array(r3.String).optional()
169
+ })
170
+ );
171
+ var setCache = /* @__PURE__ */ new Map();
172
+ var aggregateTiming = new AggregateTiming(":bannedDependencies stats");
173
+ var bannedDependencies = makeRule({
174
+ name: "bannedDependencies",
175
+ check: (context, opts, extra) => {
176
+ aggregateTiming.start((extra == null ? void 0 : extra.id) ?? "unknown id");
177
+ const packageJson = context.getPackageJson();
178
+ const packagePath = context.getPackageJsonPath();
179
+ const curDeps = packageJson.dependencies && Object.keys(packageJson.dependencies);
180
+ const curDevDeps = packageJson.devDependencies && Object.keys(packageJson.devDependencies);
181
+ const curPeerDeps = packageJson.peerDependencies && Object.keys(packageJson.peerDependencies);
182
+ const { bannedDependencies: banned, bannedTransitiveDependencies: transitives } = opts;
183
+ const globs = banned && (Array.isArray(banned) ? banned : banned.glob);
184
+ const exacts = banned && (Array.isArray(banned) ? void 0 : banned.exact);
185
+ const violations = /* @__PURE__ */ new Set();
186
+ if (globs) {
187
+ if (curDeps)
188
+ populateProblemsGlobs(globs, curDeps, violations);
189
+ if (curDevDeps)
190
+ populateProblemsGlobs(globs, curDevDeps, violations);
191
+ if (curPeerDeps)
192
+ populateProblemsGlobs(globs, curPeerDeps, violations);
193
+ }
194
+ if (exacts) {
195
+ let set = setCache.get(exacts);
196
+ if (set === void 0) {
197
+ set = new Set(exacts);
198
+ setCache.set(exacts, set);
199
+ }
200
+ if (curDeps)
201
+ populateProblemsExact(set, curDeps, violations);
202
+ if (curDevDeps)
203
+ populateProblemsExact(set, curDevDeps, violations);
204
+ if (curPeerDeps)
205
+ populateProblemsExact(set, curPeerDeps, violations);
206
+ }
207
+ if (violations.size > 0) {
208
+ context.addError({
209
+ file: packagePath,
210
+ message: `Found ${violations.size} banned dependencies of package.json:
211
+ ` + Array.from(violations).map((v) => `'${v}'`).join(", ")
212
+ });
213
+ }
214
+ if (transitives) {
215
+ let set = setCache.get(transitives);
216
+ if (set === void 0) {
217
+ set = new Set(transitives);
218
+ setCache.set(transitives, set);
219
+ }
220
+ checkTransitives(context, set);
221
+ }
222
+ aggregateTiming.stop();
223
+ },
224
+ optionsRuntype: Options3,
225
+ printStats: () => {
226
+ aggregateTiming.printResults();
227
+ }
228
+ });
229
+ function populateProblemsExact(banned, dependencies, violations) {
230
+ for (const dependency of dependencies) {
231
+ if (banned.has(dependency)) {
232
+ violations.add(dependency);
233
+ }
234
+ }
235
+ }
236
+ function populateProblemsGlobs(bannedDependencyGlobs, dependencies, violations) {
237
+ for (const dependency of dependencies) {
238
+ if (matchesAnyGlob(dependency, bannedDependencyGlobs)) {
239
+ violations.add(dependency);
240
+ }
241
+ }
242
+ }
243
+ function checkTransitives(context, banned) {
244
+ const graphService = new PackageDependencyGraphService();
245
+ const root = graphService.buildDependencyGraph(path2.resolve(context.getPackageJsonPath()), context.host);
246
+ for (const { dependencies, importPath } of graphService.traverse(root)) {
247
+ for (const [dependency] of dependencies) {
248
+ if (banned.has(dependency)) {
249
+ const [, ...importPathWithoutRoot] = importPath;
250
+ const pathing = [...importPathWithoutRoot.map(nameOrPackageJsonPath), dependency].join(" -> ");
251
+ context.addError({
252
+ file: root.paths.packageJsonPath,
253
+ message: `Banned transitive dependencies in repo: ${pathing}`
254
+ });
255
+ }
256
+ }
257
+ }
258
+ }
259
+ function nameOrPackageJsonPath(node) {
260
+ return node.packageJson.name ?? node.paths.packageJsonPath;
261
+ }
262
+
263
+ // src/consistentDependencies.ts
264
+ import { diff as diff2 } from "jest-diff";
265
+ import * as r4 from "runtypes";
266
+ var Options4 = r4.Record({
267
+ ignoredDependencies: r4.Array(r4.String).Or(r4.Undefined)
268
+ }).Or(r4.Undefined);
269
+ var skippedVersions = ["*", "latest"];
270
+ var consistentDependencies = makeRule({
271
+ name: "consistentDependencies",
272
+ check: (context, args) => {
273
+ checkDeps(context, args, "dependencies");
274
+ checkDeps(context, args, "devDependencies");
275
+ },
276
+ optionsRuntype: Options4
277
+ });
278
+ function checkDeps(context, args, block) {
279
+ const packageJson = context.getPackageJson();
280
+ const packagePath = context.getPackageJsonPath();
281
+ const dependencies = packageJson[block];
282
+ const workspacePackageJson = context.getWorkspaceContext().getPackageJson();
283
+ const workspaceDependencies = workspacePackageJson[block];
284
+ const ignoredDeps = (args == null ? void 0 : args.ignoredDependencies) ?? [];
285
+ const depsToCheck = workspaceDependencies == null || ignoredDeps.length === 0 ? workspaceDependencies : omit(workspaceDependencies, ignoredDeps);
286
+ if (dependencies === void 0 || depsToCheck === void 0) {
287
+ return;
288
+ }
289
+ const expectedDependencies = {
290
+ ...dependencies,
291
+ ...filterKeys(depsToCheck, dependencies)
292
+ };
293
+ if (JSON.stringify(dependencies) !== JSON.stringify(expectedDependencies)) {
294
+ context.addError({
295
+ file: packagePath,
296
+ message: `Inconsistent ${block} with root in package.json`,
297
+ longMessage: diff2(expectedDependencies, dependencies, { expand: true }),
298
+ fixer: () => {
299
+ const newPackageJson = { ...packageJson };
300
+ newPackageJson[block] = expectedDependencies;
301
+ context.host.writeJson(packagePath, newPackageJson);
302
+ }
303
+ });
304
+ }
305
+ }
306
+ function filterKeys(ob, filterOb) {
307
+ const newOb = {};
308
+ for (const key of Object.keys(filterOb)) {
309
+ if (ob[key] !== void 0 && skippedVersions.indexOf(filterOb[key]) === -1) {
310
+ newOb[key] = ob[key];
311
+ }
312
+ }
313
+ return newOb;
314
+ }
315
+ function omit(obj, keysToOmit) {
316
+ const newObj = {};
317
+ const filtered = Object.entries(obj).filter(([key]) => !keysToOmit.includes(key));
318
+ for (const [key, value] of filtered) {
319
+ newObj[key] = value;
320
+ }
321
+ return newObj;
322
+ }
323
+
324
+ // src/consistentVersions.ts
325
+ import { mutateJson } from "@monorepolint/utils";
326
+ import * as r5 from "runtypes";
327
+ import { coerce } from "semver";
328
+ var Options5 = r5.Record({
329
+ matchDependencyVersions: r5.Dictionary(r5.Union(r5.String, r5.Array(r5.String)))
330
+ });
331
+ var consistentVersions = makeRule({
332
+ name: "consistentVersions",
333
+ check: checkConsistentVersions,
334
+ optionsRuntype: Options5
335
+ });
336
+ function checkConsistentVersions(context, options) {
337
+ for (const [dependencyPackageName, expectedPackageDependencyValue] of Object.entries(
338
+ options.matchDependencyVersions
339
+ )) {
340
+ if (Array.isArray(expectedPackageDependencyValue)) {
341
+ ensurePackageMatchesSomeVersion(context, dependencyPackageName, expectedPackageDependencyValue);
342
+ } else {
343
+ ensurePackageIsCorrectVersion(context, dependencyPackageName, expectedPackageDependencyValue);
344
+ }
345
+ }
346
+ }
347
+ var ensurePackageIsCorrectVersion = (context, dependencyPackageName, expectedPackageDependencyValue) => {
348
+ const packageJson = context.getPackageJson();
349
+ const packageJsonPath = context.getPackageJsonPath();
350
+ const expectedPackageDependencyVersion = coerce(expectedPackageDependencyValue);
351
+ if (expectedPackageDependencyVersion == null) {
352
+ throw new Error(
353
+ `Malformed expected package dependency version defined in monorepolint configuration: ${dependencyPackageName} @ '${expectedPackageDependencyValue}'`
354
+ );
355
+ }
356
+ const actualPackageDependencyValue = packageJson.dependencies && packageJson.dependencies[dependencyPackageName];
357
+ const actualPackageDependencyVersion = coerce(actualPackageDependencyValue);
358
+ if (actualPackageDependencyVersion != null && actualPackageDependencyVersion.raw !== expectedPackageDependencyVersion.raw) {
359
+ context.addError({
360
+ file: packageJsonPath,
361
+ message: `Expected dependency on ${dependencyPackageName} to match version defined in monorepolint configuration '${expectedPackageDependencyValue}', got '${actualPackageDependencyValue}' instead.`,
362
+ fixer: () => mutateJson(packageJsonPath, context.host, (input) => {
363
+ input.dependencies[dependencyPackageName] = expectedPackageDependencyValue;
364
+ return input;
365
+ })
366
+ });
367
+ }
368
+ const actualPackageDevDependencyValue = packageJson.devDependencies && packageJson.devDependencies[dependencyPackageName];
369
+ const actualPackageDevDependencyVersion = coerce(actualPackageDevDependencyValue);
370
+ if (actualPackageDevDependencyVersion != null && actualPackageDevDependencyVersion.raw !== expectedPackageDependencyVersion.raw) {
371
+ context.addError({
372
+ file: packageJsonPath,
373
+ message: `Expected devDependency on ${dependencyPackageName} to match version defined in monorepolint configuration '${expectedPackageDependencyValue}', got '${actualPackageDevDependencyValue}' instead`,
374
+ fixer: () => mutateJson(packageJsonPath, context.host, (input) => {
375
+ input.devDependencies[dependencyPackageName] = expectedPackageDependencyValue;
376
+ return input;
377
+ })
378
+ });
379
+ }
380
+ };
381
+ var ensurePackageMatchesSomeVersion = (context, dependencyPackageName, acceptedPackageDependencyValues) => {
382
+ const packageJson = context.getPackageJson();
383
+ const packageJsonPath = context.getPackageJsonPath();
384
+ const acceptedPackageDependencyVersions = acceptedPackageDependencyValues.map(
385
+ (acceptedPackageDependencyValue) => {
386
+ const acceptedPackageDependencyVersion = coerce(acceptedPackageDependencyValue);
387
+ if (acceptedPackageDependencyVersion == null) {
388
+ throw new Error(
389
+ `Malformed accepted package dependency version defined in monorepolint configuration: ${dependencyPackageName} @ '${acceptedPackageDependencyValue}'`
390
+ );
391
+ }
392
+ return acceptedPackageDependencyVersion;
393
+ }
394
+ );
395
+ const actualPackageDependencyValue = packageJson.dependencies && packageJson.dependencies[dependencyPackageName];
396
+ const actualPackageDependencyVersion = coerce(actualPackageDependencyValue);
397
+ if (actualPackageDependencyVersion != null && acceptedPackageDependencyVersions.every(
398
+ (acceptedPackageDependencyVersion) => actualPackageDependencyVersion.raw !== acceptedPackageDependencyVersion.raw
399
+ )) {
400
+ context.addError({
401
+ file: packageJsonPath,
402
+ message: `Expected dependency on ${dependencyPackageName} to match one of '${JSON.stringify(
403
+ acceptedPackageDependencyValues
404
+ )}', got '${actualPackageDependencyValue}' instead.`
405
+ });
406
+ }
407
+ const actualPackageDevDependencyValue = packageJson.devDependencies && packageJson.devDependencies[dependencyPackageName];
408
+ const actualPackageDevDependencyVersion = coerce(actualPackageDevDependencyValue);
409
+ if (actualPackageDevDependencyVersion != null && acceptedPackageDependencyVersions.every(
410
+ (acceptedPackageDependencyVersion) => actualPackageDevDependencyVersion.raw !== acceptedPackageDependencyVersion.raw
411
+ )) {
412
+ context.addError({
413
+ file: packageJsonPath,
414
+ message: `Expected devDependency on ${dependencyPackageName} to match one of '${JSON.stringify(
415
+ acceptedPackageDependencyValues
416
+ )}', got '${actualPackageDevDependencyValue}' instead.`
417
+ });
418
+ }
419
+ };
420
+
421
+ // src/fileContents.ts
422
+ import { diff as diff3 } from "jest-diff";
423
+ import * as path3 from "path";
424
+ import * as r6 from "runtypes";
425
+ var Options6 = r6.Union(
426
+ r6.Record({
427
+ file: r6.String,
428
+ generator: r6.Function,
429
+ template: r6.Undefined.optional(),
430
+ templateFile: r6.Undefined.optional()
431
+ }),
432
+ r6.Record({
433
+ file: r6.String,
434
+ generator: r6.Undefined.optional(),
435
+ template: r6.String,
436
+ templateFile: r6.Undefined.optional()
437
+ }),
438
+ r6.Record({
439
+ file: r6.String,
440
+ generator: r6.Undefined.optional(),
441
+ template: r6.Undefined.optional(),
442
+ templateFile: r6.String
443
+ })
444
+ );
445
+ var fileContents = makeRule({
446
+ name: "fileContents",
447
+ check: (context, opts) => {
448
+ const fullPath = path3.join(context.packageDir, opts.file);
449
+ const expectedContent = getExpectedContents(context, opts);
450
+ const pathExists = context.host.exists(fullPath);
451
+ const actualContent = pathExists ? context.host.readFile(fullPath, { encoding: "utf-8" }) : void 0;
452
+ if (actualContent !== expectedContent) {
453
+ context.addError({
454
+ file: fullPath,
455
+ message: "Expect file contents to match",
456
+ longMessage: diff3(expectedContent, actualContent, { expand: true }),
457
+ fixer: () => {
458
+ if (expectedContent === void 0) {
459
+ if (pathExists)
460
+ context.host.deleteFile(fullPath);
461
+ } else {
462
+ context.host.mkdir(path3.dirname(fullPath), { recursive: true });
463
+ context.host.writeFile(fullPath, expectedContent, { encoding: "utf-8" });
464
+ }
465
+ }
466
+ });
467
+ }
468
+ },
469
+ optionsRuntype: Options6
470
+ });
471
+ var optionsCache = /* @__PURE__ */ new Map();
472
+ function getExpectedContents(context, opts) {
473
+ if (optionsCache.has(opts)) {
474
+ const cachedEntry = optionsCache.get(opts);
475
+ if (cachedEntry && typeof cachedEntry === "function") {
476
+ return cachedEntry(context);
477
+ }
478
+ return cachedEntry;
479
+ }
480
+ if (opts.generator) {
481
+ optionsCache.set(opts, opts.generator);
482
+ return opts.generator(context);
483
+ } else if (opts.templateFile) {
484
+ const { packageDir: workspacePackageDir } = context.getWorkspaceContext();
485
+ const fullPath = path3.resolve(workspacePackageDir, opts.templateFile);
486
+ const template = context.host.readFile(fullPath, { encoding: "utf-8" });
487
+ optionsCache.set(opts, template);
488
+ return template;
489
+ } else {
490
+ optionsCache.set(opts, opts.template);
491
+ return opts.template;
492
+ }
493
+ }
494
+
495
+ // src/mustSatisfyPeerDependencies.ts
496
+ import { mutateJson as mutateJson2 } from "@monorepolint/utils";
497
+ import * as path4 from "node:path";
498
+ import * as r7 from "runtypes";
499
+ import { coerce as coerce2 } from "semver";
500
+ import resolvePackagePath2 from "resolve-package-path";
501
+ var Options7 = r7.Union(
502
+ r7.Partial({
503
+ skipUnparseableRanges: r7.Undefined,
504
+ dependencyWhitelist: r7.Undefined,
505
+ dependencyBlacklist: r7.Undefined,
506
+ enforceForDevDependencies: r7.Undefined
507
+ }),
508
+ r7.Record({
509
+ skipUnparseableRanges: r7.Boolean
510
+ }).And(
511
+ r7.Partial({
512
+ dependencyWhitelist: r7.Undefined,
513
+ dependencyBlacklist: r7.Undefined,
514
+ enforceForDevDependencies: r7.Undefined
515
+ })
516
+ ),
517
+ r7.Record({
518
+ dependencyWhitelist: r7.Array(r7.String)
519
+ }).And(
520
+ r7.Partial({
521
+ skipUnparseableRanges: r7.Undefined,
522
+ dependencyBlacklist: r7.Undefined,
523
+ enforceForDevDependencies: r7.Undefined
524
+ })
525
+ ),
526
+ r7.Record({
527
+ dependencyBlacklist: r7.Array(r7.String)
528
+ }).And(
529
+ r7.Partial({
530
+ skipUnparseableRanges: r7.Undefined,
531
+ dependencyWhitelist: r7.Undefined,
532
+ enforceForDevDependencies: r7.Undefined
533
+ })
534
+ ),
535
+ r7.Record({
536
+ enforceForDevDependencies: r7.Boolean
537
+ }).And(
538
+ r7.Partial({
539
+ skipUnparseableRanges: r7.Undefined,
540
+ dependencyWhitelist: r7.Undefined,
541
+ dependencyBlacklist: r7.Undefined
542
+ })
543
+ ),
544
+ r7.Record({
545
+ skipUnparseableRanges: r7.Boolean,
546
+ dependencyWhitelist: r7.Array(r7.String)
547
+ }).And(
548
+ r7.Partial({
549
+ dependencyBlacklist: r7.Undefined,
550
+ enforceForDevDependencies: r7.Undefined
551
+ })
552
+ ),
553
+ r7.Record({
554
+ skipUnparseableRanges: r7.Boolean,
555
+ dependencyBlacklist: r7.Array(r7.String)
556
+ }).And(
557
+ r7.Partial({
558
+ dependencyWhitelist: r7.Undefined,
559
+ enforceForDevDependencies: r7.Undefined
560
+ })
561
+ ),
562
+ r7.Record({
563
+ skipUnparseableRanges: r7.Boolean,
564
+ enforceForDevDependencies: r7.Boolean
565
+ }).And(
566
+ r7.Partial({
567
+ dependencyWhitelist: r7.Undefined,
568
+ dependencyBlacklist: r7.Undefined
569
+ })
570
+ ),
571
+ r7.Record({
572
+ dependencyWhitelist: r7.Array(r7.String),
573
+ dependencyBlacklist: r7.Array(r7.String)
574
+ }).And(
575
+ r7.Partial({
576
+ skipUnparseableRanges: r7.Undefined,
577
+ enforceForDevDependencies: r7.Undefined
578
+ })
579
+ ),
580
+ r7.Record({
581
+ dependencyWhitelist: r7.Array(r7.String),
582
+ enforceForDevDependencies: r7.Boolean
583
+ }).And(
584
+ r7.Partial({
585
+ skipUnparseableRanges: r7.Undefined,
586
+ dependencyBlacklist: r7.Undefined
587
+ })
588
+ ),
589
+ r7.Record({
590
+ dependencyBlacklist: r7.Array(r7.String),
591
+ enforceForDevDependencies: r7.Boolean
592
+ }).And(
593
+ r7.Partial({
594
+ skipUnparseableRanges: r7.Undefined,
595
+ dependencyWhitelist: r7.Undefined
596
+ })
597
+ ),
598
+ r7.Record({
599
+ skipUnparseableRanges: r7.Boolean,
600
+ dependencyWhitelist: r7.Array(r7.String),
601
+ dependencyBlacklist: r7.Array(r7.String)
602
+ }).And(
603
+ r7.Partial({
604
+ enforceForDevDependencies: r7.Undefined
605
+ })
606
+ ),
607
+ r7.Record({
608
+ skipUnparseableRanges: r7.Boolean,
609
+ dependencyWhitelist: r7.Array(r7.String),
610
+ enforceForDevDependencies: r7.Boolean
611
+ }).And(
612
+ r7.Partial({
613
+ dependencyBlacklist: r7.Undefined
614
+ })
615
+ ),
616
+ r7.Record({
617
+ skipUnparseableRanges: r7.Boolean,
618
+ dependencyBlacklist: r7.Array(r7.String),
619
+ enforceForDevDependencies: r7.Boolean
620
+ }).And(
621
+ r7.Partial({
622
+ dependencyWhitelist: r7.Undefined
623
+ })
624
+ ),
625
+ r7.Record({
626
+ dependencyWhitelist: r7.Array(r7.String),
627
+ dependencyBlacklist: r7.Array(r7.String),
628
+ enforceForDevDependencies: r7.Boolean
629
+ }).And(
630
+ r7.Partial({
631
+ skipUnparseableRanges: r7.Undefined
632
+ })
633
+ ),
634
+ r7.Record({
635
+ skipUnparseableRanges: r7.Boolean,
636
+ dependencyWhitelist: r7.Array(r7.String),
637
+ dependencyBlacklist: r7.Array(r7.String),
638
+ enforceForDevDependencies: r7.Boolean
639
+ })
640
+ );
641
+ var mustSatisfyPeerDependencies = makeRule({
642
+ name: "mustSatisfyPeerDependencies",
643
+ check: checkSatisfyPeerDependencies,
644
+ optionsRuntype: Options7
645
+ });
646
+ var MATCH_ANY_VERSION_RANGE = /^(\*|x)$/;
647
+ var MATCH_GREATER_OR_EQUAL_VERSION_RANGE = /^>= ?\d+(?:\.\d+|\.\d+\.\d+(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?)?$/;
648
+ var MATCH_MAJOR_VERSION_RANGE = /^(?:\^?\d+|\^?\d+\.x|\^?\d+\.x\.x|\^\d+\.\d+|\^\d+\.\d+\.x|\^\d+\.\d+\.\d+(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?)$/;
649
+ var RANGE_REGEX = /^(\*|x|>= ?\d+(?:\.\d+|\.\d+\.\d+(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?)?|\^?\d+(\.x|\.x\.x|\.\d+|\.\d+\.x|\.\d+\.\d+(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?)?( \|\| \^?\d+(\.x|\.x\.x|\.\d+|\.\d+\.x|\.\d+\.\d+(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?)?)*)$/;
650
+ function checkSatisfyPeerDependencies(context, opts) {
651
+ const { dependencyBlacklist, dependencyWhitelist, enforceForDevDependencies, skipUnparseableRanges } = opts;
652
+ const packageJsonPath = path4.resolve(context.getPackageJsonPath());
653
+ const packageJson = context.host.readJson(packageJsonPath);
654
+ const packageDependencies = packageJson.dependencies || {};
655
+ const packageDevDependencies = packageJson.devDependencies || {};
656
+ const packagePeerDependencies = packageJson.peerDependencies || {};
657
+ const packageName = packageJson.name || packageJsonPath;
658
+ for (const [peerDependencyName, peerDependencyRange] of Object.entries(packagePeerDependencies)) {
659
+ if (shouldSkipPackage({ dependencyBlacklist, dependencyWhitelist, packageName: peerDependencyName })) {
660
+ continue;
661
+ }
662
+ const dependencyRange = packageDependencies[peerDependencyName];
663
+ if (dependencyRange != null) {
664
+ context.addError({
665
+ file: packageJsonPath,
666
+ message: `[0] Package ${packageName} has overloaded ${peerDependencyName} dependencies.
667
+ Peer dependency '${peerDependencyRange}' and regular dependency '${dependencyRange}'.`
668
+ });
669
+ }
670
+ }
671
+ const allRequiredPeerDependencies = {};
672
+ const allDependencies = enforceForDevDependencies ? [...Object.keys(packageDependencies), ...Object.keys(packageDevDependencies)] : Object.keys(packageDependencies);
673
+ for (const dependency of allDependencies) {
674
+ const dependencyPackageJsonPath = resolvePackagePath2(dependency, path4.dirname(packageJsonPath));
675
+ if (dependencyPackageJsonPath == null) {
676
+ throw new Error(`Could not resolve ${dependency} from ${path4.dirname(packageJsonPath)}`);
677
+ }
678
+ const dependencyPackageJson = context.host.readJson(dependencyPackageJsonPath);
679
+ const requiredPeerDependencies = dependencyPackageJson.peerDependencies;
680
+ if (requiredPeerDependencies == null) {
681
+ continue;
682
+ }
683
+ for (const [peerDependencyName, range] of Object.entries(requiredPeerDependencies)) {
684
+ if (shouldSkipPackage({ dependencyBlacklist, dependencyWhitelist, packageName: peerDependencyName })) {
685
+ continue;
686
+ }
687
+ if (!isValidRange(range)) {
688
+ const message = `Unable to parse ${dependencyPackageJson.name}'s ${peerDependencyName} peer dependency range '${range}'.`;
689
+ if (skipUnparseableRanges) {
690
+ context.addWarning({ file: dependencyPackageJsonPath, message });
691
+ continue;
692
+ }
693
+ throw new Error(message);
694
+ }
695
+ if (allRequiredPeerDependencies[peerDependencyName] == null) {
696
+ allRequiredPeerDependencies[peerDependencyName] = [];
697
+ }
698
+ allRequiredPeerDependencies[peerDependencyName].push({ fromPackageName: dependencyPackageJson.name, range });
699
+ }
700
+ }
701
+ for (const [peerDependencyName, peerDependencyRequirements] of Object.entries(allRequiredPeerDependencies)) {
702
+ let mostStrictPeerRequirement = {
703
+ fromPeerDependencyRequirements: [peerDependencyRequirements[0]],
704
+ range: peerDependencyRequirements[0].range
705
+ };
706
+ for (const peerRequirement of peerDependencyRequirements) {
707
+ if (doesASatisfyB(mostStrictPeerRequirement.range, peerRequirement.range)) {
708
+ continue;
709
+ } else if (doesASatisfyB(peerRequirement.range, mostStrictPeerRequirement.range)) {
710
+ mostStrictPeerRequirement = {
711
+ fromPeerDependencyRequirements: [peerRequirement],
712
+ range: peerRequirement.range
713
+ };
714
+ } else {
715
+ const maybeIntersection = findIntersection(peerRequirement.range, mostStrictPeerRequirement.range);
716
+ if (maybeIntersection !== void 0) {
717
+ mostStrictPeerRequirement = {
718
+ fromPeerDependencyRequirements: [
719
+ ...mostStrictPeerRequirement.fromPeerDependencyRequirements,
720
+ peerRequirement
721
+ ],
722
+ range: maybeIntersection
723
+ };
724
+ } else {
725
+ context.addError({
726
+ file: packageJsonPath,
727
+ message: `[1] Package ${packageName} has conflicting inherited ${peerDependencyName} peer dependencies.
728
+ Dependency ${peerRequirement.fromPackageName} requires '${peerRequirement.range}' but
729
+ ` + getMostStrictStatement(mostStrictPeerRequirement)
730
+ });
731
+ }
732
+ }
733
+ }
734
+ const packageDependencyRange = packageDependencies[peerDependencyName];
735
+ if (packageDependencyRange != null) {
736
+ if (!isValidRange(packageDependencyRange)) {
737
+ const message = `Unable to parse ${packageName}'s ${peerDependencyName} dependency range '${packageDependencyRange}'.`;
738
+ if (skipUnparseableRanges) {
739
+ context.addWarning({ file: packageJsonPath, message });
740
+ } else {
741
+ throw new Error(message);
742
+ }
743
+ } else if (!doesASatisfyB(packageDependencyRange, mostStrictPeerRequirement.range)) {
744
+ context.addError({
745
+ file: packageJsonPath,
746
+ message: `[2] Package ${packageName} dependency on ${peerDependencyName} '${packageDependencyRange}' does not satisfy inherited peer dependencies.
747
+ ` + getMostStrictStatement(mostStrictPeerRequirement)
748
+ });
749
+ }
750
+ }
751
+ const packagePeerDependencyRange = packagePeerDependencies[peerDependencyName];
752
+ if (packageDependencyRange == null && packagePeerDependencyRange == null) {
753
+ context.addError({
754
+ file: packageJsonPath,
755
+ message: `[3] Package ${packageName} is missing required ${peerDependencyName} dependency.
756
+ ` + getMostStrictStatement(mostStrictPeerRequirement),
757
+ fixer: getAddDependencyTypeFixer({
758
+ packageJsonPath,
759
+ dependencyType: "peerDependencies",
760
+ dependencyName: peerDependencyName,
761
+ version: mostStrictPeerRequirement.range,
762
+ host: context.host
763
+ })
764
+ });
765
+ }
766
+ if (packagePeerDependencyRange != null) {
767
+ if (!isValidRange(packagePeerDependencyRange)) {
768
+ const message = `Unable to parse ${packageName}'s ${peerDependencyName} peer dependency range '${packagePeerDependencyRange}'.`;
769
+ if (skipUnparseableRanges) {
770
+ context.addWarning({ file: packageJsonPath, message });
771
+ } else {
772
+ throw new Error(message);
773
+ }
774
+ } else if (!doesASatisfyB(packagePeerDependencyRange, mostStrictPeerRequirement.range)) {
775
+ context.addError({
776
+ file: packageJsonPath,
777
+ message: `[4] Package ${packageName} peer dependency on ${peerDependencyName} '${packagePeerDependencyRange}' is not strict enough.
778
+ ` + getMostStrictStatement(mostStrictPeerRequirement),
779
+ fixer: getAddDependencyTypeFixer({
780
+ packageJsonPath,
781
+ dependencyType: "peerDependencies",
782
+ dependencyName: peerDependencyName,
783
+ version: mostStrictPeerRequirement.range,
784
+ host: context.host
785
+ })
786
+ });
787
+ }
788
+ }
789
+ }
790
+ }
791
+ function shouldSkipPackage({
792
+ dependencyBlacklist,
793
+ dependencyWhitelist,
794
+ packageName
795
+ }) {
796
+ if (dependencyBlacklist != null && dependencyBlacklist.includes(packageName) || dependencyWhitelist != null && !dependencyWhitelist.includes(packageName)) {
797
+ return true;
798
+ }
799
+ return false;
800
+ }
801
+ function getMostStrictStatement(mostStrictPeerRequirement) {
802
+ if (mostStrictPeerRequirement.fromPeerDependencyRequirements.length === 1) {
803
+ const dependencyName = mostStrictPeerRequirement.fromPeerDependencyRequirements[0].fromPackageName;
804
+ return `Dependency ${dependencyName} requires '${mostStrictPeerRequirement.range}'.`;
805
+ } else {
806
+ const dependencyNames = mostStrictPeerRequirement.fromPeerDependencyRequirements.map((peerDependencyRequirement) => peerDependencyRequirement.fromPackageName).join(", ");
807
+ const dependencyRequirements = mostStrictPeerRequirement.fromPeerDependencyRequirements.map((peerDependencyRequirement) => `'${peerDependencyRequirement.range}'`).join(", ");
808
+ return `Dependencies [${dependencyNames}] require [${dependencyRequirements}] respectively, resolving to '${mostStrictPeerRequirement.range}'.`;
809
+ }
810
+ }
811
+ function findIntersection(a, b) {
812
+ if (doesASatisfyB(a, b)) {
813
+ return a;
814
+ } else if (doesASatisfyB(b, a)) {
815
+ return b;
816
+ }
817
+ if (isAnyVersionRange(a) || isAnyVersionRange(b)) {
818
+ throw new Error();
819
+ }
820
+ const aVersions = a.includes("||") ? a.split("||").map((s) => s.trim()) : [a];
821
+ const bVersions = b.includes("||") ? b.split("||").map((s) => s.trim()) : [b];
822
+ const aIsGreaterOrEqualVersionRange = isGreaterOrEqualVersionRange(a);
823
+ const bIsGreaterOrEqualVersionRange = isGreaterOrEqualVersionRange(b);
824
+ if (aIsGreaterOrEqualVersionRange && bIsGreaterOrEqualVersionRange) {
825
+ throw new Error();
826
+ }
827
+ if (aIsGreaterOrEqualVersionRange) {
828
+ const aSemVer = coerce2(a);
829
+ const compatibleBVersions = bVersions.map((bVersion) => {
830
+ const bSemVer = coerce2(bVersion);
831
+ if (bVersion.startsWith("^") && bSemVer.major >= aSemVer.major) {
832
+ return `^${bSemVer.compare(aSemVer) >= 0 ? bSemVer.raw : aSemVer.raw}`;
833
+ }
834
+ return bSemVer.compare(aSemVer) !== -1 ? bVersion : void 0;
835
+ }).filter((bVersion) => bVersion != null);
836
+ if (compatibleBVersions.length === 0) {
837
+ return void 0;
838
+ }
839
+ return compatibleBVersions.join(" || ");
840
+ }
841
+ if (bIsGreaterOrEqualVersionRange) {
842
+ const bSemVer = coerce2(b);
843
+ const compatibleAVersions = aVersions.map((aVersion) => {
844
+ const aSemVer = coerce2(aVersion);
845
+ if (aVersion.startsWith("^") && aSemVer.major >= bSemVer.major) {
846
+ return `^${aSemVer.compare(bSemVer) >= 0 ? aSemVer.raw : bSemVer.raw}`;
847
+ }
848
+ return aSemVer.compare(bSemVer) !== -1 ? aVersion : void 0;
849
+ }).filter((aVersion) => aVersion != null);
850
+ if (compatibleAVersions.length === 0) {
851
+ return void 0;
852
+ }
853
+ return compatibleAVersions.join(" || ");
854
+ }
855
+ const compatibleVersions = aVersions.map((aVersion) => {
856
+ const aSemVer = coerce2(aVersion);
857
+ const majorMatchingBVersion = bVersions.find((m) => coerce2(m).major === aSemVer.major);
858
+ if (majorMatchingBVersion === void 0) {
859
+ return void 0;
860
+ }
861
+ if (doesASatisfyB(aVersion, majorMatchingBVersion)) {
862
+ return aVersion;
863
+ } else if (doesASatisfyB(majorMatchingBVersion, aVersion)) {
864
+ return majorMatchingBVersion;
865
+ } else {
866
+ return void 0;
867
+ }
868
+ }).filter((aVersion) => aVersion !== void 0);
869
+ if (compatibleVersions.length === 0) {
870
+ return void 0;
871
+ }
872
+ return compatibleVersions.join(" || ");
873
+ }
874
+ function doesASatisfyB(a, b) {
875
+ if (a === b) {
876
+ return true;
877
+ }
878
+ const aIsAnyVersionRange = isAnyVersionRange(a);
879
+ const bIsAnyVersionRange = isAnyVersionRange(b);
880
+ if (bIsAnyVersionRange) {
881
+ return true;
882
+ } else if (aIsAnyVersionRange) {
883
+ return false;
884
+ }
885
+ const aVersions = a.includes("||") ? a.split("||").map((s) => s.trim()) : [a];
886
+ const bVersions = b.includes("||") ? b.split("||").map((s) => s.trim()) : [b];
887
+ const aIsGreaterOrEqualVersionRange = isGreaterOrEqualVersionRange(a);
888
+ const bIsGreaterOrEqualVersionRange = isGreaterOrEqualVersionRange(b);
889
+ if (aIsGreaterOrEqualVersionRange && bIsGreaterOrEqualVersionRange) {
890
+ const aSemVer = coerce2(a);
891
+ const bSemVer = coerce2(b);
892
+ return aSemVer.compare(bSemVer) !== -1;
893
+ } else if (bIsGreaterOrEqualVersionRange) {
894
+ const bSemVer = coerce2(b);
895
+ return aVersions.every((aVersion) => {
896
+ const aSemVer = coerce2(aVersion);
897
+ return aSemVer.compare(bSemVer) !== -1;
898
+ });
899
+ } else if (aIsGreaterOrEqualVersionRange) {
900
+ return false;
901
+ }
902
+ return aVersions.every((aVersion) => {
903
+ const aSemVer = coerce2(aVersion);
904
+ const majorMatchingBVersion = bVersions.find((m) => coerce2(m).major === aSemVer.major);
905
+ if (majorMatchingBVersion === void 0) {
906
+ return false;
907
+ }
908
+ const aVersionIsRange = isMajorVersionRange(aVersion);
909
+ const majorMatchingBSemVer = coerce2(majorMatchingBVersion);
910
+ const majorMatchingBVersionIsRange = isMajorVersionRange(majorMatchingBVersion);
911
+ if (majorMatchingBVersionIsRange) {
912
+ return aSemVer.compare(majorMatchingBSemVer) !== -1;
913
+ } else {
914
+ if (aVersionIsRange) {
915
+ return false;
916
+ } else {
917
+ return aSemVer.compare(majorMatchingBSemVer) === 0;
918
+ }
919
+ }
920
+ });
921
+ }
922
+ function isAnyVersionRange(version) {
923
+ return MATCH_ANY_VERSION_RANGE.test(version);
924
+ }
925
+ function isGreaterOrEqualVersionRange(version) {
926
+ return MATCH_GREATER_OR_EQUAL_VERSION_RANGE.test(version);
927
+ }
928
+ function isMajorVersionRange(version) {
929
+ return MATCH_MAJOR_VERSION_RANGE.test(version);
930
+ }
931
+ function isValidRange(version) {
932
+ return RANGE_REGEX.test(version);
933
+ }
934
+ function getAddDependencyTypeFixer({
935
+ packageJsonPath,
936
+ dependencyType,
937
+ dependencyName,
938
+ version,
939
+ host
940
+ }) {
941
+ return () => {
942
+ mutateJson2(packageJsonPath, host, (packageJson) => {
943
+ if (packageJson[dependencyType] == null) {
944
+ packageJson[dependencyType] = {};
945
+ }
946
+ packageJson[dependencyType][dependencyName] = version;
947
+ return packageJson;
948
+ });
949
+ };
950
+ }
951
+
952
+ // src/packageOrder.ts
953
+ import { diff as diff4 } from "jest-diff";
954
+ import * as r8 from "runtypes";
955
+ var Options8 = r8.Record({
956
+ order: r8.Union(r8.Array(r8.String), r8.Function)
957
+ }).Or(r8.Undefined);
958
+ var defaultKeyOrder = [
959
+ "name",
960
+ "version",
961
+ "description",
962
+ "author",
963
+ "contributors",
964
+ "url",
965
+ "license",
966
+ "type",
967
+ "exports",
968
+ "private",
969
+ "engines",
970
+ "bin",
971
+ "types",
972
+ "main",
973
+ "module",
974
+ "typings",
975
+ "style",
976
+ "sideEffects",
977
+ "workspaces",
978
+ "husky",
979
+ "lint-staged",
980
+ "files",
981
+ "scripts",
982
+ "resolutions",
983
+ "dependencies",
984
+ "peerDependencies",
985
+ "devDependencies",
986
+ "optionalDependencies",
987
+ "publishConfig"
988
+ ];
989
+ var packageOrder = makeRule({
990
+ name: "packageOrder",
991
+ check: (context, opts) => {
992
+ const packageJson = context.getPackageJson();
993
+ const packagePath = context.getPackageJsonPath();
994
+ const order = opts === void 0 ? defaultKeyOrder : opts.order;
995
+ const comparator = isOrderFunction(order) ? order(context) : createComparator(order);
996
+ const actualOrder = Object.keys(packageJson);
997
+ const expectedOrder = actualOrder.slice().sort(comparator);
998
+ if (!arrayOrderCompare2(actualOrder, expectedOrder)) {
999
+ context.addError({
1000
+ file: packagePath,
1001
+ message: "Incorrect order of fields in package.json",
1002
+ longMessage: diff4(expectedOrder, actualOrder, { expand: true }),
1003
+ fixer: () => {
1004
+ const expectedPackageJson = {};
1005
+ expectedOrder.forEach((key) => {
1006
+ expectedPackageJson[key] = packageJson[key];
1007
+ });
1008
+ context.host.writeJson(packagePath, expectedPackageJson);
1009
+ }
1010
+ });
1011
+ }
1012
+ },
1013
+ optionsRuntype: Options8
1014
+ });
1015
+ function arrayOrderCompare2(a, b) {
1016
+ for (let index = 0; index < a.length; index++) {
1017
+ if (a[index] !== b[index]) {
1018
+ return false;
1019
+ }
1020
+ }
1021
+ return true;
1022
+ }
1023
+ function createComparator(order) {
1024
+ return (a, b) => {
1025
+ const aIndex = order.indexOf(a);
1026
+ const bIndex = order.indexOf(b);
1027
+ if (aIndex >= 0 && bIndex < 0) {
1028
+ return -1;
1029
+ } else if (aIndex < 0 && bIndex >= 0) {
1030
+ return 1;
1031
+ }
1032
+ const compared = aIndex - bIndex;
1033
+ if (compared !== 0) {
1034
+ return compared;
1035
+ } else {
1036
+ return a.localeCompare(b);
1037
+ }
1038
+ };
1039
+ }
1040
+ function isOrderFunction(order) {
1041
+ return !Array.isArray(order);
1042
+ }
1043
+
1044
+ // src/packageEntry.ts
1045
+ import { mutateJson as mutateJson3 } from "@monorepolint/utils";
1046
+ import { diff as diff5 } from "jest-diff";
1047
+ import * as r9 from "runtypes";
1048
+ var Options9 = r9.Union(
1049
+ r9.Record({
1050
+ entries: r9.Dictionary(r9.Unknown)
1051
+ }).And(
1052
+ r9.Partial({
1053
+ entriesExist: r9.Undefined
1054
+ })
1055
+ ),
1056
+ r9.Record({
1057
+ entriesExist: r9.Array(r9.String)
1058
+ }).And(
1059
+ r9.Partial({
1060
+ entries: r9.Undefined
1061
+ })
1062
+ ),
1063
+ r9.Record({
1064
+ entries: r9.Dictionary(r9.Unknown),
1065
+ entriesExist: r9.Array(r9.String)
1066
+ })
1067
+ );
1068
+ var packageEntry = makeRule({
1069
+ name: "packageEntry",
1070
+ check: (context, options) => {
1071
+ const packageJson = context.getPackageJson();
1072
+ if (options.entries) {
1073
+ for (const key of Object.keys(options.entries)) {
1074
+ const value = options.entries[key];
1075
+ const entryDiff = diff5(JSON.stringify(value) + "\n", (JSON.stringify(packageJson[key]) || "") + "\n");
1076
+ if (typeof value !== "object" && value !== packageJson[key] || entryDiff == null || !entryDiff.includes("Compared values have no visual difference")) {
1077
+ context.addError({
1078
+ file: context.getPackageJsonPath(),
1079
+ message: createStandardizedEntryErrorMessage(key),
1080
+ longMessage: entryDiff,
1081
+ fixer: () => {
1082
+ mutateJson3(context.getPackageJsonPath(), context.host, (input) => {
1083
+ input[key] = value;
1084
+ return input;
1085
+ });
1086
+ }
1087
+ });
1088
+ }
1089
+ }
1090
+ }
1091
+ if (options.entriesExist) {
1092
+ for (const key of options.entriesExist) {
1093
+ if (packageJson[key] === void 0) {
1094
+ context.addError({
1095
+ file: context.getPackageJsonPath(),
1096
+ message: createExpectedEntryErrorMessage(key)
1097
+ });
1098
+ }
1099
+ }
1100
+ }
1101
+ },
1102
+ optionsRuntype: Options9
1103
+ });
1104
+ function createStandardizedEntryErrorMessage(key) {
1105
+ return `Expected standardized entry for '${key}'`;
1106
+ }
1107
+ function createExpectedEntryErrorMessage(key) {
1108
+ return `Expected entry for '${key}' to exist`;
1109
+ }
1110
+
1111
+ // src/packageScript.ts
1112
+ import { mutateJson as mutateJson4 } from "@monorepolint/utils";
1113
+ import { diff as diff6 } from "jest-diff";
1114
+ import * as r10 from "runtypes";
1115
+ var Options10 = r10.Record({
1116
+ scripts: r10.Dictionary(
1117
+ r10.Union(
1118
+ r10.String,
1119
+ r10.Record({
1120
+ options: r10.Array(r10.String.Or(r10.Undefined)),
1121
+ fixValue: r10.Union(r10.String, r10.Undefined, r10.Literal(false)).optional()
1122
+ })
1123
+ )
1124
+ )
1125
+ });
1126
+ var MSG_NO_SCRIPTS_BLOCK = "No scripts block in package.json";
1127
+ var packageScript = makeRule({
1128
+ name: "packageScript",
1129
+ check: (context, options) => {
1130
+ const packageJson = context.getPackageJson();
1131
+ if (packageJson.scripts === void 0) {
1132
+ context.addError({
1133
+ file: context.getPackageJsonPath(),
1134
+ message: MSG_NO_SCRIPTS_BLOCK,
1135
+ fixer: () => {
1136
+ mutateJson4(context.getPackageJsonPath(), context.host, (input) => {
1137
+ input.scripts = {};
1138
+ return input;
1139
+ });
1140
+ }
1141
+ });
1142
+ return;
1143
+ }
1144
+ for (const [name, value] of Object.entries(options.scripts)) {
1145
+ const allowedValues = /* @__PURE__ */ new Set();
1146
+ let fixValue;
1147
+ let allowEmpty = false;
1148
+ let fixToEmpty = false;
1149
+ if (typeof value === "string") {
1150
+ allowedValues.add(value);
1151
+ fixValue = value;
1152
+ } else {
1153
+ for (const q of value.options) {
1154
+ if (q === void 0) {
1155
+ allowEmpty = true;
1156
+ }
1157
+ allowedValues.add(q);
1158
+ }
1159
+ fixToEmpty = Object.prototype.hasOwnProperty.call(value, "fixValue") && value.fixValue === void 0;
1160
+ fixValue = value.fixValue;
1161
+ }
1162
+ const actualValue = packageJson.scripts[name];
1163
+ if (!allowedValues.has(actualValue) && !(allowEmpty === true && actualValue === void 0)) {
1164
+ let fixer;
1165
+ if (fixValue !== false && (fixValue !== void 0 || fixToEmpty === true)) {
1166
+ const q = fixValue;
1167
+ fixer = () => {
1168
+ mutateJson4(context.getPackageJsonPath(), context.host, (input) => {
1169
+ if (fixToEmpty && q === void 0) {
1170
+ delete input.scripts[name];
1171
+ } else {
1172
+ input.scripts[name] = q;
1173
+ }
1174
+ return input;
1175
+ });
1176
+ };
1177
+ }
1178
+ const validOptionsString = Array.from(allowedValues.values()).map((a) => a === void 0 ? "(empty)" : `'${a}'`).join(", ");
1179
+ context.addError({
1180
+ file: context.getPackageJsonPath(),
1181
+ message: `Expected standardized script entry for '${name}'. Valid options: ${validOptionsString}`,
1182
+ longMessage: diff6(validOptionsString + "\n", (packageJson.scripts[name] || "") + "\n"),
1183
+ fixer
1184
+ });
1185
+ }
1186
+ }
1187
+ },
1188
+ optionsRuntype: Options10
1189
+ });
1190
+
1191
+ // src/standardTsconfig.ts
1192
+ import { matchesAnyGlob as matchesAnyGlob2 } from "@monorepolint/utils";
1193
+ import { diff as diff7 } from "jest-diff";
1194
+ import * as path5 from "path";
1195
+ import * as r11 from "runtypes";
1196
+ var DEFAULT_TSCONFIG_FILENAME = "tsconfig.json";
1197
+ var Options11 = r11.Partial({
1198
+ file: r11.String,
1199
+ generator: r11.Function,
1200
+ tsconfigReferenceFile: r11.String,
1201
+ template: r11.Record({}).Or(r11.String),
1202
+ templateFile: r11.String,
1203
+ excludedReferences: r11.Array(r11.String).Or(r11.Undefined),
1204
+ additionalReferences: r11.Array(r11.String).Or(r11.Undefined)
1205
+ }).withConstraint(({ generator, template, templateFile }) => {
1206
+ let count = 0;
1207
+ if (generator) {
1208
+ count++;
1209
+ }
1210
+ if (template) {
1211
+ count++;
1212
+ }
1213
+ if (templateFile) {
1214
+ count++;
1215
+ }
1216
+ return count === 1 || "Expect one of { generator, template, templateFile }";
1217
+ });
1218
+ var standardTsconfig = makeRule({
1219
+ name: "standardTsconfig",
1220
+ check: async (context, opts) => {
1221
+ const tsconfigFileName = opts.file ?? DEFAULT_TSCONFIG_FILENAME;
1222
+ const fullPath = path5.resolve(context.packageDir, tsconfigFileName);
1223
+ const generator = getGenerator(context, opts);
1224
+ const expectedContent = await generator(context);
1225
+ const actualContent = context.host.exists(fullPath) ? context.host.readFile(fullPath, { encoding: "utf-8" }) : void 0;
1226
+ if (expectedContent === void 0) {
1227
+ context.addWarning({
1228
+ file: fullPath,
1229
+ message: "Excluding from expect-standard-tsconfig"
1230
+ });
1231
+ return;
1232
+ }
1233
+ if (actualContent !== expectedContent) {
1234
+ context.addError({
1235
+ file: fullPath,
1236
+ message: "Expect file contents to match",
1237
+ longMessage: diff7(expectedContent, actualContent, { expand: true }),
1238
+ fixer: () => {
1239
+ context.host.writeFile(fullPath, expectedContent, {
1240
+ encoding: "utf-8"
1241
+ });
1242
+ }
1243
+ });
1244
+ }
1245
+ },
1246
+ optionsRuntype: Options11
1247
+ });
1248
+ function getGenerator(context, opts) {
1249
+ if (opts.generator) {
1250
+ return opts.generator;
1251
+ } else if (opts.templateFile) {
1252
+ const { packageDir: workspacePackageDir } = context.getWorkspaceContext();
1253
+ const fullPath = path5.resolve(workspacePackageDir, opts.templateFile);
1254
+ const template = JSON.parse(context.host.readFile(fullPath, { encoding: "utf-8" }));
1255
+ return makeGenerator(template, opts.excludedReferences, opts.additionalReferences, opts.tsconfigReferenceFile);
1256
+ } else if (opts.template) {
1257
+ return makeGenerator(opts.template, opts.excludedReferences, opts.additionalReferences, opts.tsconfigReferenceFile);
1258
+ } else {
1259
+ throw new Error("Unable to make generator");
1260
+ }
1261
+ }
1262
+ function makeGenerator(template, excludedReferences, additionalReferences, tsconfigReferenceFile) {
1263
+ return async function generator(context) {
1264
+ template = {
1265
+ ...template,
1266
+ references: []
1267
+ };
1268
+ const nameToDirectory = await context.getWorkspaceContext().getPackageNameToDir();
1269
+ const packageJson = context.getPackageJson();
1270
+ const deps = [...Object.keys(packageJson.dependencies || {}), ...Object.keys(packageJson.devDependencies || {})];
1271
+ for (const dep of deps) {
1272
+ const packageDir = nameToDirectory.get(dep);
1273
+ if (packageDir !== void 0 && (excludedReferences === void 0 || !matchesAnyGlob2(dep, excludedReferences))) {
1274
+ const absoluteReferencePath = tsconfigReferenceFile !== void 0 ? path5.join(packageDir, tsconfigReferenceFile) : packageDir;
1275
+ template.references.push({
1276
+ path: path5.relative(context.packageDir, absoluteReferencePath)
1277
+ });
1278
+ }
1279
+ }
1280
+ if (additionalReferences) {
1281
+ for (const additionalReference of additionalReferences) {
1282
+ template.references.push({
1283
+ path: additionalReference
1284
+ });
1285
+ }
1286
+ }
1287
+ return JSON.stringify(template, void 0, 2) + "\n";
1288
+ };
1289
+ }
1290
+
1291
+ // src/nestedWorkspaces.ts
1292
+ import * as globby from "globby";
1293
+ import * as path6 from "node:path";
1294
+ import * as r12 from "runtypes";
1295
+ var Options12 = r12.Undefined;
1296
+ var nestedWorkspaces = makeRule({
1297
+ name: "nestedWorkspaces",
1298
+ check: (context) => {
1299
+ const rootPackageJson = context.getWorkspaceContext().getPackageJson();
1300
+ const packageJsonPaths = globby.globbySync(["*/**/package.json", "!**/node_modules/**"]);
1301
+ const workspaces = Array.isArray(rootPackageJson.workspaces) ? rootPackageJson.workspaces : rootPackageJson.workspaces !== void 0 ? rootPackageJson.workspaces.packages : void 0;
1302
+ if (workspaces === void 0 && packageJsonPaths.length > 0) {
1303
+ context.addError({
1304
+ file: context.getPackageJsonPath(),
1305
+ message: 'The "workspace" field is missing, even though there are workspaces in the repository.'
1306
+ });
1307
+ return;
1308
+ }
1309
+ const workspacePackageJsons = (workspaces || []).map((item) => `${item}/package.json`);
1310
+ const expandedWorkspacesGlobs = globby.globbySync([...workspacePackageJsons, "!**/node_modules/**"]);
1311
+ const difference = packageJsonPaths.filter((packageJsonPath) => !expandedWorkspacesGlobs.includes(packageJsonPath));
1312
+ if (difference.length !== 0) {
1313
+ const differencesList = difference.map((packageJsonPath) => path6.dirname(packageJsonPath)).join(", ");
1314
+ context.addError({
1315
+ file: context.getPackageJsonPath(),
1316
+ message: `The "workspace" field is missing one or more values: ${differencesList}. You may be able to use a glob to avoid listing each workspace individually, e.g. "packages/nested-workspace/*".`
1317
+ });
1318
+ }
1319
+ },
1320
+ optionsRuntype: Options12
1321
+ });
1322
+
1323
+ // src/requireDependency.ts
1324
+ import { mutateJson as mutateJson5 } from "@monorepolint/utils";
1325
+ import { diff as diff8 } from "jest-diff";
1326
+ import * as r13 from "runtypes";
1327
+ var Options13 = r13.Partial({
1328
+ dependencies: r13.Dictionary(r13.String),
1329
+ devDependencies: r13.Dictionary(r13.String),
1330
+ peerDependencies: r13.Dictionary(r13.String),
1331
+ optionalDependencies: r13.Dictionary(r13.String)
1332
+ });
1333
+ var requireDependency = makeRule({
1334
+ name: "requireDependency",
1335
+ check: function expectPackageEntry(context, options) {
1336
+ const packageJson = context.getPackageJson();
1337
+ const packageJsonPath = context.getPackageJsonPath();
1338
+ [
1339
+ "dependencies",
1340
+ "devDependencies",
1341
+ "peerDependencies",
1342
+ "optionalDependencies"
1343
+ ].forEach((type) => {
1344
+ if (!options[type]) {
1345
+ return;
1346
+ }
1347
+ if (packageJson[type] === void 0) {
1348
+ context.addError({
1349
+ file: packageJsonPath,
1350
+ message: `No ${type} block, cannot add required ${type}.`,
1351
+ fixer: () => {
1352
+ mutateJson5(packageJsonPath, context.host, (input) => {
1353
+ input[type] = options[type];
1354
+ return input;
1355
+ });
1356
+ }
1357
+ });
1358
+ return;
1359
+ }
1360
+ for (const [dep, version] of Object.entries(options[type])) {
1361
+ if (packageJson[type][dep] !== version) {
1362
+ context.addError({
1363
+ file: packageJsonPath,
1364
+ message: `Expected dependency ${dep}@${version}`,
1365
+ longMessage: diff8(`${dep}@${version}
1366
+ `, `${dep}@${packageJson[type][dep] || "missing"}
1367
+ `),
1368
+ fixer: () => {
1369
+ mutateJson5(packageJsonPath, context.host, (input) => {
1370
+ input[type] = { ...input[type], [dep]: version };
1371
+ return input;
1372
+ });
1373
+ }
1374
+ });
1375
+ }
1376
+ }
1377
+ });
1378
+ },
1379
+ optionsRuntype: Options13
1380
+ });
1381
+ export {
1382
+ alphabeticalDependencies,
1383
+ alphabeticalScripts,
1384
+ bannedDependencies,
1385
+ consistentDependencies,
1386
+ consistentVersions,
1387
+ fileContents,
1388
+ mustSatisfyPeerDependencies,
1389
+ nestedWorkspaces,
1390
+ packageEntry,
1391
+ packageOrder,
1392
+ packageScript,
1393
+ requireDependency,
1394
+ standardTsconfig
1395
+ };
1396
+ /*!
1397
+ * Copyright 2019 Palantir Technologies, Inc.
1398
+ *
1399
+ * Licensed under the MIT license. See LICENSE file in the project root for details.
1400
+ *
1401
+ */
1402
+ /*!
1403
+ * Copyright 2020 Palantir Technologies, Inc.
1404
+ *
1405
+ * Licensed under the MIT license. See LICENSE file in the project root for details.
1406
+ *
1407
+ */
1408
+ /*!
1409
+ * Copyright 2023 Palantir Technologies, Inc.
1410
+ *
1411
+ * Licensed under the MIT license. See LICENSE file in the project root for details.
1412
+ *
1413
+ */
1414
+ /**
1415
+ * @license Copyright 2019 Palantir Technologies, Inc. All rights reserved.
1416
+ */
1417
+ //# sourceMappingURL=index.js.map