@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,5 +1,5 @@
1
1
  const require_chunk = require('./chunk-CbDLau6x.cjs');
2
- const require_package = require('./package-4h1lfDoB.cjs');
2
+ const require_package = require('./package-CrqsFX0R.cjs');
3
3
  let citty = require("citty");
4
4
  let node_path = require("node:path");
5
5
  node_path = require_chunk.__toESM(node_path);
@@ -25,12 +25,6 @@ let string_argv = require("string-argv");
25
25
  let cosmiconfig = require("cosmiconfig");
26
26
  let jiti = require("jiti");
27
27
 
28
- //#region src/utils/parseHrtimeToSeconds.ts
29
- function parseHrtimeToSeconds(hrtime) {
30
- return (hrtime[0] + hrtime[1] / 1e9).toFixed(3);
31
- }
32
-
33
- //#endregion
34
28
  //#region src/utils/randomColour.ts
35
29
  function randomColour(text) {
36
30
  if (!text) return "white";
@@ -58,14 +52,14 @@ function randomCliColour(text) {
58
52
  //#endregion
59
53
  //#region src/utils/getSummary.ts
60
54
  function getSummary({ failedPlugins, filesCreated, status, hrStart, config, pluginTimings }) {
61
- const elapsedSeconds = parseHrtimeToSeconds(process.hrtime(hrStart));
55
+ const duration = (0, _kubb_core_utils.formatHrtime)(hrStart);
62
56
  const pluginsCount = config.plugins?.length || 0;
63
57
  const successCount = pluginsCount - failedPlugins.size;
64
58
  const meta = {
65
59
  plugins: status === "success" ? `${picocolors.default.green(`${successCount} successful`)}, ${pluginsCount} total` : `${picocolors.default.green(`${successCount} successful`)}, ${picocolors.default.red(`${failedPlugins.size} failed`)}, ${pluginsCount} total`,
66
60
  pluginsFailed: status === "failed" ? [...failedPlugins]?.map(({ plugin }) => randomCliColour(plugin.name))?.join(", ") : void 0,
67
61
  filesCreated,
68
- time: `${elapsedSeconds}s`,
62
+ time: picocolors.default.green(duration),
69
63
  output: node_path.default.isAbsolute(config.root) ? node_path.default.resolve(config.root, config.output.path) : config.root
70
64
  };
71
65
  const labels = {
@@ -122,9 +116,31 @@ const clackLogger = (0, _kubb_core.defineLogger)({
122
116
  name: "clack",
123
117
  install(context, options) {
124
118
  const logLevel = options?.logLevel || _kubb_core.LogLevel.info;
125
- const activeProgress = /* @__PURE__ */ new Map();
126
- const spinner = _clack_prompts.spinner();
127
- let isSpinning = false;
119
+ const state = {
120
+ totalPlugins: 0,
121
+ completedPlugins: 0,
122
+ failedPlugins: 0,
123
+ totalFiles: 0,
124
+ processedFiles: 0,
125
+ hrStart: node_process.default.hrtime(),
126
+ spinner: _clack_prompts.spinner(),
127
+ isSpinning: false,
128
+ activeProgress: /* @__PURE__ */ new Map()
129
+ };
130
+ function showProgressStep() {
131
+ if (logLevel <= _kubb_core.LogLevel.silent) return;
132
+ const parts = [];
133
+ const duration = (0, _kubb_core_utils.formatHrtime)(state.hrStart);
134
+ if (state.totalPlugins > 0) {
135
+ const pluginStr = state.failedPlugins > 0 ? `Plugins ${picocolors.default.green(state.completedPlugins.toString())}/${state.totalPlugins} ${picocolors.default.red(`(${state.failedPlugins} failed)`)}` : `Plugins ${picocolors.default.green(state.completedPlugins.toString())}/${state.totalPlugins}`;
136
+ parts.push(pluginStr);
137
+ }
138
+ if (state.totalFiles > 0) parts.push(`Files ${picocolors.default.green(state.processedFiles.toString())}/${state.totalFiles}`);
139
+ if (parts.length > 0) {
140
+ parts.push(picocolors.default.green(duration));
141
+ _clack_prompts.log.step(parts.join(picocolors.default.dim(" | ")));
142
+ }
143
+ }
128
144
  function getMessage(message) {
129
145
  if (logLevel >= _kubb_core.LogLevel.verbose) {
130
146
  const timestamp = (/* @__PURE__ */ new Date()).toLocaleTimeString("en-US", {
@@ -138,12 +154,12 @@ const clackLogger = (0, _kubb_core.defineLogger)({
138
154
  return message;
139
155
  }
140
156
  function startSpinner(text) {
141
- spinner.start(text);
142
- isSpinning = true;
157
+ state.spinner.start(text);
158
+ state.isSpinning = true;
143
159
  }
144
160
  function stopSpinner(text) {
145
- spinner.stop(text);
146
- isSpinning = false;
161
+ state.spinner.stop(text);
162
+ state.isSpinning = false;
147
163
  }
148
164
  context.on("info", (message, info = "") => {
149
165
  if (logLevel <= _kubb_core.LogLevel.silent) return;
@@ -152,7 +168,7 @@ const clackLogger = (0, _kubb_core.defineLogger)({
152
168
  message,
153
169
  picocolors.default.dim(info)
154
170
  ].join(" "));
155
- if (isSpinning) spinner.message(text);
171
+ if (state.isSpinning) state.spinner.message(text);
156
172
  else _clack_prompts.log.info(text);
157
173
  });
158
174
  context.on("success", (message, info = "") => {
@@ -162,7 +178,7 @@ const clackLogger = (0, _kubb_core.defineLogger)({
162
178
  message,
163
179
  logLevel >= _kubb_core.LogLevel.info ? picocolors.default.dim(info) : void 0
164
180
  ].filter(Boolean).join(" "));
165
- if (isSpinning) stopSpinner(text);
181
+ if (state.isSpinning) stopSpinner(text);
166
182
  else _clack_prompts.log.success(text);
167
183
  });
168
184
  context.on("warn", (message, info) => {
@@ -177,7 +193,7 @@ const clackLogger = (0, _kubb_core.defineLogger)({
177
193
  context.on("error", (error) => {
178
194
  const caused = error.cause;
179
195
  const text = [picocolors.default.red("✗"), error.message].join(" ");
180
- if (isSpinning) stopSpinner(getMessage(text));
196
+ if (state.isSpinning) stopSpinner(getMessage(text));
181
197
  else _clack_prompts.log.error(getMessage(text));
182
198
  if (logLevel >= _kubb_core.LogLevel.debug && error.stack) {
183
199
  const frames = error.stack.split("\n").slice(1, 4);
@@ -214,12 +230,16 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
214
230
  _clack_prompts.intro(text);
215
231
  startSpinner(getMessage("Configuration loading"));
216
232
  });
217
- context.on("config:end", () => {
233
+ context.on("config:end", (_configs) => {
218
234
  if (logLevel <= _kubb_core.LogLevel.silent) return;
219
235
  const text = getMessage("Configuration completed");
220
236
  _clack_prompts.outro(text);
221
237
  });
222
238
  context.on("generation:start", (config) => {
239
+ state.totalPlugins = config.plugins?.length || 0;
240
+ state.completedPlugins = 0;
241
+ state.failedPlugins = 0;
242
+ state.hrStart = node_process.default.hrtime();
223
243
  const text = getMessage(["Generation started", config.name ? `for ${picocolors.default.dim(config.name)}` : void 0].filter(Boolean).join(" "));
224
244
  _clack_prompts.intro(text);
225
245
  });
@@ -236,24 +256,29 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
236
256
  const interval = setInterval(() => {
237
257
  progressBar.advance();
238
258
  }, 50);
239
- activeProgress.set(plugin.name, {
259
+ state.activeProgress.set(plugin.name, {
240
260
  progressBar,
241
261
  interval
242
262
  });
243
263
  });
244
- context.on("plugin:end", (plugin, duration) => {
264
+ context.on("plugin:end", (plugin, { duration, success }) => {
245
265
  stopSpinner();
246
- const active = activeProgress.get(plugin.name);
266
+ const active = state.activeProgress.get(plugin.name);
247
267
  if (!active || logLevel === _kubb_core.LogLevel.silent) return;
248
268
  clearInterval(active.interval);
249
- const durationStr = duration >= 1e3 ? `${(duration / 1e3).toFixed(2)}s` : `${duration}ms`;
250
- const text = getMessage(`${picocolors.default.bold(plugin.name)} completed in ${picocolors.default.green(durationStr)}`);
269
+ if (success) state.completedPlugins++;
270
+ else state.failedPlugins++;
271
+ const durationStr = (0, _kubb_core_utils.formatMs)(duration);
272
+ const text = getMessage(success ? `${picocolors.default.bold(plugin.name)} completed in ${picocolors.default.green(durationStr)}` : `${picocolors.default.bold(plugin.name)} failed in ${picocolors.default.red(durationStr)}`);
251
273
  active.progressBar.stop(text);
252
- activeProgress.delete(plugin.name);
274
+ state.activeProgress.delete(plugin.name);
275
+ showProgressStep();
253
276
  });
254
277
  context.on("files:processing:start", (files) => {
255
278
  if (logLevel <= _kubb_core.LogLevel.silent) return;
256
279
  stopSpinner();
280
+ state.totalFiles = files.length;
281
+ state.processedFiles = 0;
257
282
  const text = `Writing ${files.length} files`;
258
283
  const progressBar = _clack_prompts.progress({
259
284
  style: "block",
@@ -262,13 +287,14 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
262
287
  });
263
288
  context.emit("info", text);
264
289
  progressBar.start(getMessage(text));
265
- activeProgress.set("files", { progressBar });
290
+ state.activeProgress.set("files", { progressBar });
266
291
  });
267
292
  context.on("file:processing:update", ({ file, config }) => {
268
293
  if (logLevel <= _kubb_core.LogLevel.silent) return;
269
294
  stopSpinner();
295
+ state.processedFiles++;
270
296
  const text = `Writing ${(0, node_path.relative)(config.root, file.path)}`;
271
- const active = activeProgress.get("files");
297
+ const active = state.activeProgress.get("files");
272
298
  if (!active) return;
273
299
  active.progressBar.advance(void 0, text);
274
300
  });
@@ -276,10 +302,11 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
276
302
  if (logLevel <= _kubb_core.LogLevel.silent) return;
277
303
  stopSpinner();
278
304
  const text = getMessage("Files written successfully");
279
- const active = activeProgress.get("files");
305
+ const active = state.activeProgress.get("files");
280
306
  if (!active) return;
281
307
  active.progressBar.stop(text);
282
- activeProgress.delete("files");
308
+ state.activeProgress.delete("files");
309
+ showProgressStep();
283
310
  });
284
311
  context.on("generation:end", (config) => {
285
312
  const text = getMessage(config.name ? `Generation completed for ${picocolors.default.dim(config.name)}` : "Generation completed");
@@ -393,11 +420,11 @@ Run \`npm install -g @kubb/cli\` to update`, "Update available for `Kubb`", {
393
420
  });
394
421
  });
395
422
  context.on("lifecycle:end", () => {
396
- for (const [_key, active] of activeProgress) {
423
+ for (const [_key, active] of state.activeProgress) {
397
424
  if (active.interval) clearInterval(active.interval);
398
425
  active.progressBar?.stop();
399
426
  }
400
- activeProgress.clear();
427
+ state.activeProgress.clear();
401
428
  });
402
429
  }
403
430
  });
@@ -482,7 +509,29 @@ const githubActionsLogger = (0, _kubb_core.defineLogger)({
482
509
  name: "github-actions",
483
510
  install(context, options) {
484
511
  const logLevel = options?.logLevel || _kubb_core.LogLevel.info;
485
- let currentConfigs = [];
512
+ const state = {
513
+ totalPlugins: 0,
514
+ completedPlugins: 0,
515
+ failedPlugins: 0,
516
+ totalFiles: 0,
517
+ processedFiles: 0,
518
+ hrStart: process.hrtime(),
519
+ currentConfigs: []
520
+ };
521
+ function showProgressStep() {
522
+ if (logLevel <= _kubb_core.LogLevel.silent) return;
523
+ const parts = [];
524
+ const duration = (0, _kubb_core_utils.formatHrtime)(state.hrStart);
525
+ if (state.totalPlugins > 0) {
526
+ const pluginStr = state.failedPlugins > 0 ? `Plugins ${picocolors.default.green(state.completedPlugins.toString())}/${state.totalPlugins} ${picocolors.default.red(`(${state.failedPlugins} failed)`)}` : `Plugins ${picocolors.default.green(state.completedPlugins.toString())}/${state.totalPlugins}`;
527
+ parts.push(pluginStr);
528
+ }
529
+ if (state.totalFiles > 0) parts.push(`Files ${picocolors.default.green(state.processedFiles.toString())}/${state.totalFiles}`);
530
+ if (parts.length > 0) {
531
+ parts.push(picocolors.default.green(duration));
532
+ console.log(parts.join(picocolors.default.dim(" | ")));
533
+ }
534
+ }
486
535
  function getMessage(message) {
487
536
  if (logLevel >= _kubb_core.LogLevel.verbose) {
488
537
  const timestamp = (/* @__PURE__ */ new Date()).toLocaleTimeString("en-US", {
@@ -543,34 +592,43 @@ const githubActionsLogger = (0, _kubb_core.defineLogger)({
543
592
  console.log(text);
544
593
  });
545
594
  context.on("config:end", (configs) => {
546
- currentConfigs = configs;
595
+ state.currentConfigs = configs;
547
596
  if (logLevel <= _kubb_core.LogLevel.silent) return;
548
597
  const text = getMessage("Configuration completed");
549
598
  console.log(text);
550
599
  closeGroup("Configuration");
551
600
  });
552
601
  context.on("generation:start", (config) => {
602
+ state.totalPlugins = config.plugins?.length || 0;
603
+ state.completedPlugins = 0;
604
+ state.failedPlugins = 0;
605
+ state.hrStart = process.hrtime();
553
606
  const text = config.name ? `Generation for ${picocolors.default.bold(config.name)}` : "Generation";
554
- if (currentConfigs.length > 1) openGroup(text);
555
- if (currentConfigs.length === 1) console.log(getMessage(text));
607
+ if (state.currentConfigs.length > 1) openGroup(text);
608
+ if (state.currentConfigs.length === 1) console.log(getMessage(text));
556
609
  });
557
610
  context.on("plugin:start", (plugin) => {
558
611
  if (logLevel <= _kubb_core.LogLevel.silent) return;
559
612
  const text = getMessage(`Generating ${picocolors.default.bold(plugin.name)}`);
560
- if (currentConfigs.length === 1) openGroup(`Plugin: ${plugin.name}`);
613
+ if (state.currentConfigs.length === 1) openGroup(`Plugin: ${plugin.name}`);
561
614
  console.log(text);
562
615
  });
563
- context.on("plugin:end", (plugin, duration) => {
616
+ context.on("plugin:end", (plugin, { duration, success }) => {
564
617
  if (logLevel <= _kubb_core.LogLevel.silent) return;
565
- const durationStr = duration >= 1e3 ? `${(duration / 1e3).toFixed(2)}s` : `${duration}ms`;
566
- const text = getMessage(`${picocolors.default.bold(plugin.name)} completed in ${picocolors.default.green(durationStr)}`);
618
+ if (success) state.completedPlugins++;
619
+ else state.failedPlugins++;
620
+ const durationStr = (0, _kubb_core_utils.formatMs)(duration);
621
+ const text = getMessage(success ? `${picocolors.default.bold(plugin.name)} completed in ${picocolors.default.green(durationStr)}` : `${picocolors.default.bold(plugin.name)} failed in ${picocolors.default.red(durationStr)}`);
567
622
  console.log(text);
568
- if (currentConfigs.length > 1) console.log(" ");
569
- if (currentConfigs.length === 1) closeGroup(`Plugin: ${plugin.name}`);
623
+ if (state.currentConfigs.length > 1) console.log(" ");
624
+ if (state.currentConfigs.length === 1) closeGroup(`Plugin: ${plugin.name}`);
625
+ showProgressStep();
570
626
  });
571
627
  context.on("files:processing:start", (files) => {
572
628
  if (logLevel <= _kubb_core.LogLevel.silent) return;
573
- if (currentConfigs.length === 1) openGroup("File Generation");
629
+ state.totalFiles = files.length;
630
+ state.processedFiles = 0;
631
+ if (state.currentConfigs.length === 1) openGroup("File Generation");
574
632
  const text = getMessage(`Writing ${files.length} files`);
575
633
  console.log(text);
576
634
  });
@@ -578,7 +636,15 @@ const githubActionsLogger = (0, _kubb_core.defineLogger)({
578
636
  if (logLevel <= _kubb_core.LogLevel.silent) return;
579
637
  const text = getMessage("Files written successfully");
580
638
  console.log(text);
581
- if (currentConfigs.length === 1) closeGroup("File Generation");
639
+ if (state.currentConfigs.length === 1) closeGroup("File Generation");
640
+ });
641
+ context.on("file:processing:update", () => {
642
+ if (logLevel <= _kubb_core.LogLevel.silent) return;
643
+ state.processedFiles++;
644
+ });
645
+ context.on("files:processing:end", () => {
646
+ if (logLevel <= _kubb_core.LogLevel.silent) return;
647
+ showProgressStep();
582
648
  });
583
649
  context.on("generation:end", (config) => {
584
650
  const text = getMessage(config.name ? `${picocolors.default.blue("✓")} Generation completed for ${picocolors.default.dim(config.name)}` : `${picocolors.default.blue("✓")} Generation completed`);
@@ -609,45 +675,45 @@ const githubActionsLogger = (0, _kubb_core.defineLogger)({
609
675
  context.on("format:start", () => {
610
676
  if (logLevel <= _kubb_core.LogLevel.silent) return;
611
677
  const text = getMessage("Format started");
612
- if (currentConfigs.length === 1) openGroup("Formatting");
678
+ if (state.currentConfigs.length === 1) openGroup("Formatting");
613
679
  console.log(text);
614
680
  });
615
681
  context.on("format:end", () => {
616
682
  if (logLevel <= _kubb_core.LogLevel.silent) return;
617
683
  const text = getMessage("Format completed");
618
684
  console.log(text);
619
- if (currentConfigs.length === 1) closeGroup("Formatting");
685
+ if (state.currentConfigs.length === 1) closeGroup("Formatting");
620
686
  });
621
687
  context.on("lint:start", () => {
622
688
  if (logLevel <= _kubb_core.LogLevel.silent) return;
623
689
  const text = getMessage("Lint started");
624
- if (currentConfigs.length === 1) openGroup("Linting");
690
+ if (state.currentConfigs.length === 1) openGroup("Linting");
625
691
  console.log(text);
626
692
  });
627
693
  context.on("lint:end", () => {
628
694
  if (logLevel <= _kubb_core.LogLevel.silent) return;
629
695
  const text = getMessage("Lint completed");
630
696
  console.log(text);
631
- if (currentConfigs.length === 1) closeGroup("Linting");
697
+ if (state.currentConfigs.length === 1) closeGroup("Linting");
632
698
  });
633
699
  context.on("hook:start", (command$1) => {
634
700
  if (logLevel <= _kubb_core.LogLevel.silent) return;
635
701
  const text = getMessage(`Hook ${picocolors.default.dim(command$1)} started`);
636
- if (currentConfigs.length === 1) openGroup(`Hook ${command$1}`);
702
+ if (state.currentConfigs.length === 1) openGroup(`Hook ${command$1}`);
637
703
  console.log(text);
638
704
  });
639
705
  context.on("hook:end", (command$1) => {
640
706
  if (logLevel <= _kubb_core.LogLevel.silent) return;
641
707
  const text = getMessage(`Hook ${picocolors.default.dim(command$1)} completed`);
642
708
  console.log(text);
643
- if (currentConfigs.length === 1) closeGroup(`Hook ${command$1}`);
709
+ if (state.currentConfigs.length === 1) closeGroup(`Hook ${command$1}`);
644
710
  });
645
711
  context.on("generation:summary", (config, { status, failedPlugins }) => {
646
712
  const pluginsCount = config.plugins?.length || 0;
647
713
  const successCount = pluginsCount - failedPlugins.size;
648
- if (currentConfigs.length > 1) console.log(" ");
714
+ if (state.currentConfigs.length > 1) console.log(" ");
649
715
  console.log(status === "success" ? `Kubb Summary: ${picocolors.default.blue("✓")} ${`${successCount} successful`}, ${pluginsCount} total` : `Kubb Summary: ${picocolors.default.blue("✓")} ${`${successCount} successful`}, ✗ ${`${failedPlugins.size} failed`}, ${pluginsCount} total`);
650
- if (currentConfigs.length > 1) closeGroup(config.name ? `Generation for ${picocolors.default.bold(config.name)}` : "Generation");
716
+ if (state.currentConfigs.length > 1) closeGroup(config.name ? `Generation for ${picocolors.default.bold(config.name)}` : "Generation");
651
717
  });
652
718
  }
653
719
  });
@@ -734,10 +800,10 @@ const plainLogger = (0, _kubb_core.defineLogger)({
734
800
  const text = getMessage(`Generating ${plugin.name}`);
735
801
  console.log(text);
736
802
  });
737
- context.on("plugin:end", (plugin, duration) => {
803
+ context.on("plugin:end", (plugin, { duration, success }) => {
738
804
  if (logLevel <= _kubb_core.LogLevel.silent) return;
739
- const durationStr = duration >= 1e3 ? `${(duration / 1e3).toFixed(2)}s` : `${duration}ms`;
740
- const text = getMessage(`${plugin.name} completed in ${durationStr}`);
805
+ const durationStr = (0, _kubb_core_utils.formatMs)(duration);
806
+ const text = getMessage(success ? `${plugin.name} completed in ${durationStr}` : `${plugin.name} failed in ${durationStr}`);
741
807
  console.log(text);
742
808
  });
743
809
  context.on("files:processing:start", (files) => {
@@ -1253,4 +1319,4 @@ var generate_default = command;
1253
1319
 
1254
1320
  //#endregion
1255
1321
  exports.default = generate_default;
1256
- //# sourceMappingURL=generate-DrdKyOOH.cjs.map
1322
+ //# sourceMappingURL=generate-7e5eF2O-.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-7e5eF2O-.cjs","names":["pc","pc","path","summaryLines: string[]","Writable","pc","LogLevel","process","clack","parts: string[]","pc","frames","version","command","cachedLogs: Set<CachedEvent>","files: Record<string, string[]>","LogLevel","parts: string[]","pc","version","command","LogLevel","frames","command","LogLevel","command","pc","process","definedConfig: Config","pc","LogLevel","path","error","results: Array<Config>","result: CosmiconfigResult","path","pc","AsyncEventEmitter","PromiseManager","LogLevel","version","path","process","config","pc"],"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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"}
package/dist/index.cjs CHANGED
@@ -1,5 +1,5 @@
1
1
  const require_chunk = require('./chunk-CbDLau6x.cjs');
2
- const require_package = require('./package-4h1lfDoB.cjs');
2
+ const require_package = require('./package-CrqsFX0R.cjs');
3
3
  let citty = require("citty");
4
4
 
5
5
  //#region src/index.ts
@@ -26,12 +26,12 @@ const main = (0, citty.defineCommand)({
26
26
  "validate",
27
27
  "mcp"
28
28
  ].includes(rawArgs[0])) {
29
- await (0, citty.runCommand)(await Promise.resolve().then(() => require("./generate-DrdKyOOH.cjs")).then((r) => r.default), { rawArgs });
29
+ await (0, citty.runCommand)(await Promise.resolve().then(() => require("./generate-7e5eF2O-.cjs")).then((r) => r.default), { rawArgs });
30
30
  process.exit(0);
31
31
  }
32
32
  },
33
33
  subCommands: {
34
- generate: () => Promise.resolve().then(() => require("./generate-DrdKyOOH.cjs")).then((r) => r.default),
34
+ generate: () => Promise.resolve().then(() => require("./generate-7e5eF2O-.cjs")).then((r) => r.default),
35
35
  validate: () => Promise.resolve().then(() => require("./validate-D9LPzg3-.cjs")).then((r) => r.default),
36
36
  mcp: () => Promise.resolve().then(() => require("./mcp-D7d_8Bma.cjs")).then((r) => r.default)
37
37
  }