@lumenflow/cli 3.12.6 → 3.12.8

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 (111) hide show
  1. package/dist/config-set.js +82 -32
  2. package/dist/config-set.js.map +1 -1
  3. package/dist/wu-claim.js +2 -1
  4. package/dist/wu-claim.js.map +1 -1
  5. package/dist/wu-done-policies.js +9 -9
  6. package/dist/wu-done-policies.js.map +1 -1
  7. package/dist/wu-spawn-strategy-resolver.js +14 -6
  8. package/dist/wu-spawn-strategy-resolver.js.map +1 -1
  9. package/package.json +8 -8
  10. package/packs/sidekick/.turbo/turbo-build.log +1 -1
  11. package/packs/sidekick/package.json +1 -1
  12. package/packs/software-delivery/.turbo/turbo-build.log +1 -1
  13. package/packs/software-delivery/package.json +1 -1
  14. package/dist/chunk-2D2VOCA4.js +0 -37
  15. package/dist/chunk-2D5KFYGX.js +0 -284
  16. package/dist/chunk-2GXVIN57.js +0 -14072
  17. package/dist/chunk-2MQ7HZWZ.js +0 -26
  18. package/dist/chunk-2UFQ3A3C.js +0 -643
  19. package/dist/chunk-3RG5ZIWI.js +0 -10
  20. package/dist/chunk-4N74J3UT.js +0 -15
  21. package/dist/chunk-5GTOXFYR.js +0 -392
  22. package/dist/chunk-5VY6MQMC.js +0 -240
  23. package/dist/chunk-67XVPMRY.js +0 -1297
  24. package/dist/chunk-6HO4GWJE.js +0 -164
  25. package/dist/chunk-6W5XHWYV.js +0 -1890
  26. package/dist/chunk-6X4EMYJQ.js +0 -64
  27. package/dist/chunk-6XYXI2NQ.js +0 -772
  28. package/dist/chunk-7ANSOV6Q.js +0 -285
  29. package/dist/chunk-A624LFLB.js +0 -1380
  30. package/dist/chunk-ADN5NHG4.js +0 -126
  31. package/dist/chunk-B7YJYJKG.js +0 -33
  32. package/dist/chunk-CCLHCPKG.js +0 -210
  33. package/dist/chunk-CK36VROC.js +0 -1584
  34. package/dist/chunk-D3UOFRSB.js +0 -81
  35. package/dist/chunk-DFR4DJBM.js +0 -230
  36. package/dist/chunk-DSYBDHYH.js +0 -79
  37. package/dist/chunk-DWMLTXKQ.js +0 -1176
  38. package/dist/chunk-E3REJTAJ.js +0 -28
  39. package/dist/chunk-EA3IVO64.js +0 -633
  40. package/dist/chunk-EK2AKZKD.js +0 -55
  41. package/dist/chunk-ELD7JTTT.js +0 -343
  42. package/dist/chunk-EX6TT2XI.js +0 -195
  43. package/dist/chunk-EXINSFZE.js +0 -82
  44. package/dist/chunk-EZ6ZBYBM.js +0 -510
  45. package/dist/chunk-FBKAPTJ2.js +0 -16
  46. package/dist/chunk-FVLV5RYH.js +0 -1118
  47. package/dist/chunk-GDNSBQVK.js +0 -2485
  48. package/dist/chunk-GPQHMBNN.js +0 -278
  49. package/dist/chunk-GTFJB67L.js +0 -68
  50. package/dist/chunk-HANJXVKW.js +0 -1127
  51. package/dist/chunk-HEVS5YLD.js +0 -269
  52. package/dist/chunk-HMEVZKPQ.js +0 -9
  53. package/dist/chunk-HRGSYNLM.js +0 -3511
  54. package/dist/chunk-ISZR5N4K.js +0 -60
  55. package/dist/chunk-J6SUPR2C.js +0 -226
  56. package/dist/chunk-JERYVEIZ.js +0 -244
  57. package/dist/chunk-JHHWGL2N.js +0 -87
  58. package/dist/chunk-JONWQUB5.js +0 -775
  59. package/dist/chunk-K2DIWWDM.js +0 -1766
  60. package/dist/chunk-KY4PGL5V.js +0 -969
  61. package/dist/chunk-L737LQ4C.js +0 -1285
  62. package/dist/chunk-LFTWYIB2.js +0 -497
  63. package/dist/chunk-LV47RFNJ.js +0 -41
  64. package/dist/chunk-MKSAITI7.js +0 -15
  65. package/dist/chunk-MZ7RKIX4.js +0 -212
  66. package/dist/chunk-NAP6CFSO.js +0 -84
  67. package/dist/chunk-ND6MY37M.js +0 -16
  68. package/dist/chunk-NMG736UR.js +0 -683
  69. package/dist/chunk-NRAXROED.js +0 -32
  70. package/dist/chunk-NRIZR3A7.js +0 -690
  71. package/dist/chunk-NX43BG3M.js +0 -233
  72. package/dist/chunk-O645XLSI.js +0 -297
  73. package/dist/chunk-OMJD6A3S.js +0 -235
  74. package/dist/chunk-QB6SJD4T.js +0 -430
  75. package/dist/chunk-QFSTL4J3.js +0 -276
  76. package/dist/chunk-QLGDFMFX.js +0 -212
  77. package/dist/chunk-RIAAGL2E.js +0 -13
  78. package/dist/chunk-RWO5XMZ6.js +0 -86
  79. package/dist/chunk-RXRKBBSM.js +0 -149
  80. package/dist/chunk-RZOZMML6.js +0 -363
  81. package/dist/chunk-U7I7FS7T.js +0 -113
  82. package/dist/chunk-UI42RODY.js +0 -717
  83. package/dist/chunk-UTVMVSCO.js +0 -519
  84. package/dist/chunk-V6OJGLBA.js +0 -1746
  85. package/dist/chunk-W2JHVH7D.js +0 -152
  86. package/dist/chunk-WD3Y7VQN.js +0 -280
  87. package/dist/chunk-WOCTQ5MS.js +0 -303
  88. package/dist/chunk-WZR3ZUNN.js +0 -696
  89. package/dist/chunk-XGI665H7.js +0 -150
  90. package/dist/chunk-XKY65P2T.js +0 -304
  91. package/dist/chunk-Y4CQZY65.js +0 -57
  92. package/dist/chunk-YFEXKLVE.js +0 -194
  93. package/dist/chunk-YHO3HS5X.js +0 -287
  94. package/dist/chunk-YLS7AZSX.js +0 -738
  95. package/dist/chunk-ZE473AO6.js +0 -49
  96. package/dist/chunk-ZF747T3O.js +0 -644
  97. package/dist/chunk-ZHCZHZH3.js +0 -43
  98. package/dist/chunk-ZZNZX2XY.js +0 -87
  99. package/dist/constants-7QAP3VQ4.js +0 -23
  100. package/dist/dist-IY3UUMWK.js +0 -33
  101. package/dist/invariants-runner-W5RGHCSU.js +0 -27
  102. package/dist/lane-lock-6J36HD5O.js +0 -35
  103. package/dist/mem-checkpoint-core-EANG2GVN.js +0 -14
  104. package/dist/mem-signal-core-2LZ2WYHW.js +0 -19
  105. package/dist/memory-store-OLB5FO7K.js +0 -18
  106. package/dist/service-6BYCOCO5.js +0 -13
  107. package/dist/spawn-policy-resolver-NTSZYQ6R.js +0 -17
  108. package/dist/spawn-task-builder-R4E2BHSW.js +0 -22
  109. package/dist/wu-done-pr-WLFFFEPJ.js +0 -25
  110. package/dist/wu-done-validation-3J5E36FE.js +0 -30
  111. package/dist/wu-duplicate-id-detector-5S7JHELK.js +0 -232
@@ -1,212 +0,0 @@
1
- import {
2
- INIT_PATTERNS,
3
- INIT_STATUSES,
4
- PHASE_STATUSES,
5
- PRIORITIES
6
- } from "./chunk-NAP6CFSO.js";
7
- import {
8
- INIT_PATHS
9
- } from "./chunk-ZHCZHZH3.js";
10
- import {
11
- parseYAML,
12
- readWU,
13
- stringifyYAML
14
- } from "./chunk-NRIZR3A7.js";
15
- import {
16
- WU_PATHS
17
- } from "./chunk-6HO4GWJE.js";
18
- import {
19
- ErrorCodes,
20
- createError
21
- } from "./chunk-RXRKBBSM.js";
22
-
23
- // ../initiatives/dist/initiative-yaml.js
24
- import { existsSync, readFileSync, writeFileSync, readdirSync } from "fs";
25
- import path from "path";
26
-
27
- // ../initiatives/dist/initiative-schema.js
28
- import { z } from "zod";
29
- var DATE_PATTERN = INIT_PATTERNS.DATE;
30
- var InitiativePhaseSchema = z.object({
31
- /** Phase number (non-negative integer, determines sequence; 0 valid for foundation phases) */
32
- id: z.number().int().nonnegative({ message: "Phase id must be a non-negative integer" }),
33
- /** Phase title */
34
- title: z.string().min(1, { message: "Phase title is required" }),
35
- /** Phase status */
36
- status: z.enum(PHASE_STATUSES, {
37
- error: `Status must be one of: ${PHASE_STATUSES.join(", ")}`
38
- })
39
- });
40
- var InitiativeSchema = z.object({
41
- /** Initiative identifier (INIT-NNN or INIT-NAME format) */
42
- id: z.string().regex(INIT_PATTERNS.INIT_ID, { message: "ID must match pattern INIT-NNN or INIT-NAME" }),
43
- /** Kebab-case unique identifier for URLs and references */
44
- slug: z.string().regex(INIT_PATTERNS.SLUG, { message: "Slug must be kebab-case (e.g., shock-protocol)" }),
45
- /** Initiative title */
46
- title: z.string().min(1, { message: "Title is required" }),
47
- /** Detailed description (optional) */
48
- description: z.string().optional(),
49
- /** Initiative lifecycle status */
50
- status: z.enum(INIT_STATUSES, {
51
- error: `Status must be one of: ${INIT_STATUSES.join(", ")}`
52
- }),
53
- /** Priority level (optional) */
54
- priority: z.enum(PRIORITIES, {
55
- error: `Priority must be one of: ${PRIORITIES.join(", ")}`
56
- }).optional(),
57
- /** Owner (team or individual, optional) */
58
- owner: z.string().optional(),
59
- /** Creation date (YYYY-MM-DD) */
60
- created: z.string().regex(DATE_PATTERN, { message: "Created must be YYYY-MM-DD format" }),
61
- /** Target completion date (optional, YYYY-MM-DD) */
62
- target_date: z.string().regex(DATE_PATTERN, { message: "Target date must be YYYY-MM-DD format" }).optional(),
63
- /** Ordered phases within the initiative (optional) */
64
- phases: z.array(InitiativePhaseSchema).optional(),
65
- /** Success metrics for completion (optional) */
66
- success_metrics: z.array(z.string()).optional(),
67
- /** Labels for cross-cutting concerns (optional) */
68
- labels: z.array(z.string()).optional(),
69
- /** Linked WU IDs (optional, bidirectional link with WU.initiative field) */
70
- wus: z.array(z.string()).optional()
71
- });
72
- function validateInitiative(data) {
73
- return InitiativeSchema.safeParse(data);
74
- }
75
-
76
- // ../initiatives/dist/initiative-yaml.js
77
- function readInitiative(initPath, expectedId) {
78
- if (!existsSync(initPath)) {
79
- throw createError(ErrorCodes.INIT_NOT_FOUND, `Initiative file not found: ${initPath}`, {
80
- path: initPath,
81
- expectedId
82
- });
83
- }
84
- const text = readFileSync(initPath, { encoding: "utf-8" });
85
- let rawDoc;
86
- try {
87
- rawDoc = parseYAML(text);
88
- } catch (e) {
89
- const errorMessage = e instanceof Error ? e.message : String(e);
90
- throw createError(ErrorCodes.YAML_PARSE_ERROR, `Failed to parse YAML ${initPath}: ${errorMessage}`, {
91
- path: initPath,
92
- originalError: errorMessage
93
- });
94
- }
95
- const docWithId = rawDoc;
96
- if (!docWithId || docWithId.id !== expectedId) {
97
- throw createError(ErrorCodes.INIT_NOT_FOUND, `Initiative YAML id mismatch. Expected ${expectedId}, found ${docWithId?.id}`, { path: initPath, expectedId, foundId: docWithId?.id });
98
- }
99
- const result = validateInitiative(rawDoc);
100
- if (!result.success) {
101
- const issues = result.error.issues.map((i) => `${i.path.join(".")}: ${i.message}`).join("; ");
102
- throw createError(ErrorCodes.VALIDATION_ERROR, `Initiative validation failed: ${issues}`, {
103
- path: initPath,
104
- issues: result.error.issues
105
- });
106
- }
107
- return result.data;
108
- }
109
- function writeInitiative(initPath, doc) {
110
- const out = stringifyYAML(doc);
111
- writeFileSync(initPath, out, { encoding: "utf-8" });
112
- }
113
- function listInitiatives() {
114
- const dir = INIT_PATHS.INITIATIVES_DIR();
115
- if (!existsSync(dir)) {
116
- return [];
117
- }
118
- const files = readdirSync(dir).filter((f) => f.endsWith(".yaml") && INIT_PATTERNS.INIT_ID.test(f.replace(".yaml", "")));
119
- return files.map((f) => {
120
- const filePath = path.join(dir, f);
121
- const id = f.replace(".yaml", "");
122
- try {
123
- const doc = readInitiative(filePath, id);
124
- return { id, doc, path: filePath };
125
- } catch {
126
- return null;
127
- }
128
- }).filter((entry) => entry !== null);
129
- }
130
- function findInitiative(ref) {
131
- const initiatives = listInitiatives();
132
- const byId = initiatives.find((i) => i.id === ref);
133
- if (byId)
134
- return byId;
135
- const bySlug = initiatives.find((i) => i.doc.slug === ref);
136
- return bySlug || null;
137
- }
138
- function getInitiativeWUs(initRef) {
139
- const wuDir = WU_PATHS.WU("").replace(/\/[^/]*$/, "");
140
- if (!existsSync(wuDir)) {
141
- return [];
142
- }
143
- const files = readdirSync(wuDir).filter((f) => f.endsWith(".yaml") && f.startsWith("WU-"));
144
- const initiative = findInitiative(initRef);
145
- const matchRefs = initiative ? [initiative.id, initiative.doc.slug].filter(Boolean) : [initRef];
146
- return files.map((f) => {
147
- const filePath = path.join(wuDir, f);
148
- const id = f.replace(".yaml", "");
149
- try {
150
- const doc = readWU(filePath, id);
151
- if (doc.initiative && matchRefs.includes(doc.initiative)) {
152
- return { id, doc, path: filePath };
153
- }
154
- return null;
155
- } catch {
156
- return null;
157
- }
158
- }).filter((entry) => entry !== null);
159
- }
160
- function getInitiativeProgress(initRef) {
161
- const wus = getInitiativeWUs(initRef);
162
- const counts = {
163
- total: wus.length,
164
- done: 0,
165
- inProgress: 0,
166
- blocked: 0,
167
- ready: 0,
168
- percentage: 0
169
- };
170
- for (const { doc } of wus) {
171
- switch (doc.status) {
172
- case "done":
173
- counts.done++;
174
- break;
175
- case "in_progress":
176
- counts.inProgress++;
177
- break;
178
- case "blocked":
179
- counts.blocked++;
180
- break;
181
- case "ready":
182
- counts.ready++;
183
- break;
184
- default:
185
- break;
186
- }
187
- }
188
- counts.percentage = counts.total > 0 ? Math.round(counts.done / counts.total * 100) : 0;
189
- return counts;
190
- }
191
- function getInitiativePhases(initRef) {
192
- const wus = getInitiativeWUs(initRef);
193
- const phases = /* @__PURE__ */ new Map();
194
- for (const { id, doc } of wus) {
195
- const phase = doc.phase ?? null;
196
- if (!phases.has(phase)) {
197
- phases.set(phase, []);
198
- }
199
- phases.get(phase).push({ id, doc });
200
- }
201
- return phases;
202
- }
203
-
204
- export {
205
- readInitiative,
206
- writeInitiative,
207
- listInitiatives,
208
- findInitiative,
209
- getInitiativeWUs,
210
- getInitiativeProgress,
211
- getInitiativePhases
212
- };
@@ -1,84 +0,0 @@
1
- // ../initiatives/dist/initiative-constants.js
2
- var INIT_STATUSES = ["draft", "open", "in_progress", "done", "archived"];
3
- var PHASE_STATUSES = ["pending", "in_progress", "done", "blocked"];
4
- var PRIORITIES = ["P0", "P1", "P2", "P3"];
5
- var INIT_PATTERNS = {
6
- /** Initiative ID format (INIT-NNN where NNN is digits or INIT-NAME for named initiatives) */
7
- INIT_ID: /^INIT-[\dA-Z][\dA-Z-]*$/,
8
- /** Extract INIT ID from string */
9
- INIT_ID_EXTRACT: /INIT-[\dA-Z][\dA-Z-]*/,
10
- /** Kebab-case slug format */
11
- // eslint-disable-next-line security/detect-unsafe-regex -- static slug pattern; no backtracking risk
12
- SLUG: /^[a-z0-9]+(-[a-z0-9]+)*$/,
13
- /** Date format (YYYY-MM-DD) */
14
- DATE: /^\d{4}-\d{2}-\d{2}$/
15
- };
16
- var INIT_COMMIT_FORMATS = {
17
- /**
18
- * Create initiative commit message
19
- * @param id - Initiative ID
20
- * @param title - Initiative title
21
- * @returns Commit message
22
- */
23
- CREATE: (id, title) => {
24
- const shortTitle = title.length > 50 ? `${title.substring(0, 47)}...` : title;
25
- return `docs: create ${id.toLowerCase()} for ${shortTitle.toLowerCase()}`;
26
- },
27
- /**
28
- * Update initiative commit message
29
- * @param id - Initiative ID
30
- * @returns Commit message
31
- */
32
- UPDATE: (id) => `docs: update ${id.toLowerCase()}`,
33
- /**
34
- * Link WU to initiative commit message
35
- * @param wuId - WU ID
36
- * @param initId - Initiative ID
37
- * @returns Commit message
38
- */
39
- LINK_WU: (wuId, initId) => `docs: link ${wuId.toLowerCase()} to ${initId.toLowerCase()}`,
40
- /**
41
- * Unlink WU from initiative commit message (WU-1328)
42
- * @param wuId - WU ID
43
- * @param initId - Initiative ID
44
- * @returns Commit message
45
- */
46
- UNLINK_WU: (wuId, initId) => `docs: unlink ${wuId.toLowerCase()} from ${initId.toLowerCase()}`,
47
- /**
48
- * Edit initiative commit message (WU-1451)
49
- * @param id - Initiative ID
50
- * @returns Commit message
51
- */
52
- EDIT: (id) => `docs: edit ${id.toLowerCase()}`
53
- };
54
- var INIT_LOG_PREFIX = {
55
- CREATE: "[initiative:create]",
56
- LIST: "[initiative:list]",
57
- STATUS: "[initiative:status]",
58
- ADD_WU: "[initiative:add-wu]",
59
- REMOVE_WU: "[initiative:remove-wu]",
60
- // WU-1328: Remove WU from initiative
61
- EDIT: "[initiative:edit]"
62
- // WU-1451: Initiative edit operation
63
- };
64
- var INIT_DEFAULTS = {
65
- STATUS: "draft",
66
- PRIORITY: "P2"
67
- };
68
- var OUTPUT_FORMATS = {
69
- TABLE: "table",
70
- JSON: "json",
71
- ASCII: "ascii",
72
- MERMAID: "mermaid"
73
- };
74
-
75
- export {
76
- INIT_STATUSES,
77
- PHASE_STATUSES,
78
- PRIORITIES,
79
- INIT_PATTERNS,
80
- INIT_COMMIT_FORMATS,
81
- INIT_LOG_PREFIX,
82
- INIT_DEFAULTS,
83
- OUTPUT_FORMATS
84
- };
@@ -1,16 +0,0 @@
1
- import {
2
- LUMENFLOW_MEMORY_PATHS
3
- } from "./chunk-4N74J3UT.js";
4
-
5
- // ../memory/dist/fs-utils.js
6
- import fs from "fs/promises";
7
- import path from "path";
8
- async function ensureMemoryDir(baseDir) {
9
- const memoryDir = path.join(baseDir, LUMENFLOW_MEMORY_PATHS.MEMORY_DIR);
10
- await fs.mkdir(memoryDir, { recursive: true });
11
- return memoryDir;
12
- }
13
-
14
- export {
15
- ensureMemoryDir
16
- };