padrone 1.5.0 → 1.7.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 (141) hide show
  1. package/CHANGELOG.md +44 -0
  2. package/README.md +15 -11
  3. package/dist/{args-D5PNDyNu.mjs → args-Cnq0nwSM.mjs} +91 -41
  4. package/dist/args-Cnq0nwSM.mjs.map +1 -0
  5. package/dist/codegen/index.mjs +4 -4
  6. package/dist/codegen/index.mjs.map +1 -1
  7. package/dist/commands-B_gufyR9.mjs +514 -0
  8. package/dist/commands-B_gufyR9.mjs.map +1 -0
  9. package/dist/{completion.mjs → completion-BEuflbDO.mjs} +12 -82
  10. package/dist/completion-BEuflbDO.mjs.map +1 -0
  11. package/dist/docs/index.d.mts +4 -4
  12. package/dist/docs/index.d.mts.map +1 -1
  13. package/dist/docs/index.mjs +10 -12
  14. package/dist/docs/index.mjs.map +1 -1
  15. package/dist/{errors-BiVrBgi6.mjs → errors-DA4KzK1M.mjs} +26 -3
  16. package/dist/errors-DA4KzK1M.mjs.map +1 -0
  17. package/dist/{formatter-DtHzbP22.d.mts → formatter-DrvhDMrq.d.mts} +3 -3
  18. package/dist/formatter-DrvhDMrq.d.mts.map +1 -0
  19. package/dist/{help-bbmu9-qd.mjs → help-BtxLgrF_.mjs} +190 -43
  20. package/dist/help-BtxLgrF_.mjs.map +1 -0
  21. package/dist/{types-Ch8Mk6Qb.d.mts → index-D6-7dz0l.d.mts} +634 -745
  22. package/dist/index-D6-7dz0l.d.mts.map +1 -0
  23. package/dist/index.d.mts +869 -36
  24. package/dist/index.d.mts.map +1 -1
  25. package/dist/index.mjs +3884 -1699
  26. package/dist/index.mjs.map +1 -1
  27. package/dist/{mcp-mLWIdUIu.mjs → mcp-6-Jw4Bpq.mjs} +13 -15
  28. package/dist/mcp-6-Jw4Bpq.mjs.map +1 -0
  29. package/dist/{serve-B0u43DK7.mjs → serve-YVTPzBCl.mjs} +12 -14
  30. package/dist/serve-YVTPzBCl.mjs.map +1 -0
  31. package/dist/{stream-BcC146Ud.mjs → stream-DC4H8YTx.mjs} +24 -3
  32. package/dist/stream-DC4H8YTx.mjs.map +1 -0
  33. package/dist/test.d.mts +5 -8
  34. package/dist/test.d.mts.map +1 -1
  35. package/dist/test.mjs +2 -13
  36. package/dist/test.mjs.map +1 -1
  37. package/dist/{update-check-CFX1FV3v.mjs → update-check-CZ2VqjnV.mjs} +16 -17
  38. package/dist/update-check-CZ2VqjnV.mjs.map +1 -0
  39. package/dist/zod.d.mts +2 -2
  40. package/dist/zod.d.mts.map +1 -1
  41. package/dist/zod.mjs +2 -2
  42. package/dist/zod.mjs.map +1 -1
  43. package/package.json +15 -12
  44. package/src/cli/completions.ts +14 -11
  45. package/src/cli/docs.ts +13 -10
  46. package/src/cli/doctor.ts +22 -18
  47. package/src/cli/index.ts +28 -82
  48. package/src/cli/init.ts +10 -7
  49. package/src/cli/link.ts +20 -16
  50. package/src/cli/wrap.ts +14 -11
  51. package/src/codegen/schema-to-code.ts +2 -2
  52. package/src/{args.ts → core/args.ts} +32 -225
  53. package/src/core/commands.ts +373 -0
  54. package/src/core/create.ts +301 -0
  55. package/src/core/default-runtime.ts +239 -0
  56. package/src/{errors.ts → core/errors.ts} +22 -0
  57. package/src/core/exec.ts +259 -0
  58. package/src/core/interceptors.ts +302 -0
  59. package/src/{parse.ts → core/parse.ts} +36 -89
  60. package/src/core/program-methods.ts +301 -0
  61. package/src/core/results.ts +229 -0
  62. package/src/core/runtime.ts +246 -0
  63. package/src/core/validate.ts +247 -0
  64. package/src/docs/index.ts +12 -13
  65. package/src/extension/auto-output.ts +146 -0
  66. package/src/extension/color.ts +38 -0
  67. package/src/extension/completion.ts +49 -0
  68. package/src/extension/config.ts +262 -0
  69. package/src/extension/env.ts +101 -0
  70. package/src/extension/help.ts +192 -0
  71. package/src/extension/index.ts +44 -0
  72. package/src/extension/ink.ts +93 -0
  73. package/src/extension/interactive.ts +106 -0
  74. package/src/extension/logger.ts +262 -0
  75. package/src/extension/man.ts +51 -0
  76. package/src/extension/mcp.ts +52 -0
  77. package/src/extension/progress-renderer.ts +338 -0
  78. package/src/extension/progress.ts +299 -0
  79. package/src/extension/repl.ts +94 -0
  80. package/src/extension/serve.ts +48 -0
  81. package/src/extension/signal.ts +87 -0
  82. package/src/extension/stdin.ts +62 -0
  83. package/src/extension/suggestions.ts +114 -0
  84. package/src/extension/timing.ts +81 -0
  85. package/src/extension/tracing.ts +175 -0
  86. package/src/extension/update-check.ts +77 -0
  87. package/src/extension/utils.ts +51 -0
  88. package/src/extension/version.ts +63 -0
  89. package/src/{completion.ts → feature/completion.ts} +12 -12
  90. package/src/{interactive.ts → feature/interactive.ts} +4 -4
  91. package/src/{mcp.ts → feature/mcp.ts} +12 -15
  92. package/src/{repl-loop.ts → feature/repl-loop.ts} +10 -13
  93. package/src/{serve.ts → feature/serve.ts} +11 -15
  94. package/src/feature/test.ts +262 -0
  95. package/src/{update-check.ts → feature/update-check.ts} +16 -16
  96. package/src/{wrap.ts → feature/wrap.ts} +10 -8
  97. package/src/index.ts +115 -30
  98. package/src/{formatter.ts → output/formatter.ts} +124 -176
  99. package/src/{help.ts → output/help.ts} +22 -8
  100. package/src/output/output-indicator.ts +87 -0
  101. package/src/output/primitives.ts +335 -0
  102. package/src/output/styling.ts +221 -0
  103. package/src/{zod.d.ts → schema/zod.d.ts} +1 -1
  104. package/src/schema/zod.ts +50 -0
  105. package/src/test.ts +2 -276
  106. package/src/types/args-meta.ts +151 -0
  107. package/src/types/builder.ts +718 -0
  108. package/src/types/command.ts +157 -0
  109. package/src/types/index.ts +60 -0
  110. package/src/types/interceptor.ts +296 -0
  111. package/src/types/preferences.ts +83 -0
  112. package/src/types/result.ts +71 -0
  113. package/src/types/schema.ts +19 -0
  114. package/src/util/dotenv.ts +244 -0
  115. package/src/{shell-utils.ts → util/shell-utils.ts} +26 -9
  116. package/src/{stream.ts → util/stream.ts} +27 -1
  117. package/src/{type-helpers.ts → util/type-helpers.ts} +23 -16
  118. package/src/{type-utils.ts → util/type-utils.ts} +71 -33
  119. package/src/util/utils.ts +51 -0
  120. package/src/zod.ts +1 -50
  121. package/dist/args-D5PNDyNu.mjs.map +0 -1
  122. package/dist/chunk-CjcI7cDX.mjs +0 -15
  123. package/dist/command-utils-B1D-HqCd.mjs +0 -1117
  124. package/dist/command-utils-B1D-HqCd.mjs.map +0 -1
  125. package/dist/completion.d.mts +0 -64
  126. package/dist/completion.d.mts.map +0 -1
  127. package/dist/completion.mjs.map +0 -1
  128. package/dist/errors-BiVrBgi6.mjs.map +0 -1
  129. package/dist/formatter-DtHzbP22.d.mts.map +0 -1
  130. package/dist/help-bbmu9-qd.mjs.map +0 -1
  131. package/dist/mcp-mLWIdUIu.mjs.map +0 -1
  132. package/dist/serve-B0u43DK7.mjs.map +0 -1
  133. package/dist/stream-BcC146Ud.mjs.map +0 -1
  134. package/dist/types-Ch8Mk6Qb.d.mts.map +0 -1
  135. package/dist/update-check-CFX1FV3v.mjs.map +0 -1
  136. package/src/command-utils.ts +0 -882
  137. package/src/create.ts +0 -1829
  138. package/src/runtime.ts +0 -497
  139. package/src/types.ts +0 -1291
  140. package/src/utils.ts +0 -140
  141. /package/src/{colorizer.ts → output/colorizer.ts} +0 -0
@@ -1,6 +1,6 @@
1
- import { a as extractSchemaMetadata, c as parsePositionalConfig, l as parseStdinConfig, n as camelToKebab, t as JSON_SCHEMA_OPTS } from "./args-D5PNDyNu.mjs";
2
- import { L as getRootCommand, u as findCommandByName } from "./command-utils-B1D-HqCd.mjs";
3
- //#region src/colorizer.ts
1
+ import { o as findCommandByName } from "./commands-B_gufyR9.mjs";
2
+ import { a as getJsonSchema, c as parsePositionalConfig, i as extractSchemaMetadata, u as camelToKebab } from "./args-Cnq0nwSM.mjs";
3
+ //#region src/output/colorizer.ts
4
4
  const ansiCodes = {
5
5
  reset: "\x1B[0m",
6
6
  bold: "\x1B[1m",
@@ -90,8 +90,21 @@ function createColorizer(config) {
90
90
  deprecated: makeStyleFn(resolved.deprecated)
91
91
  };
92
92
  }
93
- //#endregion
94
- //#region src/formatter.ts
93
+ function wrapText(text, maxWidth) {
94
+ if (maxWidth <= 0 || text.length <= maxWidth) return [text];
95
+ const words = text.split(" ");
96
+ const lines = [];
97
+ let current = "";
98
+ for (const word of words) if (current && current.length + 1 + word.length > maxWidth) {
99
+ lines.push(current);
100
+ current = word;
101
+ } else current = current ? `${current} ${word}` : word;
102
+ if (current) lines.push(current);
103
+ return lines.length > 0 ? lines : [text];
104
+ }
105
+ function escapeHtml(text) {
106
+ return text.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/"/g, "&quot;").replace(/'/g, "&#039;");
107
+ }
95
108
  function createTextStyler() {
96
109
  return {
97
110
  command: (text) => text,
@@ -138,9 +151,6 @@ function createMarkdownStyler() {
138
151
  deprecated: (text) => `~~${text}~~`
139
152
  };
140
153
  }
141
- function escapeHtml(text) {
142
- return text.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/"/g, "&quot;").replace(/'/g, "&#039;");
143
- }
144
154
  function createHtmlStyler() {
145
155
  return {
146
156
  command: (text) => `<strong style="color: #00bcd4;">${escapeHtml(text)}</strong>`,
@@ -181,10 +191,92 @@ function createHtmlLayout() {
181
191
  wrapDocument: (content) => `<div style="font-family: monospace; line-height: 1.6;">${content}</div>`
182
192
  };
183
193
  }
194
+ function shouldUseAnsi(env, isTTY) {
195
+ if (env?.NO_COLOR) return false;
196
+ if (env?.CI) return false;
197
+ if (typeof isTTY === "boolean") return isTTY;
198
+ return false;
199
+ }
200
+ /** Resolve the output format from the runtime and caller context. */
201
+ function resolveOutputFormat(runtime, caller) {
202
+ let format;
203
+ if (caller === "serve" || caller === "mcp" || caller === "tool") format = "json";
204
+ else if (runtime.format && runtime.format !== "auto" && runtime.format !== "console") format = runtime.format;
205
+ else format = shouldUseAnsi(runtime.env(), runtime.terminal?.isTTY) ? "ansi" : "text";
206
+ const terminalWidth = format === "markdown" || format === "html" ? void 0 : runtime.terminal?.columns ?? 80;
207
+ let styler;
208
+ let layout;
209
+ switch (format) {
210
+ case "ansi":
211
+ styler = createAnsiStyler(runtime.theme);
212
+ layout = createTextLayout();
213
+ break;
214
+ case "markdown":
215
+ styler = createMarkdownStyler();
216
+ layout = createMarkdownLayout();
217
+ break;
218
+ case "html":
219
+ styler = createHtmlStyler();
220
+ layout = createHtmlLayout();
221
+ break;
222
+ default:
223
+ styler = createTextStyler();
224
+ layout = createTextLayout();
225
+ break;
226
+ }
227
+ return {
228
+ format,
229
+ styler,
230
+ layout,
231
+ terminalWidth
232
+ };
233
+ }
234
+ //#endregion
235
+ //#region src/util/utils.ts
236
+ function getRootCommand(cmd) {
237
+ let current = cmd;
238
+ while (current.parent) current = current.parent;
239
+ return current;
240
+ }
241
+ async function readVersionFromPackageJson() {
242
+ try {
243
+ const fs = await import("node:fs");
244
+ const path = await import("node:path");
245
+ let dir = process.cwd();
246
+ for (let i = 0; i < 10; i++) {
247
+ const pkgPath = path.join(dir, "package.json");
248
+ if (fs.existsSync(pkgPath)) {
249
+ const pkg = JSON.parse(fs.readFileSync(pkgPath, "utf-8"));
250
+ if (pkg.version) return pkg.version;
251
+ }
252
+ const parentDir = path.dirname(dir);
253
+ if (parentDir === dir) break;
254
+ dir = parentDir;
255
+ }
256
+ } catch {}
257
+ return "0.0.0";
258
+ }
259
+ /**
260
+ * Attempts to get the version from various sources:
261
+ * 1. Explicit version set on the command
262
+ * 2. npm_package_version environment variable (set by npm/yarn/pnpm when running scripts)
263
+ * 3. package.json in current or parent directories
264
+ *
265
+ * Returns synchronously when an explicit version or env var is available.
266
+ * Falls back to async package.json discovery otherwise.
267
+ */
268
+ function getVersion(explicitVersion) {
269
+ if (explicitVersion) return explicitVersion;
270
+ if (typeof process !== "undefined" && process.env?.npm_package_version) return process.env.npm_package_version;
271
+ if (typeof process !== "undefined") return readVersionFromPackageJson();
272
+ return "0.0.0";
273
+ }
274
+ //#endregion
275
+ //#region src/output/formatter.ts
184
276
  /**
185
277
  * Creates a formatter that uses the given styler and layout configuration.
186
278
  */
187
- function createGenericFormatter(styler, layout, showAllBuiltins) {
279
+ function createGenericFormatter(styler, layout, showAllBuiltins, terminalWidth) {
188
280
  const { newline, indent, join, wrapDocument } = layout;
189
281
  function formatUsageSection(info) {
190
282
  const usageParts = [styler.command(info.usage.command), info.usage.hasSubcommands ? styler.meta("[command]") : ""];
@@ -259,14 +351,42 @@ function createGenericFormatter(styler, layout, showAllBuiltins) {
259
351
  const args = info.positionals;
260
352
  lines.push(styler.section("Arguments:"));
261
353
  const maxNameLength = Math.min(32, Math.max(...args.map((a) => a.name.length)));
354
+ const descCol = 2 + maxNameLength + 2;
355
+ const posAvailWidth = terminalWidth ? terminalWidth - descCol : void 0;
356
+ const descColPad = " ".repeat(descCol);
262
357
  for (const arg of args) {
263
358
  const padding = " ".repeat(Math.max(2, maxNameLength - arg.name.length + 2));
264
- const descParts = [];
265
- if (arg.description) descParts.push(styler.description(arg.description));
266
- if (info.usage.stdinField === arg.name) descParts.push(styler.meta("(stdin)"));
267
- if (arg.enum) descParts.push(styler.meta(`(choices: ${arg.enum.join(", ")})`));
268
- if (arg.default !== void 0) descParts.push(styler.meta(`(default: ${String(arg.default)})`));
269
- lines.push(indent(1) + styler.arg(arg.name) + padding + join(descParts));
359
+ const prefix = indent(1) + styler.arg(arg.name) + padding;
360
+ const descPlain = arg.description ?? "";
361
+ const styledDesc = descPlain ? styler.description(descPlain) : "";
362
+ const metaParts = [];
363
+ const styledMetaParts = [];
364
+ if (info.usage.stdinField === arg.name) {
365
+ metaParts.push("(stdin)");
366
+ styledMetaParts.push(styler.meta("(stdin)"));
367
+ }
368
+ if (arg.enum) {
369
+ const text = `(choices: ${arg.enum.join(", ")})`;
370
+ metaParts.push(text);
371
+ styledMetaParts.push(styler.meta(text));
372
+ }
373
+ if (arg.default !== void 0) {
374
+ const text = `(default: ${String(arg.default)})`;
375
+ metaParts.push(text);
376
+ styledMetaParts.push(styler.meta(text));
377
+ }
378
+ const metaStyled = join(styledMetaParts);
379
+ if (posAvailWidth && posAvailWidth > 0) if ([descPlain, metaParts.join(" ")].filter(Boolean).join(" ").length <= posAvailWidth) lines.push(prefix + [styledDesc, metaStyled].filter(Boolean).join(" "));
380
+ else if (!descPlain || descPlain.length <= posAvailWidth) {
381
+ lines.push(prefix + styledDesc);
382
+ if (metaStyled) lines.push(descColPad + metaStyled);
383
+ } else {
384
+ const wrapped = wrapText(descPlain, posAvailWidth);
385
+ lines.push(prefix + styler.description(wrapped[0]));
386
+ for (const wline of wrapped.slice(1)) lines.push(descColPad + styler.description(wline));
387
+ if (metaStyled) lines.push(descColPad + metaStyled);
388
+ }
389
+ else lines.push(prefix + join([styledDesc, metaStyled]));
270
390
  }
271
391
  return lines;
272
392
  }
@@ -295,6 +415,9 @@ function createGenericFormatter(styler, layout, showAllBuiltins) {
295
415
  const maxNamesWidth = Math.min(32, Math.max(0, ...argColumns.map((c) => c.namesPlain.length)));
296
416
  const maxTypeWidth = Math.min(16, Math.max(0, ...argColumns.map((c) => c.typePlain.length)));
297
417
  const hasAnyFlags = maxFlagsWidth > 0;
418
+ const descCol = 2 + (hasAnyFlags ? maxFlagsWidth + 2 : 0) + maxNamesWidth + 2 + (maxTypeWidth > 0 ? maxTypeWidth + 2 : 0);
419
+ const argAvailWidth = terminalWidth ? terminalWidth - descCol : void 0;
420
+ const descColPad = " ".repeat(descCol);
298
421
  const grouped = Object.groupBy(argColumns, (c) => c.arg.group ?? "");
299
422
  const renderArgColumns = (columns) => {
300
423
  for (const { flagsPlain, namesPlain, typePlain, isDeprecated, arg } of columns) {
@@ -313,21 +436,51 @@ function createGenericFormatter(styler, layout, showAllBuiltins) {
313
436
  const typePadding = " ".repeat(Math.max(2, maxTypeWidth - typePlain.length + 2));
314
437
  parts.push(styledType + typePadding);
315
438
  }
316
- const descParts = [];
317
- if (arg.description) descParts.push(isDeprecated ? styler.deprecated(arg.description) : styler.description(arg.description));
318
- lines.push(indent(1) + parts.join("") + join(descParts));
319
- const line2Parts = [];
320
- if (isDeprecated && typeof arg.deprecated !== "string") line2Parts.push(styler.meta("(deprecated)"));
321
- if (hasDefault(arg.default)) line2Parts.push(styler.meta(`(default: ${String(arg.default)})`));
322
- if (arg.enum) line2Parts.push(styler.meta(`(choices: ${arg.enum.join(", ")})`));
323
- if (line2Parts.length > 0) lines.push(indent(3) + join(line2Parts));
439
+ const prefix = indent(1) + parts.join("");
440
+ const contPad = argAvailWidth ? descColPad : indent(3);
441
+ const inlineMeta = [];
442
+ const styledInlineMeta = [];
443
+ if (isDeprecated && typeof arg.deprecated !== "string") {
444
+ inlineMeta.push("(deprecated)");
445
+ styledInlineMeta.push(styler.meta("(deprecated)"));
446
+ }
447
+ if (hasDefault(arg.default)) {
448
+ const text = `(default: ${String(arg.default)})`;
449
+ inlineMeta.push(text);
450
+ styledInlineMeta.push(styler.meta(text));
451
+ }
452
+ if (arg.enum) {
453
+ const text = `(choices: ${arg.enum.join(", ")})`;
454
+ inlineMeta.push(text);
455
+ styledInlineMeta.push(styler.meta(text));
456
+ }
457
+ const descPlain = arg.description ?? "";
458
+ const styledDesc = descPlain ? isDeprecated ? styler.deprecated(descPlain) : styler.description(descPlain) : "";
459
+ const metaStyled = join(styledInlineMeta);
460
+ if (argAvailWidth && argAvailWidth > 0) if ([descPlain, inlineMeta.join(" ")].filter(Boolean).join(" ").length <= argAvailWidth) lines.push(prefix + [styledDesc, metaStyled].filter(Boolean).join(" "));
461
+ else if (!descPlain || descPlain.length <= argAvailWidth) {
462
+ lines.push(prefix + styledDesc);
463
+ if (metaStyled) lines.push(descColPad + metaStyled);
464
+ } else {
465
+ const wrapped = wrapText(descPlain, argAvailWidth);
466
+ const styleFn = isDeprecated ? styler.deprecated : styler.description;
467
+ lines.push(prefix + styleFn(wrapped[0]));
468
+ for (const wline of wrapped.slice(1)) lines.push(descColPad + styleFn(wline));
469
+ if (metaStyled) lines.push(descColPad + metaStyled);
470
+ }
471
+ else {
472
+ const descParts = [];
473
+ if (styledDesc) descParts.push(styledDesc);
474
+ lines.push(prefix + join(descParts));
475
+ if (styledInlineMeta.length > 0) lines.push(indent(3) + metaStyled);
476
+ }
324
477
  const line3Parts = [];
325
478
  if (isDeprecated && typeof arg.deprecated === "string") line3Parts.push(styler.meta(`(deprecated: ${arg.deprecated})`));
326
479
  if (arg.examples && arg.examples.length > 0) {
327
480
  const exampleValues = arg.examples.map((example) => typeof example === "string" ? example : JSON.stringify(example)).join(", ");
328
481
  line3Parts.push(styler.example("Example:"), styler.exampleValue(exampleValues));
329
482
  }
330
- if (line3Parts.length > 0) lines.push(indent(3) + join(line3Parts));
483
+ if (line3Parts.length > 0) lines.push(contPad + join(line3Parts));
331
484
  const line4Parts = [];
332
485
  if (info.usage.stdinField === arg.name) line4Parts.push(styler.meta("(stdin)"));
333
486
  if (arg.env) {
@@ -335,7 +488,7 @@ function createGenericFormatter(styler, layout, showAllBuiltins) {
335
488
  line4Parts.push(styler.example("Env:"), styler.exampleValue(envVars.join(", ")));
336
489
  }
337
490
  if (arg.configKey) line4Parts.push(styler.example("Config:"), styler.exampleValue(arg.configKey));
338
- if (line4Parts.length > 0) lines.push(indent(3) + join(line4Parts));
491
+ if (line4Parts.length > 0) lines.push(contPad + join(line4Parts));
339
492
  }
340
493
  };
341
494
  for (const [key, items] of Object.entries(grouped)) {
@@ -442,13 +595,6 @@ function createJsonFormatter() {
442
595
  return JSON.stringify(info, null, 2);
443
596
  } };
444
597
  }
445
- function shouldUseAnsi() {
446
- if (typeof process === "undefined") return false;
447
- if (process.env.NO_COLOR) return false;
448
- if (process.env.CI) return false;
449
- if (process.stdout && typeof process.stdout.isTTY === "boolean") return process.stdout.isTTY;
450
- return false;
451
- }
452
598
  /**
453
599
  * Creates a minimal formatter that outputs just a single-line usage string.
454
600
  */
@@ -464,17 +610,18 @@ function createMinimalFormatter() {
464
610
  return parts.join(" ");
465
611
  } };
466
612
  }
467
- function createFormatter(format, detail = "standard", theme, all) {
613
+ function createFormatter(format, detail = "standard", theme, all, width, terminal, env) {
468
614
  if (detail === "minimal") return createMinimalFormatter();
469
615
  if (format === "json") return createJsonFormatter();
470
- if (format === "ansi" || format === "auto" && shouldUseAnsi()) return createGenericFormatter(createAnsiStyler(theme), createTextLayout(), all);
471
- if (format === "console") return createGenericFormatter(createConsoleStyler(theme), createTextLayout(), all);
616
+ const tw = format === "markdown" || format === "html" ? void 0 : width ?? terminal?.columns ?? 80;
617
+ if (format === "ansi" || format === "auto" && shouldUseAnsi(env, terminal?.isTTY)) return createGenericFormatter(createAnsiStyler(theme), createTextLayout(), all, tw);
618
+ if (format === "console") return createGenericFormatter(createConsoleStyler(theme), createTextLayout(), all, tw);
472
619
  if (format === "markdown") return createGenericFormatter(createMarkdownStyler(), createMarkdownLayout(), all);
473
620
  if (format === "html") return createGenericFormatter(createHtmlStyler(), createHtmlLayout(), all);
474
- return createGenericFormatter(createTextStyler(), createTextLayout(), all);
621
+ return createGenericFormatter(createTextStyler(), createTextLayout(), all, tw);
475
622
  }
476
623
  //#endregion
477
- //#region src/help.ts
624
+ //#region src/output/help.ts
478
625
  /**
479
626
  * Extract positional arguments info from schema based on meta.positional config.
480
627
  */
@@ -487,7 +634,7 @@ function extractPositionalArgsInfo(schema, meta) {
487
634
  };
488
635
  const positionalConfig = parsePositionalConfig(meta.positional);
489
636
  try {
490
- const jsonSchema = schema["~standard"].jsonSchema.input(JSON_SCHEMA_OPTS);
637
+ const jsonSchema = getJsonSchema(schema);
491
638
  if (jsonSchema.type === "object" && jsonSchema.properties) {
492
639
  const properties = jsonSchema.properties;
493
640
  const required = jsonSchema.required || [];
@@ -518,7 +665,7 @@ function extractArgsInfo(schema, meta, positionalNames) {
518
665
  if (!schema["~standard"].vendor.includes("zod")) return result;
519
666
  const argsMeta = meta?.fields;
520
667
  try {
521
- const jsonSchema = schema["~standard"].jsonSchema.input(JSON_SCHEMA_OPTS);
668
+ const jsonSchema = getJsonSchema(schema);
522
669
  if (jsonSchema.type === "object" && jsonSchema.properties) {
523
670
  const properties = jsonSchema.properties;
524
671
  const required = jsonSchema.required || [];
@@ -598,7 +745,7 @@ function getHelpInfo(cmd, detail = "standard", all) {
598
745
  hasSubcommands: !!(cmd.commands && cmd.commands.length > 0),
599
746
  hasPositionals,
600
747
  hasArguments: false,
601
- stdinField: cmd.meta?.stdin ? parseStdinConfig(cmd.meta.stdin) : void 0
748
+ stdinField: cmd.meta?.stdin
602
749
  }
603
750
  };
604
751
  if (cmd.commands && cmd.commands.length > 0) {
@@ -727,9 +874,9 @@ function getHelpInfo(cmd, detail = "standard", all) {
727
874
  }
728
875
  function generateHelp(rootCommand, commandObj = rootCommand, prefs) {
729
876
  const helpInfo = getHelpInfo(commandObj, prefs?.detail, prefs?.all);
730
- return createFormatter(prefs?.format ?? "auto", prefs?.detail, prefs?.theme, prefs?.all).format(helpInfo);
877
+ return createFormatter(prefs?.format ?? "auto", prefs?.detail, prefs?.theme, prefs?.all, prefs?.width, prefs?.terminal, prefs?.env).format(helpInfo);
731
878
  }
732
879
  //#endregion
733
- export { getHelpInfo as n, colorThemes as r, generateHelp as t };
880
+ export { escapeHtml as a, getVersion as i, getHelpInfo as n, resolveOutputFormat as o, getRootCommand as r, colorThemes as s, generateHelp as t };
734
881
 
735
- //# sourceMappingURL=help-bbmu9-qd.mjs.map
882
+ //# sourceMappingURL=help-BtxLgrF_.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"help-BtxLgrF_.mjs","names":[],"sources":["../src/output/colorizer.ts","../src/output/styling.ts","../src/util/utils.ts","../src/output/formatter.ts","../src/output/help.ts"],"sourcesContent":["// ANSI color/style codes\nconst ansiCodes: Record<AnsiStyle, string> = {\n reset: '\\x1b[0m',\n bold: '\\x1b[1m',\n dim: '\\x1b[2m',\n italic: '\\x1b[3m',\n underline: '\\x1b[4m',\n strikethrough: '\\x1b[9m',\n red: '\\x1b[31m',\n green: '\\x1b[32m',\n yellow: '\\x1b[33m',\n blue: '\\x1b[34m',\n magenta: '\\x1b[35m',\n cyan: '\\x1b[36m',\n white: '\\x1b[37m',\n gray: '\\x1b[90m',\n};\n\n/**\n * Available ANSI styles that can be combined for each color role.\n */\nexport type AnsiStyle =\n | 'reset'\n | 'bold'\n | 'dim'\n | 'italic'\n | 'underline'\n | 'strikethrough'\n | 'red'\n | 'green'\n | 'yellow'\n | 'blue'\n | 'magenta'\n | 'cyan'\n | 'white'\n | 'gray';\n\n/**\n * Maps each semantic color role to an array of ANSI styles.\n * Partial configs are merged with the default theme.\n */\nexport type ColorConfig = {\n command?: AnsiStyle[];\n arg?: AnsiStyle[];\n type?: AnsiStyle[];\n description?: AnsiStyle[];\n label?: AnsiStyle[];\n meta?: AnsiStyle[];\n example?: AnsiStyle[];\n exampleValue?: AnsiStyle[];\n deprecated?: AnsiStyle[];\n};\n\nexport type Colorizer = {\n command: (text: string) => string;\n arg: (text: string) => string;\n type: (text: string) => string;\n description: (text: string) => string;\n label: (text: string) => string;\n meta: (text: string) => string;\n example: (text: string) => string;\n exampleValue: (text: string) => string;\n deprecated: (text: string) => string;\n};\n\n// ============================================================================\n// Predefined Themes\n// ============================================================================\n\nconst defaultTheme: Required<ColorConfig> = {\n command: ['cyan', 'bold'],\n arg: ['green'],\n type: ['yellow'],\n description: ['dim'],\n label: ['bold'],\n meta: ['gray'],\n example: ['underline'],\n exampleValue: ['italic'],\n deprecated: ['strikethrough', 'gray'],\n};\n\nconst oceanTheme: Required<ColorConfig> = {\n command: ['blue', 'bold'],\n arg: ['cyan'],\n type: ['green'],\n description: ['dim'],\n label: ['bold'],\n meta: ['gray'],\n example: ['underline', 'cyan'],\n exampleValue: ['italic'],\n deprecated: ['strikethrough', 'gray'],\n};\n\nconst warmTheme: Required<ColorConfig> = {\n command: ['yellow', 'bold'],\n arg: ['red'],\n type: ['magenta'],\n description: ['dim'],\n label: ['bold'],\n meta: ['gray'],\n example: ['underline', 'yellow'],\n exampleValue: ['italic'],\n deprecated: ['strikethrough', 'gray'],\n};\n\nconst monochromeTheme: Required<ColorConfig> = {\n command: ['bold'],\n arg: ['underline'],\n type: ['dim'],\n description: ['dim'],\n label: ['bold'],\n meta: ['dim'],\n example: ['underline'],\n exampleValue: ['italic'],\n deprecated: ['strikethrough', 'dim'],\n};\n\n/**\n * Available predefined color themes.\n */\nexport type ColorTheme = 'default' | 'ocean' | 'warm' | 'monochrome';\n\nexport const colorThemes: Record<ColorTheme, Required<ColorConfig>> = {\n default: defaultTheme,\n ocean: oceanTheme,\n warm: warmTheme,\n monochrome: monochromeTheme,\n};\n\nfunction makeStyleFn(styles: AnsiStyle[]): (text: string) => string {\n const prefix = styles.map((s) => ansiCodes[s]).join('');\n return (text: string) => `${prefix}${text}${ansiCodes.reset}`;\n}\n\nfunction resolveConfig(config?: ColorTheme | ColorConfig): Required<ColorConfig> {\n if (!config) return defaultTheme;\n if (typeof config === 'string') return colorThemes[config] ?? defaultTheme;\n return { ...defaultTheme, ...config };\n}\n\nexport function createColorizer(config?: ColorTheme | ColorConfig): Colorizer {\n const resolved = resolveConfig(config);\n return {\n command: makeStyleFn(resolved.command),\n arg: makeStyleFn(resolved.arg),\n type: makeStyleFn(resolved.type),\n description: makeStyleFn(resolved.description),\n label: makeStyleFn(resolved.label),\n meta: makeStyleFn(resolved.meta),\n example: makeStyleFn(resolved.example),\n exampleValue: makeStyleFn(resolved.exampleValue),\n deprecated: makeStyleFn(resolved.deprecated),\n };\n}\n","import type { PadroneActionContext } from '../types/index.ts';\nimport { type ColorConfig, type ColorTheme, createColorizer } from './colorizer.ts';\n\nexport const DEFAULT_TERMINAL_WIDTH = 80;\n\nexport function wrapText(text: string, maxWidth: number): string[] {\n if (maxWidth <= 0 || text.length <= maxWidth) return [text];\n const words = text.split(' ');\n const lines: string[] = [];\n let current = '';\n for (const word of words) {\n if (current && current.length + 1 + word.length > maxWidth) {\n lines.push(current);\n current = word;\n } else {\n current = current ? `${current} ${word}` : word;\n }\n }\n if (current) lines.push(current);\n return lines.length > 0 ? lines : [text];\n}\n\nexport function escapeHtml(text: string): string {\n return text.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/\"/g, '&quot;').replace(/'/g, '&#039;');\n}\n\n// ── Styler ──────────────────────────────────────────────────────────────\n\n/**\n * Styling functions for semantic text roles.\n * Used by formatters to apply visual styles (ANSI, HTML, Markdown, etc.)\n * to different types of content.\n */\nexport type Styler = {\n command: (text: string) => string;\n arg: (text: string) => string;\n type: (text: string) => string;\n description: (text: string) => string;\n label: (text: string) => string;\n section: (text: string) => string;\n meta: (text: string) => string;\n example: (text: string) => string;\n exampleValue: (text: string) => string;\n deprecated: (text: string) => string;\n};\n\n/**\n * Layout configuration for formatters.\n */\nexport type LayoutConfig = {\n newline: string;\n indent: (level: number) => string;\n join: (parts: string[]) => string;\n wrapDocument?: (content: string) => string;\n};\n\n// ── Styler Factories ────────────────────────────────────────────────────\n\nexport function createTextStyler(): Styler {\n return {\n command: (text) => text,\n arg: (text) => text,\n type: (text) => text,\n description: (text) => text,\n label: (text) => text,\n section: (text) => text,\n meta: (text) => text,\n example: (text) => text,\n exampleValue: (text) => text,\n deprecated: (text) => text,\n };\n}\n\nexport function createAnsiStyler(theme?: ColorTheme | ColorConfig): Styler {\n const colorizer = createColorizer(theme);\n return {\n command: colorizer.command,\n arg: colorizer.arg,\n type: colorizer.type,\n description: colorizer.description,\n label: colorizer.label,\n section: colorizer.label,\n meta: colorizer.meta,\n example: colorizer.example,\n exampleValue: colorizer.exampleValue,\n deprecated: colorizer.deprecated,\n };\n}\n\nexport function createConsoleStyler(theme?: ColorTheme | ColorConfig): Styler {\n return createAnsiStyler(theme);\n}\n\nexport function createMarkdownStyler(): Styler {\n return {\n command: (text) => `**${text}**`,\n arg: (text) => `\\`${text}\\``,\n type: (text) => `\\`${text}\\``,\n description: (text) => text,\n label: (text) => `**${text}**`,\n section: (text) => `### ${text}`,\n meta: (text) => `*${text}*`,\n example: (text) => `**${text}**`,\n exampleValue: (text) => `\\`${text}\\``,\n deprecated: (text) => `~~${text}~~`,\n };\n}\n\nexport function createHtmlStyler(): Styler {\n return {\n command: (text) => `<strong style=\"color: #00bcd4;\">${escapeHtml(text)}</strong>`,\n arg: (text) => `<code style=\"color: #4caf50;\">${escapeHtml(text)}</code>`,\n type: (text) => `<code style=\"color: #ff9800;\">${escapeHtml(text)}</code>`,\n description: (text) => `<span style=\"color: #666;\">${escapeHtml(text)}</span>`,\n label: (text) => `<strong>${escapeHtml(text)}</strong>`,\n section: (text) => `<h3>${escapeHtml(text)}</h3>`,\n meta: (text) => `<span style=\"color: #999;\">${escapeHtml(text)}</span>`,\n example: (text) => `<strong style=\"text-decoration: underline;\">${escapeHtml(text)}</strong>`,\n exampleValue: (text) => `<em>${escapeHtml(text)}</em>`,\n deprecated: (text) => `<del style=\"color: #999;\">${escapeHtml(text)}</del>`,\n };\n}\n\n// ── Layout Factories ────────────────────────────────────────────────────\n\nexport function createTextLayout(): LayoutConfig {\n return {\n newline: '\\n',\n indent: (level) => ' '.repeat(level),\n join: (parts) => parts.filter(Boolean).join(' '),\n };\n}\n\nexport function createMarkdownLayout(): LayoutConfig {\n return {\n newline: '\\n\\n',\n indent: (level) => {\n if (level === 0) return '';\n if (level === 1) return ' ';\n return ' ';\n },\n join: (parts) => parts.filter(Boolean).join(' '),\n };\n}\n\nexport function createHtmlLayout(): LayoutConfig {\n return {\n newline: '<br>',\n indent: (level) => '&nbsp;&nbsp;'.repeat(level),\n join: (parts) => parts.filter(Boolean).join(' '),\n wrapDocument: (content) => `<div style=\"font-family: monospace; line-height: 1.6;\">${content}</div>`,\n };\n}\n\n// ── Format Detection ────────────────────────────────────────────────────\n\nexport function shouldUseAnsi(env?: Record<string, string | undefined>, isTTY?: boolean): boolean {\n if (env?.NO_COLOR) return false;\n if (env?.CI) return false;\n if (typeof isTTY === 'boolean') return isTTY;\n return false;\n}\n\n// ── Output Context ──────────────────────────────────────────────────────\n\n/** Resolved formatting context used by output primitives. */\nexport type OutputFormat = 'text' | 'ansi' | 'json' | 'markdown' | 'html';\n\nexport type OutputContext = {\n format: OutputFormat;\n styler: Styler;\n layout: LayoutConfig;\n terminalWidth?: number;\n};\n\n/** Resolve the output format from the runtime and caller context. */\nexport function resolveOutputFormat(\n runtime: {\n format?: string;\n theme?: ColorTheme | ColorConfig;\n terminal?: { columns?: number; isTTY?: boolean };\n env: () => Record<string, string | undefined>;\n },\n caller?: PadroneActionContext['caller'],\n): OutputContext {\n let format: OutputFormat;\n\n if (caller === 'serve' || caller === 'mcp' || caller === 'tool') {\n format = 'json';\n } else if (runtime.format && runtime.format !== 'auto' && runtime.format !== 'console') {\n format = runtime.format as OutputFormat;\n } else {\n format = shouldUseAnsi(runtime.env(), runtime.terminal?.isTTY) ? 'ansi' : 'text';\n }\n\n const terminalWidth = format === 'markdown' || format === 'html' ? undefined : (runtime.terminal?.columns ?? DEFAULT_TERMINAL_WIDTH);\n\n let styler: Styler;\n let layout: LayoutConfig;\n\n switch (format) {\n case 'ansi':\n styler = createAnsiStyler(runtime.theme);\n layout = createTextLayout();\n break;\n case 'markdown':\n styler = createMarkdownStyler();\n layout = createMarkdownLayout();\n break;\n case 'html':\n styler = createHtmlStyler();\n layout = createHtmlLayout();\n break;\n default:\n styler = createTextStyler();\n layout = createTextLayout();\n break;\n }\n\n return { format, styler, layout, terminalWidth };\n}\n","import type { AnyPadroneCommand } from '../types/index.ts';\n\nexport function getRootCommand(cmd: AnyPadroneCommand): AnyPadroneCommand {\n let current = cmd;\n while (current.parent) current = current.parent;\n return current;\n}\n\nasync function readVersionFromPackageJson(): Promise<string> {\n try {\n const fs = await import('node:fs');\n const path = await import('node:path');\n let dir = process.cwd();\n\n // Walk up the directory tree looking for package.json\n for (let i = 0; i < 10; i++) {\n const pkgPath = path.join(dir, 'package.json');\n if (fs.existsSync(pkgPath)) {\n const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8'));\n if (pkg.version) return pkg.version;\n }\n const parentDir = path.dirname(dir);\n if (parentDir === dir) break; // Reached root\n dir = parentDir;\n }\n } catch {\n // Ignore errors (e.g., fs not available in browser)\n }\n return '0.0.0';\n}\n\n/**\n * Attempts to get the version from various sources:\n * 1. Explicit version set on the command\n * 2. npm_package_version environment variable (set by npm/yarn/pnpm when running scripts)\n * 3. package.json in current or parent directories\n *\n * Returns synchronously when an explicit version or env var is available.\n * Falls back to async package.json discovery otherwise.\n */\nexport function getVersion(explicitVersion?: string): string | Promise<string> {\n if (explicitVersion) return explicitVersion;\n\n if (typeof process !== 'undefined' && process.env?.npm_package_version) {\n return process.env.npm_package_version;\n }\n\n if (typeof process !== 'undefined') return readVersionFromPackageJson();\n\n return '0.0.0';\n}\n","import { camelToKebab } from '../util/shell-utils.ts';\nimport type { ColorConfig, ColorTheme } from './colorizer.ts';\nimport {\n createAnsiStyler,\n createConsoleStyler,\n createHtmlLayout,\n createHtmlStyler,\n createMarkdownLayout,\n createMarkdownStyler,\n createTextLayout,\n createTextStyler,\n DEFAULT_TERMINAL_WIDTH,\n type LayoutConfig,\n type Styler,\n shouldUseAnsi,\n wrapText,\n} from './styling.ts';\n\nexport type HelpFormat = 'text' | 'ansi' | 'console' | 'markdown' | 'html' | 'json';\nexport type HelpDetail = 'minimal' | 'standard' | 'full';\n\n// ============================================================================\n// Help Info Types (shared with help.ts)\n// ============================================================================\n\n/**\n * Information about a single positional argument.\n */\nexport type HelpPositionalInfo = {\n name: string;\n description?: string;\n optional: boolean;\n default?: unknown;\n type?: string;\n enum?: string[];\n};\n\n/**\n * Information about a single argument/flag.\n */\nexport type HelpArgumentInfo = {\n name: string;\n description?: string;\n optional: boolean;\n default?: unknown;\n type?: string;\n enum?: string[];\n /** Single-character short flags (shown as `-v`) */\n flags?: string[];\n /** Multi-character alternative long names (shown as `--dry-run`) */\n aliases?: string[];\n deprecated?: boolean | string;\n hidden?: boolean;\n examples?: unknown[];\n /** Environment variable(s) this arg can be set from */\n env?: string | string[];\n /** Whether this arg is an array type (shown as <type...>) */\n variadic?: boolean;\n /** Whether this arg is a boolean (shown as --[no-]arg) */\n negatable?: boolean;\n /** Config file key that maps to this arg */\n configKey?: string;\n /** Group name for organizing this option under a labeled section in help output */\n group?: string;\n};\n\n/**\n * Information about a subcommand (minimal info for listing).\n */\nexport type HelpSubcommandInfo = {\n name: string;\n title?: string;\n description?: string;\n aliases?: string[];\n deprecated?: boolean | string;\n hidden?: boolean;\n hasSubcommands?: boolean;\n /** Group name for organizing this command under a labeled section in help output */\n group?: string;\n};\n\n/**\n * Information about a built-in command/flag entry.\n */\nexport type HelpBuiltinInfo = {\n name: string;\n description?: string;\n sub?: { name: string; description?: string }[];\n};\n\n/**\n * Comprehensive JSON structure for help information.\n * This is the single source of truth that all formatters use.\n */\nexport type HelpInfo = {\n /** The full command name (e.g., \"cli serve\" or \"<root>\") */\n name: string;\n /** Short title for the command */\n title?: string;\n /** Command description */\n description?: string;\n /** Alternative names/aliases for this command */\n aliases?: string[];\n /** Whether the command is deprecated */\n deprecated?: boolean | string;\n /** Whether the command is hidden */\n hidden?: boolean;\n /** Usage string parts for flexible formatting */\n usage: {\n command: string;\n hasSubcommands: boolean;\n hasPositionals: boolean;\n hasArguments: boolean;\n /** The name of the field that reads from stdin, if any. Shown as `[stdin > field]` in usage. */\n stdinField?: string;\n };\n /** List of subcommands */\n subcommands?: HelpSubcommandInfo[];\n /** Positional arguments */\n positionals?: HelpPositionalInfo[];\n /** Arguments/flags (only visible ones, hidden filtered out) */\n arguments?: HelpArgumentInfo[];\n /** Built-in commands and flags (shown only for root command) */\n builtins?: HelpBuiltinInfo[];\n /** Command-level usage examples (shown in help output) */\n examples?: string[];\n /** Full help info for nested commands (used in 'full' detail mode) */\n nestedCommands?: HelpInfo[];\n};\n\n// ============================================================================\n// Formatter Interface\n// ============================================================================\n\n/**\n * A formatter that takes the entire HelpInfo structure and produces formatted output.\n */\nexport type Formatter = {\n /** Format the entire help info structure into a string */\n format: (info: HelpInfo) => string;\n};\n\n// ============================================================================\n// Generic Formatter Implementation\n// ============================================================================\n\n/**\n * Creates a formatter that uses the given styler and layout configuration.\n */\nfunction createGenericFormatter(styler: Styler, layout: LayoutConfig, showAllBuiltins?: boolean, terminalWidth?: number): Formatter {\n const { newline, indent, join, wrapDocument } = layout;\n\n function formatUsageSection(info: HelpInfo): string[] {\n const usageParts: string[] = [styler.command(info.usage.command), info.usage.hasSubcommands ? styler.meta('[command]') : ''];\n // Show actual positional argument names in usage line\n if (info.positionals && info.positionals.length > 0) {\n for (const arg of info.positionals) {\n const name = arg.name.startsWith('...') ? `${arg.name}` : arg.name;\n usageParts.push(styler.meta(arg.optional ? `[${name}]` : `<${name}>`));\n }\n }\n if (info.usage.hasArguments) usageParts.push(styler.meta('[options]'));\n return [`${styler.label('Usage:')} ${join(usageParts)}`];\n }\n\n function formatSubcommandsSection(info: HelpInfo): string[] {\n const lines: string[] = [];\n const subcommands = info.subcommands!;\n\n const subcommandSuffix = (c: HelpSubcommandInfo) => (c.hasSubcommands ? ' <subcommand>' : '');\n const formatAliasParts = (c: HelpSubcommandInfo) => {\n if (!c.aliases?.length) return { plain: '', styled: '' };\n const realAliases = c.aliases.filter((a) => a !== '[default]');\n const hasDefault = c.aliases.some((a) => a === '[default]');\n const parts: string[] = [];\n const styledParts: string[] = [];\n if (realAliases.length) {\n parts.push(`(${realAliases.join(', ')})`);\n styledParts.push(`(${realAliases.join(', ')})`);\n }\n if (hasDefault) {\n parts.push('[default]');\n styledParts.push(styler.meta('[default]'));\n }\n return { plain: parts.length ? ` ${parts.join(' ')}` : '', styled: styledParts.length ? ` ${styledParts.join(' ')}` : '' };\n };\n // Column width is computed across all subcommands for consistent alignment\n const maxNameLength = Math.max(\n ...subcommands.map((c) => {\n return (c.name + subcommandSuffix(c) + formatAliasParts(c).plain).length;\n }),\n );\n\n const grouped = Object.groupBy(subcommands, (c) => c.group ?? '');\n\n const renderSubcommands = (cmds: HelpSubcommandInfo[]) => {\n for (const subCmd of cmds) {\n const aliasParts = formatAliasParts(subCmd);\n const suffix = subcommandSuffix(subCmd);\n const commandDisplay = subCmd.name + suffix + aliasParts.plain;\n const padding = ' '.repeat(Math.max(0, maxNameLength - commandDisplay.length + 2));\n const isDeprecated = !!subCmd.deprecated;\n const isDefaultEntry = subCmd.name === '[default]';\n const commandName = isDeprecated\n ? styler.deprecated(commandDisplay)\n : (isDefaultEntry ? styler.meta(subCmd.name) : styler.command(subCmd.name)) +\n (suffix ? styler.meta(suffix) : '') +\n aliasParts.styled;\n const lineParts: string[] = [commandName, padding];\n\n // Use title if available, otherwise use description\n const displayText = subCmd.title ?? subCmd.description;\n if (displayText) {\n lineParts.push(isDeprecated ? styler.deprecated(displayText) : styler.description(displayText));\n }\n if (isDeprecated) {\n const deprecatedMeta =\n typeof subCmd.deprecated === 'string' ? styler.meta(` (deprecated: ${subCmd.deprecated})`) : styler.meta(' (deprecated)');\n lineParts.push(deprecatedMeta);\n }\n lines.push(indent(1) + lineParts.join(''));\n }\n };\n\n for (const [key, items] of Object.entries(grouped)) {\n if (lines.length > 0) lines.push('');\n lines.push(styler.section(key ? `${key}:` : 'Commands:'));\n renderSubcommands(items!);\n }\n\n // Skip hint when builtins are present — the builtins section shows a combined hint\n if (!info.builtins?.length) {\n lines.push('');\n lines.push(styler.meta(`Run \"${info.name} [command] --help\" for more information on a command.`));\n }\n\n return lines;\n }\n\n function formatPositionalsSection(info: HelpInfo): string[] {\n const lines: string[] = [];\n const args = info.positionals!;\n\n lines.push(styler.section('Arguments:'));\n\n const maxNameLength = Math.min(32, Math.max(...args.map((a) => a.name.length)));\n const descCol = 2 + maxNameLength + 2;\n const posAvailWidth = terminalWidth ? terminalWidth - descCol : undefined;\n const descColPad = ' '.repeat(descCol);\n\n for (const arg of args) {\n const padding = ' '.repeat(Math.max(2, maxNameLength - arg.name.length + 2));\n const prefix = indent(1) + styler.arg(arg.name) + padding;\n\n const descPlain = arg.description ?? '';\n const styledDesc = descPlain ? styler.description(descPlain) : '';\n\n const metaParts: string[] = [];\n const styledMetaParts: string[] = [];\n if (info.usage.stdinField === arg.name) {\n metaParts.push('(stdin)');\n styledMetaParts.push(styler.meta('(stdin)'));\n }\n if (arg.enum) {\n const text = `(choices: ${arg.enum.join(', ')})`;\n metaParts.push(text);\n styledMetaParts.push(styler.meta(text));\n }\n if (arg.default !== undefined) {\n const text = `(default: ${String(arg.default)})`;\n metaParts.push(text);\n styledMetaParts.push(styler.meta(text));\n }\n\n const metaStyled = join(styledMetaParts);\n\n if (posAvailWidth && posAvailWidth > 0) {\n const metaPlain = metaParts.join(' ');\n const fullPlain = [descPlain, metaPlain].filter(Boolean).join(' ');\n if (fullPlain.length <= posAvailWidth) {\n lines.push(prefix + [styledDesc, metaStyled].filter(Boolean).join(' '));\n } else if (!descPlain || descPlain.length <= posAvailWidth) {\n lines.push(prefix + styledDesc);\n if (metaStyled) lines.push(descColPad + metaStyled);\n } else {\n const wrapped = wrapText(descPlain, posAvailWidth);\n lines.push(prefix + styler.description(wrapped[0]!));\n for (const wline of wrapped.slice(1)) lines.push(descColPad + styler.description(wline));\n if (metaStyled) lines.push(descColPad + metaStyled);\n }\n } else {\n lines.push(prefix + join([styledDesc, metaStyled]));\n }\n }\n\n return lines;\n }\n\n function formatArgumentsSection(info: HelpInfo): string[] {\n const lines: string[] = [];\n const argList = info.arguments || [];\n\n // Helper to check if a default value is meaningful (not empty string/array)\n const hasDefault = (value: unknown): boolean => {\n if (value === undefined) return false;\n if (value === '') return false;\n if (Array.isArray(value) && value.length === 0) return false;\n return true;\n };\n\n // Build columns: flags | names | type | description\n const argColumns = argList.map((arg) => {\n // Promote kebab-case alias to primary display name if it exists\n const kebab = camelToKebab(arg.name);\n const primaryName = kebab && arg.aliases?.includes(kebab) ? kebab : arg.name;\n const remainingAliases = arg.aliases?.filter((a) => a !== primaryName);\n\n const flagsPlain = arg.flags?.length ? arg.flags.map((f) => `-${f}`).join(', ') : '';\n const namesPlain = [`--${primaryName}`, ...(remainingAliases?.map((a) => `--${a}`) || [])].join(', ');\n const typePlain = arg.type && arg.type !== 'boolean' ? (arg.optional ? `[${arg.type}]` : `<${arg.type}>`) : '';\n\n const isDeprecated = !!arg.deprecated;\n\n return { flagsPlain, namesPlain, typePlain, isDeprecated, arg };\n });\n\n // Column widths are computed across all args (regardless of group) for consistent alignment\n const maxFlagsWidth = Math.min(12, Math.max(0, ...argColumns.map((c) => c.flagsPlain.length)));\n const maxNamesWidth = Math.min(32, Math.max(0, ...argColumns.map((c) => c.namesPlain.length)));\n const maxTypeWidth = Math.min(16, Math.max(0, ...argColumns.map((c) => c.typePlain.length)));\n const hasAnyFlags = maxFlagsWidth > 0;\n const descCol = 2 + (hasAnyFlags ? maxFlagsWidth + 2 : 0) + maxNamesWidth + 2 + (maxTypeWidth > 0 ? maxTypeWidth + 2 : 0);\n const argAvailWidth = terminalWidth ? terminalWidth - descCol : undefined;\n const descColPad = ' '.repeat(descCol);\n\n // Split into ordered groups: ungrouped first as \"Options:\", then each group in first-seen order\n const grouped = Object.groupBy(argColumns, (c) => c.arg.group ?? '');\n\n const renderArgColumns = (columns: typeof argColumns) => {\n for (const { flagsPlain, namesPlain, typePlain, isDeprecated, arg } of columns) {\n const parts: string[] = [];\n\n // Flags column\n if (hasAnyFlags) {\n const styledFlags = isDeprecated ? (flagsPlain ? styler.deprecated(flagsPlain) : '') : flagsPlain ? styler.arg(flagsPlain) : '';\n const flagsPadding = ' '.repeat(Math.max(0, maxFlagsWidth - flagsPlain.length));\n const separator = flagsPlain ? ', ' : ' ';\n parts.push(styledFlags + flagsPadding + separator);\n }\n\n // Names column\n const styledNames = isDeprecated ? styler.deprecated(namesPlain) : styler.arg(namesPlain);\n const namesPadding = ' '.repeat(Math.max(2, maxNamesWidth - namesPlain.length + 2));\n parts.push(styledNames + namesPadding);\n\n // Type column\n if (maxTypeWidth > 0) {\n const styledType = typePlain ? styler.type(typePlain) : '';\n const typePadding = ' '.repeat(Math.max(2, maxTypeWidth - typePlain.length + 2));\n parts.push(styledType + typePadding);\n }\n\n const prefix = indent(1) + parts.join('');\n const contPad = argAvailWidth ? descColPad : indent(3);\n\n // Build inline meta (deprecated no-reason, default, choices)\n const inlineMeta: string[] = [];\n const styledInlineMeta: string[] = [];\n if (isDeprecated && typeof arg.deprecated !== 'string') {\n inlineMeta.push('(deprecated)');\n styledInlineMeta.push(styler.meta('(deprecated)'));\n }\n if (hasDefault(arg.default)) {\n const text = `(default: ${String(arg.default)})`;\n inlineMeta.push(text);\n styledInlineMeta.push(styler.meta(text));\n }\n if (arg.enum) {\n const text = `(choices: ${arg.enum.join(', ')})`;\n inlineMeta.push(text);\n styledInlineMeta.push(styler.meta(text));\n }\n\n const descPlain = arg.description ?? '';\n const styledDesc = descPlain ? (isDeprecated ? styler.deprecated(descPlain) : styler.description(descPlain)) : '';\n const metaStyled = join(styledInlineMeta);\n\n if (argAvailWidth && argAvailWidth > 0) {\n // Terminal-width-aware: try to fit description + meta on one line\n const metaPlain = inlineMeta.join(' ');\n const fullPlain = [descPlain, metaPlain].filter(Boolean).join(' ');\n if (fullPlain.length <= argAvailWidth) {\n lines.push(prefix + [styledDesc, metaStyled].filter(Boolean).join(' '));\n } else if (!descPlain || descPlain.length <= argAvailWidth) {\n lines.push(prefix + styledDesc);\n if (metaStyled) lines.push(descColPad + metaStyled);\n } else {\n const wrapped = wrapText(descPlain, argAvailWidth);\n const styleFn = isDeprecated ? styler.deprecated : styler.description;\n lines.push(prefix + styleFn(wrapped[0]!));\n for (const wline of wrapped.slice(1)) lines.push(descColPad + styleFn(wline));\n if (metaStyled) lines.push(descColPad + metaStyled);\n }\n } else {\n // No terminal width (markdown/html): description on line 1, meta on line 2\n const descParts: string[] = [];\n if (styledDesc) descParts.push(styledDesc);\n lines.push(prefix + join(descParts));\n if (styledInlineMeta.length > 0) lines.push(indent(3) + metaStyled);\n }\n\n // Deprecated (with reason), examples — always on separate line\n const line3Parts: string[] = [];\n if (isDeprecated && typeof arg.deprecated === 'string') line3Parts.push(styler.meta(`(deprecated: ${arg.deprecated})`));\n if (arg.examples && arg.examples.length > 0) {\n const exampleValues = arg.examples.map((example) => (typeof example === 'string' ? example : JSON.stringify(example))).join(', ');\n line3Parts.push(styler.example('Example:'), styler.exampleValue(exampleValues));\n }\n if (line3Parts.length > 0) lines.push(contPad + join(line3Parts));\n\n // stdin, env, config — always on separate line\n const line4Parts: string[] = [];\n if (info.usage.stdinField === arg.name) line4Parts.push(styler.meta('(stdin)'));\n if (arg.env) {\n const envVars = typeof arg.env === 'string' ? [arg.env] : arg.env;\n line4Parts.push(styler.example('Env:'), styler.exampleValue(envVars.join(', ')));\n }\n if (arg.configKey) {\n line4Parts.push(styler.example('Config:'), styler.exampleValue(arg.configKey));\n }\n if (line4Parts.length > 0) lines.push(contPad + join(line4Parts));\n }\n };\n\n for (const [key, items] of Object.entries(grouped)) {\n if (lines.length > 0) lines.push('');\n lines.push(styler.section(key ? `${key}:` : 'Options:'));\n renderArgColumns(items!);\n }\n\n return lines;\n }\n\n function formatBuiltinsSection(info: HelpInfo): string[] {\n const lines: string[] = [];\n const builtins = info.builtins!;\n\n if (!showAllBuiltins) {\n // Collapsed summary: show selected builtins on a single line with a combined hint\n const highlights = ['help [command]', 'version', '[command] --repl'];\n lines.push(`${styler.label('Global:')} ${styler.meta(highlights.join(', '))}`);\n const hint = info.usage.hasSubcommands\n ? `Run \"${info.name} [command] --help\" for more information. Use \"--all\" for all global commands.`\n : `Use \"${info.name} help --all\" for more information on global commands.`;\n lines.push(styler.meta(hint));\n return lines;\n }\n\n lines.push(styler.section('Global:'));\n\n // Compute max effective name length for alignment across main and sub entries\n const allLengths: number[] = [];\n for (const entry of builtins) {\n allLengths.push(entry.name.length);\n if (entry.sub) {\n for (const sub of entry.sub) {\n // Sub entries get extra indent(2) - indent(1) = 2 chars\n allLengths.push(sub.name.length + 2);\n }\n }\n }\n const maxLen = Math.max(...allLengths);\n\n for (const entry of builtins) {\n const padding = ' '.repeat(Math.max(2, maxLen - entry.name.length + 2));\n const parts: string[] = [styler.command(entry.name)];\n if (entry.description) parts.push(padding + styler.description(entry.description));\n lines.push(indent(1) + parts.join(''));\n\n if (entry.sub) {\n for (const sub of entry.sub) {\n const subPadding = ' '.repeat(Math.max(2, maxLen - sub.name.length));\n const subParts: string[] = [styler.arg(sub.name)];\n if (sub.description) subParts.push(subPadding + styler.description(sub.description));\n lines.push(indent(2) + subParts.join(''));\n }\n }\n }\n\n return lines;\n }\n\n return {\n format(info: HelpInfo): string {\n const lines: string[] = [];\n\n // Show deprecation warning at the top if command is deprecated\n if (info.deprecated) {\n const deprecationMessage =\n typeof info.deprecated === 'string' ? `⚠️ This command is deprecated: ${info.deprecated}` : '⚠️ This command is deprecated';\n lines.push(styler.deprecated(deprecationMessage));\n lines.push('');\n }\n\n // Usage section\n lines.push(...formatUsageSection(info));\n lines.push('');\n\n // Title section (if present, shows a short summary line)\n if (info.title) {\n lines.push(styler.label(info.title));\n lines.push('');\n }\n\n // Aliases section (if present)\n if (info.aliases && info.aliases.length > 0) {\n lines.push(styler.meta(`Aliases: ${info.aliases.join(', ')}`));\n lines.push('');\n }\n\n // Description section (if present)\n if (info.description) {\n lines.push(styler.description(info.description));\n lines.push('');\n }\n\n // Examples section (if present)\n if (info.examples && info.examples.length > 0) {\n lines.push(styler.section('Examples:'));\n for (const ex of info.examples) {\n lines.push(indent(1) + styler.meta('$ ') + styler.exampleValue(ex));\n }\n lines.push('');\n }\n\n // Subcommands section\n if (info.subcommands && info.subcommands.length > 0) {\n lines.push(...formatSubcommandsSection(info));\n lines.push('');\n }\n\n if (info.positionals && info.positionals.length > 0) {\n lines.push(...formatPositionalsSection(info));\n lines.push('');\n }\n\n if (info.arguments && info.arguments.length > 0) {\n lines.push(...formatArgumentsSection(info));\n lines.push('');\n }\n\n if (info.builtins && info.builtins.length > 0) {\n lines.push(...formatBuiltinsSection(info));\n lines.push('');\n }\n\n // Show --no- hint when there are negatable boolean options defaulting to true\n if (info.arguments?.some((arg) => arg.negatable && arg.default === true)) {\n lines.push(styler.meta('Boolean options can be negated with --no-<option>.'));\n lines.push('');\n }\n\n // Nested commands section (full detail mode)\n if (info.nestedCommands?.length) {\n lines.push(styler.section('Subcommand Details:'));\n lines.push('');\n for (const nestedCmd of info.nestedCommands) {\n lines.push(styler.meta('─'.repeat(60)));\n lines.push(this.format(nestedCmd));\n }\n }\n\n const result = lines.join(newline);\n return wrapDocument ? wrapDocument(result) : result;\n },\n };\n}\n\n// ============================================================================\n// JSON Formatter\n// ============================================================================\n\nfunction createJsonFormatter(): Formatter {\n return {\n format(info: HelpInfo): string {\n return JSON.stringify(info, null, 2);\n },\n };\n}\n\n// ============================================================================\n// Minimal Formatter\n// ============================================================================\n\n/**\n * Creates a minimal formatter that outputs just a single-line usage string.\n */\nfunction createMinimalFormatter(): Formatter {\n return {\n format(info: HelpInfo): string {\n const parts: string[] = [info.usage.command];\n if (info.usage.hasSubcommands) parts.push('[command]');\n if (info.positionals && info.positionals.length > 0) {\n for (const arg of info.positionals) {\n const name = arg.name.startsWith('...') ? `${arg.name}` : arg.name;\n parts.push(arg.optional ? `[${name}]` : `<${name}>`);\n }\n }\n if (info.usage.hasArguments) parts.push('[options]');\n return parts.join(' ');\n },\n };\n}\n\nexport function createFormatter(\n format: HelpFormat | 'auto',\n detail: HelpDetail = 'standard',\n theme?: ColorTheme | ColorConfig,\n all?: boolean,\n width?: number,\n terminal?: { columns?: number; isTTY?: boolean },\n env?: Record<string, string | undefined>,\n): Formatter {\n if (detail === 'minimal') return createMinimalFormatter();\n if (format === 'json') return createJsonFormatter();\n const tw = format === 'markdown' || format === 'html' ? undefined : (width ?? terminal?.columns ?? DEFAULT_TERMINAL_WIDTH);\n if (format === 'ansi' || (format === 'auto' && shouldUseAnsi(env, terminal?.isTTY)))\n return createGenericFormatter(createAnsiStyler(theme), createTextLayout(), all, tw);\n if (format === 'console') return createGenericFormatter(createConsoleStyler(theme), createTextLayout(), all, tw);\n if (format === 'markdown') return createGenericFormatter(createMarkdownStyler(), createMarkdownLayout(), all);\n if (format === 'html') return createGenericFormatter(createHtmlStyler(), createHtmlLayout(), all);\n return createGenericFormatter(createTextStyler(), createTextLayout(), all, tw);\n}\n","import type { StandardJSONSchemaV1 } from '@standard-schema/spec';\nimport { extractSchemaMetadata, getJsonSchema, type PadroneArgsSchemaMeta, parsePositionalConfig } from '../core/args.ts';\nimport { findCommandByName } from '../core/commands.ts';\nimport type { AnyPadroneCommand } from '../types/index.ts';\nimport { getRootCommand } from '../util/utils.ts';\nimport type { ColorConfig, ColorTheme } from './colorizer.ts';\nimport {\n createFormatter,\n type HelpArgumentInfo,\n type HelpDetail,\n type HelpFormat,\n type HelpInfo,\n type HelpPositionalInfo,\n type HelpSubcommandInfo,\n} from './formatter.ts';\n\nexport type HelpPreferences = {\n format?: HelpFormat | 'auto';\n detail?: HelpDetail;\n theme?: ColorTheme | ColorConfig;\n /** Show all global commands and flags in full detail */\n all?: boolean;\n /** Terminal width for text wrapping. Defaults to terminal columns or 80. */\n width?: number;\n /** Terminal capabilities for auto-detection of ANSI and width. */\n terminal?: { columns?: number; isTTY?: boolean };\n /** Environment variables for auto-detection (e.g., NO_COLOR, CI). */\n env?: Record<string, string | undefined>;\n};\n\n/**\n * Extract positional arguments info from schema based on meta.positional config.\n */\nfunction extractPositionalArgsInfo(\n schema: StandardJSONSchemaV1,\n meta?: PadroneArgsSchemaMeta,\n): { args: HelpPositionalInfo[]; positionalNames: Set<string> } {\n const args: HelpPositionalInfo[] = [];\n const positionalNames = new Set<string>();\n\n if (!schema || !meta?.positional || meta.positional.length === 0) {\n return { args, positionalNames };\n }\n\n const positionalConfig = parsePositionalConfig(meta.positional);\n\n try {\n const jsonSchema = getJsonSchema(schema) as Record<string, any>;\n\n if (jsonSchema.type === 'object' && jsonSchema.properties) {\n const properties = jsonSchema.properties as Record<string, any>;\n const required = (jsonSchema.required as string[]) || [];\n\n for (const { name, variadic } of positionalConfig) {\n const prop = properties[name];\n if (!prop) continue;\n\n positionalNames.add(name);\n const optMeta = meta.fields?.[name];\n\n args.push({\n name: variadic ? `...${name}` : name,\n description: optMeta?.description ?? prop.description,\n optional: !required.includes(name),\n default: prop.default,\n type: variadic ? `array<${prop.items?.type || 'string'}>` : prop.type,\n enum: (prop.enum ?? prop.items?.enum) as string[] | undefined,\n });\n }\n }\n } catch {\n // Fallback to empty result if toJSONSchema fails\n }\n\n return { args, positionalNames };\n}\n\nfunction extractArgsInfo(schema: StandardJSONSchemaV1, meta?: PadroneArgsSchemaMeta, positionalNames?: Set<string>) {\n const result: HelpArgumentInfo[] = [];\n if (!schema) return result;\n\n const vendor = schema['~standard'].vendor;\n if (!vendor.includes('zod')) return result;\n\n const argsMeta = meta?.fields;\n\n try {\n const jsonSchema = getJsonSchema(schema) as Record<string, any>;\n\n // Handle object: z.object({ key: z.string(), ... })\n if (jsonSchema.type === 'object' && jsonSchema.properties) {\n const properties = jsonSchema.properties as Record<string, any>;\n const required = (jsonSchema.required as string[]) || [];\n const propertyNames = new Set(Object.keys(properties));\n\n // Helper to check if a negated version of an arg exists\n const hasExplicitNegation = (key: string): boolean => {\n // Check for noVerbose style (camelCase)\n const camelNegated = `no${key.charAt(0).toUpperCase()}${key.slice(1)}`;\n if (propertyNames.has(camelNegated)) return true;\n // Check for no-verbose style (kebab-case, though rare in JS)\n const kebabNegated = `no-${key}`;\n if (propertyNames.has(kebabNegated)) return true;\n return false;\n };\n\n // Helper to check if this arg is itself a negation of another arg\n const isNegationOf = (key: string): boolean => {\n // Check for noVerbose -> verbose (camelCase)\n if (key.startsWith('no') && key.length > 2 && key[2] === key[2]?.toUpperCase()) {\n const positiveKey = key.charAt(2).toLowerCase() + key.slice(3);\n if (propertyNames.has(positiveKey)) return true;\n }\n // Check for no-verbose -> verbose (kebab-case)\n if (key.startsWith('no-')) {\n const positiveKey = key.slice(3);\n if (propertyNames.has(positiveKey)) return true;\n }\n return false;\n };\n\n for (const [key, prop] of Object.entries(properties)) {\n // Skip positional arguments - they are shown in arguments section\n if (positionalNames?.has(key)) continue;\n\n const isOptional = !required.includes(key);\n const enumValues = (prop.enum ?? prop.items?.enum) as string[] | undefined;\n const optMeta = argsMeta?.[key];\n const propType = prop.type as string;\n\n // Booleans are negatable unless there's an explicit noArg property\n // or this arg is itself a negation of another arg\n const isNegatable = propType === 'boolean' && !hasExplicitNegation(key) && !isNegationOf(key);\n\n result.push({\n name: key,\n description: optMeta?.description ?? prop.description,\n optional: isOptional,\n default: prop.default,\n type: propType === 'array' ? `${prop.items?.type || 'string'}[]` : propType,\n enum: enumValues,\n deprecated: optMeta?.deprecated ?? prop?.deprecated,\n hidden: optMeta?.hidden ?? prop?.hidden,\n examples: optMeta?.examples ?? prop?.examples,\n variadic: propType === 'array',\n negatable: isNegatable,\n group: optMeta?.group,\n });\n }\n }\n } catch {\n // Fallback to empty result if toJSONSchema fails\n }\n\n return result;\n}\n\n// ============================================================================\n// Core Help Info Builder\n// ============================================================================\n\n/**\n * Builds a comprehensive HelpInfo structure from a command.\n * This is the single source of truth that all formatters use.\n * @param cmd - The command to build help info for\n * @param detail - The level of detail ('minimal', 'standard', or 'full')\n */\nexport function getHelpInfo(cmd: AnyPadroneCommand, detail: HelpPreferences['detail'] = 'standard', all?: boolean): HelpInfo {\n const rootCmd = getRootCommand(cmd);\n // A command is a \"default\" command if its name is '' or it has '' as an alias\n const isDefaultCommand = cmd.parent && (!cmd.name || cmd.aliases?.includes(''));\n // For commands with empty name, use the first non-empty alias as display name\n const nonEmptyAliases = cmd.aliases?.filter(Boolean);\n const commandName = cmd.path || cmd.name || nonEmptyAliases?.[0] || (cmd.parent ? '[default]' : 'program');\n // Build display aliases: real aliases (excluding the one promoted to display name) + [default] marker\n const remainingAliases = !cmd.name && nonEmptyAliases?.length ? nonEmptyAliases.slice(1) : (nonEmptyAliases ?? []);\n const displayAliases = isDefaultCommand ? [...remainingAliases, '[default]'] : nonEmptyAliases;\n\n // Extract positional args from schema based on meta.positional\n const { args: positionalArgs, positionalNames } = cmd.argsSchema\n ? extractPositionalArgsInfo(cmd.argsSchema, cmd.meta)\n : { args: [], positionalNames: new Set<string>() };\n\n const hasPositionals = positionalArgs.length > 0;\n\n const helpInfo: HelpInfo = {\n name: commandName,\n title: cmd.title,\n description: cmd.description,\n examples: cmd.examples,\n aliases: displayAliases,\n deprecated: cmd.deprecated,\n hidden: cmd.hidden,\n usage: {\n command: rootCmd === cmd ? commandName : `${rootCmd.name} ${commandName}`,\n hasSubcommands: !!(cmd.commands && cmd.commands.length > 0),\n hasPositionals,\n hasArguments: false, // updated below after extracting arguments\n stdinField: cmd.meta?.stdin,\n },\n };\n\n // Build subcommands info (filter out hidden commands unless showing full detail)\n if (cmd.commands && cmd.commands.length > 0) {\n const visibleCommands = detail === 'full' ? cmd.commands : cmd.commands.filter((c) => !c.hidden);\n // If the command has both a handler and subcommands, show the handler as a \"[default]\" entry\n const selfEntry: typeof helpInfo.subcommands = cmd.action\n ? [{ name: '[default]', title: cmd.title, description: cmd.description }]\n : [];\n\n helpInfo.subcommands = [\n ...selfEntry,\n ...visibleCommands.flatMap((c): HelpSubcommandInfo[] => {\n const isDefault = !c.name || c.aliases?.includes('');\n const nonEmptyAliases = c.aliases?.filter(Boolean);\n const displayName = c.name || nonEmptyAliases?.[0] || '[default]';\n const remainingAliases = !c.name && nonEmptyAliases?.length ? nonEmptyAliases.slice(1) : (nonEmptyAliases ?? []);\n // Only add [default] alias marker if it's not already the display name\n const displayAliases =\n isDefault && displayName !== '[default]' ? [...remainingAliases, '[default]'] : isDefault ? remainingAliases : nonEmptyAliases;\n const hasSubcommands = !!(c.commands && c.commands.length > 0);\n\n // If a command has subcommands AND a default handler (direct or '' subcommand),\n // show two entries: one for the default action, one for the subcommand router\n const hasDefaultHandler = c.action || c.commands?.some((sub) => !sub.name || sub.aliases?.includes(''));\n if (hasSubcommands && hasDefaultHandler) {\n const defaultSub = !c.action ? c.commands?.find((sub) => !sub.name || sub.aliases?.includes('')) : undefined;\n const hasDefaultSubInfo = defaultSub && (defaultSub.title || defaultSub.description);\n return [\n {\n name: displayName,\n title: hasDefaultSubInfo ? defaultSub.title : c.title,\n description: hasDefaultSubInfo ? defaultSub.description : c.description,\n aliases: displayAliases?.length ? displayAliases : undefined,\n deprecated: c.deprecated,\n hidden: c.hidden,\n group: c.group,\n },\n {\n name: displayName,\n title: c.title,\n description: c.description,\n deprecated: c.deprecated,\n hidden: c.hidden,\n hasSubcommands: true,\n group: c.group,\n },\n ];\n }\n\n return [\n {\n name: displayName,\n title: c.title,\n description: c.description,\n aliases: displayAliases?.length ? displayAliases : undefined,\n deprecated: c.deprecated,\n hidden: c.hidden,\n hasSubcommands,\n group: c.group,\n },\n ];\n }),\n ];\n\n // In 'full' detail mode, recursively build help for all nested commands\n if (detail === 'full') {\n helpInfo.nestedCommands = visibleCommands.map((c) => getHelpInfo(c, 'full'));\n }\n }\n\n // Build arguments info from positionals\n if (hasPositionals) {\n helpInfo.positionals = positionalArgs;\n }\n\n // Build arguments info with aliases (excluding positional args)\n if (cmd.argsSchema) {\n const argsInfo = extractArgsInfo(cmd.argsSchema, cmd.meta, positionalNames);\n const argMap: Record<string, HelpArgumentInfo> = Object.fromEntries(argsInfo.map((arg) => [arg.name, arg]));\n\n // Merge flags and aliases into arguments\n const { flags, aliases } = extractSchemaMetadata(cmd.argsSchema, cmd.meta?.fields, cmd.meta?.autoAlias);\n for (const [flag, name] of Object.entries(flags)) {\n const arg = argMap[name];\n if (!arg) continue;\n arg.flags = [...(arg.flags || []), flag];\n }\n for (const [alias, name] of Object.entries(aliases)) {\n const arg = argMap[name];\n if (!arg) continue;\n arg.aliases = [...(arg.aliases || []), alias];\n }\n\n // Filter out hidden arguments\n const visibleArgs = argsInfo.filter((arg) => !arg.hidden);\n if (visibleArgs.length > 0) {\n helpInfo.arguments = visibleArgs;\n helpInfo.usage.hasArguments = true;\n }\n }\n\n // Add global commands/flags (root command by default, all commands when --all is passed)\n if (!cmd.parent || all) {\n const builtins: HelpInfo['builtins'] = [];\n\n if (!findCommandByName('help', rootCmd.commands)) {\n builtins.push({\n name: 'help [command], -h, --help',\n description: 'Show help for a command',\n sub: [\n { name: '--all', description: 'Show all global commands and flags' },\n { name: '--detail <level>', description: 'Detail level (minimal, standard, full)' },\n { name: '--format <format>', description: 'Output format (text, ansi, json, markdown, html)' },\n ],\n });\n }\n\n if (!findCommandByName('version', rootCmd.commands)) {\n builtins.push({\n name: 'version, -v, --version',\n description: 'Show version information',\n });\n }\n\n if (!findCommandByName('completion', rootCmd.commands)) {\n builtins.push({\n name: 'completion [shell]',\n description: 'Generate shell completions (bash, zsh, fish, powershell)',\n });\n }\n\n if (!findCommandByName('man', rootCmd.commands)) {\n builtins.push({\n name: 'man',\n description: 'Show or install man pages (--setup to install, --remove to uninstall) (experimental)',\n });\n }\n\n builtins.push({\n name: '[command] --repl',\n description: 'Start interactive REPL scoped to a command',\n });\n\n if (!findCommandByName('mcp', rootCmd.commands)) {\n builtins.push({\n name: 'mcp [http|stdio]',\n description: 'Start a Model Context Protocol server to expose commands as AI tools (experimental)',\n sub: [\n { name: '--port <port>', description: 'HTTP port (default: 3000)' },\n { name: '--host <host>', description: 'HTTP host (default: 127.0.0.1)' },\n ],\n });\n }\n\n builtins.push({\n name: '--color [theme], --no-color',\n description: 'Set color theme (default, ocean, warm, monochrome) or disable colors',\n });\n\n if (builtins.length > 0) {\n helpInfo.builtins = builtins;\n }\n }\n\n return helpInfo;\n}\n\n// ============================================================================\n// Main Entry Point\n// ============================================================================\n\nexport function generateHelp(rootCommand: AnyPadroneCommand, commandObj: AnyPadroneCommand = rootCommand, prefs?: HelpPreferences): string {\n const helpInfo = getHelpInfo(commandObj, prefs?.detail, prefs?.all);\n const formatter = createFormatter(\n prefs?.format ?? 'auto',\n prefs?.detail,\n prefs?.theme,\n prefs?.all,\n prefs?.width,\n prefs?.terminal,\n prefs?.env,\n );\n return formatter.format(helpInfo);\n}\n"],"mappings":"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"}