@kubb/cli 4.12.11 → 4.12.13

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,4 +1,4 @@
1
- import { t as version } from "./package-ruTIQRno.js";
1
+ import { t as version } from "./package-BhcjqUID.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";
@@ -14,10 +14,26 @@ import gradientString from "gradient-string";
14
14
  import seedrandom from "seedrandom";
15
15
  import { Writable } from "node:stream";
16
16
  import { write } from "@kubb/core/fs";
17
+ import { createHash } from "node:crypto";
17
18
  import { parseArgsStringToArgv } from "string-argv";
18
19
  import { cosmiconfig } from "cosmiconfig";
19
20
  import { createJiti } from "jiti";
20
21
 
22
+ //#region src/utils/formatMsWithColor.ts
23
+ /**
24
+ * Formats milliseconds with color based on duration thresholds:
25
+ * - Green: <= 500ms
26
+ * - Yellow: > 500ms and <= 1000ms
27
+ * - Red: > 1000ms
28
+ */
29
+ function formatMsWithColor(ms) {
30
+ const formatted = formatMs(ms);
31
+ if (ms <= 500) return pc.green(formatted);
32
+ if (ms <= 1e3) return pc.yellow(formatted);
33
+ return pc.red(formatted);
34
+ }
35
+
36
+ //#endregion
21
37
  //#region src/utils/randomColour.ts
22
38
  function randomColour(text) {
23
39
  if (!text) return "white";
@@ -275,8 +291,8 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
275
291
  clearInterval(active.interval);
276
292
  if (success) state.completedPlugins++;
277
293
  else state.failedPlugins++;
278
- const durationStr = formatMs(duration);
279
- const text = getMessage(success ? `${pc.bold(plugin.name)} completed in ${pc.green(durationStr)}` : `${pc.bold(plugin.name)} failed in ${pc.red(durationStr)}`);
294
+ const durationStr = formatMsWithColor(duration);
295
+ const text = getMessage(success ? `${pc.bold(plugin.name)} completed in ${durationStr}` : `${pc.bold(plugin.name)} failed in ${pc.red(formatMs(duration))}`);
280
296
  active.progressBar.stop(text);
281
297
  state.activeProgress.delete(plugin.name);
282
298
  showProgressStep();
@@ -340,7 +356,9 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
340
356
  clack.outro(text);
341
357
  });
342
358
  context.on("hook:start", async ({ id, command: command$1, args }) => {
343
- const text = getMessage(`Hook ${pc.dim(command$1)} started`);
359
+ const commandWithArgs = args?.length ? `${command$1} ${args.join(" ")}` : command$1;
360
+ const text = getMessage(`Hook ${pc.dim(commandWithArgs)} started`);
361
+ if (!id) return;
344
362
  if (logLevel <= LogLevel.silent) {
345
363
  try {
346
364
  const result = await execa(command$1, args, {
@@ -353,6 +371,7 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
353
371
  });
354
372
  await context.emit("hook:end", {
355
373
  command: command$1,
374
+ args,
356
375
  id
357
376
  });
358
377
  } catch (err) {
@@ -367,7 +386,7 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
367
386
  return;
368
387
  }
369
388
  clack.intro(text);
370
- const writable = new ClackWritable(clack.taskLog({ title: getMessage(["Executing hook", logLevel >= LogLevel.info ? pc.dim(`${command$1} ${args?.join(" ")}`) : void 0].filter(Boolean).join(" ")) }));
389
+ const writable = new ClackWritable(clack.taskLog({ title: getMessage(["Executing hook", logLevel >= LogLevel.info ? pc.dim(commandWithArgs) : void 0].filter(Boolean).join(" ")) }));
371
390
  try {
372
391
  const result = await execa(command$1, args, {
373
392
  detached: true,
@@ -380,6 +399,7 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
380
399
  });
381
400
  await context.emit("hook:end", {
382
401
  command: command$1,
402
+ args,
383
403
  id
384
404
  });
385
405
  } catch (err) {
@@ -392,9 +412,10 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
392
412
  await context.emit("error", error);
393
413
  }
394
414
  });
395
- context.on("hook:end", ({ command: command$1 }) => {
415
+ context.on("hook:end", ({ command: command$1, args }) => {
396
416
  if (logLevel <= LogLevel.silent) return;
397
- const text = getMessage(`Hook ${pc.dim(command$1)} successfully executed`);
417
+ const commandWithArgs = args?.length ? `${command$1} ${args.join(" ")}` : command$1;
418
+ const text = getMessage(`Hook ${pc.dim(commandWithArgs)} successfully executed`);
398
419
  clack.outro(text);
399
420
  });
400
421
  context.on("generation:summary", (config, { pluginTimings, failedPlugins, filesCreated, status, hrStart }) => {
@@ -477,7 +498,7 @@ const fileSystemLogger = defineLogger({
477
498
  state.startDate = Date.now();
478
499
  }
479
500
  async function writeLogs(name) {
480
- if (state.cachedLogs.size === 0) return;
501
+ if (state.cachedLogs.size === 0) return [];
481
502
  const files = {};
482
503
  for (const log of state.cachedLogs) {
483
504
  const baseName = log.fileName || `${[
@@ -495,6 +516,7 @@ const fileSystemLogger = defineLogger({
495
516
  await Promise.all(Object.entries(files).map(async ([fileName, logs]) => {
496
517
  return write(fileName, logs.join("\n\n"));
497
518
  }));
519
+ return Object.keys(files);
498
520
  }
499
521
  context.on("info", (message, info) => {
500
522
  state.cachedLogs.add({
@@ -554,9 +576,14 @@ const fileSystemLogger = defineLogger({
554
576
  });
555
577
  });
556
578
  context.on("generation:end", async (config) => {
557
- await writeLogs(config.name);
579
+ const writtenFilePaths = await writeLogs(config.name);
580
+ if (writtenFilePaths.length > 0) {
581
+ const files = writtenFilePaths.map((f) => relative(process.cwd(), f));
582
+ await context.emit("info", "Debug files written to:", files.join(", "));
583
+ }
558
584
  reset();
559
585
  });
586
+ context.on("lifecycle:end", async () => {});
560
587
  const exitHandler = () => {
561
588
  if (state.cachedLogs.size > 0) writeLogs().catch(() => {});
562
589
  };
@@ -653,9 +680,19 @@ const githubActionsLogger = defineLogger({
653
680
  console.warn(`::warning::${text}`);
654
681
  });
655
682
  context.on("error", (error) => {
683
+ const caused = error.cause;
656
684
  if (logLevel <= LogLevel.silent) return;
657
685
  const message = error.message || String(error);
658
686
  console.error(`::error::${message}`);
687
+ if (logLevel >= LogLevel.debug && error.stack) {
688
+ const frames = error.stack.split("\n").slice(1, 4);
689
+ for (const frame of frames) console.log(getMessage(pc.dim(frame.trim())));
690
+ if (caused?.stack) {
691
+ console.log(pc.dim(`└─ caused by ${caused.message}`));
692
+ const frames$1 = caused.stack.split("\n").slice(1, 4);
693
+ for (const frame of frames$1) console.log(getMessage(` ${pc.dim(frame.trim())}`));
694
+ }
695
+ }
659
696
  });
660
697
  context.on("lifecycle:start", (version$1) => {
661
698
  console.log(pc.yellow(`Kubb ${version$1} 🧩`));
@@ -691,8 +728,8 @@ const githubActionsLogger = defineLogger({
691
728
  if (logLevel <= LogLevel.silent) return;
692
729
  if (success) state.completedPlugins++;
693
730
  else state.failedPlugins++;
694
- const durationStr = formatMs(duration);
695
- const text = getMessage(success ? `${pc.bold(plugin.name)} completed in ${pc.green(durationStr)}` : `${pc.bold(plugin.name)} failed in ${pc.red(durationStr)}`);
731
+ const durationStr = formatMsWithColor(duration);
732
+ const text = getMessage(success ? `${pc.bold(plugin.name)} completed in ${durationStr}` : `${pc.bold(plugin.name)} failed in ${pc.red(formatMs(duration))}`);
696
733
  console.log(text);
697
734
  if (state.currentConfigs.length > 1) console.log(" ");
698
735
  if (state.currentConfigs.length === 1) closeGroup(`Plugin: ${plugin.name}`);
@@ -749,11 +786,13 @@ const githubActionsLogger = defineLogger({
749
786
  if (state.currentConfigs.length === 1) closeGroup("Linting");
750
787
  });
751
788
  context.on("hook:start", async ({ id, command: command$1, args }) => {
752
- const text = getMessage(`Hook ${pc.dim(command$1)} started`);
789
+ const commandWithArgs = args?.length ? `${command$1} ${args.join(" ")}` : command$1;
790
+ const text = getMessage(`Hook ${pc.dim(commandWithArgs)} started`);
753
791
  if (logLevel > LogLevel.silent) {
754
- if (state.currentConfigs.length === 1) openGroup(`Hook ${command$1}`);
792
+ if (state.currentConfigs.length === 1) openGroup(`Hook ${commandWithArgs}`);
755
793
  console.log(text);
756
794
  }
795
+ if (!id) return;
757
796
  try {
758
797
  const result = await execa(command$1, args, {
759
798
  detached: true,
@@ -766,6 +805,7 @@ const githubActionsLogger = defineLogger({
766
805
  console.log(result.stdout);
767
806
  await context.emit("hook:end", {
768
807
  command: command$1,
808
+ args,
769
809
  id
770
810
  });
771
811
  } catch (err) {
@@ -778,11 +818,12 @@ const githubActionsLogger = defineLogger({
778
818
  await context.emit("error", error);
779
819
  }
780
820
  });
781
- context.on("hook:end", ({ command: command$1 }) => {
821
+ context.on("hook:end", ({ command: command$1, args }) => {
782
822
  if (logLevel <= LogLevel.silent) return;
783
- const text = getMessage(`Hook ${pc.dim(command$1)} completed`);
823
+ const commandWithArgs = args?.length ? `${command$1} ${args.join(" ")}` : command$1;
824
+ const text = getMessage(`Hook ${pc.dim(commandWithArgs)} completed`);
784
825
  console.log(text);
785
- if (state.currentConfigs.length === 1) closeGroup(`Hook ${command$1}`);
826
+ if (state.currentConfigs.length === 1) closeGroup(`Hook ${commandWithArgs}`);
786
827
  });
787
828
  context.on("generation:summary", (config, { status, hrStart, failedPlugins }) => {
788
829
  const pluginsCount = config.plugins?.length || 0;
@@ -923,8 +964,9 @@ const plainLogger = defineLogger({
923
964
  console.log(text);
924
965
  });
925
966
  context.on("hook:start", async ({ id, command: command$1, args }) => {
926
- const text = getMessage(`Hook ${command$1} started`);
967
+ const text = getMessage(`Hook ${args?.length ? `${command$1} ${args.join(" ")}` : command$1} started`);
927
968
  if (logLevel > LogLevel.silent) console.log(text);
969
+ if (!id) return;
928
970
  try {
929
971
  const result = await execa(command$1, args, {
930
972
  detached: true,
@@ -937,6 +979,7 @@ const plainLogger = defineLogger({
937
979
  console.log(result.stdout);
938
980
  await context.emit("hook:end", {
939
981
  command: command$1,
982
+ args,
940
983
  id
941
984
  });
942
985
  } catch (err) {
@@ -949,9 +992,9 @@ const plainLogger = defineLogger({
949
992
  await context.emit("error", error);
950
993
  }
951
994
  });
952
- context.on("hook:end", (command$1) => {
995
+ context.on("hook:end", ({ command: command$1, args }) => {
953
996
  if (logLevel <= LogLevel.silent) return;
954
- const text = getMessage(`Hook ${command$1} completed`);
997
+ const text = getMessage(`Hook ${args?.length ? `${command$1} ${args.join(" ")}` : command$1} completed`);
955
998
  console.log(text);
956
999
  });
957
1000
  context.on("generation:summary", (config, { pluginTimings, status, hrStart, failedPlugins, filesCreated }) => {
@@ -998,7 +1041,9 @@ async function executeHooks({ hooks, events }) {
998
1041
  for (const command$1 of commands) {
999
1042
  const [cmd, ...args] = [...parseArgsStringToArgv(command$1)];
1000
1043
  if (!cmd) continue;
1044
+ const hookId = createHash("sha256").update(command$1).digest("hex");
1001
1045
  await events.emit("hook:start", {
1046
+ id: hookId,
1002
1047
  command: cmd,
1003
1048
  args
1004
1049
  });
@@ -1065,7 +1110,9 @@ async function generate({ input, config: userConfig, events, logLevel }) {
1065
1110
  await events.emit("info", [`Formatting with ${pc.dim(config.output.format)}`, logLevel >= LogLevel.info ? `on ${pc.dim(path.resolve(config.root, config.output.path))}` : void 0].filter(Boolean).join(" "));
1066
1111
  if (config.output.format === "prettier") {
1067
1112
  try {
1113
+ const hookId = createHash("sha256").update([config.name, config.output.format].filter(Boolean).join("-")).digest("hex");
1068
1114
  await events.emit("hook:start", {
1115
+ id: hookId,
1069
1116
  command: "prettier",
1070
1117
  args: [
1071
1118
  "--ignore-unknown",
@@ -1086,7 +1133,9 @@ async function generate({ input, config: userConfig, events, logLevel }) {
1086
1133
  await events.emit("success", `Formatted with ${config.output.format}`);
1087
1134
  }
1088
1135
  if (config.output.format === "biome") try {
1136
+ const hookId = createHash("sha256").update([config.name, config.output.format].filter(Boolean).join("-")).digest("hex");
1089
1137
  await events.emit("hook:start", {
1138
+ id: hookId,
1090
1139
  command: "biome",
1091
1140
  args: [
1092
1141
  "format",
@@ -1112,7 +1161,9 @@ async function generate({ input, config: userConfig, events, logLevel }) {
1112
1161
  await events.emit("lint:start");
1113
1162
  await events.emit("info", [`Linting with ${pc.dim(config.output.lint)}`, logLevel >= LogLevel.info ? `on ${pc.dim(path.resolve(config.root, config.output.path))}` : void 0].filter(Boolean).join(" "));
1114
1163
  if (config.output.lint === "eslint") try {
1164
+ const hookId = createHash("sha256").update([config.name, config.output.lint].filter(Boolean).join("-")).digest("hex");
1115
1165
  await events.emit("hook:start", {
1166
+ id: hookId,
1116
1167
  command: "eslint",
1117
1168
  args: [path.resolve(config.root, config.output.path), "--fix"]
1118
1169
  });
@@ -1129,7 +1180,9 @@ async function generate({ input, config: userConfig, events, logLevel }) {
1129
1180
  await events.emit("error", error$1);
1130
1181
  }
1131
1182
  if (config.output.lint === "biome") try {
1183
+ const hookId = createHash("sha256").update([config.name, config.output.lint].filter(Boolean).join("-")).digest("hex");
1132
1184
  await events.emit("hook:start", {
1185
+ id: hookId,
1133
1186
  command: "biome",
1134
1187
  args: [
1135
1188
  "lint",
@@ -1150,7 +1203,9 @@ async function generate({ input, config: userConfig, events, logLevel }) {
1150
1203
  await events.emit("error", error$1);
1151
1204
  }
1152
1205
  if (config.output.lint === "oxlint") try {
1206
+ const hookId = createHash("sha256").update([config.name, config.output.lint].filter(Boolean).join("-")).digest("hex");
1153
1207
  await events.emit("hook:start", {
1208
+ id: hookId,
1154
1209
  command: "oxlint",
1155
1210
  args: ["--fix", path.resolve(config.root, config.output.path)]
1156
1211
  });
@@ -1236,12 +1291,13 @@ async function getConfig(result, args) {
1236
1291
  //#endregion
1237
1292
  //#region src/utils/getCosmiConfig.ts
1238
1293
  const tsLoader = async (configFile) => {
1239
- return await createJiti(import.meta.url, {
1294
+ return await createJiti(configFile, {
1240
1295
  jsx: {
1241
1296
  runtime: "automatic",
1242
1297
  importSource: "@kubb/react-fabric"
1243
1298
  },
1244
- sourceMaps: true
1299
+ sourceMaps: true,
1300
+ interopDefault: true
1245
1301
  }).import(configFile, { default: true });
1246
1302
  };
1247
1303
  async function getCosmiConfig(moduleName, config) {
@@ -1406,4 +1462,4 @@ var generate_default = command;
1406
1462
 
1407
1463
  //#endregion
1408
1464
  export { generate_default as default };
1409
- //# sourceMappingURL=generate-Dtd6QodJ.js.map
1465
+ //# sourceMappingURL=generate-DV1QP67S.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-DV1QP67S.js","names":["summaryLines: string[]","process","parts: string[]","frames","version","command","files: Record<string, string[]>","parts: string[]","frames","version","command","frames","command","command","process","config: Config","error","results: Array<Config>","result: CosmiconfigResult","path","process","config"],"sources":["../src/utils/formatMsWithColor.ts","../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 { formatMs } from '@kubb/core/utils'\nimport pc from 'picocolors'\n\n/**\n * Formats milliseconds with color based on duration thresholds:\n * - Green: <= 500ms\n * - Yellow: > 500ms and <= 1000ms\n * - Red: > 1000ms\n */\nexport function formatMsWithColor(ms: number): string {\n const formatted = formatMs(ms)\n\n if (ms <= 500) {\n return pc.green(formatted)\n }\n\n if (ms <= 1000) {\n return pc.yellow(formatted)\n }\n\n return pc.red(formatted)\n}\n","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 { formatMsWithColor } from '../utils/formatMsWithColor.ts'\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 reset() {\n for (const [_key, active] of state.activeProgress) {\n if (active.interval) {\n clearInterval(active.interval)\n }\n active.progressBar?.stop()\n }\n\n state.totalPlugins = 0\n state.completedPlugins = 0\n state.failedPlugins = 0\n state.totalFiles = 0\n state.processedFiles = 0\n state.hrStart = process.hrtime()\n state.spinner = clack.spinner()\n state.isSpinning = false\n state.activeProgress.clear()\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)} elapsed`)\n clack.log.step(getMessage(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 reset()\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\n const text = getMessage(['Generation started', config.name ? `for ${pc.dim(config.name)}` : undefined].filter(Boolean).join(' '))\n\n clack.intro(text)\n reset()\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 }, 100)\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 = formatMsWithColor(duration)\n const text = getMessage(\n success ? `${pc.bold(plugin.name)} completed in ${durationStr}` : `${pc.bold(plugin.name)} failed in ${pc.red(formatMs(duration))}`,\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('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', async ({ id, command, args }) => {\n const commandWithArgs = args?.length ? `${command} ${args.join(' ')}` : command\n const text = getMessage(`Hook ${pc.dim(commandWithArgs)} started`)\n\n // Skip hook execution if no id is provided (e.g., during benchmarks or tests)\n if (!id) {\n return\n }\n\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 await context.emit('hook:end', { command, args, id })\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 clack.intro(text)\n\n const logger = clack.taskLog({\n title: getMessage(['Executing hook', logLevel >= LogLevel.info ? pc.dim(commandWithArgs) : 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 await context.emit('hook:end', { command, args, id })\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('hook:end', ({ command, args }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const commandWithArgs = args?.length ? `${command} ${args.join(' ')}` : command\n const text = getMessage(`Hook ${pc.dim(commandWithArgs)} successfully executed`)\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 reset()\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 { relative, resolve } from 'node:path'\nimport { defineLogger } from '@kubb/core'\nimport { write } from '@kubb/core/fs'\nimport { formatMs } from '@kubb/core/utils'\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 state = {\n cachedLogs: new Set<CachedEvent>(),\n startDate: Date.now(),\n }\n\n function reset() {\n state.cachedLogs = new Set<CachedEvent>()\n state.startDate = Date.now()\n }\n\n async function writeLogs(name?: string) {\n if (state.cachedLogs.size === 0) {\n return []\n }\n\n const files: Record<string, string[]> = {}\n\n for (const log of state.cachedLogs) {\n const baseName = log.fileName || `${['kubb', name, state.startDate].filter(Boolean).join('-')}.log`\n const pathName = resolve(process.cwd(), '.kubb', baseName)\n\n if (!files[pathName]) {\n files[pathName] = []\n }\n\n if (log.logs.length > 0) {\n const timestamp = log.date.toLocaleString()\n files[pathName].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 return Object.keys(files)\n }\n\n context.on('info', (message, info) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`ℹ ${message} ${info}`],\n fileName: undefined,\n })\n })\n\n context.on('success', (message, info) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`✓ ${message} ${info}`],\n fileName: undefined,\n })\n })\n\n context.on('warn', (message, info) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`⚠ ${message} ${info}`],\n fileName: undefined,\n })\n })\n\n context.on('error', (error) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`✗ ${error.message}`, error.stack || 'unknown stack'],\n fileName: undefined,\n })\n })\n\n context.on('debug', (message) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: message.logs,\n fileName: undefined,\n })\n })\n\n context.on('plugin:start', (plugin) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`Generating ${plugin.name}`],\n fileName: undefined,\n })\n })\n\n context.on('plugin:end', (plugin, { duration, success }) => {\n const durationStr = formatMs(duration)\n\n state.cachedLogs.add({\n date: new Date(),\n logs: [success ? `${plugin.name} completed in ${durationStr}` : `${plugin.name} failed in ${durationStr}`],\n fileName: undefined,\n })\n })\n\n context.on('files:processing:start', (files) => {\n state.cachedLogs.add({\n date: new Date(),\n logs: [`Start ${files.length} writing:`, ...files.map((file) => file.path)],\n fileName: undefined,\n })\n })\n\n context.on('generation:end', async (config) => {\n const writtenFilePaths = await writeLogs(config.name)\n if (writtenFilePaths.length > 0) {\n const files = writtenFilePaths.map((f) => relative(process.cwd(), f))\n await context.emit('info', 'Debug files written to:', files.join(', '))\n }\n reset()\n })\n\n context.on('lifecycle:end', async () => {\n // lifecycle:end handler can be used for cleanup if needed in the future\n })\n\n // Fallback: Write logs on process exit to handle crashes\n const exitHandler = () => {\n // Synchronous write on exit - best effort\n if (state.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'\nimport { formatMsWithColor } from '../utils/formatMsWithColor.ts'\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 reset() {\n state.totalPlugins = 0\n state.completedPlugins = 0\n state.failedPlugins = 0\n state.totalFiles = 0\n state.processedFiles = 0\n state.hrStart = process.hrtime()\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)} elapsed`)\n console.log(getMessage(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 const caused = error.cause as Error\n\n if (logLevel <= LogLevel.silent) {\n return\n }\n const message = error.message || String(error)\n console.error(`::error::${message}`)\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(pc.dim(frame.trim())))\n }\n\n if (caused?.stack) {\n console.log(pc.dim(`└─ 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(` ${pc.dim(frame.trim())}`))\n }\n }\n }\n })\n\n context.on('lifecycle:start', (version) => {\n console.log(pc.yellow(`Kubb ${version} 🧩`))\n reset()\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\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 reset()\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 = formatMsWithColor(duration)\n const text = getMessage(\n success ? `${pc.bold(plugin.name)} completed in ${durationStr}` : `${pc.bold(plugin.name)} failed in ${pc.red(formatMs(duration))}`,\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('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', async ({ id, command, args }) => {\n const commandWithArgs = args?.length ? `${command} ${args.join(' ')}` : command\n const text = getMessage(`Hook ${pc.dim(commandWithArgs)} started`)\n\n if (logLevel > LogLevel.silent) {\n if (state.currentConfigs.length === 1) {\n openGroup(`Hook ${commandWithArgs}`)\n }\n\n console.log(text)\n }\n\n // Skip hook execution if no id is provided (e.g., during benchmarks or tests)\n if (!id) {\n return\n }\n\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 await context.emit('hook:end', { command, args, id })\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('hook:end', ({ command, args }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const commandWithArgs = args?.length ? `${command} ${args.join(' ')}` : command\n const text = getMessage(`Hook ${pc.dim(commandWithArgs)} completed`)\n\n console.log(text)\n\n if (state.currentConfigs.length === 1) {\n closeGroup(`Hook ${commandWithArgs}`)\n }\n })\n\n context.on('generation:summary', (config, { status, hrStart, failedPlugins }) => {\n const pluginsCount = config.plugins?.length || 0\n const successCount = pluginsCount - failedPlugins.size\n const duration = formatHrtime(hrStart)\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, ${pc.green(duration)}`\n : `Kubb Summary: ${pc.blue('✓')} ${`${successCount} successful`}, ✗ ${`${failedPlugins.size} failed`}, ${pluginsCount} total, ${pc.green(duration)}`,\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('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', async ({ id, command, args }) => {\n const commandWithArgs = args?.length ? `${command} ${args.join(' ')}` : command\n const text = getMessage(`Hook ${commandWithArgs} started`)\n\n if (logLevel > LogLevel.silent) {\n console.log(text)\n }\n\n // Skip hook execution if no id is provided (e.g., during benchmarks or tests)\n if (!id) {\n return\n }\n\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 await context.emit('hook:end', { command, args, id })\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('hook:end', ({ command, args }) => {\n if (logLevel <= LogLevel.silent) {\n return\n }\n\n const commandWithArgs = args?.length ? `${command} ${args.join(' ')}` : command\n const text = getMessage(`Hook ${commandWithArgs} 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 { createHash } from 'node:crypto'\nimport 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 const hookId = createHash('sha256').update(command).digest('hex')\n await events.emit('hook:start', { id: hookId, command: cmd, args })\n\n await events.onOnce('hook:end', async () => {\n await events.emit('success', `${pc.dim(command)} successfully executed`)\n })\n }\n}\n","import { createHash } from 'node:crypto'\nimport 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: userConfig, events, logLevel }: GenerateProps): Promise<void> {\n const inputPath = input ?? ('path' in userConfig.input ? userConfig.input.path : undefined)\n const hrStart = process.hrtime()\n\n const config: Config = {\n ...userConfig,\n root: userConfig.root || process.cwd(),\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', config)\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,\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,\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', config)\n\n await events.emit('generation:summary', config, {\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', config)\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(config.root, config.output.path))}` : undefined,\n ]\n .filter(Boolean)\n .join(' '),\n )\n\n if (config.output.format === 'prettier') {\n try {\n const hookId = createHash('sha256').update([config.name, config.output.format].filter(Boolean).join('-')).digest('hex')\n await events.emit('hook:start', {\n id: hookId,\n command: 'prettier',\n args: ['--ignore-unknown', '--write', path.resolve(config.root, config.output.path)],\n })\n\n await events.onOnce('hook:end', 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(config.root, config.output.path))}` : undefined,\n 'successfully',\n ]\n .filter(Boolean)\n .join(' '),\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 const hookId = createHash('sha256').update([config.name, config.output.format].filter(Boolean).join('-')).digest('hex')\n await events.emit('hook:start', {\n id: hookId,\n command: 'biome',\n args: ['format', '--write', path.resolve(config.root, config.output.path)],\n })\n\n await events.onOnce('hook:end', 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(config.root, config.output.path))}` : undefined,\n 'successfully',\n ]\n .filter(Boolean)\n .join(' '),\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(config.root, config.output.path))}` : undefined,\n ]\n .filter(Boolean)\n .join(' '),\n )\n\n if (config.output.lint === 'eslint') {\n try {\n const hookId = createHash('sha256').update([config.name, config.output.lint].filter(Boolean).join('-')).digest('hex')\n await events.emit('hook:start', {\n id: hookId,\n command: 'eslint',\n args: [path.resolve(config.root, config.output.path), '--fix'],\n })\n\n await events.onOnce('hook:end', 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(config.root, config.output.path))}` : undefined,\n 'successfully',\n ]\n .filter(Boolean)\n .join(' '),\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 const hookId = createHash('sha256').update([config.name, config.output.lint].filter(Boolean).join('-')).digest('hex')\n await events.emit('hook:start', {\n id: hookId,\n command: 'biome',\n args: ['lint', '--fix', path.resolve(config.root, config.output.path)],\n })\n\n await events.onOnce('hook:end', 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(config.root, config.output.path))}` : undefined,\n 'successfully',\n ]\n .filter(Boolean)\n .join(' '),\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 const hookId = createHash('sha256').update([config.name, config.output.lint].filter(Boolean).join('-')).digest('hex')\n await events.emit('hook:start', {\n id: hookId,\n command: 'oxlint',\n args: ['--fix', path.resolve(config.root, config.output.path)],\n })\n\n await events.onOnce('hook:end', 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(config.root, config.output.path))}` : undefined,\n 'successfully',\n ]\n .filter(Boolean)\n .join(' '),\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', config, {\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(configFile, {\n jsx: {\n runtime: 'automatic',\n importSource: '@kubb/react-fabric',\n },\n sourceMaps: true,\n interopDefault: 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 silent: {\n type: 'boolean',\n description: 'Override logLevel to silent',\n alias: 's',\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 if (args.silent) {\n args.logLevel = 'silent'\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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"}
package/dist/index.cjs CHANGED
@@ -1,5 +1,5 @@
1
1
  const require_chunk = require('./chunk-CbDLau6x.cjs');
2
- const require_package = require('./package-yC2On1WI.cjs');
2
+ const require_package = require('./package-BRJpSEzh.cjs');
3
3
  let citty = require("citty");
4
4
 
5
5
  //#region src/index.ts
@@ -24,12 +24,12 @@ const main = (0, citty.defineCommand)({
24
24
  "validate",
25
25
  "mcp"
26
26
  ].includes(rawArgs[0])) {
27
- await (0, citty.runCommand)(await Promise.resolve().then(() => require("./generate-DinDgyVI.cjs")).then((r) => r.default), { rawArgs });
27
+ await (0, citty.runCommand)(await Promise.resolve().then(() => require("./generate-BxTaKNGW.cjs")).then((r) => r.default), { rawArgs });
28
28
  process.exit(0);
29
29
  }
30
30
  },
31
31
  subCommands: {
32
- generate: () => Promise.resolve().then(() => require("./generate-DinDgyVI.cjs")).then((r) => r.default),
32
+ generate: () => Promise.resolve().then(() => require("./generate-BxTaKNGW.cjs")).then((r) => r.default),
33
33
  validate: () => Promise.resolve().then(() => require("./validate-D9LPzg3-.cjs")).then((r) => r.default),
34
34
  mcp: () => Promise.resolve().then(() => require("./mcp-D7d_8Bma.cjs")).then((r) => r.default)
35
35
  }
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
- import { t as version } from "./package-ruTIQRno.js";
1
+ import { t as version } from "./package-BhcjqUID.js";
2
2
  import { defineCommand, runCommand, runMain } from "citty";
3
3
 
4
4
  //#region src/index.ts
@@ -23,12 +23,12 @@ const main = defineCommand({
23
23
  "validate",
24
24
  "mcp"
25
25
  ].includes(rawArgs[0])) {
26
- await runCommand(await import("./generate-Dtd6QodJ.js").then((r) => r.default), { rawArgs });
26
+ await runCommand(await import("./generate-DV1QP67S.js").then((r) => r.default), { rawArgs });
27
27
  process.exit(0);
28
28
  }
29
29
  },
30
30
  subCommands: {
31
- generate: () => import("./generate-Dtd6QodJ.js").then((r) => r.default),
31
+ generate: () => import("./generate-DV1QP67S.js").then((r) => r.default),
32
32
  validate: () => import("./validate-Bt922JN-.js").then((r) => r.default),
33
33
  mcp: () => import("./mcp-B5FWDVjp.js").then((r) => r.default)
34
34
  }
@@ -1,6 +1,6 @@
1
1
 
2
2
  //#region package.json
3
- var version = "4.12.11";
3
+ var version = "4.12.13";
4
4
 
5
5
  //#endregion
6
6
  Object.defineProperty(exports, 'version', {
@@ -9,4 +9,4 @@ Object.defineProperty(exports, 'version', {
9
9
  return version;
10
10
  }
11
11
  });
12
- //# sourceMappingURL=package-yC2On1WI.cjs.map
12
+ //# sourceMappingURL=package-BRJpSEzh.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"package-BRJpSEzh.cjs","names":[],"sources":["../package.json"],"sourcesContent":[""],"mappings":""}
@@ -0,0 +1,6 @@
1
+ //#region package.json
2
+ var version = "4.12.13";
3
+
4
+ //#endregion
5
+ export { version as t };
6
+ //# sourceMappingURL=package-BhcjqUID.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"package-BhcjqUID.js","names":[],"sources":["../package.json"],"sourcesContent":[""],"mappings":""}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kubb/cli",
3
- "version": "4.12.11",
3
+ "version": "4.12.13",
4
4
  "description": "Command-line interface for Kubb, enabling easy generation of TypeScript, React-Query, Zod, and other code from OpenAPI specifications.",
5
5
  "keywords": [
6
6
  "cli",
@@ -62,14 +62,14 @@
62
62
  "seedrandom": "^3.0.5",
63
63
  "semver": "^7.7.3",
64
64
  "string-argv": "^0.3.2",
65
- "@kubb/core": "4.12.11"
65
+ "@kubb/core": "4.12.13"
66
66
  },
67
67
  "devDependencies": {
68
68
  "@types/seedrandom": "^3.0.8",
69
69
  "@types/semver": "^7.7.1",
70
70
  "source-map-support": "^0.5.21",
71
- "@kubb/mcp": "4.12.11",
72
- "@kubb/oas": "4.12.11"
71
+ "@kubb/mcp": "4.12.13",
72
+ "@kubb/oas": "4.12.13"
73
73
  },
74
74
  "engines": {
75
75
  "node": ">=20"