@ulpi/cli 0.1.5 → 0.1.7

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/README.md +143 -214
  2. package/dist/{auth-PN7TMQHV-2W4ICG64.js → auth-FWM7MM4Q-VZC3U2XZ.js} +1 -1
  3. package/dist/{auth-BFFBUJUC.js → auth-HDK7ECJL.js} +2 -1
  4. package/dist/{chunk-RJIRWQJD.js → chunk-3BCW6ABU.js} +402 -142
  5. package/dist/{chunk-L3PWNHSA.js → chunk-3WB5CXH4.js} +180 -5
  6. package/dist/{chunk-K4OVPFY2.js → chunk-4UCJIAOU.js} +2 -2
  7. package/dist/chunk-4XTHZVDS.js +109 -0
  8. package/dist/chunk-4ZPOZULQ.js +6522 -0
  9. package/dist/{chunk-SIAQVRKG.js → chunk-5MI5GIXM.js} +48 -2
  10. package/dist/{chunk-KLEASXUR.js → chunk-6ZL6NXMV.js} +1 -1
  11. package/dist/{chunk-AV5RB3N2.js → chunk-76D3BYJD.js} +48 -0
  12. package/dist/{chunk-DOIKS6C5.js → chunk-AWOSRA5F.js} +1 -1
  13. package/dist/{chunk-UCMT5OKP.js → chunk-BFEKZZHM.js} +274 -57
  14. package/dist/chunk-C7CLUQI6.js +1286 -0
  15. package/dist/{chunk-ELTGWMDE.js → chunk-E3B5NROU.js} +7 -7
  16. package/dist/chunk-EJ7TW77N.js +1418 -0
  17. package/dist/{chunk-P2RESJRN.js → chunk-EWLYVXQ4.js} +2 -2
  18. package/dist/{chunk-6OURRFP7.js → chunk-IV6MWETF.js} +383 -168
  19. package/dist/chunk-IZPJHSPX.js +1478 -0
  20. package/dist/chunk-JLHNLM3C.js +228 -0
  21. package/dist/chunk-PO4NUZUU.js +147 -0
  22. package/dist/chunk-S6ANCSYO.js +1271 -0
  23. package/dist/chunk-SEU7WWNQ.js +1251 -0
  24. package/dist/chunk-SNQ7NAIS.js +453 -0
  25. package/dist/{ulpi-RMMCUAGP-EWYUE7RU.js → chunk-TSLDGT5O.js} +73 -35
  26. package/dist/{chunk-EIWYSP3A.js → chunk-UXHCHOWQ.js} +83 -62
  27. package/dist/chunk-WED4LM5N.js +322 -0
  28. package/dist/chunk-WVOZE25N.js +6757 -0
  29. package/dist/{chunk-5SCG7UYM.js → chunk-XKF4DPUM.js} +7 -7
  30. package/dist/{chunk-74WVVWJ4.js → chunk-YOKL7RB5.js} +184 -15
  31. package/dist/chunk-Z53CAR7G.js +298 -0
  32. package/dist/{ci-JQ56YIKC.js → ci-COZRTPGQ.js} +124 -26
  33. package/dist/cloud-2F3NLVHN.js +274 -0
  34. package/dist/{codemap-HMYBXJL2.js → codemap-XNGMAF3F.js} +37 -37
  35. package/dist/codex-MB5YTMRT.js +132 -0
  36. package/dist/{config-YYWEN7U2.js → config-OOELBYTH.js} +1 -1
  37. package/dist/dist-2BJYR5EI.js +59 -0
  38. package/dist/dist-3EIQTZHT.js +1380 -0
  39. package/dist/{dist-WAMAQVPK.js → dist-4U5L2X2C.js} +2 -2
  40. package/dist/{dist-4XTJ6HLM.js → dist-54KAMNLO.js} +16 -15
  41. package/dist/dist-6M4MZWZW.js +58 -0
  42. package/dist/dist-6X576SU2.js +27 -0
  43. package/dist/dist-7QOEYLFX.js +103 -0
  44. package/dist/dist-AYBGHEDY.js +2541 -0
  45. package/dist/dist-EK45QNEM.js +45 -0
  46. package/dist/{dist-U7ZIJMZD.js → dist-FKFEJRPX.js} +16 -15
  47. package/dist/dist-GTEJUBBT.js +66 -0
  48. package/dist/dist-HA74OKJZ.js +40 -0
  49. package/dist/{dist-XG2GG5SD.js → dist-HU5RZAON.js} +14 -2
  50. package/dist/dist-IYE3OBRB.js +374 -0
  51. package/dist/{dist-7WLLPWWB.js → dist-JLU26AB6.js} +12 -9
  52. package/dist/{dist-6G7JC2RA.js → dist-KUCI6JFE.js} +49 -9
  53. package/dist/dist-NUEMFZFL.js +33 -0
  54. package/dist/{dist-GWGTAHNM.js → dist-NUXMDXZ3.js} +31 -3
  55. package/dist/{dist-5R4RYNQO.js → dist-YCNWHSLN.js} +15 -5
  56. package/dist/{dist-6MFVWIFF.js → dist-YFFG2ZD6.js} +9 -16
  57. package/dist/dist-ZG4OKCSR.js +15 -0
  58. package/dist/doctor-FKYSIHER.js +345 -0
  59. package/dist/{export-import-4A5MWLIA.js → export-import-JFQH4KSJ.js} +1 -1
  60. package/dist/{history-RNUWO4JZ.js → history-UMGQNQQ7.js} +7 -7
  61. package/dist/{hooks-installer-K2JXEBNN.js → hooks-installer-YEYTYA6Q.js} +2 -2
  62. package/dist/index.js +398 -622
  63. package/dist/{init-NQWFZPKO.js → init-TJYW5ROZ.js} +78 -12
  64. package/dist/job-HIDMAFW2.js +376 -0
  65. package/dist/jobs.memory-PLMMSFHB-VBECCTHN.js +33 -0
  66. package/dist/kiro-VMUHDFGK.js +153 -0
  67. package/dist/{launchd-OYXUAVW6.js → launchd-U3MSWBRH.js} +9 -17
  68. package/dist/mcp-PDUD7SGP.js +249 -0
  69. package/dist/mcp-installer-PQU3XOGO.js +259 -0
  70. package/dist/mcp-setup-OA7IB3H3.js +263 -0
  71. package/dist/{memory-D6ZFFCI2.js → memory-ZNAEAK3B.js} +17 -17
  72. package/dist/{ollama-3XCUZMZT-FYKHW4TZ.js → ollama-3XCUZMZT-4JMH6B7P.js} +1 -1
  73. package/dist/{openai-E7G2YAHU-IG33BFYF.js → openai-E7G2YAHU-T3HMBPH7.js} +2 -2
  74. package/dist/portal-JYWVHXDU.js +210 -0
  75. package/dist/prd-Q4J5NVAR.js +408 -0
  76. package/dist/repos-WWZXNN3P.js +271 -0
  77. package/dist/review-integration-RQE4KMAV.js +14 -0
  78. package/dist/{rules-3OFGWHP4.js → rules-Y4VSOY5Y.js} +3 -3
  79. package/dist/run-VPNXEIBY.js +687 -0
  80. package/dist/server-COL4AXKU-P7S7NNF6.js +11 -0
  81. package/dist/server-U7PQ6FTS-MG4MJPTS.js +20 -0
  82. package/dist/{skills-GY2CTPWN.js → skills-QEYU2N27.js} +4 -2
  83. package/dist/start-IJKY5RVT.js +303 -0
  84. package/dist/{status-SE43TIFJ.js → status-BHQYYGAL.js} +2 -2
  85. package/dist/{templates-O2XDKB5R.js → templates-CBRUJ66V.js} +6 -5
  86. package/dist/tui-DP7736EX.js +61 -0
  87. package/dist/ulpi-5EN6JCAS-LFE3WSL4.js +10 -0
  88. package/dist/{uninstall-KWGSGZTI.js → uninstall-BX6FOV77.js} +3 -3
  89. package/dist/{update-QYZA4D23.js → update-AQKTHFVQ.js} +3 -3
  90. package/dist/{version-checker-MVB74DEX.js → version-checker-5L5PUOEX.js} +2 -2
  91. package/package.json +13 -4
  92. package/dist/chunk-26LLDX2T.js +0 -553
  93. package/dist/chunk-DDRLI6JU.js +0 -331
  94. package/dist/chunk-IFATANHR.js +0 -453
  95. package/dist/chunk-JWUUVXIV.js +0 -13694
  96. package/dist/chunk-LD52XG3X.js +0 -4273
  97. package/dist/chunk-MIAQVCFW.js +0 -39
  98. package/dist/chunk-YYZOFYS6.js +0 -415
  99. package/dist/dist-XD4YI27T.js +0 -26
  100. package/dist/mcp-installer-TOYDP77X.js +0 -124
  101. package/dist/projects-COUJP4ZC.js +0 -271
  102. package/dist/review-KMGP2S25.js +0 -152
  103. package/dist/server-USLHY6GH-F4JSXCWA.js +0 -18
  104. package/dist/server-X5P6WH2M-ULZF5WHZ.js +0 -11
  105. package/dist/ui-4SM2SUI6.js +0 -167
  106. package/dist/ui.html +0 -698
  107. /package/dist/skills/{ulpi-generate-guardian → ulpi-generate-guards}/SKILL.md +0 -0
  108. /package/dist/skills/{ulpi-generate-guardian → ulpi-generate-guards}/references/framework-rules.md +0 -0
  109. /package/dist/skills/{ulpi-generate-guardian → ulpi-generate-guards}/references/language-rules.md +0 -0
@@ -0,0 +1,1286 @@
1
+ // ../../packages/config/dist/index.js
2
+ import { existsSync, readFileSync } from "fs";
3
+ import { homedir, userInfo } from "os";
4
+ import { join } from "path";
5
+ import { execFileSync } from "child_process";
6
+ import { existsSync as existsSync2, readFileSync as readFileSync2, writeFileSync, mkdirSync } from "fs";
7
+ import { dirname } from "path";
8
+ import { existsSync as existsSync3, readFileSync as readFileSync3, writeFileSync as writeFileSync2, mkdirSync as mkdirSync2 } from "fs";
9
+ import { dirname as dirname2 } from "path";
10
+
11
+ // ../../node_modules/.pnpm/smol-toml@1.6.0/node_modules/smol-toml/dist/error.js
12
+ function getLineColFromPtr(string, ptr) {
13
+ let lines = string.slice(0, ptr).split(/\r\n|\n|\r/g);
14
+ return [lines.length, lines.pop().length + 1];
15
+ }
16
+ function makeCodeBlock(string, line, column) {
17
+ let lines = string.split(/\r\n|\n|\r/g);
18
+ let codeblock = "";
19
+ let numberLen = (Math.log10(line + 1) | 0) + 1;
20
+ for (let i = line - 1; i <= line + 1; i++) {
21
+ let l = lines[i - 1];
22
+ if (!l)
23
+ continue;
24
+ codeblock += i.toString().padEnd(numberLen, " ");
25
+ codeblock += ": ";
26
+ codeblock += l;
27
+ codeblock += "\n";
28
+ if (i === line) {
29
+ codeblock += " ".repeat(numberLen + column + 2);
30
+ codeblock += "^\n";
31
+ }
32
+ }
33
+ return codeblock;
34
+ }
35
+ var TomlError = class extends Error {
36
+ line;
37
+ column;
38
+ codeblock;
39
+ constructor(message, options) {
40
+ const [line, column] = getLineColFromPtr(options.toml, options.ptr);
41
+ const codeblock = makeCodeBlock(options.toml, line, column);
42
+ super(`Invalid TOML document: ${message}
43
+
44
+ ${codeblock}`, options);
45
+ this.line = line;
46
+ this.column = column;
47
+ this.codeblock = codeblock;
48
+ }
49
+ };
50
+
51
+ // ../../node_modules/.pnpm/smol-toml@1.6.0/node_modules/smol-toml/dist/util.js
52
+ function isEscaped(str, ptr) {
53
+ let i = 0;
54
+ while (str[ptr - ++i] === "\\")
55
+ ;
56
+ return --i && i % 2;
57
+ }
58
+ function indexOfNewline(str, start = 0, end = str.length) {
59
+ let idx = str.indexOf("\n", start);
60
+ if (str[idx - 1] === "\r")
61
+ idx--;
62
+ return idx <= end ? idx : -1;
63
+ }
64
+ function skipComment(str, ptr) {
65
+ for (let i = ptr; i < str.length; i++) {
66
+ let c = str[i];
67
+ if (c === "\n")
68
+ return i;
69
+ if (c === "\r" && str[i + 1] === "\n")
70
+ return i + 1;
71
+ if (c < " " && c !== " " || c === "\x7F") {
72
+ throw new TomlError("control characters are not allowed in comments", {
73
+ toml: str,
74
+ ptr
75
+ });
76
+ }
77
+ }
78
+ return str.length;
79
+ }
80
+ function skipVoid(str, ptr, banNewLines, banComments) {
81
+ let c;
82
+ while ((c = str[ptr]) === " " || c === " " || !banNewLines && (c === "\n" || c === "\r" && str[ptr + 1] === "\n"))
83
+ ptr++;
84
+ return banComments || c !== "#" ? ptr : skipVoid(str, skipComment(str, ptr), banNewLines);
85
+ }
86
+ function skipUntil(str, ptr, sep, end, banNewLines = false) {
87
+ if (!end) {
88
+ ptr = indexOfNewline(str, ptr);
89
+ return ptr < 0 ? str.length : ptr;
90
+ }
91
+ for (let i = ptr; i < str.length; i++) {
92
+ let c = str[i];
93
+ if (c === "#") {
94
+ i = indexOfNewline(str, i);
95
+ } else if (c === sep) {
96
+ return i + 1;
97
+ } else if (c === end || banNewLines && (c === "\n" || c === "\r" && str[i + 1] === "\n")) {
98
+ return i;
99
+ }
100
+ }
101
+ throw new TomlError("cannot find end of structure", {
102
+ toml: str,
103
+ ptr
104
+ });
105
+ }
106
+ function getStringEnd(str, seek) {
107
+ let first = str[seek];
108
+ let target = first === str[seek + 1] && str[seek + 1] === str[seek + 2] ? str.slice(seek, seek + 3) : first;
109
+ seek += target.length - 1;
110
+ do
111
+ seek = str.indexOf(target, ++seek);
112
+ while (seek > -1 && first !== "'" && isEscaped(str, seek));
113
+ if (seek > -1) {
114
+ seek += target.length;
115
+ if (target.length > 1) {
116
+ if (str[seek] === first)
117
+ seek++;
118
+ if (str[seek] === first)
119
+ seek++;
120
+ }
121
+ }
122
+ return seek;
123
+ }
124
+
125
+ // ../../node_modules/.pnpm/smol-toml@1.6.0/node_modules/smol-toml/dist/date.js
126
+ var DATE_TIME_RE = /^(\d{4}-\d{2}-\d{2})?[T ]?(?:(\d{2}):\d{2}(?::\d{2}(?:\.\d+)?)?)?(Z|[-+]\d{2}:\d{2})?$/i;
127
+ var TomlDate = class _TomlDate extends Date {
128
+ #hasDate = false;
129
+ #hasTime = false;
130
+ #offset = null;
131
+ constructor(date) {
132
+ let hasDate = true;
133
+ let hasTime = true;
134
+ let offset = "Z";
135
+ if (typeof date === "string") {
136
+ let match = date.match(DATE_TIME_RE);
137
+ if (match) {
138
+ if (!match[1]) {
139
+ hasDate = false;
140
+ date = `0000-01-01T${date}`;
141
+ }
142
+ hasTime = !!match[2];
143
+ hasTime && date[10] === " " && (date = date.replace(" ", "T"));
144
+ if (match[2] && +match[2] > 23) {
145
+ date = "";
146
+ } else {
147
+ offset = match[3] || null;
148
+ date = date.toUpperCase();
149
+ if (!offset && hasTime)
150
+ date += "Z";
151
+ }
152
+ } else {
153
+ date = "";
154
+ }
155
+ }
156
+ super(date);
157
+ if (!isNaN(this.getTime())) {
158
+ this.#hasDate = hasDate;
159
+ this.#hasTime = hasTime;
160
+ this.#offset = offset;
161
+ }
162
+ }
163
+ isDateTime() {
164
+ return this.#hasDate && this.#hasTime;
165
+ }
166
+ isLocal() {
167
+ return !this.#hasDate || !this.#hasTime || !this.#offset;
168
+ }
169
+ isDate() {
170
+ return this.#hasDate && !this.#hasTime;
171
+ }
172
+ isTime() {
173
+ return this.#hasTime && !this.#hasDate;
174
+ }
175
+ isValid() {
176
+ return this.#hasDate || this.#hasTime;
177
+ }
178
+ toISOString() {
179
+ let iso = super.toISOString();
180
+ if (this.isDate())
181
+ return iso.slice(0, 10);
182
+ if (this.isTime())
183
+ return iso.slice(11, 23);
184
+ if (this.#offset === null)
185
+ return iso.slice(0, -1);
186
+ if (this.#offset === "Z")
187
+ return iso;
188
+ let offset = +this.#offset.slice(1, 3) * 60 + +this.#offset.slice(4, 6);
189
+ offset = this.#offset[0] === "-" ? offset : -offset;
190
+ let offsetDate = new Date(this.getTime() - offset * 6e4);
191
+ return offsetDate.toISOString().slice(0, -1) + this.#offset;
192
+ }
193
+ static wrapAsOffsetDateTime(jsDate, offset = "Z") {
194
+ let date = new _TomlDate(jsDate);
195
+ date.#offset = offset;
196
+ return date;
197
+ }
198
+ static wrapAsLocalDateTime(jsDate) {
199
+ let date = new _TomlDate(jsDate);
200
+ date.#offset = null;
201
+ return date;
202
+ }
203
+ static wrapAsLocalDate(jsDate) {
204
+ let date = new _TomlDate(jsDate);
205
+ date.#hasTime = false;
206
+ date.#offset = null;
207
+ return date;
208
+ }
209
+ static wrapAsLocalTime(jsDate) {
210
+ let date = new _TomlDate(jsDate);
211
+ date.#hasDate = false;
212
+ date.#offset = null;
213
+ return date;
214
+ }
215
+ };
216
+
217
+ // ../../node_modules/.pnpm/smol-toml@1.6.0/node_modules/smol-toml/dist/primitive.js
218
+ var INT_REGEX = /^((0x[0-9a-fA-F](_?[0-9a-fA-F])*)|(([+-]|0[ob])?\d(_?\d)*))$/;
219
+ var FLOAT_REGEX = /^[+-]?\d(_?\d)*(\.\d(_?\d)*)?([eE][+-]?\d(_?\d)*)?$/;
220
+ var LEADING_ZERO = /^[+-]?0[0-9_]/;
221
+ var ESCAPE_REGEX = /^[0-9a-f]{2,8}$/i;
222
+ var ESC_MAP = {
223
+ b: "\b",
224
+ t: " ",
225
+ n: "\n",
226
+ f: "\f",
227
+ r: "\r",
228
+ e: "\x1B",
229
+ '"': '"',
230
+ "\\": "\\"
231
+ };
232
+ function parseString(str, ptr = 0, endPtr = str.length) {
233
+ let isLiteral = str[ptr] === "'";
234
+ let isMultiline = str[ptr++] === str[ptr] && str[ptr] === str[ptr + 1];
235
+ if (isMultiline) {
236
+ endPtr -= 2;
237
+ if (str[ptr += 2] === "\r")
238
+ ptr++;
239
+ if (str[ptr] === "\n")
240
+ ptr++;
241
+ }
242
+ let tmp = 0;
243
+ let isEscape;
244
+ let parsed = "";
245
+ let sliceStart = ptr;
246
+ while (ptr < endPtr - 1) {
247
+ let c = str[ptr++];
248
+ if (c === "\n" || c === "\r" && str[ptr] === "\n") {
249
+ if (!isMultiline) {
250
+ throw new TomlError("newlines are not allowed in strings", {
251
+ toml: str,
252
+ ptr: ptr - 1
253
+ });
254
+ }
255
+ } else if (c < " " && c !== " " || c === "\x7F") {
256
+ throw new TomlError("control characters are not allowed in strings", {
257
+ toml: str,
258
+ ptr: ptr - 1
259
+ });
260
+ }
261
+ if (isEscape) {
262
+ isEscape = false;
263
+ if (c === "x" || c === "u" || c === "U") {
264
+ let code = str.slice(ptr, ptr += c === "x" ? 2 : c === "u" ? 4 : 8);
265
+ if (!ESCAPE_REGEX.test(code)) {
266
+ throw new TomlError("invalid unicode escape", {
267
+ toml: str,
268
+ ptr: tmp
269
+ });
270
+ }
271
+ try {
272
+ parsed += String.fromCodePoint(parseInt(code, 16));
273
+ } catch {
274
+ throw new TomlError("invalid unicode escape", {
275
+ toml: str,
276
+ ptr: tmp
277
+ });
278
+ }
279
+ } else if (isMultiline && (c === "\n" || c === " " || c === " " || c === "\r")) {
280
+ ptr = skipVoid(str, ptr - 1, true);
281
+ if (str[ptr] !== "\n" && str[ptr] !== "\r") {
282
+ throw new TomlError("invalid escape: only line-ending whitespace may be escaped", {
283
+ toml: str,
284
+ ptr: tmp
285
+ });
286
+ }
287
+ ptr = skipVoid(str, ptr);
288
+ } else if (c in ESC_MAP) {
289
+ parsed += ESC_MAP[c];
290
+ } else {
291
+ throw new TomlError("unrecognized escape sequence", {
292
+ toml: str,
293
+ ptr: tmp
294
+ });
295
+ }
296
+ sliceStart = ptr;
297
+ } else if (!isLiteral && c === "\\") {
298
+ tmp = ptr - 1;
299
+ isEscape = true;
300
+ parsed += str.slice(sliceStart, tmp);
301
+ }
302
+ }
303
+ return parsed + str.slice(sliceStart, endPtr - 1);
304
+ }
305
+ function parseValue(value, toml, ptr, integersAsBigInt) {
306
+ if (value === "true")
307
+ return true;
308
+ if (value === "false")
309
+ return false;
310
+ if (value === "-inf")
311
+ return -Infinity;
312
+ if (value === "inf" || value === "+inf")
313
+ return Infinity;
314
+ if (value === "nan" || value === "+nan" || value === "-nan")
315
+ return NaN;
316
+ if (value === "-0")
317
+ return integersAsBigInt ? 0n : 0;
318
+ let isInt = INT_REGEX.test(value);
319
+ if (isInt || FLOAT_REGEX.test(value)) {
320
+ if (LEADING_ZERO.test(value)) {
321
+ throw new TomlError("leading zeroes are not allowed", {
322
+ toml,
323
+ ptr
324
+ });
325
+ }
326
+ value = value.replace(/_/g, "");
327
+ let numeric = +value;
328
+ if (isNaN(numeric)) {
329
+ throw new TomlError("invalid number", {
330
+ toml,
331
+ ptr
332
+ });
333
+ }
334
+ if (isInt) {
335
+ if ((isInt = !Number.isSafeInteger(numeric)) && !integersAsBigInt) {
336
+ throw new TomlError("integer value cannot be represented losslessly", {
337
+ toml,
338
+ ptr
339
+ });
340
+ }
341
+ if (isInt || integersAsBigInt === true)
342
+ numeric = BigInt(value);
343
+ }
344
+ return numeric;
345
+ }
346
+ const date = new TomlDate(value);
347
+ if (!date.isValid()) {
348
+ throw new TomlError("invalid value", {
349
+ toml,
350
+ ptr
351
+ });
352
+ }
353
+ return date;
354
+ }
355
+
356
+ // ../../node_modules/.pnpm/smol-toml@1.6.0/node_modules/smol-toml/dist/extract.js
357
+ function sliceAndTrimEndOf(str, startPtr, endPtr) {
358
+ let value = str.slice(startPtr, endPtr);
359
+ let commentIdx = value.indexOf("#");
360
+ if (commentIdx > -1) {
361
+ skipComment(str, commentIdx);
362
+ value = value.slice(0, commentIdx);
363
+ }
364
+ return [value.trimEnd(), commentIdx];
365
+ }
366
+ function extractValue(str, ptr, end, depth, integersAsBigInt) {
367
+ if (depth === 0) {
368
+ throw new TomlError("document contains excessively nested structures. aborting.", {
369
+ toml: str,
370
+ ptr
371
+ });
372
+ }
373
+ let c = str[ptr];
374
+ if (c === "[" || c === "{") {
375
+ let [value, endPtr2] = c === "[" ? parseArray(str, ptr, depth, integersAsBigInt) : parseInlineTable(str, ptr, depth, integersAsBigInt);
376
+ if (end) {
377
+ endPtr2 = skipVoid(str, endPtr2);
378
+ if (str[endPtr2] === ",")
379
+ endPtr2++;
380
+ else if (str[endPtr2] !== end) {
381
+ throw new TomlError("expected comma or end of structure", {
382
+ toml: str,
383
+ ptr: endPtr2
384
+ });
385
+ }
386
+ }
387
+ return [value, endPtr2];
388
+ }
389
+ let endPtr;
390
+ if (c === '"' || c === "'") {
391
+ endPtr = getStringEnd(str, ptr);
392
+ let parsed = parseString(str, ptr, endPtr);
393
+ if (end) {
394
+ endPtr = skipVoid(str, endPtr);
395
+ if (str[endPtr] && str[endPtr] !== "," && str[endPtr] !== end && str[endPtr] !== "\n" && str[endPtr] !== "\r") {
396
+ throw new TomlError("unexpected character encountered", {
397
+ toml: str,
398
+ ptr: endPtr
399
+ });
400
+ }
401
+ endPtr += +(str[endPtr] === ",");
402
+ }
403
+ return [parsed, endPtr];
404
+ }
405
+ endPtr = skipUntil(str, ptr, ",", end);
406
+ let slice = sliceAndTrimEndOf(str, ptr, endPtr - +(str[endPtr - 1] === ","));
407
+ if (!slice[0]) {
408
+ throw new TomlError("incomplete key-value declaration: no value specified", {
409
+ toml: str,
410
+ ptr
411
+ });
412
+ }
413
+ if (end && slice[1] > -1) {
414
+ endPtr = skipVoid(str, ptr + slice[1]);
415
+ endPtr += +(str[endPtr] === ",");
416
+ }
417
+ return [
418
+ parseValue(slice[0], str, ptr, integersAsBigInt),
419
+ endPtr
420
+ ];
421
+ }
422
+
423
+ // ../../node_modules/.pnpm/smol-toml@1.6.0/node_modules/smol-toml/dist/struct.js
424
+ var KEY_PART_RE = /^[a-zA-Z0-9-_]+[ \t]*$/;
425
+ function parseKey(str, ptr, end = "=") {
426
+ let dot = ptr - 1;
427
+ let parsed = [];
428
+ let endPtr = str.indexOf(end, ptr);
429
+ if (endPtr < 0) {
430
+ throw new TomlError("incomplete key-value: cannot find end of key", {
431
+ toml: str,
432
+ ptr
433
+ });
434
+ }
435
+ do {
436
+ let c = str[ptr = ++dot];
437
+ if (c !== " " && c !== " ") {
438
+ if (c === '"' || c === "'") {
439
+ if (c === str[ptr + 1] && c === str[ptr + 2]) {
440
+ throw new TomlError("multiline strings are not allowed in keys", {
441
+ toml: str,
442
+ ptr
443
+ });
444
+ }
445
+ let eos = getStringEnd(str, ptr);
446
+ if (eos < 0) {
447
+ throw new TomlError("unfinished string encountered", {
448
+ toml: str,
449
+ ptr
450
+ });
451
+ }
452
+ dot = str.indexOf(".", eos);
453
+ let strEnd = str.slice(eos, dot < 0 || dot > endPtr ? endPtr : dot);
454
+ let newLine = indexOfNewline(strEnd);
455
+ if (newLine > -1) {
456
+ throw new TomlError("newlines are not allowed in keys", {
457
+ toml: str,
458
+ ptr: ptr + dot + newLine
459
+ });
460
+ }
461
+ if (strEnd.trimStart()) {
462
+ throw new TomlError("found extra tokens after the string part", {
463
+ toml: str,
464
+ ptr: eos
465
+ });
466
+ }
467
+ if (endPtr < eos) {
468
+ endPtr = str.indexOf(end, eos);
469
+ if (endPtr < 0) {
470
+ throw new TomlError("incomplete key-value: cannot find end of key", {
471
+ toml: str,
472
+ ptr
473
+ });
474
+ }
475
+ }
476
+ parsed.push(parseString(str, ptr, eos));
477
+ } else {
478
+ dot = str.indexOf(".", ptr);
479
+ let part = str.slice(ptr, dot < 0 || dot > endPtr ? endPtr : dot);
480
+ if (!KEY_PART_RE.test(part)) {
481
+ throw new TomlError("only letter, numbers, dashes and underscores are allowed in keys", {
482
+ toml: str,
483
+ ptr
484
+ });
485
+ }
486
+ parsed.push(part.trimEnd());
487
+ }
488
+ }
489
+ } while (dot + 1 && dot < endPtr);
490
+ return [parsed, skipVoid(str, endPtr + 1, true, true)];
491
+ }
492
+ function parseInlineTable(str, ptr, depth, integersAsBigInt) {
493
+ let res = {};
494
+ let seen = /* @__PURE__ */ new Set();
495
+ let c;
496
+ ptr++;
497
+ while ((c = str[ptr++]) !== "}" && c) {
498
+ if (c === ",") {
499
+ throw new TomlError("expected value, found comma", {
500
+ toml: str,
501
+ ptr: ptr - 1
502
+ });
503
+ } else if (c === "#")
504
+ ptr = skipComment(str, ptr);
505
+ else if (c !== " " && c !== " " && c !== "\n" && c !== "\r") {
506
+ let k;
507
+ let t = res;
508
+ let hasOwn = false;
509
+ let [key, keyEndPtr] = parseKey(str, ptr - 1);
510
+ for (let i = 0; i < key.length; i++) {
511
+ if (i)
512
+ t = hasOwn ? t[k] : t[k] = {};
513
+ k = key[i];
514
+ if ((hasOwn = Object.hasOwn(t, k)) && (typeof t[k] !== "object" || seen.has(t[k]))) {
515
+ throw new TomlError("trying to redefine an already defined value", {
516
+ toml: str,
517
+ ptr
518
+ });
519
+ }
520
+ if (!hasOwn && k === "__proto__") {
521
+ Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });
522
+ }
523
+ }
524
+ if (hasOwn) {
525
+ throw new TomlError("trying to redefine an already defined value", {
526
+ toml: str,
527
+ ptr
528
+ });
529
+ }
530
+ let [value, valueEndPtr] = extractValue(str, keyEndPtr, "}", depth - 1, integersAsBigInt);
531
+ seen.add(value);
532
+ t[k] = value;
533
+ ptr = valueEndPtr;
534
+ }
535
+ }
536
+ if (!c) {
537
+ throw new TomlError("unfinished table encountered", {
538
+ toml: str,
539
+ ptr
540
+ });
541
+ }
542
+ return [res, ptr];
543
+ }
544
+ function parseArray(str, ptr, depth, integersAsBigInt) {
545
+ let res = [];
546
+ let c;
547
+ ptr++;
548
+ while ((c = str[ptr++]) !== "]" && c) {
549
+ if (c === ",") {
550
+ throw new TomlError("expected value, found comma", {
551
+ toml: str,
552
+ ptr: ptr - 1
553
+ });
554
+ } else if (c === "#")
555
+ ptr = skipComment(str, ptr);
556
+ else if (c !== " " && c !== " " && c !== "\n" && c !== "\r") {
557
+ let e = extractValue(str, ptr - 1, "]", depth - 1, integersAsBigInt);
558
+ res.push(e[0]);
559
+ ptr = e[1];
560
+ }
561
+ }
562
+ if (!c) {
563
+ throw new TomlError("unfinished array encountered", {
564
+ toml: str,
565
+ ptr
566
+ });
567
+ }
568
+ return [res, ptr];
569
+ }
570
+
571
+ // ../../node_modules/.pnpm/smol-toml@1.6.0/node_modules/smol-toml/dist/parse.js
572
+ function peekTable(key, table, meta, type) {
573
+ let t = table;
574
+ let m = meta;
575
+ let k;
576
+ let hasOwn = false;
577
+ let state;
578
+ for (let i = 0; i < key.length; i++) {
579
+ if (i) {
580
+ t = hasOwn ? t[k] : t[k] = {};
581
+ m = (state = m[k]).c;
582
+ if (type === 0 && (state.t === 1 || state.t === 2)) {
583
+ return null;
584
+ }
585
+ if (state.t === 2) {
586
+ let l = t.length - 1;
587
+ t = t[l];
588
+ m = m[l].c;
589
+ }
590
+ }
591
+ k = key[i];
592
+ if ((hasOwn = Object.hasOwn(t, k)) && m[k]?.t === 0 && m[k]?.d) {
593
+ return null;
594
+ }
595
+ if (!hasOwn) {
596
+ if (k === "__proto__") {
597
+ Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });
598
+ Object.defineProperty(m, k, { enumerable: true, configurable: true, writable: true });
599
+ }
600
+ m[k] = {
601
+ t: i < key.length - 1 && type === 2 ? 3 : type,
602
+ d: false,
603
+ i: 0,
604
+ c: {}
605
+ };
606
+ }
607
+ }
608
+ state = m[k];
609
+ if (state.t !== type && !(type === 1 && state.t === 3)) {
610
+ return null;
611
+ }
612
+ if (type === 2) {
613
+ if (!state.d) {
614
+ state.d = true;
615
+ t[k] = [];
616
+ }
617
+ t[k].push(t = {});
618
+ state.c[state.i++] = state = { t: 1, d: false, i: 0, c: {} };
619
+ }
620
+ if (state.d) {
621
+ return null;
622
+ }
623
+ state.d = true;
624
+ if (type === 1) {
625
+ t = hasOwn ? t[k] : t[k] = {};
626
+ } else if (type === 0 && hasOwn) {
627
+ return null;
628
+ }
629
+ return [k, t, state.c];
630
+ }
631
+ function parse(toml, { maxDepth = 1e3, integersAsBigInt } = {}) {
632
+ let res = {};
633
+ let meta = {};
634
+ let tbl = res;
635
+ let m = meta;
636
+ for (let ptr = skipVoid(toml, 0); ptr < toml.length; ) {
637
+ if (toml[ptr] === "[") {
638
+ let isTableArray = toml[++ptr] === "[";
639
+ let k = parseKey(toml, ptr += +isTableArray, "]");
640
+ if (isTableArray) {
641
+ if (toml[k[1] - 1] !== "]") {
642
+ throw new TomlError("expected end of table declaration", {
643
+ toml,
644
+ ptr: k[1] - 1
645
+ });
646
+ }
647
+ k[1]++;
648
+ }
649
+ let p = peekTable(
650
+ k[0],
651
+ res,
652
+ meta,
653
+ isTableArray ? 2 : 1
654
+ /* Type.EXPLICIT */
655
+ );
656
+ if (!p) {
657
+ throw new TomlError("trying to redefine an already defined table or value", {
658
+ toml,
659
+ ptr
660
+ });
661
+ }
662
+ m = p[2];
663
+ tbl = p[1];
664
+ ptr = k[1];
665
+ } else {
666
+ let k = parseKey(toml, ptr);
667
+ let p = peekTable(
668
+ k[0],
669
+ tbl,
670
+ m,
671
+ 0
672
+ /* Type.DOTTED */
673
+ );
674
+ if (!p) {
675
+ throw new TomlError("trying to redefine an already defined table or value", {
676
+ toml,
677
+ ptr
678
+ });
679
+ }
680
+ let v = extractValue(toml, k[1], void 0, maxDepth, integersAsBigInt);
681
+ p[1][p[0]] = v[0];
682
+ ptr = v[1];
683
+ }
684
+ ptr = skipVoid(toml, ptr, true);
685
+ if (toml[ptr] && toml[ptr] !== "\n" && toml[ptr] !== "\r") {
686
+ throw new TomlError("each key-value declaration must be followed by an end-of-line", {
687
+ toml,
688
+ ptr
689
+ });
690
+ }
691
+ ptr = skipVoid(toml, ptr);
692
+ }
693
+ return res;
694
+ }
695
+
696
+ // ../../node_modules/.pnpm/smol-toml@1.6.0/node_modules/smol-toml/dist/stringify.js
697
+ var BARE_KEY = /^[a-z0-9-_]+$/i;
698
+ function extendedTypeOf(obj) {
699
+ let type = typeof obj;
700
+ if (type === "object") {
701
+ if (Array.isArray(obj))
702
+ return "array";
703
+ if (obj instanceof Date)
704
+ return "date";
705
+ }
706
+ return type;
707
+ }
708
+ function isArrayOfTables(obj) {
709
+ for (let i = 0; i < obj.length; i++) {
710
+ if (extendedTypeOf(obj[i]) !== "object")
711
+ return false;
712
+ }
713
+ return obj.length != 0;
714
+ }
715
+ function formatString(s) {
716
+ return JSON.stringify(s).replace(/\x7f/g, "\\u007f");
717
+ }
718
+ function stringifyValue(val, type, depth, numberAsFloat) {
719
+ if (depth === 0) {
720
+ throw new Error("Could not stringify the object: maximum object depth exceeded");
721
+ }
722
+ if (type === "number") {
723
+ if (isNaN(val))
724
+ return "nan";
725
+ if (val === Infinity)
726
+ return "inf";
727
+ if (val === -Infinity)
728
+ return "-inf";
729
+ if (numberAsFloat && Number.isInteger(val))
730
+ return val.toFixed(1);
731
+ return val.toString();
732
+ }
733
+ if (type === "bigint" || type === "boolean") {
734
+ return val.toString();
735
+ }
736
+ if (type === "string") {
737
+ return formatString(val);
738
+ }
739
+ if (type === "date") {
740
+ if (isNaN(val.getTime())) {
741
+ throw new TypeError("cannot serialize invalid date");
742
+ }
743
+ return val.toISOString();
744
+ }
745
+ if (type === "object") {
746
+ return stringifyInlineTable(val, depth, numberAsFloat);
747
+ }
748
+ if (type === "array") {
749
+ return stringifyArray(val, depth, numberAsFloat);
750
+ }
751
+ }
752
+ function stringifyInlineTable(obj, depth, numberAsFloat) {
753
+ let keys = Object.keys(obj);
754
+ if (keys.length === 0)
755
+ return "{}";
756
+ let res = "{ ";
757
+ for (let i = 0; i < keys.length; i++) {
758
+ let k = keys[i];
759
+ if (i)
760
+ res += ", ";
761
+ res += BARE_KEY.test(k) ? k : formatString(k);
762
+ res += " = ";
763
+ res += stringifyValue(obj[k], extendedTypeOf(obj[k]), depth - 1, numberAsFloat);
764
+ }
765
+ return res + " }";
766
+ }
767
+ function stringifyArray(array, depth, numberAsFloat) {
768
+ if (array.length === 0)
769
+ return "[]";
770
+ let res = "[ ";
771
+ for (let i = 0; i < array.length; i++) {
772
+ if (i)
773
+ res += ", ";
774
+ if (array[i] === null || array[i] === void 0) {
775
+ throw new TypeError("arrays cannot contain null or undefined values");
776
+ }
777
+ res += stringifyValue(array[i], extendedTypeOf(array[i]), depth - 1, numberAsFloat);
778
+ }
779
+ return res + " ]";
780
+ }
781
+ function stringifyArrayTable(array, key, depth, numberAsFloat) {
782
+ if (depth === 0) {
783
+ throw new Error("Could not stringify the object: maximum object depth exceeded");
784
+ }
785
+ let res = "";
786
+ for (let i = 0; i < array.length; i++) {
787
+ res += `${res && "\n"}[[${key}]]
788
+ `;
789
+ res += stringifyTable(0, array[i], key, depth, numberAsFloat);
790
+ }
791
+ return res;
792
+ }
793
+ function stringifyTable(tableKey, obj, prefix, depth, numberAsFloat) {
794
+ if (depth === 0) {
795
+ throw new Error("Could not stringify the object: maximum object depth exceeded");
796
+ }
797
+ let preamble = "";
798
+ let tables = "";
799
+ let keys = Object.keys(obj);
800
+ for (let i = 0; i < keys.length; i++) {
801
+ let k = keys[i];
802
+ if (obj[k] !== null && obj[k] !== void 0) {
803
+ let type = extendedTypeOf(obj[k]);
804
+ if (type === "symbol" || type === "function") {
805
+ throw new TypeError(`cannot serialize values of type '${type}'`);
806
+ }
807
+ let key = BARE_KEY.test(k) ? k : formatString(k);
808
+ if (type === "array" && isArrayOfTables(obj[k])) {
809
+ tables += (tables && "\n") + stringifyArrayTable(obj[k], prefix ? `${prefix}.${key}` : key, depth - 1, numberAsFloat);
810
+ } else if (type === "object") {
811
+ let tblKey = prefix ? `${prefix}.${key}` : key;
812
+ tables += (tables && "\n") + stringifyTable(tblKey, obj[k], tblKey, depth - 1, numberAsFloat);
813
+ } else {
814
+ preamble += key;
815
+ preamble += " = ";
816
+ preamble += stringifyValue(obj[k], type, depth, numberAsFloat);
817
+ preamble += "\n";
818
+ }
819
+ }
820
+ }
821
+ if (tableKey && (preamble || !tables))
822
+ preamble = preamble ? `[${tableKey}]
823
+ ${preamble}` : `[${tableKey}]`;
824
+ return preamble && tables ? `${preamble}
825
+ ${tables}` : preamble || tables;
826
+ }
827
+ function stringify(obj, { maxDepth = 1e3, numbersAsFloat = false } = {}) {
828
+ if (extendedTypeOf(obj) !== "object") {
829
+ throw new TypeError("stringify can only be called with an object");
830
+ }
831
+ let str = stringifyTable(0, obj, "", maxDepth, numbersAsFloat);
832
+ if (str[str.length - 1] !== "\n")
833
+ return str + "\n";
834
+ return str;
835
+ }
836
+
837
+ // ../../packages/config/dist/index.js
838
+ import * as fs from "fs";
839
+ import * as path from "path";
840
+ var ULPI_GLOBAL_DIR = process.env.ULPI_GLOBAL_DIR || join(homedir(), ".ulpi");
841
+ var ULPI_PROJECT_DIR = ".ulpi";
842
+ var GUARDS_FILENAME = "guards.yml";
843
+ var GUARDS_FILENAME_ALT = "guards.yaml";
844
+ var SESSIONS_DIR = join(ULPI_GLOBAL_DIR, "sessions");
845
+ var REVIEWS_DIR = join(ULPI_GLOBAL_DIR, "reviews");
846
+ var REVIEW_FLAGS_DIR = join(ULPI_GLOBAL_DIR, "review-flags");
847
+ var REVIEW_IMAGES_DIR = join(ULPI_GLOBAL_DIR, "review-images");
848
+ var REPOS_FILE = join(ULPI_GLOBAL_DIR, "repos.json");
849
+ var USER_TEMPLATES_DIR = join(ULPI_GLOBAL_DIR, "templates");
850
+ var USER_SKILLS_DIR = join(ULPI_GLOBAL_DIR, "skills");
851
+ var VERSION_CACHE_FILE = join(ULPI_GLOBAL_DIR, ".version-cache.json");
852
+ var SETTINGS_FILE = join(ULPI_GLOBAL_DIR, "settings.json");
853
+ var ULPI_CONFIG_FILE = join(ULPI_GLOBAL_DIR, "config.toml");
854
+ var LOGS_DIR = join(ULPI_GLOBAL_DIR, "logs");
855
+ var NOTIFICATIONS_LOG_FILE = join(ULPI_GLOBAL_DIR, "notifications.log");
856
+ var API_LOCK_FILE = join(ULPI_GLOBAL_DIR, "api.lock");
857
+ var HISTORY_BRANCH_PREFIX = "ulpi/history";
858
+ var CODEMAP_DIR_NAME = "codemap";
859
+ var CODEMAP_DIR = join(ULPI_GLOBAL_DIR, CODEMAP_DIR_NAME);
860
+ var CODEMAP_BRANCH_PREFIX = "ulpi/codemap";
861
+ function branchToSlug(branch) {
862
+ const slug = branch.replace(/\//g, "--").replace(/\.\./g, "__").replace(/[^a-zA-Z0-9_\-]/g, "-").replace(/-{3,}/g, "--").replace(/^-|-$/g, "").toLowerCase();
863
+ return slug || "main";
864
+ }
865
+ function codemapProjectSlug(dir) {
866
+ const slug = dir.replace(/^\//, "").replace(/\//g, "-").replace(/\./g, "_").replace(/-{2,}/g, "-").replace(/^-|-$/g, "").toLowerCase();
867
+ return slug || "unknown-project";
868
+ }
869
+ function getCurrentBranch(projectDir) {
870
+ try {
871
+ const branch = execFileSync("git", ["rev-parse", "--abbrev-ref", "HEAD"], {
872
+ cwd: requireProjectDir(projectDir),
873
+ encoding: "utf-8",
874
+ timeout: 5e3,
875
+ stdio: ["pipe", "pipe", "pipe"]
876
+ }).trim();
877
+ if (branch && branch !== "HEAD") return branch;
878
+ } catch {
879
+ }
880
+ return "main";
881
+ }
882
+ function projectCodemapDir(projectDir) {
883
+ return join(CODEMAP_DIR, codemapProjectSlug(requireProjectDir(projectDir)));
884
+ }
885
+ function codemapBranchDir(projectDir, branch) {
886
+ return join(projectCodemapDir(projectDir), branchToSlug(branch));
887
+ }
888
+ function resolveUsername() {
889
+ try {
890
+ if (existsSync(SETTINGS_FILE)) {
891
+ const raw = JSON.parse(readFileSync(SETTINGS_FILE, "utf-8"));
892
+ if (typeof raw.username === "string" && raw.username) {
893
+ return raw.username.toLowerCase();
894
+ }
895
+ }
896
+ } catch {
897
+ }
898
+ try {
899
+ const login = execFileSync("gh", ["api", "user", "--jq", ".login"], {
900
+ encoding: "utf-8",
901
+ timeout: 5e3,
902
+ stdio: ["pipe", "pipe", "pipe"]
903
+ }).trim();
904
+ if (login) return login.toLowerCase();
905
+ } catch {
906
+ }
907
+ return userInfo().username.toLowerCase();
908
+ }
909
+ function getCodemapBranch(branch) {
910
+ return `${CODEMAP_BRANCH_PREFIX}-${branchToSlug(branch)}`;
911
+ }
912
+ function getHistoryBranch() {
913
+ return `${HISTORY_BRANCH_PREFIX}-${resolveUsername()}`;
914
+ }
915
+ function codemapConfigFile(projectDir) {
916
+ return join(projectCodemapDir(projectDir), "config.json");
917
+ }
918
+ function codemapManifestFile(projectDir, branch) {
919
+ return join(codemapBranchDir(projectDir, branch), "manifest.json");
920
+ }
921
+ function codemapSchemaFile(projectDir, branch) {
922
+ return join(codemapBranchDir(projectDir, branch), "schema.json");
923
+ }
924
+ function codemapStatsFile(projectDir, branch) {
925
+ return join(codemapBranchDir(projectDir, branch), "stats.json");
926
+ }
927
+ function codemapLanceDir(projectDir, branch) {
928
+ return join(codemapBranchDir(projectDir, branch), "index", "lance");
929
+ }
930
+ function codemapMetadataDir(projectDir, branch) {
931
+ return join(codemapBranchDir(projectDir, branch), "index", "metadata");
932
+ }
933
+ function depgraphDir(projectDir, branch) {
934
+ return join(codemapBranchDir(projectDir, branch), "index", "metadata", "depgraph");
935
+ }
936
+ function depgraphGraphFile(projectDir, branch) {
937
+ return join(depgraphDir(projectDir, branch), "graph.json");
938
+ }
939
+ function depgraphPagerankFile(projectDir, branch) {
940
+ return join(depgraphDir(projectDir, branch), "pagerank.json");
941
+ }
942
+ function depgraphMetricsFile(projectDir, branch) {
943
+ return join(depgraphDir(projectDir, branch), "metrics.json");
944
+ }
945
+ function depgraphCacheFile(projectDir, branch) {
946
+ return join(depgraphDir(projectDir, branch), "tags-cache.json");
947
+ }
948
+ var MEMORY_DIR = join(ULPI_GLOBAL_DIR, "memory");
949
+ var MEMORY_BRANCH_PREFIX = "ulpi/memory";
950
+ function memoryProjectSlug(dir) {
951
+ const slug = dir.replace(/^\//, "").replace(/\//g, "-").replace(/\./g, "_").replace(/-{2,}/g, "-").replace(/^-|-$/g, "").toLowerCase();
952
+ return slug || "unknown-project";
953
+ }
954
+ function getMemoryBranch() {
955
+ return `${MEMORY_BRANCH_PREFIX}-${resolveUsername()}`;
956
+ }
957
+ function projectMemoryDir(projectDir) {
958
+ return join(MEMORY_DIR, memoryProjectSlug(requireProjectDir(projectDir)));
959
+ }
960
+ function memoryConfigFile(projectDir) {
961
+ return join(projectMemoryDir(projectDir), "config.json");
962
+ }
963
+ function memoryIndexDir(projectDir) {
964
+ return join(projectMemoryDir(projectDir), "index");
965
+ }
966
+ function memoryLanceDir(projectDir) {
967
+ return join(projectMemoryDir(projectDir), "index", "lance");
968
+ }
969
+ function memoryEntriesDir(projectDir) {
970
+ return join(projectMemoryDir(projectDir), "entries");
971
+ }
972
+ function memoryHistoryDir(projectDir) {
973
+ return join(projectMemoryDir(projectDir), "history");
974
+ }
975
+ function memoryWatermarksDir(projectDir) {
976
+ return join(projectMemoryDir(projectDir), "watermarks");
977
+ }
978
+ function memoryStatsFile(projectDir) {
979
+ return join(projectMemoryDir(projectDir), "stats.json");
980
+ }
981
+ function memoryPromptsDir(projectDir) {
982
+ return join(projectMemoryDir(projectDir), "prompts");
983
+ }
984
+ var MCPS_LIBRARY_FILE = join(ULPI_GLOBAL_DIR, "mcps.yml");
985
+ var MCPS_FILENAME = "mcps.yml";
986
+ function projectMcpsFile(projectDir) {
987
+ return join(requireProjectDir(projectDir), ULPI_PROJECT_DIR, MCPS_FILENAME);
988
+ }
989
+ var JOBS_DIR = join(ULPI_GLOBAL_DIR, "jobs");
990
+ function jobFile(jobId) {
991
+ return join(JOBS_DIR, `${jobId}.json`);
992
+ }
993
+ var CLI_BIN_NAME = "ulpi";
994
+ function getBinaryPath() {
995
+ return CLI_BIN_NAME;
996
+ }
997
+ var CLI_NPM_PACKAGE = "@ulpi/cli";
998
+ var CLI_REGISTRY_URL = `https://registry.npmjs.org/${CLI_NPM_PACKAGE}/latest`;
999
+ var NO_AUTO_GEN_FILE = ".no-auto-gen";
1000
+ var LAUNCHD_LABEL = "com.ulpi.ui";
1001
+ function requireProjectDir(projectDir) {
1002
+ if (!projectDir || !projectDir.trim()) {
1003
+ throw new Error("projectDir must be a non-empty string");
1004
+ }
1005
+ return projectDir;
1006
+ }
1007
+ function projectConfigDir(projectDir) {
1008
+ return join(requireProjectDir(projectDir), ULPI_PROJECT_DIR);
1009
+ }
1010
+ function projectGuardsFile(projectDir) {
1011
+ return join(requireProjectDir(projectDir), ULPI_PROJECT_DIR, GUARDS_FILENAME);
1012
+ }
1013
+ function projectGuardsFileAlt(projectDir) {
1014
+ return join(requireProjectDir(projectDir), ULPI_PROJECT_DIR, GUARDS_FILENAME_ALT);
1015
+ }
1016
+ function globalGuardsFile() {
1017
+ return join(ULPI_GLOBAL_DIR, GUARDS_FILENAME);
1018
+ }
1019
+ function projectNoAutoGenFile(projectDir) {
1020
+ return join(requireProjectDir(projectDir), ULPI_PROJECT_DIR, NO_AUTO_GEN_FILE);
1021
+ }
1022
+ function getAnthropicApiKey() {
1023
+ return process.env.ANTHROPIC_API_KEY;
1024
+ }
1025
+ function isDebugMode() {
1026
+ return process.env.ULPI_DEBUG === "1" || process.env.ULPI_DEBUG === "true";
1027
+ }
1028
+ function getApiPort() {
1029
+ const port = process.env.ULPI_API_PORT;
1030
+ if (!port) return 9800;
1031
+ const parsed = parseInt(port, 10);
1032
+ if (Number.isNaN(parsed) || parsed < 1 || parsed > 65535) return 9800;
1033
+ return parsed;
1034
+ }
1035
+ function getApiHost() {
1036
+ return process.env.ULPI_API_HOST || "127.0.0.1";
1037
+ }
1038
+ function getPortalPort() {
1039
+ const port = process.env.ULPI_PORTAL_PORT;
1040
+ if (!port) return 9801;
1041
+ const parsed = parseInt(port, 10);
1042
+ if (Number.isNaN(parsed) || parsed < 1 || parsed > 65535) return 9801;
1043
+ return parsed;
1044
+ }
1045
+ function isCI() {
1046
+ return process.env.CI === "true" || process.env.CI === "1";
1047
+ }
1048
+ var DEFAULT_AI_MODEL = "claude-sonnet-4-20250514";
1049
+ var DEFAULT_SETTINGS = {
1050
+ review: {
1051
+ enabled: true,
1052
+ plan_review: true,
1053
+ code_review: true,
1054
+ auto_open_browser: true,
1055
+ require_server: false,
1056
+ review_timeout_seconds: 0,
1057
+ timeout_behavior: "allow",
1058
+ default_export_format: "markdown",
1059
+ webhook_url: ""
1060
+ },
1061
+ apiKeys: {}
1062
+ };
1063
+ function loadUlpiSettings() {
1064
+ try {
1065
+ const p = SETTINGS_FILE;
1066
+ if (!existsSync2(p)) return { ...DEFAULT_SETTINGS };
1067
+ const raw = JSON.parse(readFileSync2(p, "utf-8"));
1068
+ return {
1069
+ review: { ...DEFAULT_SETTINGS.review, ...raw.review },
1070
+ apiKeys: { ...DEFAULT_SETTINGS.apiKeys, ...raw.apiKeys },
1071
+ username: typeof raw.username === "string" ? raw.username : void 0,
1072
+ ulpiUrl: typeof raw.ulpiUrl === "string" ? raw.ulpiUrl : void 0
1073
+ };
1074
+ } catch {
1075
+ return { ...DEFAULT_SETTINGS };
1076
+ }
1077
+ }
1078
+ function resolveApiKey(provider) {
1079
+ const settings = loadUlpiSettings();
1080
+ const fromSettings = settings.apiKeys?.[provider];
1081
+ if (fromSettings) return fromSettings;
1082
+ const envMap = {
1083
+ openai: "OPENAI_API_KEY",
1084
+ anthropic: "ANTHROPIC_API_KEY",
1085
+ ulpi: "ULPI_API_KEY"
1086
+ };
1087
+ return process.env[envMap[provider]];
1088
+ }
1089
+ var DEFAULT_ULPI_URL = "http://localhost:10271";
1090
+ function resolveUlpiUrl() {
1091
+ const settings = loadUlpiSettings();
1092
+ if (settings.ulpiUrl) return settings.ulpiUrl;
1093
+ return process.env.ULPI_EMBED_URL ?? DEFAULT_ULPI_URL;
1094
+ }
1095
+ function saveUlpiSettings(settings) {
1096
+ const p = SETTINGS_FILE;
1097
+ const dir = dirname(p);
1098
+ if (!existsSync2(dir)) mkdirSync(dir, { recursive: true });
1099
+ writeFileSync(p, JSON.stringify(settings, null, 2) + "\n");
1100
+ }
1101
+ function loadTomlConfig(path2) {
1102
+ if (!existsSync3(path2)) return null;
1103
+ const content = readFileSync3(path2, "utf-8");
1104
+ const parsed = parse(content);
1105
+ return parsed;
1106
+ }
1107
+ function saveTomlConfig(path2, config) {
1108
+ const dir = dirname2(path2);
1109
+ if (!existsSync3(dir)) mkdirSync2(dir, { recursive: true });
1110
+ const content = stringify(config);
1111
+ writeFileSync2(path2, content + "\n");
1112
+ }
1113
+ function mergeConfigs(base, override) {
1114
+ const merged = { ...base };
1115
+ for (const key of Object.keys(override)) {
1116
+ const baseVal = base[key];
1117
+ const overrideVal = override[key];
1118
+ if (overrideVal === void 0 || overrideVal === null) continue;
1119
+ if (Array.isArray(overrideVal)) {
1120
+ merged[key] = overrideVal;
1121
+ continue;
1122
+ }
1123
+ if (typeof overrideVal === "object" && typeof baseVal === "object" && !Array.isArray(baseVal) && baseVal !== null) {
1124
+ merged[key] = {
1125
+ ...baseVal,
1126
+ ...overrideVal
1127
+ };
1128
+ continue;
1129
+ }
1130
+ merged[key] = overrideVal;
1131
+ }
1132
+ return merged;
1133
+ }
1134
+ var CLOUD_GATEWAY_FILE = path.join(ULPI_GLOBAL_DIR, "cloud-gateway.json");
1135
+ function loadCloudGatewayConfig() {
1136
+ try {
1137
+ if (!fs.existsSync(CLOUD_GATEWAY_FILE)) return null;
1138
+ return JSON.parse(fs.readFileSync(CLOUD_GATEWAY_FILE, "utf-8"));
1139
+ } catch {
1140
+ return null;
1141
+ }
1142
+ }
1143
+ function saveCloudGatewayConfig(config) {
1144
+ const dir = path.dirname(CLOUD_GATEWAY_FILE);
1145
+ if (!fs.existsSync(dir)) fs.mkdirSync(dir, { recursive: true });
1146
+ fs.writeFileSync(CLOUD_GATEWAY_FILE, JSON.stringify(config, null, 2) + "\n", "utf-8");
1147
+ }
1148
+ function removeCloudGatewayConfig() {
1149
+ try {
1150
+ if (fs.existsSync(CLOUD_GATEWAY_FILE)) {
1151
+ fs.unlinkSync(CLOUD_GATEWAY_FILE);
1152
+ return true;
1153
+ }
1154
+ } catch {
1155
+ }
1156
+ return false;
1157
+ }
1158
+
1159
+ export {
1160
+ ULPI_GLOBAL_DIR,
1161
+ ULPI_PROJECT_DIR,
1162
+ GUARDS_FILENAME,
1163
+ GUARDS_FILENAME_ALT,
1164
+ SESSIONS_DIR,
1165
+ REVIEWS_DIR,
1166
+ REVIEW_FLAGS_DIR,
1167
+ REVIEW_IMAGES_DIR,
1168
+ REPOS_FILE,
1169
+ USER_TEMPLATES_DIR,
1170
+ USER_SKILLS_DIR,
1171
+ VERSION_CACHE_FILE,
1172
+ SETTINGS_FILE,
1173
+ ULPI_CONFIG_FILE,
1174
+ LOGS_DIR,
1175
+ NOTIFICATIONS_LOG_FILE,
1176
+ API_LOCK_FILE,
1177
+ HISTORY_BRANCH_PREFIX,
1178
+ CODEMAP_DIR_NAME,
1179
+ CODEMAP_DIR,
1180
+ CODEMAP_BRANCH_PREFIX,
1181
+ branchToSlug,
1182
+ codemapProjectSlug,
1183
+ getCurrentBranch,
1184
+ projectCodemapDir,
1185
+ codemapBranchDir,
1186
+ resolveUsername,
1187
+ getCodemapBranch,
1188
+ getHistoryBranch,
1189
+ codemapConfigFile,
1190
+ codemapManifestFile,
1191
+ codemapSchemaFile,
1192
+ codemapStatsFile,
1193
+ codemapLanceDir,
1194
+ codemapMetadataDir,
1195
+ depgraphDir,
1196
+ depgraphGraphFile,
1197
+ depgraphPagerankFile,
1198
+ depgraphMetricsFile,
1199
+ depgraphCacheFile,
1200
+ MEMORY_DIR,
1201
+ MEMORY_BRANCH_PREFIX,
1202
+ memoryProjectSlug,
1203
+ getMemoryBranch,
1204
+ projectMemoryDir,
1205
+ memoryConfigFile,
1206
+ memoryIndexDir,
1207
+ memoryLanceDir,
1208
+ memoryEntriesDir,
1209
+ memoryHistoryDir,
1210
+ memoryWatermarksDir,
1211
+ memoryStatsFile,
1212
+ memoryPromptsDir,
1213
+ MCPS_LIBRARY_FILE,
1214
+ MCPS_FILENAME,
1215
+ projectMcpsFile,
1216
+ JOBS_DIR,
1217
+ jobFile,
1218
+ CLI_BIN_NAME,
1219
+ getBinaryPath,
1220
+ CLI_NPM_PACKAGE,
1221
+ CLI_REGISTRY_URL,
1222
+ NO_AUTO_GEN_FILE,
1223
+ LAUNCHD_LABEL,
1224
+ projectConfigDir,
1225
+ projectGuardsFile,
1226
+ projectGuardsFileAlt,
1227
+ globalGuardsFile,
1228
+ projectNoAutoGenFile,
1229
+ getAnthropicApiKey,
1230
+ isDebugMode,
1231
+ getApiPort,
1232
+ getApiHost,
1233
+ getPortalPort,
1234
+ isCI,
1235
+ DEFAULT_AI_MODEL,
1236
+ loadUlpiSettings,
1237
+ resolveApiKey,
1238
+ resolveUlpiUrl,
1239
+ saveUlpiSettings,
1240
+ loadTomlConfig,
1241
+ saveTomlConfig,
1242
+ mergeConfigs,
1243
+ CLOUD_GATEWAY_FILE,
1244
+ loadCloudGatewayConfig,
1245
+ saveCloudGatewayConfig,
1246
+ removeCloudGatewayConfig
1247
+ };
1248
+ /*! Bundled license information:
1249
+
1250
+ smol-toml/dist/error.js:
1251
+ smol-toml/dist/util.js:
1252
+ smol-toml/dist/date.js:
1253
+ smol-toml/dist/primitive.js:
1254
+ smol-toml/dist/extract.js:
1255
+ smol-toml/dist/struct.js:
1256
+ smol-toml/dist/parse.js:
1257
+ smol-toml/dist/stringify.js:
1258
+ smol-toml/dist/index.js:
1259
+ (*!
1260
+ * Copyright (c) Squirrel Chat et al., All rights reserved.
1261
+ * SPDX-License-Identifier: BSD-3-Clause
1262
+ *
1263
+ * Redistribution and use in source and binary forms, with or without
1264
+ * modification, are permitted provided that the following conditions are met:
1265
+ *
1266
+ * 1. Redistributions of source code must retain the above copyright notice, this
1267
+ * list of conditions and the following disclaimer.
1268
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
1269
+ * this list of conditions and the following disclaimer in the
1270
+ * documentation and/or other materials provided with the distribution.
1271
+ * 3. Neither the name of the copyright holder nor the names of its contributors
1272
+ * may be used to endorse or promote products derived from this software without
1273
+ * specific prior written permission.
1274
+ *
1275
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
1276
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
1277
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
1278
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
1279
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
1280
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
1281
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
1282
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
1283
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
1284
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
1285
+ *)
1286
+ */