@kubb/cli 4.12.6 → 4.12.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,11 +1,11 @@
1
- import { t as version } from "./package-B857a-xb.js";
1
+ import { t as version } from "./package-V7YSB1bN.js";
2
2
  import { defineCommand, showUsage } from "citty";
3
3
  import path, { relative, resolve } from "node:path";
4
4
  import * as process$2 from "node:process";
5
5
  import process$1 from "node:process";
6
6
  import * as clack from "@clack/prompts";
7
7
  import { LogLevel, PromiseManager, defineLogger, isInputPath, safeBuild, setup } from "@kubb/core";
8
- import { AsyncEventEmitter, isPromise } from "@kubb/core/utils";
8
+ import { AsyncEventEmitter, formatHrtime, formatMs, isPromise } from "@kubb/core/utils";
9
9
  import getLatestVersion from "latest-version";
10
10
  import pc from "picocolors";
11
11
  import { lt } from "semver";
@@ -18,12 +18,6 @@ import { parseArgsStringToArgv } from "string-argv";
18
18
  import { cosmiconfig } from "cosmiconfig";
19
19
  import { createJiti } from "jiti";
20
20
 
21
- //#region src/utils/parseHrtimeToSeconds.ts
22
- function parseHrtimeToSeconds(hrtime) {
23
- return (hrtime[0] + hrtime[1] / 1e9).toFixed(3);
24
- }
25
-
26
- //#endregion
27
21
  //#region src/utils/randomColour.ts
28
22
  function randomColour(text) {
29
23
  if (!text) return "white";
@@ -51,14 +45,14 @@ function randomCliColour(text) {
51
45
  //#endregion
52
46
  //#region src/utils/getSummary.ts
53
47
  function getSummary({ failedPlugins, filesCreated, status, hrStart, config, pluginTimings }) {
54
- const elapsedSeconds = parseHrtimeToSeconds(process.hrtime(hrStart));
48
+ const duration = formatHrtime(hrStart);
55
49
  const pluginsCount = config.plugins?.length || 0;
56
50
  const successCount = pluginsCount - failedPlugins.size;
57
51
  const meta = {
58
52
  plugins: status === "success" ? `${pc.green(`${successCount} successful`)}, ${pluginsCount} total` : `${pc.green(`${successCount} successful`)}, ${pc.red(`${failedPlugins.size} failed`)}, ${pluginsCount} total`,
59
53
  pluginsFailed: status === "failed" ? [...failedPlugins]?.map(({ plugin }) => randomCliColour(plugin.name))?.join(", ") : void 0,
60
54
  filesCreated,
61
- time: `${elapsedSeconds}s`,
55
+ time: pc.green(duration),
62
56
  output: path.isAbsolute(config.root) ? path.resolve(config.root, config.output.path) : config.root
63
57
  };
64
58
  const labels = {
@@ -115,9 +109,31 @@ const clackLogger = defineLogger({
115
109
  name: "clack",
116
110
  install(context, options) {
117
111
  const logLevel = options?.logLevel || LogLevel.info;
118
- const activeProgress = /* @__PURE__ */ new Map();
119
- const spinner = clack.spinner();
120
- let isSpinning = false;
112
+ const state = {
113
+ totalPlugins: 0,
114
+ completedPlugins: 0,
115
+ failedPlugins: 0,
116
+ totalFiles: 0,
117
+ processedFiles: 0,
118
+ hrStart: process$1.hrtime(),
119
+ spinner: clack.spinner(),
120
+ isSpinning: false,
121
+ activeProgress: /* @__PURE__ */ new Map()
122
+ };
123
+ function showProgressStep() {
124
+ if (logLevel <= LogLevel.silent) return;
125
+ const parts = [];
126
+ const duration = formatHrtime(state.hrStart);
127
+ if (state.totalPlugins > 0) {
128
+ const pluginStr = state.failedPlugins > 0 ? `Plugins ${pc.green(state.completedPlugins.toString())}/${state.totalPlugins} ${pc.red(`(${state.failedPlugins} failed)`)}` : `Plugins ${pc.green(state.completedPlugins.toString())}/${state.totalPlugins}`;
129
+ parts.push(pluginStr);
130
+ }
131
+ if (state.totalFiles > 0) parts.push(`Files ${pc.green(state.processedFiles.toString())}/${state.totalFiles}`);
132
+ if (parts.length > 0) {
133
+ parts.push(pc.green(duration));
134
+ clack.log.step(parts.join(pc.dim(" | ")));
135
+ }
136
+ }
121
137
  function getMessage(message) {
122
138
  if (logLevel >= LogLevel.verbose) {
123
139
  const timestamp = (/* @__PURE__ */ new Date()).toLocaleTimeString("en-US", {
@@ -131,12 +147,12 @@ const clackLogger = defineLogger({
131
147
  return message;
132
148
  }
133
149
  function startSpinner(text) {
134
- spinner.start(text);
135
- isSpinning = true;
150
+ state.spinner.start(text);
151
+ state.isSpinning = true;
136
152
  }
137
153
  function stopSpinner(text) {
138
- spinner.stop(text);
139
- isSpinning = false;
154
+ state.spinner.stop(text);
155
+ state.isSpinning = false;
140
156
  }
141
157
  context.on("info", (message, info = "") => {
142
158
  if (logLevel <= LogLevel.silent) return;
@@ -145,7 +161,7 @@ const clackLogger = defineLogger({
145
161
  message,
146
162
  pc.dim(info)
147
163
  ].join(" "));
148
- if (isSpinning) spinner.message(text);
164
+ if (state.isSpinning) state.spinner.message(text);
149
165
  else clack.log.info(text);
150
166
  });
151
167
  context.on("success", (message, info = "") => {
@@ -155,7 +171,7 @@ const clackLogger = defineLogger({
155
171
  message,
156
172
  logLevel >= LogLevel.info ? pc.dim(info) : void 0
157
173
  ].filter(Boolean).join(" "));
158
- if (isSpinning) stopSpinner(text);
174
+ if (state.isSpinning) stopSpinner(text);
159
175
  else clack.log.success(text);
160
176
  });
161
177
  context.on("warn", (message, info) => {
@@ -170,7 +186,7 @@ const clackLogger = defineLogger({
170
186
  context.on("error", (error) => {
171
187
  const caused = error.cause;
172
188
  const text = [pc.red("✗"), error.message].join(" ");
173
- if (isSpinning) stopSpinner(getMessage(text));
189
+ if (state.isSpinning) stopSpinner(getMessage(text));
174
190
  else clack.log.error(getMessage(text));
175
191
  if (logLevel >= LogLevel.debug && error.stack) {
176
192
  const frames = error.stack.split("\n").slice(1, 4);
@@ -207,12 +223,16 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
207
223
  clack.intro(text);
208
224
  startSpinner(getMessage("Configuration loading"));
209
225
  });
210
- context.on("config:end", () => {
226
+ context.on("config:end", (_configs) => {
211
227
  if (logLevel <= LogLevel.silent) return;
212
228
  const text = getMessage("Configuration completed");
213
229
  clack.outro(text);
214
230
  });
215
231
  context.on("generation:start", (config) => {
232
+ state.totalPlugins = config.plugins?.length || 0;
233
+ state.completedPlugins = 0;
234
+ state.failedPlugins = 0;
235
+ state.hrStart = process$1.hrtime();
216
236
  const text = getMessage(["Generation started", config.name ? `for ${pc.dim(config.name)}` : void 0].filter(Boolean).join(" "));
217
237
  clack.intro(text);
218
238
  });
@@ -229,24 +249,29 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
229
249
  const interval = setInterval(() => {
230
250
  progressBar.advance();
231
251
  }, 50);
232
- activeProgress.set(plugin.name, {
252
+ state.activeProgress.set(plugin.name, {
233
253
  progressBar,
234
254
  interval
235
255
  });
236
256
  });
237
- context.on("plugin:end", (plugin, duration) => {
257
+ context.on("plugin:end", (plugin, { duration, success }) => {
238
258
  stopSpinner();
239
- const active = activeProgress.get(plugin.name);
259
+ const active = state.activeProgress.get(plugin.name);
240
260
  if (!active || logLevel === LogLevel.silent) return;
241
261
  clearInterval(active.interval);
242
- const durationStr = duration >= 1e3 ? `${(duration / 1e3).toFixed(2)}s` : `${duration}ms`;
243
- const text = getMessage(`${pc.bold(plugin.name)} completed in ${pc.green(durationStr)}`);
262
+ if (success) state.completedPlugins++;
263
+ else state.failedPlugins++;
264
+ const durationStr = formatMs(duration);
265
+ const text = getMessage(success ? `${pc.bold(plugin.name)} completed in ${pc.green(durationStr)}` : `${pc.bold(plugin.name)} failed in ${pc.red(durationStr)}`);
244
266
  active.progressBar.stop(text);
245
- activeProgress.delete(plugin.name);
267
+ state.activeProgress.delete(plugin.name);
268
+ showProgressStep();
246
269
  });
247
270
  context.on("files:processing:start", (files) => {
248
271
  if (logLevel <= LogLevel.silent) return;
249
272
  stopSpinner();
273
+ state.totalFiles = files.length;
274
+ state.processedFiles = 0;
250
275
  const text = `Writing ${files.length} files`;
251
276
  const progressBar = clack.progress({
252
277
  style: "block",
@@ -255,13 +280,14 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
255
280
  });
256
281
  context.emit("info", text);
257
282
  progressBar.start(getMessage(text));
258
- activeProgress.set("files", { progressBar });
283
+ state.activeProgress.set("files", { progressBar });
259
284
  });
260
285
  context.on("file:processing:update", ({ file, config }) => {
261
286
  if (logLevel <= LogLevel.silent) return;
262
287
  stopSpinner();
288
+ state.processedFiles++;
263
289
  const text = `Writing ${relative(config.root, file.path)}`;
264
- const active = activeProgress.get("files");
290
+ const active = state.activeProgress.get("files");
265
291
  if (!active) return;
266
292
  active.progressBar.advance(void 0, text);
267
293
  });
@@ -269,10 +295,11 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
269
295
  if (logLevel <= LogLevel.silent) return;
270
296
  stopSpinner();
271
297
  const text = getMessage("Files written successfully");
272
- const active = activeProgress.get("files");
298
+ const active = state.activeProgress.get("files");
273
299
  if (!active) return;
274
300
  active.progressBar.stop(text);
275
- activeProgress.delete("files");
301
+ state.activeProgress.delete("files");
302
+ showProgressStep();
276
303
  });
277
304
  context.on("generation:end", (config) => {
278
305
  const text = getMessage(config.name ? `Generation completed for ${pc.dim(config.name)}` : "Generation completed");
@@ -386,11 +413,11 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
386
413
  });
387
414
  });
388
415
  context.on("lifecycle:end", () => {
389
- for (const [_key, active] of activeProgress) {
416
+ for (const [_key, active] of state.activeProgress) {
390
417
  if (active.interval) clearInterval(active.interval);
391
418
  active.progressBar?.stop();
392
419
  }
393
- activeProgress.clear();
420
+ state.activeProgress.clear();
394
421
  });
395
422
  }
396
423
  });
@@ -475,7 +502,29 @@ const githubActionsLogger = defineLogger({
475
502
  name: "github-actions",
476
503
  install(context, options) {
477
504
  const logLevel = options?.logLevel || LogLevel.info;
478
- let currentConfigs = [];
505
+ const state = {
506
+ totalPlugins: 0,
507
+ completedPlugins: 0,
508
+ failedPlugins: 0,
509
+ totalFiles: 0,
510
+ processedFiles: 0,
511
+ hrStart: process.hrtime(),
512
+ currentConfigs: []
513
+ };
514
+ function showProgressStep() {
515
+ if (logLevel <= LogLevel.silent) return;
516
+ const parts = [];
517
+ const duration = formatHrtime(state.hrStart);
518
+ if (state.totalPlugins > 0) {
519
+ const pluginStr = state.failedPlugins > 0 ? `Plugins ${pc.green(state.completedPlugins.toString())}/${state.totalPlugins} ${pc.red(`(${state.failedPlugins} failed)`)}` : `Plugins ${pc.green(state.completedPlugins.toString())}/${state.totalPlugins}`;
520
+ parts.push(pluginStr);
521
+ }
522
+ if (state.totalFiles > 0) parts.push(`Files ${pc.green(state.processedFiles.toString())}/${state.totalFiles}`);
523
+ if (parts.length > 0) {
524
+ parts.push(pc.green(duration));
525
+ console.log(parts.join(pc.dim(" | ")));
526
+ }
527
+ }
479
528
  function getMessage(message) {
480
529
  if (logLevel >= LogLevel.verbose) {
481
530
  const timestamp = (/* @__PURE__ */ new Date()).toLocaleTimeString("en-US", {
@@ -536,34 +585,43 @@ const githubActionsLogger = defineLogger({
536
585
  console.log(text);
537
586
  });
538
587
  context.on("config:end", (configs) => {
539
- currentConfigs = configs;
588
+ state.currentConfigs = configs;
540
589
  if (logLevel <= LogLevel.silent) return;
541
590
  const text = getMessage("Configuration completed");
542
591
  console.log(text);
543
592
  closeGroup("Configuration");
544
593
  });
545
594
  context.on("generation:start", (config) => {
595
+ state.totalPlugins = config.plugins?.length || 0;
596
+ state.completedPlugins = 0;
597
+ state.failedPlugins = 0;
598
+ state.hrStart = process.hrtime();
546
599
  const text = config.name ? `Generation for ${pc.bold(config.name)}` : "Generation";
547
- if (currentConfigs.length > 1) openGroup(text);
548
- if (currentConfigs.length === 1) console.log(getMessage(text));
600
+ if (state.currentConfigs.length > 1) openGroup(text);
601
+ if (state.currentConfigs.length === 1) console.log(getMessage(text));
549
602
  });
550
603
  context.on("plugin:start", (plugin) => {
551
604
  if (logLevel <= LogLevel.silent) return;
552
605
  const text = getMessage(`Generating ${pc.bold(plugin.name)}`);
553
- if (currentConfigs.length === 1) openGroup(`Plugin: ${plugin.name}`);
606
+ if (state.currentConfigs.length === 1) openGroup(`Plugin: ${plugin.name}`);
554
607
  console.log(text);
555
608
  });
556
- context.on("plugin:end", (plugin, duration) => {
609
+ context.on("plugin:end", (plugin, { duration, success }) => {
557
610
  if (logLevel <= LogLevel.silent) return;
558
- const durationStr = duration >= 1e3 ? `${(duration / 1e3).toFixed(2)}s` : `${duration}ms`;
559
- const text = getMessage(`${pc.bold(plugin.name)} completed in ${pc.green(durationStr)}`);
611
+ if (success) state.completedPlugins++;
612
+ else state.failedPlugins++;
613
+ const durationStr = formatMs(duration);
614
+ const text = getMessage(success ? `${pc.bold(plugin.name)} completed in ${pc.green(durationStr)}` : `${pc.bold(plugin.name)} failed in ${pc.red(durationStr)}`);
560
615
  console.log(text);
561
- if (currentConfigs.length > 1) console.log(" ");
562
- if (currentConfigs.length === 1) closeGroup(`Plugin: ${plugin.name}`);
616
+ if (state.currentConfigs.length > 1) console.log(" ");
617
+ if (state.currentConfigs.length === 1) closeGroup(`Plugin: ${plugin.name}`);
618
+ showProgressStep();
563
619
  });
564
620
  context.on("files:processing:start", (files) => {
565
621
  if (logLevel <= LogLevel.silent) return;
566
- if (currentConfigs.length === 1) openGroup("File Generation");
622
+ state.totalFiles = files.length;
623
+ state.processedFiles = 0;
624
+ if (state.currentConfigs.length === 1) openGroup("File Generation");
567
625
  const text = getMessage(`Writing ${files.length} files`);
568
626
  console.log(text);
569
627
  });
@@ -571,7 +629,15 @@ const githubActionsLogger = defineLogger({
571
629
  if (logLevel <= LogLevel.silent) return;
572
630
  const text = getMessage("Files written successfully");
573
631
  console.log(text);
574
- if (currentConfigs.length === 1) closeGroup("File Generation");
632
+ if (state.currentConfigs.length === 1) closeGroup("File Generation");
633
+ });
634
+ context.on("file:processing:update", () => {
635
+ if (logLevel <= LogLevel.silent) return;
636
+ state.processedFiles++;
637
+ });
638
+ context.on("files:processing:end", () => {
639
+ if (logLevel <= LogLevel.silent) return;
640
+ showProgressStep();
575
641
  });
576
642
  context.on("generation:end", (config) => {
577
643
  const text = getMessage(config.name ? `${pc.blue("✓")} Generation completed for ${pc.dim(config.name)}` : `${pc.blue("✓")} Generation completed`);
@@ -602,45 +668,45 @@ const githubActionsLogger = defineLogger({
602
668
  context.on("format:start", () => {
603
669
  if (logLevel <= LogLevel.silent) return;
604
670
  const text = getMessage("Format started");
605
- if (currentConfigs.length === 1) openGroup("Formatting");
671
+ if (state.currentConfigs.length === 1) openGroup("Formatting");
606
672
  console.log(text);
607
673
  });
608
674
  context.on("format:end", () => {
609
675
  if (logLevel <= LogLevel.silent) return;
610
676
  const text = getMessage("Format completed");
611
677
  console.log(text);
612
- if (currentConfigs.length === 1) closeGroup("Formatting");
678
+ if (state.currentConfigs.length === 1) closeGroup("Formatting");
613
679
  });
614
680
  context.on("lint:start", () => {
615
681
  if (logLevel <= LogLevel.silent) return;
616
682
  const text = getMessage("Lint started");
617
- if (currentConfigs.length === 1) openGroup("Linting");
683
+ if (state.currentConfigs.length === 1) openGroup("Linting");
618
684
  console.log(text);
619
685
  });
620
686
  context.on("lint:end", () => {
621
687
  if (logLevel <= LogLevel.silent) return;
622
688
  const text = getMessage("Lint completed");
623
689
  console.log(text);
624
- if (currentConfigs.length === 1) closeGroup("Linting");
690
+ if (state.currentConfigs.length === 1) closeGroup("Linting");
625
691
  });
626
692
  context.on("hook:start", (command$1) => {
627
693
  if (logLevel <= LogLevel.silent) return;
628
694
  const text = getMessage(`Hook ${pc.dim(command$1)} started`);
629
- if (currentConfigs.length === 1) openGroup(`Hook ${command$1}`);
695
+ if (state.currentConfigs.length === 1) openGroup(`Hook ${command$1}`);
630
696
  console.log(text);
631
697
  });
632
698
  context.on("hook:end", (command$1) => {
633
699
  if (logLevel <= LogLevel.silent) return;
634
700
  const text = getMessage(`Hook ${pc.dim(command$1)} completed`);
635
701
  console.log(text);
636
- if (currentConfigs.length === 1) closeGroup(`Hook ${command$1}`);
702
+ if (state.currentConfigs.length === 1) closeGroup(`Hook ${command$1}`);
637
703
  });
638
704
  context.on("generation:summary", (config, { status, failedPlugins }) => {
639
705
  const pluginsCount = config.plugins?.length || 0;
640
706
  const successCount = pluginsCount - failedPlugins.size;
641
- if (currentConfigs.length > 1) console.log(" ");
707
+ if (state.currentConfigs.length > 1) console.log(" ");
642
708
  console.log(status === "success" ? `Kubb Summary: ${pc.blue("✓")} ${`${successCount} successful`}, ${pluginsCount} total` : `Kubb Summary: ${pc.blue("✓")} ${`${successCount} successful`}, ✗ ${`${failedPlugins.size} failed`}, ${pluginsCount} total`);
643
- if (currentConfigs.length > 1) closeGroup(config.name ? `Generation for ${pc.bold(config.name)}` : "Generation");
709
+ if (state.currentConfigs.length > 1) closeGroup(config.name ? `Generation for ${pc.bold(config.name)}` : "Generation");
644
710
  });
645
711
  }
646
712
  });
@@ -727,10 +793,10 @@ const plainLogger = defineLogger({
727
793
  const text = getMessage(`Generating ${plugin.name}`);
728
794
  console.log(text);
729
795
  });
730
- context.on("plugin:end", (plugin, duration) => {
796
+ context.on("plugin:end", (plugin, { duration, success }) => {
731
797
  if (logLevel <= LogLevel.silent) return;
732
- const durationStr = duration >= 1e3 ? `${(duration / 1e3).toFixed(2)}s` : `${duration}ms`;
733
- const text = getMessage(`${plugin.name} completed in ${durationStr}`);
798
+ const durationStr = formatMs(duration);
799
+ const text = getMessage(success ? `${plugin.name} completed in ${durationStr}` : `${plugin.name} failed in ${durationStr}`);
734
800
  console.log(text);
735
801
  });
736
802
  context.on("files:processing:start", (files) => {
@@ -1246,4 +1312,4 @@ var generate_default = command;
1246
1312
 
1247
1313
  //#endregion
1248
1314
  export { generate_default as default };
1249
- //# sourceMappingURL=generate-M-5j2zqa.js.map
1315
+ //# sourceMappingURL=generate--x91ECr5.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate--x91ECr5.js","names":["summaryLines: string[]","process","parts: string[]","frames","version","command","cachedLogs: Set<CachedEvent>","files: Record<string, string[]>","parts: string[]","version","command","frames","command","command","process","definedConfig: Config","error","results: Array<Config>","result: CosmiconfigResult","path","process","config"],"sources":["../src/utils/randomColour.ts","../src/utils/getSummary.ts","../src/utils/Writables.ts","../src/loggers/clackLogger.ts","../src/loggers/envDetection.ts","../src/loggers/fileSystemLogger.ts","../src/loggers/githubActionsLogger.ts","../src/loggers/plainLogger.ts","../src/loggers/utils.ts","../src/utils/executeHooks.ts","../src/runners/generate.ts","../src/utils/getPlugins.ts","../src/utils/getConfig.ts","../src/utils/getCosmiConfig.ts","../src/utils/watcher.ts","../src/commands/generate.ts"],"sourcesContent":["import pc from 'picocolors'\nimport seedrandom from 'seedrandom'\n\nexport function randomColour(text?: string): 'black' | 'red' | 'green' | 'yellow' | 'blue' | 'magenta' | 'cyan' | 'white' | 'gray' {\n if (!text) {\n return 'white'\n }\n\n const defaultColours = ['black', 'red', 'green', 'yellow', 'blue', 'red', 'green', 'magenta', 'cyan', 'gray'] as const\n\n const random = seedrandom(text)\n const colour = defaultColours.at(Math.floor(random() * defaultColours.length)) || 'white'\n\n return colour\n}\n\nexport function randomCliColour(text?: string): string {\n if (!text) {\n return ''\n }\n\n const colour = randomColour(text)\n\n const fn = pc[colour]\n return fn ? fn(text) : text\n}\n","import path from 'node:path'\nimport type { Config, Plugin } from '@kubb/core'\nimport { formatHrtime } from '@kubb/core/utils'\nimport pc from 'picocolors'\nimport { randomCliColour } from './randomColour.ts'\n\ntype SummaryProps = {\n failedPlugins: Set<{ plugin: Plugin; error: Error }>\n status: 'success' | 'failed'\n hrStart: [number, number]\n filesCreated: number\n config: Config\n pluginTimings?: Map<string, number>\n}\n\nexport function getSummary({ failedPlugins, filesCreated, status, hrStart, config, pluginTimings }: SummaryProps): string[] {\n const duration = formatHrtime(hrStart)\n\n const pluginsCount = config.plugins?.length || 0\n const successCount = pluginsCount - failedPlugins.size\n\n const meta = {\n plugins:\n status === 'success'\n ? `${pc.green(`${successCount} successful`)}, ${pluginsCount} total`\n : `${pc.green(`${successCount} successful`)}, ${pc.red(`${failedPlugins.size} failed`)}, ${pluginsCount} total`,\n pluginsFailed: status === 'failed' ? [...failedPlugins]?.map(({ plugin }) => randomCliColour(plugin.name))?.join(', ') : undefined,\n filesCreated: filesCreated,\n time: pc.green(duration),\n output: path.isAbsolute(config.root) ? path.resolve(config.root, config.output.path) : config.root,\n } as const\n\n const labels = {\n plugins: 'Plugins:',\n failed: 'Failed:',\n generated: 'Generated:',\n pluginTimings: 'Plugin Timings:',\n output: 'Output:',\n }\n const maxLength = Math.max(0, ...[...Object.values(labels), ...(pluginTimings ? Array.from(pluginTimings.keys()) : [])].map((s) => s.length))\n\n const summaryLines: string[] = []\n summaryLines.push(`${labels.plugins.padEnd(maxLength + 2)} ${meta.plugins}`)\n\n if (meta.pluginsFailed) {\n summaryLines.push(`${labels.failed.padEnd(maxLength + 2)} ${meta.pluginsFailed}`)\n }\n\n summaryLines.push(`${labels.generated.padEnd(maxLength + 2)} ${meta.filesCreated} files in ${meta.time}`)\n\n if (pluginTimings && pluginTimings.size > 0) {\n const TIME_SCALE_DIVISOR = 100\n const MAX_BAR_LENGTH = 10\n\n const sortedTimings = Array.from(pluginTimings.entries()).sort((a, b) => b[1] - a[1])\n\n if (sortedTimings.length > 0) {\n summaryLines.push(`${labels.pluginTimings}`)\n\n sortedTimings.forEach(([name, time]) => {\n const timeStr = time >= 1000 ? `${(time / 1000).toFixed(2)}s` : `${Math.round(time)}ms`\n const barLength = Math.min(Math.ceil(time / TIME_SCALE_DIVISOR), MAX_BAR_LENGTH)\n const bar = pc.dim('█'.repeat(barLength))\n\n summaryLines.push(`${pc.dim('•')} ${name.padEnd(maxLength + 1)}${bar} ${timeStr}`)\n })\n }\n }\n\n summaryLines.push(`${labels.output.padEnd(maxLength + 2)} ${meta.output}`)\n\n return summaryLines\n}\n","import type { WritableOptions } from 'node:stream'\nimport { Writable } from 'node:stream'\nimport type * as clack from '@clack/prompts'\nimport pc from 'picocolors'\n\nexport class ClackWritable extends Writable {\n taskLog: ReturnType<typeof clack.taskLog>\n constructor(taskLog: ReturnType<typeof clack.taskLog>, opts?: WritableOptions) {\n super(opts)\n\n this.taskLog = taskLog\n }\n _write(chunk: any, _encoding: BufferEncoding, callback: (error?: Error | null) => void): void {\n this.taskLog.message(`${pc.dim(chunk?.toString())}`)\n callback()\n }\n}\n","import { relative } from 'node:path'\nimport process from 'node:process'\nimport * as clack from '@clack/prompts'\nimport { defineLogger, LogLevel } from '@kubb/core'\nimport { formatHrtime, formatMs } from '@kubb/core/utils'\nimport { execa } from 'execa'\nimport { default as gradientString } from 'gradient-string'\nimport pc from 'picocolors'\nimport { getSummary } from '../utils/getSummary.ts'\nimport { ClackWritable } from '../utils/Writables.ts'\n\n/**\n * Clack adapter for local TTY environments\n * Provides a beautiful CLI UI with flat structure inspired by Claude's CLI patterns\n */\nexport const clackLogger = defineLogger({\n name: 'clack',\n install(context, options) {\n const logLevel = options?.logLevel || LogLevel.info\n const state = {\n totalPlugins: 0,\n completedPlugins: 0,\n failedPlugins: 0,\n totalFiles: 0,\n processedFiles: 0,\n hrStart: process.hrtime(),\n spinner: clack.spinner(),\n isSpinning: false,\n activeProgress: new Map<string, { interval?: NodeJS.Timeout; progressBar: clack.ProgressResult }>(),\n }\n\n function showProgressStep() {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const parts: string[] = []\n const duration = formatHrtime(state.hrStart)\n\n if (state.totalPlugins > 0) {\n const pluginStr =\n state.failedPlugins > 0\n ? `Plugins ${pc.green(state.completedPlugins.toString())}/${state.totalPlugins} ${pc.red(`(${state.failedPlugins} failed)`)}`\n : `Plugins ${pc.green(state.completedPlugins.toString())}/${state.totalPlugins}`\n parts.push(pluginStr)\n }\n\n if (state.totalFiles > 0) {\n parts.push(`Files ${pc.green(state.processedFiles.toString())}/${state.totalFiles}`)\n }\n\n if (parts.length > 0) {\n parts.push(pc.green(duration))\n clack.log.step(parts.join(pc.dim(' | ')))\n }\n }\n\n function getMessage(message: string): string {\n if (logLevel >= LogLevel.verbose) {\n const timestamp = new Date().toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit',\n })\n\n return [pc.dim(`[${timestamp}]`), message].join(' ')\n }\n\n return message\n }\n\n function startSpinner(text?: string) {\n state.spinner.start(text)\n state.isSpinning = true\n }\n\n function stopSpinner(text?: string) {\n state.spinner.stop(text)\n state.isSpinning = false\n }\n\n context.on('info', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage([pc.blue('ℹ'), message, pc.dim(info)].join(' '))\n\n if (state.isSpinning) {\n state.spinner.message(text)\n } else {\n clack.log.info(text)\n }\n })\n\n context.on('success', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage([pc.blue('✓'), message, logLevel >= LogLevel.info ? pc.dim(info) : undefined].filter(Boolean).join(' '))\n\n if (state.isSpinning) {\n stopSpinner(text)\n } else {\n clack.log.success(text)\n }\n })\n\n context.on('warn', (message, info) => {\n if (logLevel < LogLevel.warn) {\n return\n }\n\n const text = getMessage([pc.yellow('⚠'), message, logLevel >= LogLevel.info ? pc.dim(info) : undefined].filter(Boolean).join(' '))\n\n clack.log.warn(text)\n })\n\n context.on('error', (error) => {\n const caused = error.cause as Error\n\n const text = [pc.red('✗'), error.message].join(' ')\n\n if (state.isSpinning) {\n stopSpinner(getMessage(text))\n } else {\n clack.log.error(getMessage(text))\n }\n\n // Show stack trace in debug mode (first 3 frames)\n if (logLevel >= LogLevel.debug && error.stack) {\n const frames = error.stack.split('\\n').slice(1, 4)\n for (const frame of frames) {\n clack.log.message(getMessage(pc.dim(frame.trim())))\n }\n\n if (caused?.stack) {\n clack.log.message(pc.dim(`└─ caused by ${caused.message}`))\n\n const frames = caused.stack.split('\\n').slice(1, 4)\n for (const frame of frames) {\n clack.log.message(getMessage(` ${pc.dim(frame.trim())}`))\n }\n }\n }\n })\n\n context.on('version:new', (version, latestVersion) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n clack.box(\n `\\`v${version}\\` → \\`v${latestVersion}\\`\nRun \\`npm install -g @kubb/cli\\` to update`,\n 'Update available for `Kubb`',\n {\n width: 'auto',\n formatBorder: pc.yellow,\n rounded: true,\n withGuide: false,\n contentAlign: 'center',\n titleAlign: 'center',\n },\n )\n })\n\n context.on('lifecycle:start', (version) => {\n console.log(gradientString(['#F58517', '#F5A217', '#F55A17'])(`Kubb ${version} 🧩`))\n })\n\n context.on('config:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration started')\n\n clack.intro(text)\n startSpinner(getMessage('Configuration loading'))\n })\n\n context.on('config:end', (_configs) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration completed')\n\n clack.outro(text)\n })\n\n context.on('generation:start', (config) => {\n // Initialize progress tracking\n state.totalPlugins = config.plugins?.length || 0\n state.completedPlugins = 0\n state.failedPlugins = 0\n state.hrStart = process.hrtime()\n\n const text = getMessage(['Generation started', config.name ? `for ${pc.dim(config.name)}` : undefined].filter(Boolean).join(' '))\n\n clack.intro(text)\n })\n\n context.on('plugin:start', (plugin) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n stopSpinner()\n\n const progressBar = clack.progress({\n style: 'block',\n max: 100,\n size: 30,\n })\n const text = getMessage(`Generating ${pc.bold(plugin.name)}`)\n progressBar.start(text)\n\n const interval = setInterval(() => {\n progressBar.advance()\n }, 50)\n\n state.activeProgress.set(plugin.name, { progressBar, interval })\n })\n\n context.on('plugin:end', (plugin, { duration, success }) => {\n stopSpinner()\n\n const active = state.activeProgress.get(plugin.name)\n\n if (!active || logLevel === LogLevel.silent) {\n return\n }\n\n clearInterval(active.interval)\n\n if (success) {\n state.completedPlugins++\n } else {\n state.failedPlugins++\n }\n\n const durationStr = formatMs(duration)\n const text = getMessage(\n success ? `${pc.bold(plugin.name)} completed in ${pc.green(durationStr)}` : `${pc.bold(plugin.name)} failed in ${pc.red(durationStr)}`,\n )\n\n active.progressBar.stop(text)\n state.activeProgress.delete(plugin.name)\n\n // Show progress step after each plugin\n showProgressStep()\n })\n\n context.on('files:processing:start', (files) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n stopSpinner()\n\n state.totalFiles = files.length\n state.processedFiles = 0\n\n const text = `Writing ${files.length} files`\n const progressBar = clack.progress({\n style: 'block',\n max: files.length,\n size: 30,\n })\n\n context.emit('info', text)\n progressBar.start(getMessage(text))\n state.activeProgress.set('files', { progressBar })\n })\n\n context.on('file:processing:update', ({ file, config }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n stopSpinner()\n\n state.processedFiles++\n\n const text = `Writing ${relative(config.root, file.path)}`\n const active = state.activeProgress.get('files')\n\n if (!active) {\n return\n }\n\n active.progressBar.advance(undefined, text)\n })\n context.on('files:processing:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n stopSpinner()\n\n const text = getMessage('Files written successfully')\n const active = state.activeProgress.get('files')\n\n if (!active) {\n return\n }\n\n active.progressBar.stop(text)\n state.activeProgress.delete('files')\n\n // Show final progress step after files are written\n showProgressStep()\n })\n\n context.on('generation:end', (config) => {\n const text = getMessage(config.name ? `Generation completed for ${pc.dim(config.name)}` : 'Generation completed')\n\n clack.outro(text)\n })\n\n context.on('hook:execute', async ({ command, args }, cb) => {\n if (logLevel <= LogLevel.silent) {\n try {\n const result = await execa(command, args, {\n detached: true,\n stripFinalNewline: true,\n })\n\n await context.emit('debug', {\n date: new Date(),\n logs: [result.stdout],\n })\n\n cb()\n } catch (err) {\n const error = new Error('Hook execute failed')\n error.cause = err\n\n await context.emit('debug', {\n date: new Date(),\n logs: [(err as any).stdout],\n })\n\n await context.emit('error', error)\n }\n\n return\n }\n\n const logger = clack.taskLog({\n title: getMessage(['Executing hook', logLevel >= LogLevel.info ? pc.dim(`${command} ${args?.join(' ')}`) : undefined].filter(Boolean).join(' ')),\n })\n\n const writable = new ClackWritable(logger)\n\n try {\n const result = await execa(command, args, {\n detached: true,\n stdout: ['pipe', writable],\n stripFinalNewline: true,\n })\n\n await context.emit('debug', {\n date: new Date(),\n logs: [result.stdout],\n })\n\n cb()\n } catch (err) {\n const error = new Error('Hook execute failed')\n error.cause = err\n\n await context.emit('debug', {\n date: new Date(),\n logs: [(err as any).stdout],\n })\n\n await context.emit('error', error)\n }\n })\n\n context.on('format:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format started')\n\n clack.intro(text)\n })\n\n context.on('format:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format completed')\n\n clack.outro(text)\n })\n\n context.on('lint:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint started')\n\n clack.intro(text)\n })\n\n context.on('lint:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint completed')\n\n clack.outro(text)\n })\n\n context.on('hook:start', (command) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(`Hook ${pc.dim(command)} started`)\n\n clack.intro(text)\n })\n\n context.on('hook:end', (command) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(`Hook ${pc.dim(command)} completed`)\n\n clack.outro(text)\n })\n\n context.on('generation:summary', (config, { pluginTimings, failedPlugins, filesCreated, status, hrStart }) => {\n const summary = getSummary({\n failedPlugins,\n filesCreated,\n config,\n status,\n hrStart,\n pluginTimings: logLevel >= LogLevel.verbose ? pluginTimings : undefined,\n })\n const title = config.name || ''\n\n summary.unshift('\\n')\n summary.push('\\n')\n\n if (status === 'success') {\n clack.box(summary.join('\\n'), getMessage(title), {\n width: 'auto',\n formatBorder: pc.green,\n rounded: true,\n withGuide: false,\n contentAlign: 'left',\n titleAlign: 'center',\n })\n\n return\n }\n\n clack.box(summary.join('\\n'), getMessage(title), {\n width: 'auto',\n formatBorder: pc.red,\n rounded: true,\n withGuide: false,\n contentAlign: 'left',\n titleAlign: 'center',\n })\n })\n\n context.on('lifecycle:end', () => {\n for (const [_key, active] of state.activeProgress) {\n if (active.interval) {\n clearInterval(active.interval)\n }\n active.progressBar?.stop()\n }\n state.activeProgress.clear()\n })\n },\n})\n","/**\n * Check if running in GitHub Actions environment\n */\nexport function isGitHubActions(): boolean {\n return !!process.env.GITHUB_ACTIONS\n}\n\n/**\n * Check if running in any CI environment\n */\nexport function isCIEnvironment(): boolean {\n return !!(\n process.env.CI ||\n process.env.GITHUB_ACTIONS ||\n process.env.GITLAB_CI ||\n process.env.CIRCLECI ||\n process.env.TRAVIS ||\n process.env.JENKINS_URL ||\n process.env.BUILDKITE\n )\n}\n\n/**\n * Check if TTY is available for interactive output\n */\nexport function canUseTTY(): boolean {\n return !!process.stdout.isTTY && !isCIEnvironment()\n}\n","import { resolve } from 'node:path'\nimport { defineLogger } from '@kubb/core'\nimport { write } from '@kubb/core/fs'\n\ntype CachedEvent = {\n date: Date\n logs: string[]\n fileName?: string\n}\n\n/**\n * FileSystem logger for debug log persistence\n * Captures debug and verbose events and writes them to files in .kubb directory\n *\n * Note: Logs are written on lifecycle:end or process exit. If the process crashes\n * before these events, some cached logs may be lost.\n */\nexport const fileSystemLogger = defineLogger({\n name: 'filesystem',\n install(context) {\n const cachedLogs: Set<CachedEvent> = new Set()\n const startDate = Date.now()\n\n async function writeLogs() {\n if (cachedLogs.size === 0) {\n return\n }\n\n const files: Record<string, string[]> = {}\n\n for (const log of cachedLogs) {\n const fileName = resolve(process.cwd(), '.kubb', log.fileName || `kubb-${startDate}.log`)\n\n if (!files[fileName]) {\n files[fileName] = []\n }\n\n if (log.logs.length > 0) {\n const timestamp = log.date.toLocaleString()\n files[fileName].push(`[${timestamp}]\\n${log.logs.join('\\n')}`)\n }\n }\n\n await Promise.all(\n Object.entries(files).map(async ([fileName, logs]) => {\n return write(fileName, logs.join('\\n\\n'))\n }),\n )\n\n cachedLogs.clear()\n }\n\n context.on('debug', (message) => {\n cachedLogs.add({\n date: new Date(),\n logs: message.logs,\n fileName: undefined,\n })\n })\n\n context.on('lifecycle:end', async () => {\n await writeLogs()\n })\n\n // Fallback: Write logs on process exit to handle crashes\n const exitHandler = () => {\n // Synchronous write on exit - best effort\n if (cachedLogs.size > 0) {\n writeLogs().catch(() => {\n // Ignore errors on exit\n })\n }\n }\n\n process.once('exit', exitHandler)\n process.once('SIGINT', exitHandler)\n process.once('SIGTERM', exitHandler)\n },\n})\n","import { type Config, defineLogger, LogLevel } from '@kubb/core'\nimport { formatHrtime, formatMs } from '@kubb/core/utils'\nimport { execa } from 'execa'\nimport pc from 'picocolors'\n\n/**\n * GitHub Actions adapter for CI environments\n * Uses ::group:: and ::endgroup:: annotations for collapsible sections\n */\nexport const githubActionsLogger = defineLogger({\n name: 'github-actions',\n install(context, options) {\n const logLevel = options?.logLevel || LogLevel.info\n const state = {\n totalPlugins: 0,\n completedPlugins: 0,\n failedPlugins: 0,\n totalFiles: 0,\n processedFiles: 0,\n hrStart: process.hrtime(),\n currentConfigs: [] as Array<Config>,\n }\n\n function showProgressStep() {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const parts: string[] = []\n const duration = formatHrtime(state.hrStart)\n\n if (state.totalPlugins > 0) {\n const pluginStr =\n state.failedPlugins > 0\n ? `Plugins ${pc.green(state.completedPlugins.toString())}/${state.totalPlugins} ${pc.red(`(${state.failedPlugins} failed)`)}`\n : `Plugins ${pc.green(state.completedPlugins.toString())}/${state.totalPlugins}`\n parts.push(pluginStr)\n }\n\n if (state.totalFiles > 0) {\n parts.push(`Files ${pc.green(state.processedFiles.toString())}/${state.totalFiles}`)\n }\n\n if (parts.length > 0) {\n parts.push(pc.green(duration))\n console.log(parts.join(pc.dim(' | ')))\n }\n }\n\n function getMessage(message: string): string {\n if (logLevel >= LogLevel.verbose) {\n const timestamp = new Date().toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit',\n })\n\n return [pc.dim(`[${timestamp}]`), message].join(' ')\n }\n\n return message\n }\n\n function openGroup(name: string) {\n console.log(`::group::${name}`)\n }\n\n function closeGroup(_name: string) {\n console.log('::endgroup::')\n }\n\n context.on('info', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage([pc.blue('ℹ'), message, pc.dim(info)].join(' '))\n\n console.log(text)\n })\n\n context.on('success', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage([pc.blue('✓'), message, logLevel >= LogLevel.info ? pc.dim(info) : undefined].filter(Boolean).join(' '))\n\n console.log(text)\n })\n\n context.on('warn', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage([pc.yellow('⚠'), message, logLevel >= LogLevel.info ? pc.dim(info) : undefined].filter(Boolean).join(' '))\n\n console.warn(`::warning::${text}`)\n })\n\n context.on('error', (error) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n const message = error.message || String(error)\n console.error(`::error::${message}`)\n })\n\n context.on('lifecycle:start', (version) => {\n console.log(pc.yellow(`Kubb ${version} 🧩`))\n })\n\n context.on('config:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration started')\n\n openGroup('Configuration')\n\n console.log(text)\n })\n\n context.on('config:end', (configs) => {\n state.currentConfigs = configs\n\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration completed')\n\n console.log(text)\n\n closeGroup('Configuration')\n })\n\n context.on('generation:start', (config) => {\n // Initialize progress tracking\n state.totalPlugins = config.plugins?.length || 0\n state.completedPlugins = 0\n state.failedPlugins = 0\n state.hrStart = process.hrtime()\n\n const text = config.name ? `Generation for ${pc.bold(config.name)}` : 'Generation'\n\n if (state.currentConfigs.length > 1) {\n openGroup(text)\n }\n\n if (state.currentConfigs.length === 1) {\n console.log(getMessage(text))\n }\n })\n\n context.on('plugin:start', (plugin) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n const text = getMessage(`Generating ${pc.bold(plugin.name)}`)\n\n if (state.currentConfigs.length === 1) {\n openGroup(`Plugin: ${plugin.name}`)\n }\n\n console.log(text)\n })\n\n context.on('plugin:end', (plugin, { duration, success }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n if (success) {\n state.completedPlugins++\n } else {\n state.failedPlugins++\n }\n\n const durationStr = formatMs(duration)\n const text = getMessage(\n success ? `${pc.bold(plugin.name)} completed in ${pc.green(durationStr)}` : `${pc.bold(plugin.name)} failed in ${pc.red(durationStr)}`,\n )\n\n console.log(text)\n if (state.currentConfigs.length > 1) {\n console.log(' ')\n }\n\n if (state.currentConfigs.length === 1) {\n closeGroup(`Plugin: ${plugin.name}`)\n }\n\n // Show progress step after each plugin\n showProgressStep()\n })\n\n context.on('files:processing:start', (files) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n state.totalFiles = files.length\n state.processedFiles = 0\n\n if (state.currentConfigs.length === 1) {\n openGroup('File Generation')\n }\n const text = getMessage(`Writing ${files.length} files`)\n\n console.log(text)\n })\n\n context.on('files:processing:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n const text = getMessage('Files written successfully')\n\n console.log(text)\n\n if (state.currentConfigs.length === 1) {\n closeGroup('File Generation')\n }\n })\n\n context.on('file:processing:update', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n state.processedFiles++\n })\n\n context.on('files:processing:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n // Show final progress step after files are written\n showProgressStep()\n })\n\n context.on('generation:end', (config) => {\n const text = getMessage(config.name ? `${pc.blue('✓')} Generation completed for ${pc.dim(config.name)}` : `${pc.blue('✓')} Generation completed`)\n\n console.log(text)\n })\n\n context.on('hook:execute', async ({ command, args }, cb) => {\n try {\n const result = await execa(command, args, {\n detached: true,\n stripFinalNewline: true,\n })\n\n await context.emit('debug', {\n date: new Date(),\n logs: [result.stdout],\n })\n\n console.log(result.stdout)\n\n cb()\n } catch (err) {\n const error = new Error('Hook execute failed')\n error.cause = err\n\n await context.emit('debug', {\n date: new Date(),\n logs: [(err as any).stdout],\n })\n\n await context.emit('error', error)\n }\n })\n\n context.on('format:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format started')\n\n if (state.currentConfigs.length === 1) {\n openGroup('Formatting')\n }\n\n console.log(text)\n })\n\n context.on('format:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format completed')\n\n console.log(text)\n\n if (state.currentConfigs.length === 1) {\n closeGroup('Formatting')\n }\n })\n\n context.on('lint:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint started')\n\n if (state.currentConfigs.length === 1) {\n openGroup('Linting')\n }\n\n console.log(text)\n })\n\n context.on('lint:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint completed')\n\n console.log(text)\n\n if (state.currentConfigs.length === 1) {\n closeGroup('Linting')\n }\n })\n\n context.on('hook:start', (command) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(`Hook ${pc.dim(command)} started`)\n\n if (state.currentConfigs.length === 1) {\n openGroup(`Hook ${command}`)\n }\n\n console.log(text)\n })\n\n context.on('hook:end', (command) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(`Hook ${pc.dim(command)} completed`)\n\n console.log(text)\n\n if (state.currentConfigs.length === 1) {\n closeGroup(`Hook ${command}`)\n }\n })\n\n context.on('generation:summary', (config, { status, failedPlugins }) => {\n const pluginsCount = config.plugins?.length || 0\n const successCount = pluginsCount - failedPlugins.size\n\n if (state.currentConfigs.length > 1) {\n console.log(' ')\n }\n\n console.log(\n status === 'success'\n ? `Kubb Summary: ${pc.blue('✓')} ${`${successCount} successful`}, ${pluginsCount} total`\n : `Kubb Summary: ${pc.blue('✓')} ${`${successCount} successful`}, ✗ ${`${failedPlugins.size} failed`}, ${pluginsCount} total`,\n )\n\n if (state.currentConfigs.length > 1) {\n closeGroup(config.name ? `Generation for ${pc.bold(config.name)}` : 'Generation')\n }\n })\n },\n})\n","import { relative } from 'node:path'\nimport { defineLogger, LogLevel } from '@kubb/core'\nimport { formatMs } from '@kubb/core/utils'\nimport { execa } from 'execa'\nimport { getSummary } from '../utils/getSummary.ts'\n\n/**\n * Plain console adapter for non-TTY environments\n * Simple console.log output with indentation\n */\nexport const plainLogger = defineLogger({\n name: 'plain',\n install(context, options) {\n const logLevel = options?.logLevel || 3\n\n function getMessage(message: string): string {\n if (logLevel >= LogLevel.verbose) {\n const timestamp = new Date().toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit',\n })\n\n return [`[${timestamp}]`, message].join(' ')\n }\n\n return message\n }\n\n context.on('info', (message, info) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(['ℹ', message, info].join(' '))\n\n console.log(text)\n })\n\n context.on('success', (message, info = '') => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(['✓', message, logLevel >= LogLevel.info ? info : undefined].filter(Boolean).join(' '))\n\n console.log(text)\n })\n\n context.on('warn', (message, info) => {\n if (logLevel < LogLevel.warn) {\n return\n }\n\n const text = getMessage(['⚠', message, logLevel >= LogLevel.info ? info : undefined].filter(Boolean).join(' '))\n\n console.log(text)\n })\n\n context.on('error', (error) => {\n const caused = error.cause as Error\n\n const text = getMessage(['✗', error.message].join(' '))\n\n console.log(text)\n\n // Show stack trace in debug mode (first 3 frames)\n if (logLevel >= LogLevel.debug && error.stack) {\n const frames = error.stack.split('\\n').slice(1, 4)\n for (const frame of frames) {\n console.log(getMessage(frame.trim()))\n }\n\n if (caused?.stack) {\n console.log(`└─ caused by ${caused.message}`)\n\n const frames = caused.stack.split('\\n').slice(1, 4)\n for (const frame of frames) {\n console.log(getMessage(` ${frame.trim()}`))\n }\n }\n }\n })\n\n context.on('lifecycle:start', () => {\n console.log('Kubb CLI 🧩')\n })\n\n context.on('config:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration started')\n\n console.log(text)\n })\n\n context.on('config:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Configuration completed')\n\n console.log(text)\n })\n\n context.on('generation:start', () => {\n const text = getMessage('Configuration started')\n\n console.log(text)\n })\n\n context.on('plugin:start', (plugin) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n const text = getMessage(`Generating ${plugin.name}`)\n\n console.log(text)\n })\n\n context.on('plugin:end', (plugin, { duration, success }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const durationStr = formatMs(duration)\n const text = getMessage(success ? `${plugin.name} completed in ${durationStr}` : `${plugin.name} failed in ${durationStr}`)\n\n console.log(text)\n })\n\n context.on('files:processing:start', (files) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(`Writing ${files.length} files`)\n\n console.log(text)\n })\n\n context.on('file:processing:update', ({ file, config }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(`Writing ${relative(config.root, file.path)}`)\n\n console.log(text)\n })\n\n context.on('files:processing:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Files written successfully')\n\n console.log(text)\n })\n\n context.on('generation:end', (config) => {\n const text = getMessage(config.name ? `Generation completed for ${config.name}` : 'Generation completed')\n\n console.log(text)\n })\n\n context.on('hook:execute', async ({ command, args }, cb) => {\n try {\n const result = await execa(command, args, {\n detached: true,\n stripFinalNewline: true,\n })\n\n await context.emit('debug', {\n date: new Date(),\n logs: [result.stdout],\n })\n\n console.log(result.stdout)\n\n cb()\n } catch (err) {\n const error = new Error('Hook execute failed')\n error.cause = err\n\n await context.emit('debug', {\n date: new Date(),\n logs: [(err as any).stdout],\n })\n\n await context.emit('error', error)\n }\n })\n\n context.on('format:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format started')\n\n console.log(text)\n })\n\n context.on('format:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Format completed')\n\n console.log(text)\n })\n\n context.on('lint:start', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint started')\n\n console.log(text)\n })\n\n context.on('lint:end', () => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage('Lint completed')\n\n console.log(text)\n })\n\n context.on('hook:start', (command) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(`Hook ${command} started`)\n\n console.log(text)\n })\n\n context.on('hook:end', (command) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const text = getMessage(`Hook ${command} completed`)\n\n console.log(text)\n })\n\n context.on('generation:summary', (config, { pluginTimings, status, hrStart, failedPlugins, filesCreated }) => {\n const summary = getSummary({\n failedPlugins,\n filesCreated,\n config,\n status,\n hrStart,\n pluginTimings: logLevel >= LogLevel.verbose ? pluginTimings : undefined,\n })\n\n console.log('---------------------------')\n console.log(summary.join('\\n'))\n console.log('---------------------------')\n })\n },\n})\n","import type { Logger, LoggerContext, LoggerOptions } from '@kubb/core'\nimport { LogLevel } from '@kubb/core'\nimport { clackLogger } from './clackLogger.ts'\nimport { canUseTTY, isGitHubActions } from './envDetection.ts'\nimport { fileSystemLogger } from './fileSystemLogger.ts'\nimport { githubActionsLogger } from './githubActionsLogger.ts'\nimport { plainLogger } from './plainLogger.ts'\nimport type { LoggerType } from './types.ts'\n\nexport function detectLogger(): LoggerType {\n if (isGitHubActions()) {\n return 'github-actions'\n }\n if (canUseTTY()) {\n return 'clack'\n }\n return 'plain'\n}\n\nconst logMapper = {\n clack: clackLogger,\n plain: plainLogger,\n 'github-actions': githubActionsLogger,\n} as const satisfies Record<LoggerType, Logger>\n\nexport async function setupLogger(context: LoggerContext, { logLevel }: LoggerOptions): Promise<void> {\n const type = detectLogger()\n\n const logger = logMapper[type] as Logger\n\n if (!logger) {\n throw new Error(`Unknown adapter type: ${type}`)\n }\n\n // Install primary logger\n const cleanup = await logger.install(context, { logLevel })\n\n if (logLevel >= LogLevel.debug) {\n await fileSystemLogger.install(context, { logLevel })\n }\n\n return cleanup\n}\n","import type { Config, KubbEvents } from '@kubb/core'\nimport type { AsyncEventEmitter } from '@kubb/core/utils'\n\nimport pc from 'picocolors'\nimport { parseArgsStringToArgv } from 'string-argv'\n\ntype ExecutingHooksProps = {\n hooks: NonNullable<Config['hooks']>\n events: AsyncEventEmitter<KubbEvents>\n}\n\nexport async function executeHooks({ hooks, events }: ExecutingHooksProps): Promise<void> {\n const commands = Array.isArray(hooks.done) ? hooks.done : [hooks.done].filter(Boolean)\n\n for (const command of commands) {\n const [cmd, ...args] = [...parseArgsStringToArgv(command)]\n\n if (!cmd) {\n continue\n }\n\n await events.emit('hook:start', command)\n\n await events.emit('hook:execute', { command: cmd, args }, async () => {\n await events.emit('success', `${pc.dim(command)} successfully executed`)\n\n await events.emit('hook:end', command)\n })\n }\n}\n","import path from 'node:path'\nimport process from 'node:process'\nimport { type Config, type KubbEvents, LogLevel, safeBuild, setup } from '@kubb/core'\nimport type { AsyncEventEmitter } from '@kubb/core/utils'\nimport pc from 'picocolors'\nimport { executeHooks } from '../utils/executeHooks.ts'\n\ntype GenerateProps = {\n input?: string\n config: Config\n events: AsyncEventEmitter<KubbEvents>\n logLevel: number\n}\n\nexport async function generate({ input, config, events, logLevel }: GenerateProps): Promise<void> {\n const { root = process.cwd(), ...userConfig } = config\n const inputPath = input ?? ('path' in userConfig.input ? userConfig.input.path : undefined)\n const hrStart = process.hrtime()\n\n const definedConfig: Config = {\n root,\n ...userConfig,\n input: inputPath\n ? {\n ...userConfig.input,\n path: inputPath,\n }\n : userConfig.input,\n output: {\n write: true,\n barrelType: 'named',\n extension: {\n '.ts': '.ts',\n },\n format: 'prettier',\n ...userConfig.output,\n },\n }\n\n await events.emit('generation:start', definedConfig)\n\n await events.emit('info', config.name ? `Setup generation ${pc.bold(config.name)}` : 'Setup generation', inputPath)\n\n const { fabric, pluginManager } = await setup({\n config: definedConfig,\n events,\n })\n\n await events.emit('info', config.name ? `Build generation ${pc.bold(config.name)}` : 'Build generation', inputPath)\n\n const { files, failedPlugins, pluginTimings, error } = await safeBuild(\n {\n config: definedConfig,\n events,\n },\n { pluginManager, fabric, events },\n )\n\n await events.emit('info', 'Load summary')\n\n // Handle build failures (either from failed plugins or general errors)\n\n const hasFailures = failedPlugins.size > 0 || error\n if (hasFailures) {\n // Collect all errors from failed plugins and general error\n const allErrors: Error[] = [\n error,\n ...Array.from(failedPlugins)\n .filter((it) => it.error)\n .map((it) => it.error),\n ].filter(Boolean)\n\n allErrors.forEach((err) => {\n events.emit('error', err)\n })\n\n await events.emit('generation:end', definedConfig)\n\n await events.emit('generation:summary', definedConfig, {\n failedPlugins,\n filesCreated: files.length,\n status: failedPlugins.size > 0 || error ? 'failed' : 'success',\n hrStart,\n pluginTimings: logLevel >= LogLevel.verbose ? pluginTimings : undefined,\n })\n\n process.exit(1)\n }\n\n await events.emit('success', 'Generation successfully', inputPath)\n await events.emit('generation:end', definedConfig)\n\n // formatting\n if (config.output.format) {\n await events.emit('format:start')\n\n await events.emit(\n 'info',\n [\n `Formatting with ${pc.dim(config.output.format as string)}`,\n logLevel >= LogLevel.info ? `on ${pc.dim(path.resolve(definedConfig.root, definedConfig.output.path))}` : undefined,\n ]\n .filter(Boolean)\n .join(' '),\n )\n\n if (config.output.format === 'prettier') {\n try {\n await events.emit(\n 'hook:execute',\n {\n command: 'prettier',\n args: ['--ignore-unknown', '--write', path.resolve(definedConfig.root, definedConfig.output.path)],\n },\n async () => {\n await events.emit(\n 'success',\n [\n `Formatting with ${pc.dim(config.output.format as string)}`,\n logLevel >= LogLevel.info ? `on ${pc.dim(path.resolve(definedConfig.root, definedConfig.output.path))}` : undefined,\n 'successfully',\n ]\n .filter(Boolean)\n .join(' '),\n )\n },\n )\n } catch (caughtError) {\n await events.emit('error', caughtError as Error)\n }\n\n await events.emit('success', `Formatted with ${config.output.format}`)\n }\n\n if (config.output.format === 'biome') {\n try {\n await events.emit(\n 'hook:execute',\n {\n command: 'biome',\n args: ['format', '--write', path.resolve(definedConfig.root, definedConfig.output.path)],\n },\n async () => {\n await events.emit(\n 'success',\n [\n `Formatting with ${pc.dim(config.output.format as string)}`,\n logLevel >= LogLevel.info ? `on ${pc.dim(path.resolve(definedConfig.root, definedConfig.output.path))}` : undefined,\n 'successfully',\n ]\n .filter(Boolean)\n .join(' '),\n )\n },\n )\n } catch (caughtError) {\n const error = new Error('Biome not found')\n error.cause = caughtError\n await events.emit('error', error)\n }\n }\n\n await events.emit('format:end')\n }\n\n // linting\n if (config.output.lint) {\n await events.emit('lint:start')\n\n await events.emit(\n 'info',\n [\n `Linting with ${pc.dim(config.output.lint as string)}`,\n logLevel >= LogLevel.info ? `on ${pc.dim(path.resolve(definedConfig.root, definedConfig.output.path))}` : undefined,\n ]\n .filter(Boolean)\n .join(' '),\n )\n\n if (config.output.lint === 'eslint') {\n try {\n await events.emit(\n 'hook:execute',\n {\n command: 'eslint',\n args: [path.resolve(definedConfig.root, definedConfig.output.path), '--fix'],\n },\n async () => {\n await events.emit(\n 'success',\n [\n `Linted with ${pc.dim(config.output.lint as string)}`,\n logLevel >= LogLevel.info ? `on ${pc.dim(path.resolve(definedConfig.root, definedConfig.output.path))}` : undefined,\n 'successfully',\n ]\n .filter(Boolean)\n .join(' '),\n )\n },\n )\n } catch (caughtError) {\n const error = new Error('Eslint not found')\n error.cause = caughtError\n await events.emit('error', error)\n }\n }\n\n if (config.output.lint === 'biome') {\n try {\n await events.emit(\n 'hook:execute',\n {\n command: 'biome',\n args: ['lint', '--fix', path.resolve(definedConfig.root, definedConfig.output.path)],\n },\n async () => {\n await events.emit(\n 'success',\n [\n `Linted with ${pc.dim(config.output.lint as string)}`,\n logLevel >= LogLevel.info ? `on ${pc.dim(path.resolve(definedConfig.root, definedConfig.output.path))}` : undefined,\n 'successfully',\n ]\n .filter(Boolean)\n .join(' '),\n )\n },\n )\n } catch (caughtError) {\n const error = new Error('Biome not found')\n error.cause = caughtError\n await events.emit('error', error)\n }\n }\n\n if (config.output.lint === 'oxlint') {\n try {\n await events.emit(\n 'hook:execute',\n {\n command: 'oxlint',\n args: ['--fix', path.resolve(definedConfig.root, definedConfig.output.path)],\n },\n async () => {\n await events.emit(\n 'success',\n [\n `Linted with ${pc.dim(config.output.lint as string)}`,\n logLevel >= LogLevel.info ? `on ${pc.dim(path.resolve(definedConfig.root, definedConfig.output.path))}` : undefined,\n 'successfully',\n ]\n .filter(Boolean)\n .join(' '),\n )\n },\n )\n } catch (caughtError) {\n const error = new Error('Oxlint not found')\n error.cause = caughtError\n await events.emit('error', error)\n }\n }\n\n await events.emit('lint:end')\n }\n\n if (config.hooks) {\n await events.emit('hooks:start')\n await executeHooks({ hooks: config.hooks, events })\n\n await events.emit('hooks:end')\n }\n\n await events.emit('generation:summary', definedConfig, {\n failedPlugins,\n filesCreated: files.length,\n status: failedPlugins.size > 0 || error ? 'failed' : 'success',\n hrStart,\n pluginTimings,\n })\n}\n","import type { UserConfig } from '@kubb/core'\n\nfunction isJSONPlugins(plugins: UserConfig['plugins']) {\n return !!(plugins as any)?.some((plugin: any) => {\n return Array.isArray(plugin) && typeof plugin?.at(0) === 'string'\n })\n}\n\nfunction isObjectPlugins(plugins: UserConfig['plugins']): plugins is any {\n return plugins instanceof Object && !Array.isArray(plugins)\n}\n\nexport function getPlugins(plugins: UserConfig['plugins']): Promise<UserConfig['plugins']> {\n if (isObjectPlugins(plugins)) {\n throw new Error('Object plugins are not supported anymore, best to use http://kubb.dev/getting-started/configure#json')\n }\n\n if (isJSONPlugins(plugins)) {\n throw new Error('JSON plugins are not supported anymore, best to use http://kubb.dev/getting-started/configure#json')\n }\n\n return Promise.resolve(plugins)\n}\n","import type { CLIOptions, Config, UserConfig } from '@kubb/core'\nimport { isPromise } from '@kubb/core/utils'\nimport type { Args } from '../commands/generate.ts'\nimport type { CosmiconfigResult } from './getCosmiConfig.ts'\nimport { getPlugins } from './getPlugins.ts'\n\n/**\n * Converting UserConfig to Config without a change in the object beside the JSON convert.\n */\nexport async function getConfig(result: CosmiconfigResult, args: Args): Promise<Array<Config> | Config> {\n const config = result?.config\n let kubbUserConfig = Promise.resolve(config) as Promise<UserConfig | Array<UserConfig>>\n\n // for ts or js files\n if (typeof config === 'function') {\n const possiblePromise = config(args as CLIOptions)\n if (isPromise(possiblePromise)) {\n kubbUserConfig = possiblePromise\n }\n kubbUserConfig = Promise.resolve(possiblePromise)\n }\n\n let JSONConfig = await kubbUserConfig\n\n if (Array.isArray(JSONConfig)) {\n const results: Array<Config> = []\n\n for (const item of JSONConfig) {\n const plugins = item.plugins ? await getPlugins(item.plugins) : undefined\n\n results.push({\n ...item,\n plugins,\n } as Config)\n }\n\n return results\n }\n\n JSONConfig = {\n ...JSONConfig,\n plugins: JSONConfig.plugins ? await getPlugins(JSONConfig.plugins) : undefined,\n }\n\n return JSONConfig as Config\n}\n","import type { defineConfig, UserConfig } from '@kubb/core'\nimport { cosmiconfig } from 'cosmiconfig'\nimport { createJiti } from 'jiti'\n\nexport type CosmiconfigResult = {\n filepath: string\n isEmpty?: boolean\n config: ReturnType<typeof defineConfig> | UserConfig\n}\n\nconst tsLoader = async (configFile: string) => {\n const jiti = createJiti(import.meta.url, {\n jsx: {\n runtime: 'automatic',\n importSource: '@kubb/react-fabric',\n },\n sourceMaps: true,\n })\n\n const mod = await jiti.import(configFile, { default: true })\n\n return mod\n}\n\nexport async function getCosmiConfig(moduleName: string, config?: string): Promise<CosmiconfigResult> {\n let result: CosmiconfigResult\n const searchPlaces = [\n 'package.json',\n `.${moduleName}rc`,\n `.${moduleName}rc.json`,\n `.${moduleName}rc.yaml`,\n `.${moduleName}rc.yml`,\n\n `.${moduleName}rc.ts`,\n `.${moduleName}rc.js`,\n `.${moduleName}rc.mjs`,\n `.${moduleName}rc.cjs`,\n\n `${moduleName}.config.ts`,\n `${moduleName}.config.js`,\n `${moduleName}.config.mjs`,\n `${moduleName}.config.cjs`,\n ]\n const explorer = cosmiconfig(moduleName, {\n cache: false,\n searchPlaces: [\n ...searchPlaces.map((searchPlace) => {\n return `.config/${searchPlace}`\n }),\n ...searchPlaces.map((searchPlace) => {\n return `configs/${searchPlace}`\n }),\n ...searchPlaces,\n ],\n loaders: {\n '.ts': tsLoader,\n },\n })\n\n try {\n result = config ? ((await explorer.load(config)) as CosmiconfigResult) : ((await explorer.search()) as CosmiconfigResult)\n } catch (error) {\n throw new Error('Config failed loading', { cause: error })\n }\n\n if (result?.isEmpty || !result || !result.config) {\n throw new Error('Config not defined, create a kubb.config.js or pass through your config with the option --config')\n }\n\n return result as CosmiconfigResult\n}\n","import pc from 'picocolors'\n\nexport async function startWatcher(path: string[], cb: (path: string[]) => Promise<void>): Promise<void> {\n const { watch } = await import('chokidar')\n\n const ignored = '**/{.git,node_modules}/**'\n\n const watcher = watch(path, {\n ignorePermissionErrors: true,\n ignored,\n })\n watcher.on('all', (type, file) => {\n console.log(pc.yellow(pc.bold(`Change detected: ${type} ${file}`)))\n\n try {\n cb(path)\n } catch (_e) {\n console.log(pc.red('Watcher failed'))\n }\n })\n}\n","import path from 'node:path'\nimport * as process from 'node:process'\nimport * as clack from '@clack/prompts'\nimport { isInputPath, type KubbEvents, LogLevel, PromiseManager } from '@kubb/core'\nimport { AsyncEventEmitter } from '@kubb/core/utils'\nimport type { ArgsDef, ParsedArgs } from 'citty'\nimport { defineCommand, showUsage } from 'citty'\nimport getLatestVersion from 'latest-version'\nimport pc from 'picocolors'\nimport { lt } from 'semver'\nimport { version } from '../../package.json'\nimport { setupLogger } from '../loggers/utils.ts'\nimport { generate } from '../runners/generate.ts'\nimport { getConfig } from '../utils/getConfig.ts'\nimport { getCosmiConfig } from '../utils/getCosmiConfig.ts'\nimport { startWatcher } from '../utils/watcher.ts'\n\nconst args = {\n config: {\n type: 'string',\n description: 'Path to the Kubb config',\n alias: 'c',\n },\n logLevel: {\n type: 'string',\n description: 'Info, silent, verbose or debug',\n alias: 'l',\n default: 'info',\n valueHint: 'silent|info|verbose|debug',\n },\n watch: {\n type: 'boolean',\n description: 'Watch mode based on the input file',\n alias: 'w',\n default: false,\n },\n debug: {\n type: 'boolean',\n description: 'Override logLevel to debug',\n alias: 'd',\n default: false,\n },\n verbose: {\n type: 'boolean',\n description: 'Override logLevel to verbose',\n alias: 'v',\n default: false,\n },\n help: {\n type: 'boolean',\n description: 'Show help',\n alias: 'h',\n default: false,\n },\n} as const satisfies ArgsDef\n\nexport type Args = ParsedArgs<typeof args>\n\nconst command = defineCommand({\n meta: {\n name: 'generate',\n description: \"[input] Generate files based on a 'kubb.config.ts' file\",\n },\n args,\n async run(commandContext) {\n const { args } = commandContext\n const input = args._[0]\n const events = new AsyncEventEmitter<KubbEvents>()\n const promiseManager = new PromiseManager()\n\n if (args.help) {\n return showUsage(command)\n }\n\n if (args.debug) {\n args.logLevel = 'debug'\n }\n\n if (args.verbose) {\n args.logLevel = 'verbose'\n }\n\n const logLevel = LogLevel[args.logLevel as keyof typeof LogLevel] || 3\n\n await setupLogger(events, { logLevel })\n\n const latestVersion = await getLatestVersion('@kubb/cli')\n\n if (lt(version, latestVersion)) {\n await events.emit('version:new', version, latestVersion)\n }\n\n try {\n await events.emit('lifecycle:start', version)\n\n await events.emit('config:start')\n\n const result = await getCosmiConfig('kubb', args.config)\n\n await events.emit('info', 'Config loaded', path.relative(process.cwd(), result.filepath))\n\n const config = await getConfig(result, args)\n const configs = Array.isArray(config) ? config : [config]\n\n await events.emit('success', 'Config loaded successfully', path.relative(process.cwd(), result.filepath))\n await events.emit('config:end', configs)\n\n const promises = configs.map((config) => {\n return async () => {\n if (isInputPath(config) && args.watch) {\n await startWatcher([input || config.input.path], async (paths) => {\n await generate({\n input,\n config,\n logLevel,\n events,\n })\n\n clack.log.step(pc.yellow(`Watching for changes in ${paths.join(' and ')}`))\n })\n\n return\n }\n\n await generate({\n input,\n config,\n logLevel,\n events,\n })\n }\n })\n\n await promiseManager.run('seq', promises)\n\n await events.emit('lifecycle:end')\n } catch (error) {\n await events.emit('error', error as Error)\n }\n },\n})\n\nexport default command\n"],"mappings":"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"}