@lumenflow/cli 4.20.2 → 4.22.0

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 (131) hide show
  1. package/README.md +30 -27
  2. package/dist/config-set.js +54 -36
  3. package/dist/config-set.js.map +1 -1
  4. package/dist/delegation-list.js +86 -53
  5. package/dist/delegation-list.js.map +1 -1
  6. package/dist/gate-conditional.js +476 -0
  7. package/dist/gate-conditional.js.map +1 -0
  8. package/dist/gates-plan-resolvers.js +24 -1
  9. package/dist/gates-plan-resolvers.js.map +1 -1
  10. package/dist/init-templates.js +13 -0
  11. package/dist/init-templates.js.map +1 -1
  12. package/dist/initiative-create.js +1 -1
  13. package/dist/orchestrate-init-status.js +24 -31
  14. package/dist/orchestrate-init-status.js.map +1 -1
  15. package/dist/orchestrate-initiative.js +31 -2
  16. package/dist/orchestrate-initiative.js.map +1 -1
  17. package/dist/orchestrate-monitor.js +433 -1
  18. package/dist/orchestrate-monitor.js.map +1 -1
  19. package/dist/public-manifest.js +11 -4
  20. package/dist/public-manifest.js.map +1 -1
  21. package/package.json +9 -8
  22. package/packs/agent-runtime/.turbo/turbo-build.log +1 -1
  23. package/packs/agent-runtime/package.json +1 -1
  24. package/packs/sidekick/.turbo/turbo-build.log +1 -1
  25. package/packs/sidekick/package.json +1 -1
  26. package/packs/software-delivery/.turbo/turbo-build.log +1 -1
  27. package/packs/software-delivery/package.json +1 -1
  28. package/templates/core/LUMENFLOW.md.template +6 -3
  29. package/templates/core/ai/onboarding/first-wu-mistakes.md.template +2 -2
  30. package/templates/core/ai/onboarding/initiative-orchestration.md.template +83 -27
  31. package/templates/core/ai/onboarding/quick-ref-commands.md.template +9 -5
  32. package/templates/core/ai/onboarding/starting-prompt.md.template +1 -1
  33. package/templates/core/ai/onboarding/vendor-support.md.template +13 -0
  34. package/dist/chunk-2D2VOCA4.js +0 -37
  35. package/dist/chunk-2D5KFYGX.js +0 -284
  36. package/dist/chunk-2GXVIN57.js +0 -14072
  37. package/dist/chunk-2MQ7HZWZ.js +0 -26
  38. package/dist/chunk-2UFQ3A3C.js +0 -643
  39. package/dist/chunk-3RG5ZIWI.js +0 -10
  40. package/dist/chunk-4N74J3UT.js +0 -15
  41. package/dist/chunk-5GTOXFYR.js +0 -392
  42. package/dist/chunk-5VY6MQMC.js +0 -240
  43. package/dist/chunk-67XVPMRY.js +0 -1297
  44. package/dist/chunk-6HO4GWJE.js +0 -164
  45. package/dist/chunk-6W5XHWYV.js +0 -1890
  46. package/dist/chunk-6X4EMYJQ.js +0 -64
  47. package/dist/chunk-6XYXI2NQ.js +0 -772
  48. package/dist/chunk-7ANSOV6Q.js +0 -285
  49. package/dist/chunk-A624LFLB.js +0 -1380
  50. package/dist/chunk-ADN5NHG4.js +0 -126
  51. package/dist/chunk-B7YJYJKG.js +0 -33
  52. package/dist/chunk-CCLHCPKG.js +0 -210
  53. package/dist/chunk-CK36VROC.js +0 -1584
  54. package/dist/chunk-D3UOFRSB.js +0 -81
  55. package/dist/chunk-DFR4DJBM.js +0 -230
  56. package/dist/chunk-DSYBDHYH.js +0 -79
  57. package/dist/chunk-DWMLTXKQ.js +0 -1176
  58. package/dist/chunk-E3REJTAJ.js +0 -28
  59. package/dist/chunk-EA3IVO64.js +0 -633
  60. package/dist/chunk-EK2AKZKD.js +0 -55
  61. package/dist/chunk-ELD7JTTT.js +0 -343
  62. package/dist/chunk-EX6TT2XI.js +0 -195
  63. package/dist/chunk-EXINSFZE.js +0 -82
  64. package/dist/chunk-EZ6ZBYBM.js +0 -510
  65. package/dist/chunk-FBKAPTJ2.js +0 -16
  66. package/dist/chunk-FVLV5RYH.js +0 -1118
  67. package/dist/chunk-GDNSBQVK.js +0 -2485
  68. package/dist/chunk-GPQHMBNN.js +0 -278
  69. package/dist/chunk-GTFJB67L.js +0 -68
  70. package/dist/chunk-HANJXVKW.js +0 -1127
  71. package/dist/chunk-HEVS5YLD.js +0 -269
  72. package/dist/chunk-HMEVZKPQ.js +0 -9
  73. package/dist/chunk-HRGSYNLM.js +0 -3511
  74. package/dist/chunk-ISZR5N4K.js +0 -60
  75. package/dist/chunk-J6SUPR2C.js +0 -226
  76. package/dist/chunk-JERYVEIZ.js +0 -244
  77. package/dist/chunk-JHHWGL2N.js +0 -87
  78. package/dist/chunk-JONWQUB5.js +0 -775
  79. package/dist/chunk-K2DIWWDM.js +0 -1766
  80. package/dist/chunk-KY4PGL5V.js +0 -969
  81. package/dist/chunk-L737LQ4C.js +0 -1285
  82. package/dist/chunk-LFTWYIB2.js +0 -497
  83. package/dist/chunk-LV47RFNJ.js +0 -41
  84. package/dist/chunk-MKSAITI7.js +0 -15
  85. package/dist/chunk-MZ7RKIX4.js +0 -212
  86. package/dist/chunk-NAP6CFSO.js +0 -84
  87. package/dist/chunk-ND6MY37M.js +0 -16
  88. package/dist/chunk-NMG736UR.js +0 -683
  89. package/dist/chunk-NRAXROED.js +0 -32
  90. package/dist/chunk-NRIZR3A7.js +0 -690
  91. package/dist/chunk-NX43BG3M.js +0 -233
  92. package/dist/chunk-O645XLSI.js +0 -297
  93. package/dist/chunk-OMJD6A3S.js +0 -235
  94. package/dist/chunk-QB6SJD4T.js +0 -430
  95. package/dist/chunk-QFSTL4J3.js +0 -276
  96. package/dist/chunk-QLGDFMFX.js +0 -212
  97. package/dist/chunk-RIAAGL2E.js +0 -13
  98. package/dist/chunk-RWO5XMZ6.js +0 -86
  99. package/dist/chunk-RXRKBBSM.js +0 -149
  100. package/dist/chunk-RZOZMML6.js +0 -363
  101. package/dist/chunk-U7I7FS7T.js +0 -113
  102. package/dist/chunk-UI42RODY.js +0 -717
  103. package/dist/chunk-UTVMVSCO.js +0 -519
  104. package/dist/chunk-V6OJGLBA.js +0 -1746
  105. package/dist/chunk-W2JHVH7D.js +0 -152
  106. package/dist/chunk-WD3Y7VQN.js +0 -280
  107. package/dist/chunk-WOCTQ5MS.js +0 -303
  108. package/dist/chunk-WZR3ZUNN.js +0 -696
  109. package/dist/chunk-XGI665H7.js +0 -150
  110. package/dist/chunk-XKY65P2T.js +0 -304
  111. package/dist/chunk-Y4CQZY65.js +0 -57
  112. package/dist/chunk-YFEXKLVE.js +0 -194
  113. package/dist/chunk-YHO3HS5X.js +0 -287
  114. package/dist/chunk-YLS7AZSX.js +0 -738
  115. package/dist/chunk-ZE473AO6.js +0 -49
  116. package/dist/chunk-ZF747T3O.js +0 -644
  117. package/dist/chunk-ZHCZHZH3.js +0 -43
  118. package/dist/chunk-ZZNZX2XY.js +0 -87
  119. package/dist/constants-7QAP3VQ4.js +0 -23
  120. package/dist/dist-IY3UUMWK.js +0 -33
  121. package/dist/invariants-runner-W5RGHCSU.js +0 -27
  122. package/dist/lane-lock-6J36HD5O.js +0 -35
  123. package/dist/mem-checkpoint-core-EANG2GVN.js +0 -14
  124. package/dist/mem-signal-core-2LZ2WYHW.js +0 -19
  125. package/dist/memory-store-OLB5FO7K.js +0 -18
  126. package/dist/service-6BYCOCO5.js +0 -13
  127. package/dist/spawn-policy-resolver-NTSZYQ6R.js +0 -17
  128. package/dist/spawn-task-builder-R4E2BHSW.js +0 -22
  129. package/dist/wu-done-pr-WLFFFEPJ.js +0 -25
  130. package/dist/wu-done-validation-3J5E36FE.js +0 -30
  131. package/dist/wu-duplicate-id-detector-5S7JHELK.js +0 -232
@@ -1,269 +0,0 @@
1
- import {
2
- resolveCliTemplatesDir
3
- } from "./chunk-D3UOFRSB.js";
4
- import {
5
- ErrorCodes,
6
- createError
7
- } from "./chunk-RXRKBBSM.js";
8
-
9
- // src/init-scaffolding.ts
10
- import * as fs from "fs";
11
- import * as path from "path";
12
-
13
- // src/merge-block.ts
14
- var MARKERS = {
15
- START: "<!-- LUMENFLOW:START -->",
16
- END: "<!-- LUMENFLOW:END -->"
17
- };
18
- function detectLineEnding(content) {
19
- if (!content) {
20
- return "\n";
21
- }
22
- const crlfCount = (content.match(/\r\n/g) || []).length;
23
- const lfCount = (content.match(/(?<!\r)\n/g) || []).length;
24
- if (crlfCount === 0 && lfCount === 0) {
25
- return "\n";
26
- }
27
- return crlfCount >= lfCount ? "\r\n" : "\n";
28
- }
29
- function normalizeLineEndings(content, lineEnding) {
30
- const normalized = content.replace(/\r\n/g, "\n");
31
- if (lineEnding === "\r\n") {
32
- return normalized.replace(/\n/g, "\r\n");
33
- }
34
- return normalized;
35
- }
36
- function extractMergeBlock(content) {
37
- const startIndexes = [];
38
- const endIndexes = [];
39
- let pos = 0;
40
- while ((pos = content.indexOf(MARKERS.START, pos)) !== -1) {
41
- startIndexes.push(pos);
42
- pos += MARKERS.START.length;
43
- }
44
- pos = 0;
45
- while ((pos = content.indexOf(MARKERS.END, pos)) !== -1) {
46
- endIndexes.push(pos);
47
- pos += MARKERS.END.length;
48
- }
49
- if (startIndexes.length > 1) {
50
- return { found: false, malformed: true, malformedReason: "multiple-start" };
51
- }
52
- if (endIndexes.length > 1) {
53
- return { found: false, malformed: true, malformedReason: "multiple-end" };
54
- }
55
- const hasStart = startIndexes.length === 1;
56
- const hasEnd = endIndexes.length === 1;
57
- if (hasStart && !hasEnd) {
58
- return { found: false, malformed: true, malformedReason: "missing-end" };
59
- }
60
- if (!hasStart && hasEnd) {
61
- return { found: false, malformed: true, malformedReason: "missing-start" };
62
- }
63
- if (!hasStart && !hasEnd) {
64
- return { found: false };
65
- }
66
- const startIndex = startIndexes[0];
67
- const endMarkerIndex = endIndexes[0];
68
- const endIndex = endMarkerIndex + MARKERS.END.length;
69
- if (endMarkerIndex <= startIndex) {
70
- return { found: false, malformed: true, malformedReason: "missing-end" };
71
- }
72
- const afterStart = startIndex + MARKERS.START.length;
73
- const beforeEnd = endMarkerIndex;
74
- let blockContent = content.slice(afterStart, beforeEnd);
75
- blockContent = trimNewlines(blockContent);
76
- return {
77
- found: true,
78
- content: blockContent,
79
- startIndex,
80
- endIndex
81
- };
82
- }
83
- function insertMergeBlock(originalContent, blockContent) {
84
- const lineEnding = detectLineEnding(originalContent);
85
- const normalizedBlock = normalizeLineEndings(blockContent, lineEnding);
86
- let content = originalContent;
87
- if (!content.endsWith(lineEnding)) {
88
- content += lineEnding;
89
- }
90
- if (!content.endsWith(lineEnding + lineEnding) && content.trim().length > 0) {
91
- content += lineEnding;
92
- }
93
- const block = [MARKERS.START, normalizedBlock, MARKERS.END, ""].join(lineEnding);
94
- return content + block;
95
- }
96
- function updateMergeBlock(originalContent, newBlockContent) {
97
- const lineEnding = detectLineEnding(originalContent);
98
- const extraction = extractMergeBlock(originalContent);
99
- if (extraction.malformed) {
100
- const warning = `LumenFlow markers are malformed (${extraction.malformedReason}). Appending fresh block.`;
101
- const result2 = insertMergeBlock(originalContent, newBlockContent);
102
- return {
103
- content: result2,
104
- updated: true,
105
- wasInserted: true,
106
- warning
107
- };
108
- }
109
- if (!extraction.found) {
110
- return {
111
- content: insertMergeBlock(originalContent, newBlockContent),
112
- updated: true,
113
- wasInserted: true
114
- };
115
- }
116
- const normalizedNew = normalizeLineEndings(newBlockContent, lineEnding).trim();
117
- const normalizedExisting = (extraction.content || "").trim();
118
- if (normalizedNew === normalizedExisting) {
119
- return {
120
- content: originalContent,
121
- updated: false,
122
- unchanged: true
123
- };
124
- }
125
- const startIdx = extraction.startIndex ?? 0;
126
- const endIdx = extraction.endIndex ?? originalContent.length;
127
- const before = originalContent.slice(0, startIdx);
128
- const after = originalContent.slice(endIdx);
129
- const newBlock = [
130
- MARKERS.START,
131
- normalizeLineEndings(newBlockContent, lineEnding),
132
- MARKERS.END
133
- ].join(lineEnding);
134
- let result = before;
135
- if (!result.endsWith(lineEnding) && result.length > 0) {
136
- result += lineEnding;
137
- }
138
- result += newBlock;
139
- if (after.trim().length > 0) {
140
- if (!result.endsWith(lineEnding)) {
141
- result += lineEnding;
142
- }
143
- result += after;
144
- } else if (after.includes(lineEnding)) {
145
- if (!result.endsWith(lineEnding)) {
146
- result += lineEnding;
147
- }
148
- }
149
- return {
150
- content: result,
151
- updated: true
152
- };
153
- }
154
- function trimNewlines(str) {
155
- let start = 0;
156
- let end = str.length;
157
- while (start < end && (str[start] === "\r" || str[start] === "\n")) {
158
- start++;
159
- }
160
- while (end > start && (str[end - 1] === "\r" || str[end - 1] === "\n")) {
161
- end--;
162
- }
163
- return str.slice(start, end);
164
- }
165
-
166
- // src/init-scaffolding.ts
167
- function processTemplate(content, tokens) {
168
- let output = content;
169
- for (const [key, value] of Object.entries(tokens)) {
170
- output = output.replace(new RegExp(`\\{\\{${key}\\}\\}`, "g"), value);
171
- }
172
- return output;
173
- }
174
- function getRelativePath(targetDir, filePath) {
175
- return path.relative(targetDir, filePath).split(path.sep).join("/");
176
- }
177
- function getTemplatesDir() {
178
- return resolveCliTemplatesDir();
179
- }
180
- function loadTemplate(templatePath) {
181
- const templatesDir = getTemplatesDir();
182
- const fullPath = path.join(templatesDir, templatePath);
183
- if (!fs.existsSync(fullPath)) {
184
- throw createError(ErrorCodes.FILE_NOT_FOUND, `Template not found: ${templatePath}`);
185
- }
186
- return fs.readFileSync(fullPath, "utf-8");
187
- }
188
- function resolveBooleanToFileMode(mode) {
189
- if (typeof mode === "boolean") {
190
- return mode ? "force" : "skip";
191
- }
192
- return mode;
193
- }
194
- function handleMergeMode(filePath, content, result, relativePath) {
195
- const existingContent = fs.readFileSync(filePath, "utf-8");
196
- const mergeResult = updateMergeBlock(existingContent, content);
197
- if (mergeResult.unchanged) {
198
- result.skipped.push(relativePath);
199
- return;
200
- }
201
- if (mergeResult.warning) {
202
- result.warnings?.push(`${relativePath}: ${mergeResult.warning}`);
203
- }
204
- fs.writeFileSync(filePath, mergeResult.content);
205
- result.merged?.push(relativePath);
206
- }
207
- function writeNewFile(filePath, content, result, relativePath) {
208
- const parentDir = path.dirname(filePath);
209
- if (!fs.existsSync(parentDir)) {
210
- fs.mkdirSync(parentDir, { recursive: true });
211
- }
212
- fs.writeFileSync(filePath, content);
213
- result.created.push(relativePath);
214
- }
215
- async function createDirectory(dirPath, result, targetDir) {
216
- if (!fs.existsSync(dirPath)) {
217
- fs.mkdirSync(dirPath, { recursive: true });
218
- result.created.push(getRelativePath(targetDir, dirPath));
219
- }
220
- }
221
- async function createFile(filePath, content, mode, result, targetDir) {
222
- const relativePath = getRelativePath(targetDir, filePath);
223
- const resolvedMode = resolveBooleanToFileMode(mode);
224
- result.merged = result.merged ?? [];
225
- result.warnings = result.warnings ?? [];
226
- result.overwritten = result.overwritten ?? [];
227
- const fileExists = fs.existsSync(filePath);
228
- if (fileExists && resolvedMode === "skip") {
229
- result.skipped.push(relativePath);
230
- return;
231
- }
232
- if (fileExists && resolvedMode === "merge") {
233
- handleMergeMode(filePath, content, result, relativePath);
234
- return;
235
- }
236
- if (fileExists && resolvedMode === "force") {
237
- result.overwritten.push(relativePath);
238
- }
239
- writeNewFile(filePath, content, result, relativePath);
240
- }
241
- async function createExecutableScript(filePath, content, mode, result, targetDir) {
242
- const relativePath = getRelativePath(targetDir, filePath);
243
- const resolvedMode = resolveBooleanToFileMode(mode);
244
- result.merged = result.merged ?? [];
245
- result.warnings = result.warnings ?? [];
246
- result.overwritten = result.overwritten ?? [];
247
- const fileExists = fs.existsSync(filePath);
248
- if (fileExists && resolvedMode === "skip") {
249
- result.skipped.push(relativePath);
250
- return;
251
- }
252
- if (fileExists && (resolvedMode === "force" || resolvedMode === "merge")) {
253
- result.overwritten.push(relativePath);
254
- }
255
- const parentDir = path.dirname(filePath);
256
- if (!fs.existsSync(parentDir)) {
257
- fs.mkdirSync(parentDir, { recursive: true });
258
- }
259
- fs.writeFileSync(filePath, content, { mode: 493 });
260
- result.created.push(relativePath);
261
- }
262
-
263
- export {
264
- processTemplate,
265
- loadTemplate,
266
- createDirectory,
267
- createFile,
268
- createExecutableScript
269
- };
@@ -1,9 +0,0 @@
1
- // src/object-guards.ts
2
- var TYPEOF_OBJECT = "object";
3
- function asRecord(value) {
4
- return value && typeof value === TYPEOF_OBJECT && !Array.isArray(value) ? value : null;
5
- }
6
-
7
- export {
8
- asRecord
9
- };