@lumenflow/cli 4.0.0 → 4.0.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 (119) hide show
  1. package/dist/wu-done-preflight.js +4 -3
  2. package/dist/wu-done-preflight.js.map +1 -1
  3. package/dist/wu-done.js +1 -1
  4. package/dist/wu-done.js.map +1 -1
  5. package/dist/wu-prep.js +13 -3
  6. package/dist/wu-prep.js.map +1 -1
  7. package/dist/wu-state-mutation-ownership.js +3 -1
  8. package/dist/wu-state-mutation-ownership.js.map +1 -1
  9. package/package.json +8 -8
  10. package/packs/agent-runtime/.turbo/turbo-build.log +1 -1
  11. package/packs/agent-runtime/package.json +1 -1
  12. package/packs/sidekick/.turbo/turbo-build.log +1 -1
  13. package/packs/sidekick/package.json +1 -1
  14. package/packs/software-delivery/.turbo/turbo-build.log +1 -1
  15. package/packs/software-delivery/package.json +1 -1
  16. package/dist/chunk-2D2VOCA4.js +0 -37
  17. package/dist/chunk-2D5KFYGX.js +0 -284
  18. package/dist/chunk-2GXVIN57.js +0 -14072
  19. package/dist/chunk-2MQ7HZWZ.js +0 -26
  20. package/dist/chunk-2UFQ3A3C.js +0 -643
  21. package/dist/chunk-3RG5ZIWI.js +0 -10
  22. package/dist/chunk-4N74J3UT.js +0 -15
  23. package/dist/chunk-5GTOXFYR.js +0 -392
  24. package/dist/chunk-5VY6MQMC.js +0 -240
  25. package/dist/chunk-67XVPMRY.js +0 -1297
  26. package/dist/chunk-6HO4GWJE.js +0 -164
  27. package/dist/chunk-6W5XHWYV.js +0 -1890
  28. package/dist/chunk-6X4EMYJQ.js +0 -64
  29. package/dist/chunk-6XYXI2NQ.js +0 -772
  30. package/dist/chunk-7ANSOV6Q.js +0 -285
  31. package/dist/chunk-A624LFLB.js +0 -1380
  32. package/dist/chunk-ADN5NHG4.js +0 -126
  33. package/dist/chunk-B7YJYJKG.js +0 -33
  34. package/dist/chunk-CCLHCPKG.js +0 -210
  35. package/dist/chunk-CK36VROC.js +0 -1584
  36. package/dist/chunk-D3UOFRSB.js +0 -81
  37. package/dist/chunk-DFR4DJBM.js +0 -230
  38. package/dist/chunk-DSYBDHYH.js +0 -79
  39. package/dist/chunk-DWMLTXKQ.js +0 -1176
  40. package/dist/chunk-E3REJTAJ.js +0 -28
  41. package/dist/chunk-EA3IVO64.js +0 -633
  42. package/dist/chunk-EK2AKZKD.js +0 -55
  43. package/dist/chunk-ELD7JTTT.js +0 -343
  44. package/dist/chunk-EX6TT2XI.js +0 -195
  45. package/dist/chunk-EXINSFZE.js +0 -82
  46. package/dist/chunk-EZ6ZBYBM.js +0 -510
  47. package/dist/chunk-FBKAPTJ2.js +0 -16
  48. package/dist/chunk-FVLV5RYH.js +0 -1118
  49. package/dist/chunk-GDNSBQVK.js +0 -2485
  50. package/dist/chunk-GPQHMBNN.js +0 -278
  51. package/dist/chunk-GTFJB67L.js +0 -68
  52. package/dist/chunk-HANJXVKW.js +0 -1127
  53. package/dist/chunk-HEVS5YLD.js +0 -269
  54. package/dist/chunk-HMEVZKPQ.js +0 -9
  55. package/dist/chunk-HRGSYNLM.js +0 -3511
  56. package/dist/chunk-ISZR5N4K.js +0 -60
  57. package/dist/chunk-J6SUPR2C.js +0 -226
  58. package/dist/chunk-JERYVEIZ.js +0 -244
  59. package/dist/chunk-JHHWGL2N.js +0 -87
  60. package/dist/chunk-JONWQUB5.js +0 -775
  61. package/dist/chunk-K2DIWWDM.js +0 -1766
  62. package/dist/chunk-KY4PGL5V.js +0 -969
  63. package/dist/chunk-L737LQ4C.js +0 -1285
  64. package/dist/chunk-LFTWYIB2.js +0 -497
  65. package/dist/chunk-LV47RFNJ.js +0 -41
  66. package/dist/chunk-MKSAITI7.js +0 -15
  67. package/dist/chunk-MZ7RKIX4.js +0 -212
  68. package/dist/chunk-NAP6CFSO.js +0 -84
  69. package/dist/chunk-ND6MY37M.js +0 -16
  70. package/dist/chunk-NMG736UR.js +0 -683
  71. package/dist/chunk-NRAXROED.js +0 -32
  72. package/dist/chunk-NRIZR3A7.js +0 -690
  73. package/dist/chunk-NX43BG3M.js +0 -233
  74. package/dist/chunk-O645XLSI.js +0 -297
  75. package/dist/chunk-OMJD6A3S.js +0 -235
  76. package/dist/chunk-QB6SJD4T.js +0 -430
  77. package/dist/chunk-QFSTL4J3.js +0 -276
  78. package/dist/chunk-QLGDFMFX.js +0 -212
  79. package/dist/chunk-RIAAGL2E.js +0 -13
  80. package/dist/chunk-RWO5XMZ6.js +0 -86
  81. package/dist/chunk-RXRKBBSM.js +0 -149
  82. package/dist/chunk-RZOZMML6.js +0 -363
  83. package/dist/chunk-U7I7FS7T.js +0 -113
  84. package/dist/chunk-UI42RODY.js +0 -717
  85. package/dist/chunk-UTVMVSCO.js +0 -519
  86. package/dist/chunk-V6OJGLBA.js +0 -1746
  87. package/dist/chunk-W2JHVH7D.js +0 -152
  88. package/dist/chunk-WD3Y7VQN.js +0 -280
  89. package/dist/chunk-WOCTQ5MS.js +0 -303
  90. package/dist/chunk-WZR3ZUNN.js +0 -696
  91. package/dist/chunk-XGI665H7.js +0 -150
  92. package/dist/chunk-XKY65P2T.js +0 -304
  93. package/dist/chunk-Y4CQZY65.js +0 -57
  94. package/dist/chunk-YFEXKLVE.js +0 -194
  95. package/dist/chunk-YHO3HS5X.js +0 -287
  96. package/dist/chunk-YLS7AZSX.js +0 -738
  97. package/dist/chunk-ZE473AO6.js +0 -49
  98. package/dist/chunk-ZF747T3O.js +0 -644
  99. package/dist/chunk-ZHCZHZH3.js +0 -43
  100. package/dist/chunk-ZZNZX2XY.js +0 -87
  101. package/dist/constants-7QAP3VQ4.js +0 -23
  102. package/dist/dist-IY3UUMWK.js +0 -33
  103. package/dist/invariants-runner-W5RGHCSU.js +0 -27
  104. package/dist/lane-lock-6J36HD5O.js +0 -35
  105. package/dist/mem-checkpoint-core-EANG2GVN.js +0 -14
  106. package/dist/mem-signal-core-2LZ2WYHW.js +0 -19
  107. package/dist/memory-store-OLB5FO7K.js +0 -18
  108. package/dist/service-6BYCOCO5.js +0 -13
  109. package/dist/spawn-policy-resolver-NTSZYQ6R.js +0 -17
  110. package/dist/spawn-task-builder-R4E2BHSW.js +0 -22
  111. package/dist/wu-done-pr-WLFFFEPJ.js +0 -25
  112. package/dist/wu-done-validation-3J5E36FE.js +0 -30
  113. package/dist/wu-duplicate-id-detector-5S7JHELK.js +0 -232
  114. package/packs/agent-runtime/.turbo/turbo-test.log +0 -21
  115. package/packs/agent-runtime/.turbo/turbo-typecheck.log +0 -4
  116. package/packs/sidekick/.turbo/turbo-test.log +0 -157
  117. package/packs/sidekick/.turbo/turbo-typecheck.log +0 -4
  118. package/packs/software-delivery/.turbo/turbo-test.log +0 -32
  119. package/packs/software-delivery/.turbo/turbo-typecheck.log +0 -4
@@ -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
- };