padrone 1.6.0 → 1.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/dist/docs/index.mjs +1 -1
  3. package/dist/{errors-CL63UOzt.mjs → errors-DA4KzK1M.mjs} +1 -1
  4. package/dist/{errors-CL63UOzt.mjs.map → errors-DA4KzK1M.mjs.map} +1 -1
  5. package/dist/formatter-DrvhDMrq.d.mts.map +1 -1
  6. package/dist/{help-B5Kk83of.mjs → help-BtxLgrF_.mjs} +88 -55
  7. package/dist/help-BtxLgrF_.mjs.map +1 -0
  8. package/dist/{index-BaU3X6dY.d.mts → index-C0Tab27T.d.mts} +25 -4
  9. package/dist/{index-BaU3X6dY.d.mts.map → index-C0Tab27T.d.mts.map} +1 -1
  10. package/dist/index.d.mts +143 -8
  11. package/dist/index.d.mts.map +1 -1
  12. package/dist/index.mjs +363 -24
  13. package/dist/index.mjs.map +1 -1
  14. package/dist/{mcp-BM-d0nZi.mjs → mcp-6-Jw4Bpq.mjs} +2 -2
  15. package/dist/{mcp-BM-d0nZi.mjs.map → mcp-6-Jw4Bpq.mjs.map} +1 -1
  16. package/dist/{serve-Bk0JUlCj.mjs → serve-YVTPzBCl.mjs} +3 -3
  17. package/dist/{serve-Bk0JUlCj.mjs.map → serve-YVTPzBCl.mjs.map} +1 -1
  18. package/dist/test.d.mts +1 -1
  19. package/dist/zod.d.mts +1 -1
  20. package/package.json +1 -1
  21. package/src/core/create.ts +33 -0
  22. package/src/extension/auto-output.ts +72 -21
  23. package/src/extension/config.ts +1 -1
  24. package/src/extension/index.ts +1 -0
  25. package/src/extension/logger.ts +49 -1
  26. package/src/index.ts +5 -1
  27. package/src/output/formatter.ts +16 -168
  28. package/src/output/output-indicator.ts +87 -0
  29. package/src/output/primitives.ts +335 -0
  30. package/src/output/styling.ts +221 -0
  31. package/src/types/builder.ts +87 -37
  32. package/src/types/index.ts +1 -0
  33. package/dist/help-B5Kk83of.mjs.map +0 -1
@@ -0,0 +1,221 @@
1
+ import type { PadroneActionContext } from '../types/index.ts';
2
+ import { type ColorConfig, type ColorTheme, createColorizer } from './colorizer.ts';
3
+
4
+ export const DEFAULT_TERMINAL_WIDTH = 80;
5
+
6
+ export function wrapText(text: string, maxWidth: number): string[] {
7
+ if (maxWidth <= 0 || text.length <= maxWidth) return [text];
8
+ const words = text.split(' ');
9
+ const lines: string[] = [];
10
+ let current = '';
11
+ for (const word of words) {
12
+ if (current && current.length + 1 + word.length > maxWidth) {
13
+ lines.push(current);
14
+ current = word;
15
+ } else {
16
+ current = current ? `${current} ${word}` : word;
17
+ }
18
+ }
19
+ if (current) lines.push(current);
20
+ return lines.length > 0 ? lines : [text];
21
+ }
22
+
23
+ export function escapeHtml(text: string): string {
24
+ return text.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/"/g, '&quot;').replace(/'/g, '&#039;');
25
+ }
26
+
27
+ // ── Styler ──────────────────────────────────────────────────────────────
28
+
29
+ /**
30
+ * Styling functions for semantic text roles.
31
+ * Used by formatters to apply visual styles (ANSI, HTML, Markdown, etc.)
32
+ * to different types of content.
33
+ */
34
+ export type Styler = {
35
+ command: (text: string) => string;
36
+ arg: (text: string) => string;
37
+ type: (text: string) => string;
38
+ description: (text: string) => string;
39
+ label: (text: string) => string;
40
+ section: (text: string) => string;
41
+ meta: (text: string) => string;
42
+ example: (text: string) => string;
43
+ exampleValue: (text: string) => string;
44
+ deprecated: (text: string) => string;
45
+ };
46
+
47
+ /**
48
+ * Layout configuration for formatters.
49
+ */
50
+ export type LayoutConfig = {
51
+ newline: string;
52
+ indent: (level: number) => string;
53
+ join: (parts: string[]) => string;
54
+ wrapDocument?: (content: string) => string;
55
+ };
56
+
57
+ // ── Styler Factories ────────────────────────────────────────────────────
58
+
59
+ export function createTextStyler(): Styler {
60
+ return {
61
+ command: (text) => text,
62
+ arg: (text) => text,
63
+ type: (text) => text,
64
+ description: (text) => text,
65
+ label: (text) => text,
66
+ section: (text) => text,
67
+ meta: (text) => text,
68
+ example: (text) => text,
69
+ exampleValue: (text) => text,
70
+ deprecated: (text) => text,
71
+ };
72
+ }
73
+
74
+ export function createAnsiStyler(theme?: ColorTheme | ColorConfig): Styler {
75
+ const colorizer = createColorizer(theme);
76
+ return {
77
+ command: colorizer.command,
78
+ arg: colorizer.arg,
79
+ type: colorizer.type,
80
+ description: colorizer.description,
81
+ label: colorizer.label,
82
+ section: colorizer.label,
83
+ meta: colorizer.meta,
84
+ example: colorizer.example,
85
+ exampleValue: colorizer.exampleValue,
86
+ deprecated: colorizer.deprecated,
87
+ };
88
+ }
89
+
90
+ export function createConsoleStyler(theme?: ColorTheme | ColorConfig): Styler {
91
+ return createAnsiStyler(theme);
92
+ }
93
+
94
+ export function createMarkdownStyler(): Styler {
95
+ return {
96
+ command: (text) => `**${text}**`,
97
+ arg: (text) => `\`${text}\``,
98
+ type: (text) => `\`${text}\``,
99
+ description: (text) => text,
100
+ label: (text) => `**${text}**`,
101
+ section: (text) => `### ${text}`,
102
+ meta: (text) => `*${text}*`,
103
+ example: (text) => `**${text}**`,
104
+ exampleValue: (text) => `\`${text}\``,
105
+ deprecated: (text) => `~~${text}~~`,
106
+ };
107
+ }
108
+
109
+ export function createHtmlStyler(): Styler {
110
+ return {
111
+ command: (text) => `<strong style="color: #00bcd4;">${escapeHtml(text)}</strong>`,
112
+ arg: (text) => `<code style="color: #4caf50;">${escapeHtml(text)}</code>`,
113
+ type: (text) => `<code style="color: #ff9800;">${escapeHtml(text)}</code>`,
114
+ description: (text) => `<span style="color: #666;">${escapeHtml(text)}</span>`,
115
+ label: (text) => `<strong>${escapeHtml(text)}</strong>`,
116
+ section: (text) => `<h3>${escapeHtml(text)}</h3>`,
117
+ meta: (text) => `<span style="color: #999;">${escapeHtml(text)}</span>`,
118
+ example: (text) => `<strong style="text-decoration: underline;">${escapeHtml(text)}</strong>`,
119
+ exampleValue: (text) => `<em>${escapeHtml(text)}</em>`,
120
+ deprecated: (text) => `<del style="color: #999;">${escapeHtml(text)}</del>`,
121
+ };
122
+ }
123
+
124
+ // ── Layout Factories ────────────────────────────────────────────────────
125
+
126
+ export function createTextLayout(): LayoutConfig {
127
+ return {
128
+ newline: '\n',
129
+ indent: (level) => ' '.repeat(level),
130
+ join: (parts) => parts.filter(Boolean).join(' '),
131
+ };
132
+ }
133
+
134
+ export function createMarkdownLayout(): LayoutConfig {
135
+ return {
136
+ newline: '\n\n',
137
+ indent: (level) => {
138
+ if (level === 0) return '';
139
+ if (level === 1) return ' ';
140
+ return ' ';
141
+ },
142
+ join: (parts) => parts.filter(Boolean).join(' '),
143
+ };
144
+ }
145
+
146
+ export function createHtmlLayout(): LayoutConfig {
147
+ return {
148
+ newline: '<br>',
149
+ indent: (level) => '&nbsp;&nbsp;'.repeat(level),
150
+ join: (parts) => parts.filter(Boolean).join(' '),
151
+ wrapDocument: (content) => `<div style="font-family: monospace; line-height: 1.6;">${content}</div>`,
152
+ };
153
+ }
154
+
155
+ // ── Format Detection ────────────────────────────────────────────────────
156
+
157
+ export function shouldUseAnsi(env?: Record<string, string | undefined>, isTTY?: boolean): boolean {
158
+ if (env?.NO_COLOR) return false;
159
+ if (env?.CI) return false;
160
+ if (typeof isTTY === 'boolean') return isTTY;
161
+ return false;
162
+ }
163
+
164
+ // ── Output Context ──────────────────────────────────────────────────────
165
+
166
+ /** Resolved formatting context used by output primitives. */
167
+ export type OutputFormat = 'text' | 'ansi' | 'json' | 'markdown' | 'html';
168
+
169
+ export type OutputContext = {
170
+ format: OutputFormat;
171
+ styler: Styler;
172
+ layout: LayoutConfig;
173
+ terminalWidth?: number;
174
+ };
175
+
176
+ /** Resolve the output format from the runtime and caller context. */
177
+ export function resolveOutputFormat(
178
+ runtime: {
179
+ format?: string;
180
+ theme?: ColorTheme | ColorConfig;
181
+ terminal?: { columns?: number; isTTY?: boolean };
182
+ env: () => Record<string, string | undefined>;
183
+ },
184
+ caller?: PadroneActionContext['caller'],
185
+ ): OutputContext {
186
+ let format: OutputFormat;
187
+
188
+ if (caller === 'serve' || caller === 'mcp' || caller === 'tool') {
189
+ format = 'json';
190
+ } else if (runtime.format && runtime.format !== 'auto' && runtime.format !== 'console') {
191
+ format = runtime.format as OutputFormat;
192
+ } else {
193
+ format = shouldUseAnsi(runtime.env(), runtime.terminal?.isTTY) ? 'ansi' : 'text';
194
+ }
195
+
196
+ const terminalWidth = format === 'markdown' || format === 'html' ? undefined : (runtime.terminal?.columns ?? DEFAULT_TERMINAL_WIDTH);
197
+
198
+ let styler: Styler;
199
+ let layout: LayoutConfig;
200
+
201
+ switch (format) {
202
+ case 'ansi':
203
+ styler = createAnsiStyler(runtime.theme);
204
+ layout = createTextLayout();
205
+ break;
206
+ case 'markdown':
207
+ styler = createMarkdownStyler();
208
+ layout = createMarkdownLayout();
209
+ break;
210
+ case 'html':
211
+ styler = createHtmlStyler();
212
+ layout = createHtmlLayout();
213
+ break;
214
+ default:
215
+ styler = createTextStyler();
216
+ layout = createTextLayout();
217
+ break;
218
+ }
219
+
220
+ return { format, styler, layout, terminalWidth };
221
+ }
@@ -109,7 +109,7 @@ type InitialCommandBuilder<
109
109
  >
110
110
  : PadroneBuilder<TProgramName, TNameNested, TParentPath, PadroneSchema<void>, void, [], TParentArgs, false, TParentContext>;
111
111
 
112
- export type AnyPadroneBuilder = InitialCommandBuilder<string, string, string, any, [...AnyPadroneCommand[]], any>;
112
+ export type AnyPadroneBuilder = InitialCommandBuilder<string, string, string, PadroneSchema, [...AnyPadroneCommand[]], unknown>;
113
113
 
114
114
  /**
115
115
  * Like InitialCommandBuilder but uses `any` for args in the fresh case.
@@ -340,21 +340,11 @@ export type PadroneBuilderMethods<
340
340
  >;
341
341
 
342
342
  /** Add or override a subcommand. Pass a builder function to define its schema, action, and nested commands. @category Builder */
343
- command: <
344
- TNameNested extends string,
345
- TAliases extends string[] = [],
346
- TBuilder extends CommandTypesBase = DefaultCommandBuilder<
347
- TProgramName,
348
- TNameNested,
349
- FullCommandName<TName, TParentName>,
350
- TArgs,
351
- TCommands,
352
- TContext & TContextProvided
353
- >,
354
- >(
355
- name: TNameNested | readonly [TNameNested, ...TAliases],
356
- builderFn?: (
357
- builder: InitialCommandBuilder<
343
+ command: {
344
+ <
345
+ TNameNested extends string,
346
+ TAliases extends string[] = [],
347
+ TBuilder extends CommandTypesBase = DefaultCommandBuilder<
358
348
  TProgramName,
359
349
  TNameNested,
360
350
  FullCommandName<TName, TParentName>,
@@ -362,28 +352,67 @@ export type PadroneBuilderMethods<
362
352
  TCommands,
363
353
  TContext & TContextProvided
364
354
  >,
365
- ) => TBuilder,
366
- ) => BuilderOrProgram<
367
- TReturn,
368
- TProgramName,
369
- TName,
370
- TParentName,
371
- TArgs,
372
- TRes,
373
- TCommands extends []
374
- ? [WithAliases<TBuilder['~types']['command'], TAliases>]
375
- : AnyPadroneCommand[] extends TCommands
355
+ >(
356
+ name: TNameNested | readonly [TNameNested, ...TAliases],
357
+ builderFn?: (
358
+ builder: InitialCommandBuilder<
359
+ TProgramName,
360
+ TNameNested,
361
+ FullCommandName<TName, TParentName>,
362
+ TArgs,
363
+ TCommands,
364
+ TContext & TContextProvided
365
+ >,
366
+ ) => TBuilder,
367
+ ): BuilderOrProgram<
368
+ TReturn,
369
+ TProgramName,
370
+ TName,
371
+ TParentName,
372
+ TArgs,
373
+ TRes,
374
+ TCommands extends []
376
375
  ? [WithAliases<TBuilder['~types']['command'], TAliases>]
377
- : ReplaceOrAppendCommand<
378
- TCommands,
379
- TNameNested,
380
- WithAliases<TBuilder['~types']['command'], ResolvedAliases<TCommands, TNameNested, TAliases>>
381
- >,
382
- TParentArgs,
383
- TAsync,
384
- TContext,
385
- TContextProvided
386
- >;
376
+ : AnyPadroneCommand[] extends TCommands
377
+ ? [WithAliases<TBuilder['~types']['command'], TAliases>]
378
+ : ReplaceOrAppendCommand<
379
+ TCommands,
380
+ TNameNested,
381
+ WithAliases<TBuilder['~types']['command'], ResolvedAliases<TCommands, TNameNested, TAliases>>
382
+ >,
383
+ TParentArgs,
384
+ TAsync,
385
+ TContext,
386
+ TContextProvided
387
+ >;
388
+ // Fallback overload: accepts DefineCommand-typed callbacks where the builder type is not structurally compatible
389
+ // (e.g., DefineCommand with unknown context used in a parent with specific context)
390
+ <TNameNested extends string, TAliases extends string[] = [], TBuilder extends CommandTypesBase = CommandTypesBase>(
391
+ name: TNameNested | readonly [TNameNested, ...TAliases],
392
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
393
+ builderFn?: (builder: any) => TBuilder,
394
+ ): BuilderOrProgram<
395
+ TReturn,
396
+ TProgramName,
397
+ TName,
398
+ TParentName,
399
+ TArgs,
400
+ TRes,
401
+ TCommands extends []
402
+ ? [WithAliases<TBuilder['~types']['command'], TAliases>]
403
+ : AnyPadroneCommand[] extends TCommands
404
+ ? [WithAliases<TBuilder['~types']['command'], TAliases>]
405
+ : ReplaceOrAppendCommand<
406
+ TCommands,
407
+ TNameNested,
408
+ WithAliases<TBuilder['~types']['command'], ResolvedAliases<TCommands, TNameNested, TAliases>>
409
+ >,
410
+ TParentArgs,
411
+ TAsync,
412
+ TContext,
413
+ TContextProvided
414
+ >;
415
+ };
387
416
 
388
417
  /** Mount an existing program as a subcommand, optionally transforming the context. @category Builder */
389
418
  mount: {
@@ -694,4 +723,25 @@ export type AnyPadroneProgram = PadroneProgram<string, string, string, any, any,
694
723
  */
695
724
  export type PadroneExtension<TIn extends CommandTypesBase = CommandTypesBase, TOut extends CommandTypesBase = TIn> = (builder: TIn) => TOut;
696
725
 
726
+ /**
727
+ * Type for a command builder callback used with `.command()`.
728
+ * Use this when defining commands in separate files where full return type inference isn't needed.
729
+ *
730
+ * For full type preservation at the parent, use `defineCommand()` instead.
731
+ *
732
+ * @example
733
+ * ```ts
734
+ * // my-command.ts
735
+ * export const myCommand: DefineCommand = (c) =>
736
+ * c.arguments(z.object({ name: z.string() }))
737
+ * .action((args) => console.log(args.name));
738
+ *
739
+ * // cli.ts
740
+ * createPadrone('test').command('my-command', myCommand)
741
+ * ```
742
+ */
743
+ export type DefineCommand<TContext = unknown, TParentArgs extends PadroneSchema = PadroneSchema> = (
744
+ builder: PadroneBuilder<string, string, string, PadroneSchema<void>, void, [], TParentArgs, false, TContext>,
745
+ ) => CommandTypesBase;
746
+
697
747
  type DefaultArgs = Record<string, unknown> | void;
@@ -2,6 +2,7 @@ export type { PadroneArgsSchemaMeta, PadroneFieldMeta, SingleChar, StdinConfig }
2
2
  export type {
3
3
  AnyPadroneBuilder,
4
4
  AnyPadroneProgram,
5
+ DefineCommand,
5
6
  PadroneBuilder,
6
7
  PadroneBuilderMethods,
7
8
  PadroneExtension,
@@ -1 +0,0 @@
1
- {"version":3,"file":"help-B5Kk83of.mjs","names":[],"sources":["../src/util/utils.ts","../src/output/colorizer.ts","../src/output/formatter.ts","../src/output/help.ts"],"sourcesContent":["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","// 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 { camelToKebab } from '../util/shell-utils.ts';\nimport { type ColorConfig, type ColorTheme, createColorizer } from './colorizer.ts';\n\nconst DEFAULT_TERMINAL_WIDTH = 80;\n\nfunction 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 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// Internal Styling Types\n// ============================================================================\n\n/**\n * Internal styling functions used by formatters.\n * These handle the visual styling of individual text elements.\n */\ntype 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 */\ntype LayoutConfig = {\n newline: string;\n indent: (level: number) => string;\n join: (parts: string[]) => string;\n wrapDocument?: (content: string) => string;\n};\n\n// ============================================================================\n// Styler Factories\n// ============================================================================\n\nfunction 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\nfunction 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\nfunction createConsoleStyler(theme?: ColorTheme | ColorConfig): Styler {\n return createAnsiStyler(theme);\n}\n\nfunction 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\nfunction escapeHtml(text: string): string {\n return text.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/\"/g, '&quot;').replace(/'/g, '&#039;');\n}\n\nfunction 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// ============================================================================\n// Layout Configurations\n// ============================================================================\n\nfunction createTextLayout(): LayoutConfig {\n return {\n newline: '\\n',\n indent: (level) => ' '.repeat(level),\n join: (parts) => parts.filter(Boolean).join(' '),\n };\n}\n\nfunction 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\nfunction 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// ============================================================================\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// Formatter Factory\n// ============================================================================\n\nfunction 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// ============================================================================\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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"}