@lumenflow/cli 3.16.0 → 3.16.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 (109) hide show
  1. package/dist/docs-sync.js +97 -46
  2. package/dist/docs-sync.js.map +1 -1
  3. package/dist/lumenflow-upgrade.js +19 -13
  4. package/dist/lumenflow-upgrade.js.map +1 -1
  5. package/package.json +8 -8
  6. package/packs/sidekick/.turbo/turbo-build.log +1 -1
  7. package/packs/sidekick/package.json +1 -1
  8. package/packs/software-delivery/.turbo/turbo-build.log +1 -1
  9. package/packs/software-delivery/package.json +1 -1
  10. package/dist/chunk-2D2VOCA4.js +0 -37
  11. package/dist/chunk-2D5KFYGX.js +0 -284
  12. package/dist/chunk-2GXVIN57.js +0 -14072
  13. package/dist/chunk-2MQ7HZWZ.js +0 -26
  14. package/dist/chunk-2UFQ3A3C.js +0 -643
  15. package/dist/chunk-3RG5ZIWI.js +0 -10
  16. package/dist/chunk-4N74J3UT.js +0 -15
  17. package/dist/chunk-5GTOXFYR.js +0 -392
  18. package/dist/chunk-5VY6MQMC.js +0 -240
  19. package/dist/chunk-67XVPMRY.js +0 -1297
  20. package/dist/chunk-6HO4GWJE.js +0 -164
  21. package/dist/chunk-6W5XHWYV.js +0 -1890
  22. package/dist/chunk-6X4EMYJQ.js +0 -64
  23. package/dist/chunk-6XYXI2NQ.js +0 -772
  24. package/dist/chunk-7ANSOV6Q.js +0 -285
  25. package/dist/chunk-A624LFLB.js +0 -1380
  26. package/dist/chunk-ADN5NHG4.js +0 -126
  27. package/dist/chunk-B7YJYJKG.js +0 -33
  28. package/dist/chunk-CCLHCPKG.js +0 -210
  29. package/dist/chunk-CK36VROC.js +0 -1584
  30. package/dist/chunk-D3UOFRSB.js +0 -81
  31. package/dist/chunk-DFR4DJBM.js +0 -230
  32. package/dist/chunk-DSYBDHYH.js +0 -79
  33. package/dist/chunk-DWMLTXKQ.js +0 -1176
  34. package/dist/chunk-E3REJTAJ.js +0 -28
  35. package/dist/chunk-EA3IVO64.js +0 -633
  36. package/dist/chunk-EK2AKZKD.js +0 -55
  37. package/dist/chunk-ELD7JTTT.js +0 -343
  38. package/dist/chunk-EX6TT2XI.js +0 -195
  39. package/dist/chunk-EXINSFZE.js +0 -82
  40. package/dist/chunk-EZ6ZBYBM.js +0 -510
  41. package/dist/chunk-FBKAPTJ2.js +0 -16
  42. package/dist/chunk-FVLV5RYH.js +0 -1118
  43. package/dist/chunk-GDNSBQVK.js +0 -2485
  44. package/dist/chunk-GPQHMBNN.js +0 -278
  45. package/dist/chunk-GTFJB67L.js +0 -68
  46. package/dist/chunk-HANJXVKW.js +0 -1127
  47. package/dist/chunk-HEVS5YLD.js +0 -269
  48. package/dist/chunk-HMEVZKPQ.js +0 -9
  49. package/dist/chunk-HRGSYNLM.js +0 -3511
  50. package/dist/chunk-ISZR5N4K.js +0 -60
  51. package/dist/chunk-J6SUPR2C.js +0 -226
  52. package/dist/chunk-JERYVEIZ.js +0 -244
  53. package/dist/chunk-JHHWGL2N.js +0 -87
  54. package/dist/chunk-JONWQUB5.js +0 -775
  55. package/dist/chunk-K2DIWWDM.js +0 -1766
  56. package/dist/chunk-KY4PGL5V.js +0 -969
  57. package/dist/chunk-L737LQ4C.js +0 -1285
  58. package/dist/chunk-LFTWYIB2.js +0 -497
  59. package/dist/chunk-LV47RFNJ.js +0 -41
  60. package/dist/chunk-MKSAITI7.js +0 -15
  61. package/dist/chunk-MZ7RKIX4.js +0 -212
  62. package/dist/chunk-NAP6CFSO.js +0 -84
  63. package/dist/chunk-ND6MY37M.js +0 -16
  64. package/dist/chunk-NMG736UR.js +0 -683
  65. package/dist/chunk-NRAXROED.js +0 -32
  66. package/dist/chunk-NRIZR3A7.js +0 -690
  67. package/dist/chunk-NX43BG3M.js +0 -233
  68. package/dist/chunk-O645XLSI.js +0 -297
  69. package/dist/chunk-OMJD6A3S.js +0 -235
  70. package/dist/chunk-QB6SJD4T.js +0 -430
  71. package/dist/chunk-QFSTL4J3.js +0 -276
  72. package/dist/chunk-QLGDFMFX.js +0 -212
  73. package/dist/chunk-RIAAGL2E.js +0 -13
  74. package/dist/chunk-RWO5XMZ6.js +0 -86
  75. package/dist/chunk-RXRKBBSM.js +0 -149
  76. package/dist/chunk-RZOZMML6.js +0 -363
  77. package/dist/chunk-U7I7FS7T.js +0 -113
  78. package/dist/chunk-UI42RODY.js +0 -717
  79. package/dist/chunk-UTVMVSCO.js +0 -519
  80. package/dist/chunk-V6OJGLBA.js +0 -1746
  81. package/dist/chunk-W2JHVH7D.js +0 -152
  82. package/dist/chunk-WD3Y7VQN.js +0 -280
  83. package/dist/chunk-WOCTQ5MS.js +0 -303
  84. package/dist/chunk-WZR3ZUNN.js +0 -696
  85. package/dist/chunk-XGI665H7.js +0 -150
  86. package/dist/chunk-XKY65P2T.js +0 -304
  87. package/dist/chunk-Y4CQZY65.js +0 -57
  88. package/dist/chunk-YFEXKLVE.js +0 -194
  89. package/dist/chunk-YHO3HS5X.js +0 -287
  90. package/dist/chunk-YLS7AZSX.js +0 -738
  91. package/dist/chunk-ZE473AO6.js +0 -49
  92. package/dist/chunk-ZF747T3O.js +0 -644
  93. package/dist/chunk-ZHCZHZH3.js +0 -43
  94. package/dist/chunk-ZZNZX2XY.js +0 -87
  95. package/dist/constants-7QAP3VQ4.js +0 -23
  96. package/dist/dist-IY3UUMWK.js +0 -33
  97. package/dist/invariants-runner-W5RGHCSU.js +0 -27
  98. package/dist/lane-lock-6J36HD5O.js +0 -35
  99. package/dist/mem-checkpoint-core-EANG2GVN.js +0 -14
  100. package/dist/mem-signal-core-2LZ2WYHW.js +0 -19
  101. package/dist/memory-store-OLB5FO7K.js +0 -18
  102. package/dist/service-6BYCOCO5.js +0 -13
  103. package/dist/spawn-policy-resolver-NTSZYQ6R.js +0 -17
  104. package/dist/spawn-task-builder-R4E2BHSW.js +0 -22
  105. package/dist/wu-done-pr-WLFFFEPJ.js +0 -25
  106. package/dist/wu-done-validation-3J5E36FE.js +0 -30
  107. package/dist/wu-duplicate-id-detector-5S7JHELK.js +0 -232
  108. package/packs/sidekick/.turbo/turbo-typecheck.log +0 -4
  109. package/packs/software-delivery/.turbo/turbo-typecheck.log +0 -4
@@ -1,510 +0,0 @@
1
- import {
2
- isCodeFile,
3
- validateAutomatedTestRequirement
4
- } from "./chunk-U7I7FS7T.js";
5
- import {
6
- parseYAML
7
- } from "./chunk-NRIZR3A7.js";
8
- import {
9
- DIRECTORIES
10
- } from "./chunk-DWMLTXKQ.js";
11
- import {
12
- GIT_DIRECTORY_NAME,
13
- WU_STATUS
14
- } from "./chunk-V6OJGLBA.js";
15
- import {
16
- ErrorCodes,
17
- createError,
18
- getErrorMessage
19
- } from "./chunk-RXRKBBSM.js";
20
-
21
- // ../core/dist/invariants-runner.js
22
- import { existsSync as existsSync2, readFileSync as readFileSync2 } from "fs";
23
- import path2 from "path";
24
- import { globSync } from "glob";
25
-
26
- // ../core/dist/invariants/check-automated-tests.js
27
- import { existsSync, readdirSync, readFileSync } from "fs";
28
- import path from "path";
29
- var INVARIANT_ID = "INV-AUTOMATED-TESTS-FOR-CODE";
30
- var INVARIANT_TYPE = "wu-automated-tests";
31
- var ACTIVE_STATUSES = Object.freeze([WU_STATUS.IN_PROGRESS, WU_STATUS.BLOCKED]);
32
- var WU_YAML_PATH = DIRECTORIES.WU_DIR;
33
- function checkWUFile(filePath, options = {}) {
34
- const { skipStatusCheck = false } = options;
35
- try {
36
- const content = readFileSync(filePath, "utf-8");
37
- const doc = parseYAML(content);
38
- if (!doc) {
39
- return { valid: true, wuId: null, error: null };
40
- }
41
- const wuId = doc.id || path.basename(filePath, ".yaml");
42
- const status = doc.status || "";
43
- if (!skipStatusCheck && !ACTIVE_STATUSES.includes(status)) {
44
- return { valid: true, wuId, error: null };
45
- }
46
- const result = validateAutomatedTestRequirement(doc);
47
- if (!result.valid) {
48
- return {
49
- valid: false,
50
- wuId,
51
- error: result.errors.join("\n"),
52
- codeFiles: getCodeFilesFromPaths(doc.code_paths || [])
53
- };
54
- }
55
- return { valid: true, wuId, error: null };
56
- } catch {
57
- return { valid: true, wuId: null, error: null };
58
- }
59
- }
60
- function getCodeFilesFromPaths(codePaths) {
61
- if (!codePaths || !Array.isArray(codePaths)) {
62
- return [];
63
- }
64
- return codePaths.filter((p) => isCodeFile(p));
65
- }
66
- function checkAutomatedTestsInvariant(options = {}) {
67
- const { baseDir = process.cwd(), wuId } = options;
68
- const wuDir = path.join(baseDir, WU_YAML_PATH);
69
- const violations = [];
70
- if (!existsSync(wuDir)) {
71
- return { valid: true, violations: [] };
72
- }
73
- if (wuId) {
74
- const filePath = path.join(wuDir, `${wuId}.yaml`);
75
- if (!existsSync(filePath)) {
76
- return { valid: true, violations: [] };
77
- }
78
- const result = checkWUFile(filePath, { skipStatusCheck: true });
79
- if (!result.valid) {
80
- violations.push({
81
- id: INVARIANT_ID,
82
- type: INVARIANT_TYPE,
83
- wuId: result.wuId,
84
- description: `WU ${result.wuId} has code files but no automated tests`,
85
- message: result.error,
86
- codeFiles: result.codeFiles
87
- });
88
- }
89
- return {
90
- valid: violations.length === 0,
91
- violations
92
- };
93
- }
94
- let files;
95
- try {
96
- files = readdirSync(wuDir).filter((f) => f.startsWith("WU-") && (f.endsWith(".yaml") || f.endsWith(".yml")));
97
- } catch {
98
- return { valid: true, violations: [] };
99
- }
100
- for (const file of files) {
101
- const filePath = path.join(wuDir, file);
102
- const result = checkWUFile(filePath);
103
- if (!result.valid) {
104
- violations.push({
105
- id: INVARIANT_ID,
106
- type: INVARIANT_TYPE,
107
- wuId: result.wuId,
108
- description: `WU ${result.wuId} has code files but no automated tests`,
109
- message: result.error,
110
- codeFiles: result.codeFiles
111
- });
112
- }
113
- }
114
- return {
115
- valid: violations.length === 0,
116
- violations
117
- };
118
- }
119
-
120
- // ../core/dist/invariants-runner.js
121
- var INVARIANT_TYPES = {
122
- REQUIRED_FILE: "required-file",
123
- FORBIDDEN_FILE: "forbidden-file",
124
- MUTUAL_EXCLUSIVITY: "mutual-exclusivity",
125
- FORBIDDEN_PATTERN: "forbidden-pattern",
126
- // WU-2254: New invariant types
127
- REQUIRED_PATTERN: "required-pattern",
128
- FORBIDDEN_IMPORT: "forbidden-import",
129
- // WU-2333: WU automated tests invariant
130
- WU_AUTOMATED_TESTS: "wu-automated-tests"
131
- };
132
- var EXCLUDED_DIRS = ["node_modules", "worktrees", ".next", "dist", GIT_DIRECTORY_NAME];
133
- var checkerRegistry = /* @__PURE__ */ new Map();
134
- function registerInvariantChecker(type, checker) {
135
- checkerRegistry.set(type, checker);
136
- }
137
- function getInvariantChecker(type) {
138
- return checkerRegistry.get(type);
139
- }
140
- var RequiredFileChecker = class {
141
- validate(invariant, baseDir) {
142
- if (typeof invariant.path !== "string") {
143
- return {
144
- ...invariant,
145
- valid: false,
146
- path: invariant.path
147
- };
148
- }
149
- const fullPath = path2.join(baseDir, invariant.path);
150
- if (!existsSync2(fullPath)) {
151
- return {
152
- ...invariant,
153
- valid: false,
154
- path: invariant.path
155
- };
156
- }
157
- return null;
158
- }
159
- };
160
- var ForbiddenFileChecker = class {
161
- validate(invariant, baseDir) {
162
- if (typeof invariant.path !== "string") {
163
- return null;
164
- }
165
- const fullPath = path2.join(baseDir, invariant.path);
166
- if (existsSync2(fullPath)) {
167
- return {
168
- ...invariant,
169
- valid: false,
170
- path: invariant.path
171
- };
172
- }
173
- return null;
174
- }
175
- };
176
- var MutualExclusivityChecker = class {
177
- validate(invariant, baseDir) {
178
- const paths = Array.isArray(invariant.paths) ? invariant.paths : [];
179
- const existingPaths = paths.filter((p) => {
180
- const fullPath = path2.join(baseDir, p);
181
- return existsSync2(fullPath);
182
- });
183
- if (existingPaths.length > 1) {
184
- return {
185
- ...invariant,
186
- valid: false,
187
- existingPaths
188
- };
189
- }
190
- return null;
191
- }
192
- };
193
- var ForbiddenPatternChecker = class {
194
- validate(invariant, baseDir) {
195
- const { pattern, scope } = invariant;
196
- if (!pattern || !scope || !Array.isArray(scope)) {
197
- return null;
198
- }
199
- const ignorePatterns = EXCLUDED_DIRS.map((dir) => `**/${dir}/**`);
200
- const matchingFiles = [];
201
- for (const scopePattern of scope) {
202
- const files = globSync(scopePattern, {
203
- cwd: baseDir,
204
- ignore: ignorePatterns,
205
- nodir: true
206
- });
207
- const regex = new RegExp(pattern);
208
- for (const file of files) {
209
- const fullPath = path2.join(baseDir, file);
210
- try {
211
- const content = readFileSync2(fullPath, "utf-8");
212
- if (regex.test(content)) {
213
- matchingFiles.push(file);
214
- }
215
- } catch {
216
- }
217
- }
218
- }
219
- if (matchingFiles.length > 0) {
220
- return {
221
- ...invariant,
222
- valid: false,
223
- matchingFiles
224
- };
225
- }
226
- return null;
227
- }
228
- };
229
- var RequiredPatternChecker = class {
230
- validate(invariant, baseDir) {
231
- const { pattern, scope } = invariant;
232
- if (!pattern || !scope || !Array.isArray(scope)) {
233
- return null;
234
- }
235
- const ignorePatterns = EXCLUDED_DIRS.map((dir) => `**/${dir}/**`);
236
- const regex = new RegExp(pattern);
237
- for (const scopePattern of scope) {
238
- const files = globSync(scopePattern, {
239
- cwd: baseDir,
240
- ignore: ignorePatterns,
241
- nodir: true
242
- });
243
- for (const file of files) {
244
- const fullPath = path2.join(baseDir, file);
245
- try {
246
- const content = readFileSync2(fullPath, "utf-8");
247
- if (regex.test(content)) {
248
- return null;
249
- }
250
- } catch {
251
- }
252
- }
253
- }
254
- return {
255
- ...invariant,
256
- valid: false,
257
- patternNotFound: true
258
- };
259
- }
260
- };
261
- var ForbiddenImportChecker = class {
262
- validate(invariant, baseDir) {
263
- const { from, cannot_import } = invariant;
264
- if (!from || !cannot_import || !Array.isArray(cannot_import)) {
265
- return null;
266
- }
267
- const ignorePatterns = EXCLUDED_DIRS.map((dir) => `**/${dir}/**`);
268
- const files = globSync(from, {
269
- cwd: baseDir,
270
- ignore: ignorePatterns,
271
- nodir: true
272
- });
273
- const violatingFiles = [];
274
- const violatingImports = {};
275
- const forbiddenModulePatterns = cannot_import.map((mod) => {
276
- const escapedMod = mod.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
277
- return new RegExp(`(?:import\\s+[^;]*from\\s*['"]${escapedMod}['"]|export\\s+[^;]*from\\s*['"]${escapedMod}['"]|require\\s*\\(\\s*['"]${escapedMod}['"]\\s*\\)|import\\s*\\(\\s*['"]${escapedMod}['"]\\s*\\))`);
278
- });
279
- for (const file of files) {
280
- const fullPath = path2.join(baseDir, file);
281
- try {
282
- const content = readFileSync2(fullPath, "utf-8");
283
- for (let i = 0; i < forbiddenModulePatterns.length; i++) {
284
- const pattern = forbiddenModulePatterns[i];
285
- if (!pattern)
286
- continue;
287
- const moduleName = cannot_import[i] ?? "unknown-module";
288
- if (pattern.test(content)) {
289
- if (!violatingFiles.includes(file)) {
290
- violatingFiles.push(file);
291
- }
292
- violatingImports[moduleName] = (violatingImports[moduleName] || 0) + 1;
293
- }
294
- }
295
- } catch {
296
- }
297
- }
298
- if (violatingFiles.length > 0) {
299
- return {
300
- ...invariant,
301
- valid: false,
302
- violatingFiles,
303
- violatingImports
304
- };
305
- }
306
- return null;
307
- }
308
- };
309
- var WUAutomatedTestsChecker = class {
310
- validate(invariant, baseDir, context = {}) {
311
- const { wuId } = context;
312
- const result = checkAutomatedTestsInvariant({ baseDir, wuId });
313
- if (!result.valid && result.violations.length > 0) {
314
- return {
315
- ...invariant,
316
- valid: false,
317
- wuViolations: result.violations
318
- };
319
- }
320
- return null;
321
- }
322
- };
323
- registerInvariantChecker(INVARIANT_TYPES.REQUIRED_FILE, new RequiredFileChecker());
324
- registerInvariantChecker(INVARIANT_TYPES.FORBIDDEN_FILE, new ForbiddenFileChecker());
325
- registerInvariantChecker(INVARIANT_TYPES.MUTUAL_EXCLUSIVITY, new MutualExclusivityChecker());
326
- registerInvariantChecker(INVARIANT_TYPES.FORBIDDEN_PATTERN, new ForbiddenPatternChecker());
327
- registerInvariantChecker(INVARIANT_TYPES.REQUIRED_PATTERN, new RequiredPatternChecker());
328
- registerInvariantChecker(INVARIANT_TYPES.FORBIDDEN_IMPORT, new ForbiddenImportChecker());
329
- registerInvariantChecker(INVARIANT_TYPES.WU_AUTOMATED_TESTS, new WUAutomatedTestsChecker());
330
- var InvariantError = class extends Error {
331
- /** The invariant ID */
332
- invariantId;
333
- /**
334
- * @param {string} invariantId - The invariant ID (e.g., 'INV-001')
335
- * @param {string} message - Error message
336
- */
337
- constructor(invariantId, message) {
338
- super(message);
339
- this.name = "InvariantError";
340
- this.invariantId = invariantId;
341
- }
342
- };
343
- function loadInvariants(filePath) {
344
- if (!existsSync2(filePath)) {
345
- throw createError(ErrorCodes.FILE_NOT_FOUND, `Invariants file not found: ${filePath}`);
346
- }
347
- const content = readFileSync2(filePath, "utf-8");
348
- let doc;
349
- try {
350
- doc = parseYAML(content);
351
- } catch (e) {
352
- throw createError(ErrorCodes.YAML_PARSE_ERROR, `Invalid YAML in ${filePath}: ${getErrorMessage(e)}`);
353
- }
354
- if (!doc || !Array.isArray(doc.invariants)) {
355
- throw createError(ErrorCodes.INVARIANT_ERROR, `Invalid invariants.yml: expected 'invariants' array at root`);
356
- }
357
- return doc.invariants;
358
- }
359
- function validateInvariants(invariants, options = {}) {
360
- const { baseDir = process.cwd(), wuId } = options;
361
- const violations = [];
362
- const context = { wuId };
363
- for (const invariant of invariants) {
364
- const checker = checkerRegistry.get(invariant.type);
365
- if (checker) {
366
- const violation = checker.validate(invariant, baseDir, context);
367
- if (violation) {
368
- violations.push(violation);
369
- }
370
- } else {
371
- console.warn(`[invariants] Unknown invariant type: ${invariant.type} (${invariant.id})`);
372
- }
373
- }
374
- return {
375
- valid: violations.length === 0,
376
- violations
377
- };
378
- }
379
- function formatFileViolationDetails(violation) {
380
- const lines = [];
381
- if (violation.path) {
382
- lines.push(`Path: ${violation.path}`);
383
- }
384
- if (violation.existingPaths) {
385
- lines.push(`Conflicting files: ${violation.existingPaths.join(", ")}`);
386
- }
387
- if (violation.matchingFiles) {
388
- lines.push(`Files with forbidden pattern: ${violation.matchingFiles.join(", ")}`);
389
- }
390
- return lines;
391
- }
392
- function formatImportViolationDetails(violation) {
393
- const lines = [];
394
- if (violation.from) {
395
- lines.push(`From: ${violation.from}`);
396
- }
397
- if (violation.cannot_import) {
398
- lines.push(`Cannot import: ${violation.cannot_import.join(", ")}`);
399
- }
400
- if (violation.violatingFiles) {
401
- lines.push(`Files with forbidden imports: ${violation.violatingFiles.join(", ")}`);
402
- }
403
- if (violation.violatingImports) {
404
- const imports = Object.entries(violation.violatingImports).map(([mod, count]) => `${mod} (${count} occurrence${count > 1 ? "s" : ""})`).join(", ");
405
- lines.push(`Forbidden imports found: ${imports}`);
406
- }
407
- return lines;
408
- }
409
- function formatPatternViolationDetails(violation) {
410
- const lines = [];
411
- if (violation.patternNotFound) {
412
- lines.push(`Required pattern not found: ${violation.pattern}`);
413
- if (violation.scope) {
414
- lines.push(`Searched in: ${violation.scope.join(", ")}`);
415
- }
416
- }
417
- return lines;
418
- }
419
- function formatWUAutomatedTestsViolationDetails(violation) {
420
- const lines = [];
421
- if (violation.wuViolations) {
422
- lines.push(`WUs missing automated tests:`);
423
- for (const wuViolation of violation.wuViolations) {
424
- lines.push(` - ${wuViolation.wuId}`);
425
- if (wuViolation.codeFiles && wuViolation.codeFiles.length > 0) {
426
- lines.push(` Code files: ${wuViolation.codeFiles.join(", ")}`);
427
- }
428
- }
429
- }
430
- return lines;
431
- }
432
- function formatViolationDetails(violation) {
433
- return [
434
- ...formatFileViolationDetails(violation),
435
- ...formatImportViolationDetails(violation),
436
- ...formatPatternViolationDetails(violation),
437
- ...formatWUAutomatedTestsViolationDetails(violation)
438
- ];
439
- }
440
- function formatInvariantError(violation) {
441
- const lines = [
442
- `INVARIANT VIOLATION: ${violation.id}`,
443
- `Type: ${violation.type}`,
444
- `Description: ${violation.description}`,
445
- ...formatViolationDetails(violation)
446
- ];
447
- if (violation.message) {
448
- lines.push("");
449
- lines.push(`Action: ${violation.message}`);
450
- }
451
- return lines.join("\n");
452
- }
453
- function runInvariants(options = {}) {
454
- const { configPath = "tools/invariants.yml", baseDir = process.cwd(), silent = false, wuId } = options;
455
- const fullConfigPath = path2.isAbsolute(configPath) ? configPath : path2.join(baseDir, configPath);
456
- if (!existsSync2(fullConfigPath)) {
457
- if (!silent) {
458
- console.log("[invariants] No tools/invariants.yml found - skipping");
459
- }
460
- return { success: true, violations: [], formatted: "" };
461
- }
462
- try {
463
- const invariants = loadInvariants(fullConfigPath);
464
- if (invariants.length === 0) {
465
- if (!silent) {
466
- console.log("[invariants] No invariants defined - skipping");
467
- }
468
- return { success: true, violations: [], formatted: "" };
469
- }
470
- const result = validateInvariants(invariants, { baseDir, wuId });
471
- if (result.valid) {
472
- if (!silent) {
473
- console.log(`[invariants] All ${invariants.length} invariants passed`);
474
- }
475
- return { success: true, violations: [], formatted: "" };
476
- }
477
- const formatted = result.violations.map(formatInvariantError).join("\n\n");
478
- if (!silent) {
479
- console.error("[invariants] FAILED - violations detected:");
480
- console.error("");
481
- console.error(formatted);
482
- }
483
- return {
484
- success: false,
485
- violations: result.violations,
486
- formatted
487
- };
488
- } catch (e) {
489
- const error = `[invariants] Error: ${getErrorMessage(e)}`;
490
- if (!silent) {
491
- console.error(error);
492
- }
493
- return {
494
- success: false,
495
- violations: [],
496
- formatted: error
497
- };
498
- }
499
- }
500
-
501
- export {
502
- INVARIANT_TYPES,
503
- registerInvariantChecker,
504
- getInvariantChecker,
505
- InvariantError,
506
- loadInvariants,
507
- validateInvariants,
508
- formatInvariantError,
509
- runInvariants
510
- };
@@ -1,16 +0,0 @@
1
- // src/onboarding-template-paths.ts
2
- var SCAFFOLDED_ONBOARDING_TEMPLATE_PATHS = {
3
- "starting-prompt.md": "core/ai/onboarding/starting-prompt.md.template",
4
- "first-15-mins.md": "core/ai/onboarding/first-15-mins.md.template",
5
- "local-only.md": "core/ai/onboarding/local-only.md.template",
6
- "quick-ref-commands.md": "core/ai/onboarding/quick-ref-commands.md.template",
7
- "first-wu-mistakes.md": "core/ai/onboarding/first-wu-mistakes.md.template",
8
- "troubleshooting-wu-done.md": "core/ai/onboarding/troubleshooting-wu-done.md.template",
9
- "agent-safety-card.md": "core/ai/onboarding/agent-safety-card.md.template",
10
- "wu-create-checklist.md": "core/ai/onboarding/wu-create-checklist.md.template",
11
- "wu-sizing-guide.md": "core/ai/onboarding/wu-sizing-guide.md.template"
12
- };
13
-
14
- export {
15
- SCAFFOLDED_ONBOARDING_TEMPLATE_PATHS
16
- };