@kubb/cli 4.24.1 → 4.25.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{agent-C9MWOHKX.js → agent-C1v0TR8w.js} +3 -3
- package/dist/{agent-C9MWOHKX.js.map → agent-C1v0TR8w.js.map} +1 -1
- package/dist/{agent-Buz_5Op4.cjs → agent-CUCCncEE.cjs} +2 -2
- package/dist/{agent-Buz_5Op4.cjs.map → agent-CUCCncEE.cjs.map} +1 -1
- package/dist/{chunk-EyRqdYP6.js → chunk-jHaXqnEa.js} +1 -4
- package/dist/{generate-TlZuy-_J.js → generate-CatXFtMP.js} +16 -225
- package/dist/generate-CatXFtMP.js.map +1 -0
- package/dist/{generate-DOptfS-i.cjs → generate-DDB1uKUL.cjs} +17 -226
- package/dist/generate-DDB1uKUL.cjs.map +1 -0
- package/dist/index.cjs +5 -5
- package/dist/index.d.ts +1 -1
- package/dist/index.js +8 -8
- package/dist/{init-Buvji__l.js → init-DNeV1F1V.js} +9 -4
- package/dist/{init-Buvji__l.js.map → init-DNeV1F1V.js.map} +1 -1
- package/dist/{init-DAtR-Gc3.cjs → init-nVbwjr1J.cjs} +8 -3
- package/dist/{init-DAtR-Gc3.cjs.map → init-nVbwjr1J.cjs.map} +1 -1
- package/dist/{mcp-85caBdzd.js → mcp-C-e4yatL.js} +2 -2
- package/dist/{mcp-85caBdzd.js.map → mcp-C-e4yatL.js.map} +1 -1
- package/dist/{package-zgKn_S0Q.cjs → package-dw0pujbh.cjs} +2 -2
- package/dist/package-dw0pujbh.cjs.map +1 -0
- package/dist/package-enrPgQqs.js +6 -0
- package/dist/package-enrPgQqs.js.map +1 -0
- package/dist/start-3QvnMf49.js +102 -0
- package/dist/start-3QvnMf49.js.map +1 -0
- package/dist/{start-Vf8kCm8g.cjs → start-CktvgGht.cjs} +39 -13
- package/dist/start-CktvgGht.cjs.map +1 -0
- package/dist/{validate-DaGKH-63.js → validate-YI4YkVTl.js} +2 -2
- package/dist/{validate-DaGKH-63.js.map → validate-YI4YkVTl.js.map} +1 -1
- package/package.json +6 -5
- package/src/commands/agent/start.ts +65 -15
- package/src/commands/generate.ts +3 -4
- package/src/commands/init.ts +1 -1
- package/src/runners/generate.ts +23 -104
- package/src/utils/getCosmiConfig.ts +1 -1
- package/dist/generate-DOptfS-i.cjs.map +0 -1
- package/dist/generate-TlZuy-_J.js.map +0 -1
- package/dist/package-CCCewbUD.js +0 -6
- package/dist/package-CCCewbUD.js.map +0 -1
- package/dist/package-zgKn_S0Q.cjs.map +0 -1
- package/dist/start-DdvHHe8S.js +0 -76
- package/dist/start-DdvHHe8S.js.map +0 -1
- package/dist/start-Vf8kCm8g.cjs.map +0 -1
- package/src/utils/detectFormatter.ts +0 -55
- package/src/utils/detectLinter.ts +0 -55
- package/src/utils/formatters.ts +0 -17
- package/src/utils/getConfigs.ts +0 -41
- package/src/utils/getPlugins.ts +0 -23
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
const require_chunk = require('./chunk-C1_xRkKa.cjs');
|
|
2
|
-
const require_package = require('./package-
|
|
2
|
+
const require_package = require('./package-dw0pujbh.cjs');
|
|
3
3
|
let citty = require("citty");
|
|
4
4
|
let node_path = require("node:path");
|
|
5
5
|
node_path = require_chunk.__toESM(node_path);
|
|
@@ -1151,102 +1151,6 @@ async function setupLogger(context, { logLevel }) {
|
|
|
1151
1151
|
return cleanup;
|
|
1152
1152
|
}
|
|
1153
1153
|
|
|
1154
|
-
//#endregion
|
|
1155
|
-
//#region src/utils/detectFormatter.ts
|
|
1156
|
-
/**
|
|
1157
|
-
* Check if a formatter command is available in the system.
|
|
1158
|
-
*
|
|
1159
|
-
* @param formatter - The formatter to check ('biome', 'prettier', or 'oxfmt')
|
|
1160
|
-
* @returns Promise that resolves to true if the formatter is available, false otherwise
|
|
1161
|
-
*
|
|
1162
|
-
* @remarks
|
|
1163
|
-
* This function checks availability by running `<formatter> --version` command.
|
|
1164
|
-
* All supported formatters (biome, prettier, oxfmt) implement the --version flag.
|
|
1165
|
-
*/
|
|
1166
|
-
async function isFormatterAvailable(formatter) {
|
|
1167
|
-
try {
|
|
1168
|
-
await (0, execa.execaCommand)(`${formatter} --version`, { stdio: "ignore" });
|
|
1169
|
-
return true;
|
|
1170
|
-
} catch {
|
|
1171
|
-
return false;
|
|
1172
|
-
}
|
|
1173
|
-
}
|
|
1174
|
-
/**
|
|
1175
|
-
* Detect which formatter is available in the system.
|
|
1176
|
-
*
|
|
1177
|
-
* @returns Promise that resolves to the first available formatter or undefined if none are found
|
|
1178
|
-
*
|
|
1179
|
-
* @remarks
|
|
1180
|
-
* Checks in order of preference: biome, oxfmt, prettier.
|
|
1181
|
-
* Uses the `--version` flag to detect if each formatter command is available.
|
|
1182
|
-
* This is a reliable method as all supported formatters implement this flag.
|
|
1183
|
-
*
|
|
1184
|
-
* @example
|
|
1185
|
-
* ```typescript
|
|
1186
|
-
* const formatter = await detectFormatter()
|
|
1187
|
-
* if (formatter) {
|
|
1188
|
-
* console.log(`Using ${formatter} for formatting`)
|
|
1189
|
-
* } else {
|
|
1190
|
-
* console.log('No formatter found')
|
|
1191
|
-
* }
|
|
1192
|
-
* ```
|
|
1193
|
-
*/
|
|
1194
|
-
async function detectFormatter() {
|
|
1195
|
-
for (const formatter of [
|
|
1196
|
-
"biome",
|
|
1197
|
-
"oxfmt",
|
|
1198
|
-
"prettier"
|
|
1199
|
-
]) if (await isFormatterAvailable(formatter)) return formatter;
|
|
1200
|
-
}
|
|
1201
|
-
|
|
1202
|
-
//#endregion
|
|
1203
|
-
//#region src/utils/detectLinter.ts
|
|
1204
|
-
/**
|
|
1205
|
-
* Check if a linter command is available in the system.
|
|
1206
|
-
*
|
|
1207
|
-
* @param linter - The linter to check ('biome', 'oxlint', or 'eslint')
|
|
1208
|
-
* @returns Promise that resolves to true if the linter is available, false otherwise
|
|
1209
|
-
*
|
|
1210
|
-
* @remarks
|
|
1211
|
-
* This function checks availability by running `<linter> --version` command.
|
|
1212
|
-
* All supported linters (biome, oxlint, eslint) implement the --version flag.
|
|
1213
|
-
*/
|
|
1214
|
-
async function isLinterAvailable(linter) {
|
|
1215
|
-
try {
|
|
1216
|
-
await (0, execa.execaCommand)(`${linter} --version`, { stdio: "ignore" });
|
|
1217
|
-
return true;
|
|
1218
|
-
} catch {
|
|
1219
|
-
return false;
|
|
1220
|
-
}
|
|
1221
|
-
}
|
|
1222
|
-
/**
|
|
1223
|
-
* Detect which linter is available in the system.
|
|
1224
|
-
*
|
|
1225
|
-
* @returns Promise that resolves to the first available linter or undefined if none are found
|
|
1226
|
-
*
|
|
1227
|
-
* @remarks
|
|
1228
|
-
* Checks in order of preference: biome, oxlint, eslint.
|
|
1229
|
-
* Uses the `--version` flag to detect if each linter command is available.
|
|
1230
|
-
* This is a reliable method as all supported linters implement this flag.
|
|
1231
|
-
*
|
|
1232
|
-
* @example
|
|
1233
|
-
* ```typescript
|
|
1234
|
-
* const linter = await detectLinter()
|
|
1235
|
-
* if (linter) {
|
|
1236
|
-
* console.log(`Using ${linter} for linting`)
|
|
1237
|
-
* } else {
|
|
1238
|
-
* console.log('No linter found')
|
|
1239
|
-
* }
|
|
1240
|
-
* ```
|
|
1241
|
-
*/
|
|
1242
|
-
async function detectLinter() {
|
|
1243
|
-
for (const linter of [
|
|
1244
|
-
"biome",
|
|
1245
|
-
"oxlint",
|
|
1246
|
-
"eslint"
|
|
1247
|
-
]) if (await isLinterAvailable(linter)) return linter;
|
|
1248
|
-
}
|
|
1249
|
-
|
|
1250
1154
|
//#endregion
|
|
1251
1155
|
//#region src/utils/executeHooks.ts
|
|
1252
1156
|
async function executeHooks({ hooks, events }) {
|
|
@@ -1267,34 +1171,6 @@ async function executeHooks({ hooks, events }) {
|
|
|
1267
1171
|
}
|
|
1268
1172
|
}
|
|
1269
1173
|
|
|
1270
|
-
//#endregion
|
|
1271
|
-
//#region src/utils/formatters.ts
|
|
1272
|
-
const formatters = {
|
|
1273
|
-
prettier: {
|
|
1274
|
-
command: "prettier",
|
|
1275
|
-
args: (outputPath) => [
|
|
1276
|
-
"--ignore-unknown",
|
|
1277
|
-
"--write",
|
|
1278
|
-
outputPath
|
|
1279
|
-
],
|
|
1280
|
-
errorMessage: "Prettier not found"
|
|
1281
|
-
},
|
|
1282
|
-
biome: {
|
|
1283
|
-
command: "biome",
|
|
1284
|
-
args: (outputPath) => [
|
|
1285
|
-
"format",
|
|
1286
|
-
"--write",
|
|
1287
|
-
outputPath
|
|
1288
|
-
],
|
|
1289
|
-
errorMessage: "Biome not found"
|
|
1290
|
-
},
|
|
1291
|
-
oxfmt: {
|
|
1292
|
-
command: "oxfmt",
|
|
1293
|
-
args: (outputPath) => [outputPath],
|
|
1294
|
-
errorMessage: "Oxfmt not found"
|
|
1295
|
-
}
|
|
1296
|
-
};
|
|
1297
|
-
|
|
1298
1174
|
//#endregion
|
|
1299
1175
|
//#region src/runners/generate.ts
|
|
1300
1176
|
async function generate({ input, config: userConfig, events, logLevel }) {
|
|
@@ -1352,15 +1228,15 @@ async function generate({ input, config: userConfig, events, logLevel }) {
|
|
|
1352
1228
|
await events.emit("format:start");
|
|
1353
1229
|
let formatter = config.output.format;
|
|
1354
1230
|
if (formatter === "auto") {
|
|
1355
|
-
const detectedFormatter = await detectFormatter();
|
|
1231
|
+
const detectedFormatter = await (0, _kubb_core_utils.detectFormatter)();
|
|
1356
1232
|
if (!detectedFormatter) await events.emit("warn", "No formatter found (biome, prettier, or oxfmt). Skipping formatting.");
|
|
1357
1233
|
else {
|
|
1358
1234
|
formatter = detectedFormatter;
|
|
1359
1235
|
await events.emit("info", `Auto-detected formatter: ${picocolors.default.dim(formatter)}`);
|
|
1360
1236
|
}
|
|
1361
1237
|
}
|
|
1362
|
-
if (formatter && formatter !== "auto" && formatter in formatters) {
|
|
1363
|
-
const formatterConfig = formatters[formatter];
|
|
1238
|
+
if (formatter && formatter !== "auto" && formatter in _kubb_core_utils.formatters) {
|
|
1239
|
+
const formatterConfig = _kubb_core_utils.formatters[formatter];
|
|
1364
1240
|
const outputPath = node_path.default.resolve(config.root, config.output.path);
|
|
1365
1241
|
try {
|
|
1366
1242
|
const hookId = (0, node_crypto.createHash)("sha256").update([config.name, formatter].filter(Boolean).join("-")).digest("hex");
|
|
@@ -1389,76 +1265,33 @@ async function generate({ input, config: userConfig, events, logLevel }) {
|
|
|
1389
1265
|
await events.emit("lint:start");
|
|
1390
1266
|
let linter = config.output.lint;
|
|
1391
1267
|
if (linter === "auto") {
|
|
1392
|
-
const detectedLinter = await detectLinter();
|
|
1268
|
+
const detectedLinter = await (0, _kubb_core_utils.detectLinter)();
|
|
1393
1269
|
if (!detectedLinter) await events.emit("warn", "No linter found (biome, oxlint, or eslint). Skipping linting.");
|
|
1394
1270
|
else {
|
|
1395
1271
|
linter = detectedLinter;
|
|
1396
1272
|
await events.emit("info", `Auto-detected linter: ${picocolors.default.dim(linter)}`);
|
|
1397
1273
|
}
|
|
1398
1274
|
}
|
|
1399
|
-
if (linter && linter !== "auto") {
|
|
1400
|
-
|
|
1401
|
-
|
|
1402
|
-
|
|
1403
|
-
await events.emit("hook:start", {
|
|
1404
|
-
id: hookId,
|
|
1405
|
-
command: "eslint",
|
|
1406
|
-
args: [node_path.default.resolve(config.root, config.output.path), "--fix"]
|
|
1407
|
-
});
|
|
1408
|
-
await events.onOnce("hook:end", async ({ success, error: error$1 }) => {
|
|
1409
|
-
if (!success) throw error$1;
|
|
1410
|
-
await events.emit("success", [
|
|
1411
|
-
`Linted with ${picocolors.default.dim(linter)}`,
|
|
1412
|
-
logLevel >= _kubb_core.LogLevel.info ? `on ${picocolors.default.dim(node_path.default.resolve(config.root, config.output.path))}` : void 0,
|
|
1413
|
-
"successfully"
|
|
1414
|
-
].filter(Boolean).join(" "));
|
|
1415
|
-
});
|
|
1416
|
-
} catch (caughtError) {
|
|
1417
|
-
const error$1 = /* @__PURE__ */ new Error("Eslint not found");
|
|
1418
|
-
error$1.cause = caughtError;
|
|
1419
|
-
await events.emit("error", error$1);
|
|
1420
|
-
}
|
|
1421
|
-
if (linter === "biome") try {
|
|
1422
|
-
const hookId = (0, node_crypto.createHash)("sha256").update([config.name, linter].filter(Boolean).join("-")).digest("hex");
|
|
1423
|
-
await events.emit("hook:start", {
|
|
1424
|
-
id: hookId,
|
|
1425
|
-
command: "biome",
|
|
1426
|
-
args: [
|
|
1427
|
-
"lint",
|
|
1428
|
-
"--fix",
|
|
1429
|
-
node_path.default.resolve(config.root, config.output.path)
|
|
1430
|
-
]
|
|
1431
|
-
});
|
|
1432
|
-
await events.onOnce("hook:end", async ({ success, error: error$1 }) => {
|
|
1433
|
-
if (!success) throw error$1;
|
|
1434
|
-
await events.emit("success", [
|
|
1435
|
-
`Linted with ${picocolors.default.dim(linter)}`,
|
|
1436
|
-
logLevel >= _kubb_core.LogLevel.info ? `on ${picocolors.default.dim(node_path.default.resolve(config.root, config.output.path))}` : void 0,
|
|
1437
|
-
"successfully"
|
|
1438
|
-
].filter(Boolean).join(" "));
|
|
1439
|
-
});
|
|
1440
|
-
} catch (caughtError) {
|
|
1441
|
-
const error$1 = /* @__PURE__ */ new Error("Biome not found");
|
|
1442
|
-
error$1.cause = caughtError;
|
|
1443
|
-
await events.emit("error", error$1);
|
|
1444
|
-
}
|
|
1445
|
-
if (linter === "oxlint") try {
|
|
1275
|
+
if (linter && linter !== "auto" && linter in _kubb_core_utils.linters) {
|
|
1276
|
+
const linterConfig = _kubb_core_utils.linters[linter];
|
|
1277
|
+
const outputPath = node_path.default.resolve(config.root, config.output.path);
|
|
1278
|
+
try {
|
|
1446
1279
|
const hookId = (0, node_crypto.createHash)("sha256").update([config.name, linter].filter(Boolean).join("-")).digest("hex");
|
|
1447
1280
|
await events.emit("hook:start", {
|
|
1448
1281
|
id: hookId,
|
|
1449
|
-
command:
|
|
1450
|
-
args:
|
|
1282
|
+
command: linterConfig.command,
|
|
1283
|
+
args: linterConfig.args(outputPath)
|
|
1451
1284
|
});
|
|
1452
1285
|
await events.onOnce("hook:end", async ({ success, error: error$1 }) => {
|
|
1453
1286
|
if (!success) throw error$1;
|
|
1454
1287
|
await events.emit("success", [
|
|
1455
|
-
`
|
|
1456
|
-
logLevel >= _kubb_core.LogLevel.info ? `on ${picocolors.default.dim(
|
|
1288
|
+
`Linting with ${picocolors.default.dim(linter)}`,
|
|
1289
|
+
logLevel >= _kubb_core.LogLevel.info ? `on ${picocolors.default.dim(outputPath)}` : void 0,
|
|
1457
1290
|
"successfully"
|
|
1458
1291
|
].filter(Boolean).join(" "));
|
|
1459
1292
|
});
|
|
1460
1293
|
} catch (caughtError) {
|
|
1461
|
-
const error$1 =
|
|
1294
|
+
const error$1 = new Error(linterConfig.errorMessage);
|
|
1462
1295
|
error$1.cause = caughtError;
|
|
1463
1296
|
await events.emit("error", error$1);
|
|
1464
1297
|
}
|
|
@@ -1482,52 +1315,10 @@ async function generate({ input, config: userConfig, events, logLevel }) {
|
|
|
1482
1315
|
});
|
|
1483
1316
|
}
|
|
1484
1317
|
|
|
1485
|
-
//#endregion
|
|
1486
|
-
//#region src/utils/getPlugins.ts
|
|
1487
|
-
function isJSONPlugins(plugins) {
|
|
1488
|
-
return !!plugins?.some((plugin) => {
|
|
1489
|
-
return Array.isArray(plugin) && typeof plugin?.at(0) === "string";
|
|
1490
|
-
});
|
|
1491
|
-
}
|
|
1492
|
-
function isObjectPlugins(plugins) {
|
|
1493
|
-
return plugins instanceof Object && !Array.isArray(plugins);
|
|
1494
|
-
}
|
|
1495
|
-
function getPlugins(plugins) {
|
|
1496
|
-
if (isObjectPlugins(plugins)) throw new Error("Object plugins are not supported anymore, best to use http://kubb.dev/getting-started/configure#json");
|
|
1497
|
-
if (isJSONPlugins(plugins)) throw new Error("JSON plugins are not supported anymore, best to use http://kubb.dev/getting-started/configure#json");
|
|
1498
|
-
return Promise.resolve(plugins);
|
|
1499
|
-
}
|
|
1500
|
-
|
|
1501
|
-
//#endregion
|
|
1502
|
-
//#region src/utils/getConfigs.ts
|
|
1503
|
-
/**
|
|
1504
|
-
* Converting UserConfig to Config Array without a change in the object beside the JSON convert.
|
|
1505
|
-
*/
|
|
1506
|
-
async function getConfigs(result, args) {
|
|
1507
|
-
const config = result?.config;
|
|
1508
|
-
let kubbUserConfig = Promise.resolve(config);
|
|
1509
|
-
if (typeof config === "function") {
|
|
1510
|
-
const possiblePromise = config(args);
|
|
1511
|
-
if ((0, _kubb_core_utils.isPromise)(possiblePromise)) kubbUserConfig = possiblePromise;
|
|
1512
|
-
kubbUserConfig = Promise.resolve(possiblePromise);
|
|
1513
|
-
}
|
|
1514
|
-
let JSONConfig = await kubbUserConfig;
|
|
1515
|
-
if (!Array.isArray(JSONConfig)) JSONConfig = [JSONConfig];
|
|
1516
|
-
const results = [];
|
|
1517
|
-
for (const item of JSONConfig) {
|
|
1518
|
-
const plugins = item.plugins ? await getPlugins(item.plugins) : void 0;
|
|
1519
|
-
results.push({
|
|
1520
|
-
...item,
|
|
1521
|
-
plugins
|
|
1522
|
-
});
|
|
1523
|
-
}
|
|
1524
|
-
return results;
|
|
1525
|
-
}
|
|
1526
|
-
|
|
1527
1318
|
//#endregion
|
|
1528
1319
|
//#region src/utils/getCosmiConfig.ts
|
|
1529
1320
|
const tsLoader = async (configFile) => {
|
|
1530
|
-
return await (0, jiti.createJiti)(
|
|
1321
|
+
return await (0, jiti.createJiti)(require("url").pathToFileURL(__filename).href, {
|
|
1531
1322
|
jsx: {
|
|
1532
1323
|
runtime: "automatic",
|
|
1533
1324
|
importSource: "@kubb/react-fabric"
|
|
@@ -1660,7 +1451,7 @@ const command = (0, citty.defineCommand)({
|
|
|
1660
1451
|
});
|
|
1661
1452
|
try {
|
|
1662
1453
|
const result = await getCosmiConfig("kubb", args.config);
|
|
1663
|
-
const configs = await getConfigs(result, args);
|
|
1454
|
+
const configs = await (0, _kubb_core_utils.getConfigs)(result.config, args);
|
|
1664
1455
|
await events.emit("config:start");
|
|
1665
1456
|
await events.emit("info", "Config loaded", node_path.default.relative(node_process.cwd(), result.filepath));
|
|
1666
1457
|
await events.emit("success", "Config loaded successfully", node_path.default.relative(node_process.cwd(), result.filepath));
|
|
@@ -1700,4 +1491,4 @@ var generate_default = command;
|
|
|
1700
1491
|
|
|
1701
1492
|
//#endregion
|
|
1702
1493
|
exports.default = generate_default;
|
|
1703
|
-
//# sourceMappingURL=generate-
|
|
1494
|
+
//# sourceMappingURL=generate-DDB1uKUL.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate-DDB1uKUL.cjs","names":["pc","version","pc","pc","pc","path","Writable","pc","LogLevel","process","clack","pc","frames","version","command","LogLevel","pc","frames","version","command","LogLevel","frames","command","LogLevel","command","pc","process","pc","LogLevel","formatters","path","error","linters","path","pc","AsyncEventEmitter","PromiseManager","LogLevel","version","path","process","pc"],"sources":["../src/utils/formatMsWithColor.ts","../src/utils/ansiColors.ts","../src/utils/getIntro.ts","../src/utils/randomColor.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/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","/**\n * ANSI True Color (24-bit) utilities for terminal output\n * Supports hex color codes without external dependencies like chalk\n */\n\n/**\n * Convert hex color to ANSI 24-bit true color escape sequence\n * @param color - Hex color code (with or without #), e.g., '#FF5500' or 'FF5500'\n * @returns Function that wraps text with the color\n */\nexport function hex(color: string): (text: string) => string {\n const cleanHex = color.replace('#', '')\n const r = Number.parseInt(cleanHex.slice(0, 2), 16)\n const g = Number.parseInt(cleanHex.slice(2, 4), 16)\n const b = Number.parseInt(cleanHex.slice(4, 6), 16)\n\n // Default to white (255) if parsing fails (NaN)\n const safeR = Number.isNaN(r) ? 255 : r\n const safeG = Number.isNaN(g) ? 255 : g\n const safeB = Number.isNaN(b) ? 255 : b\n\n return (text: string) => `\\x1b[38;2;${safeR};${safeG};${safeB}m${text}\\x1b[0m`\n}\n","import { default as gradientString } from 'gradient-string'\nimport pc from 'picocolors'\nimport { hex } from './ansiColors.ts'\n\n// Custom Color Palette for \"Wooden\" Depth\nconst colors = {\n lid: hex('#F55A17'), // Dark Wood\n woodTop: hex('#F5A217'), // Bright Orange (Light source)\n woodMid: hex('#F58517'), // Main Orange\n woodBase: hex('#B45309'), // Shadow Orange\n eye: hex('#FFFFFF'), // Deep Slate\n highlight: hex('#adadc6'), // Eye shine\n blush: hex('#FDA4AF'), // Soft Rose\n}\n\n/**\n * Generates the Kubb mascot face welcome message\n * @param version - The version string to display\n * @returns Formatted mascot face string\n */\nexport function getIntro({ title, description, version, areEyesOpen }: { title: string; description: string; version: string; areEyesOpen: boolean }): string {\n // Use gradient-string for the KUBB version text\n const kubbVersion = gradientString(['#F58517', '#F5A217', '#F55A17'])(`KUBB v${version}`)\n\n const eyeTop = areEyesOpen ? colors.eye('█▀█') : colors.eye('───')\n const eyeBottom = areEyesOpen ? colors.eye('▀▀▀') : colors.eye('───')\n\n return `\n ${colors.lid('▄▄▄▄▄▄▄▄▄▄▄▄▄')}\n ${colors.woodTop('█ ')}${colors.highlight('▄▄')}${colors.woodTop(' ')}${colors.highlight('▄▄')}${colors.woodTop(' █')} ${kubbVersion}\n ${colors.woodMid('█ ')}${eyeTop}${colors.woodMid(' ')}${eyeTop}${colors.woodMid(' █')} ${pc.gray(title)}\n ${colors.woodMid('█ ')}${eyeBottom}${colors.woodMid(' ')}${colors.blush('◡')}${colors.woodMid(' ')}${eyeBottom}${colors.woodMid(' █')} ${pc.yellow('➜')} ${pc.white(description)}\n ${colors.woodBase('▀▀▀▀▀▀▀▀▀▀▀▀▀')}\n`\n}\n","import pc from 'picocolors'\nimport seedrandom from 'seedrandom'\n\nexport function randomColor(text?: string): 'black' | 'red' | 'green' | 'yellow' | 'blue' | 'magenta' | 'cyan' | 'white' | 'gray' {\n if (!text) {\n return 'white'\n }\n\n const defaultColors = ['black', 'red', 'green', 'yellow', 'blue', 'red', 'green', 'magenta', 'cyan', 'gray'] as const\n\n const random = seedrandom(text)\n return defaultColors.at(Math.floor(random() * defaultColors.length)) || 'white'\n}\n\nexport function randomCliColor(text?: string): string {\n if (!text) {\n return ''\n }\n\n const color = randomColor(text)\n\n const fn = pc[color]\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 { randomCliColor } from './randomColor.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 }) => randomCliColor(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 { type ExecaError, execa } from 'execa'\nimport pc from 'picocolors'\nimport { formatMsWithColor } from '../utils/formatMsWithColor.ts'\nimport { getIntro } from '../utils/getIntro.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 | undefined\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', async (version) => {\n console.log(`\\n${getIntro({ title: 'The ultimate toolkit for working with APIs', description: 'Ready to start', version, areEyesOpen: true })}\\n`)\n\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', {\n command,\n args,\n id,\n success: true,\n error: null,\n })\n } catch (err) {\n const error = err as ExecaError\n const stderr = typeof error.stderr === 'string' ? error.stderr : String(error.stderr)\n const stdout = typeof error.stdout === 'string' ? error.stdout : String(error.stdout)\n\n await context.emit('debug', {\n date: new Date(),\n logs: [stdout, stderr].filter(Boolean),\n })\n\n if (stderr) {\n console.error(stderr)\n }\n if (stdout) {\n console.log(stdout)\n }\n\n const errorMessage = new Error(`Hook execute failed: ${commandWithArgs}`)\n\n await context.emit('hook:end', {\n command,\n args,\n id,\n success: false,\n error: errorMessage,\n })\n await context.emit('error', errorMessage)\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, success: true, error: null })\n } catch (err) {\n const error = err as ExecaError\n const stderr = typeof error.stderr === 'string' ? error.stderr : String(error.stderr)\n const stdout = typeof error.stdout === 'string' ? error.stdout : String(error.stdout)\n\n await context.emit('debug', {\n date: new Date(),\n logs: [stdout, stderr].filter(Boolean),\n })\n\n if (stderr) {\n logger.error(stderr)\n }\n if (stdout) {\n logger.message(stdout)\n }\n\n const errorMessage = new Error(`Hook execute failed: ${commandWithArgs}`)\n\n await context.emit('hook:end', { command, args, id, success: false, error: errorMessage })\n await context.emit('error', errorMessage)\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 { type ExecaError, execa } from 'execa'\nimport pc from 'picocolors'\nimport { formatMsWithColor } from '../utils/formatMsWithColor.ts'\n\n/**\n * GitHub Actions adapter for CI environments\n * Uses Github group 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 | undefined\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 if (logLevel > LogLevel.silent) {\n console.log(result.stdout)\n }\n\n await context.emit('hook:end', {\n command,\n args,\n id,\n success: true,\n error: null,\n })\n } catch (err) {\n const error = err as ExecaError\n const stderr = typeof error.stderr === 'string' ? error.stderr : String(error.stderr)\n const stdout = typeof error.stdout === 'string' ? error.stdout : String(error.stdout)\n\n await context.emit('debug', {\n date: new Date(),\n logs: [stdout, stderr].filter(Boolean),\n })\n\n // Display stderr/stdout in GitHub Actions format\n if (stderr) {\n console.error(`::error::${stderr}`)\n }\n if (stdout) {\n console.log(stdout)\n }\n\n const errorMessage = new Error(`Hook execute failed: ${commandWithArgs}`)\n\n await context.emit('hook:end', {\n command,\n args,\n id,\n success: false,\n error: errorMessage,\n })\n await context.emit('error', errorMessage)\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 { type ExecaError, 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 | undefined\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 if (logLevel > LogLevel.silent) {\n console.log(result.stdout)\n }\n\n await context.emit('hook:end', {\n command,\n args,\n id,\n success: true,\n error: null,\n })\n } catch (err) {\n const error = err as ExecaError\n const stderr = typeof error.stderr === 'string' ? error.stderr : String(error.stderr)\n const stdout = typeof error.stdout === 'string' ? error.stdout : String(error.stdout)\n\n await context.emit('debug', {\n date: new Date(),\n logs: [stdout, stderr].filter(Boolean),\n })\n\n if (stderr) {\n console.error(stderr)\n }\n if (stdout) {\n console.log(stdout)\n }\n\n const errorMessage = new Error(`Hook execute failed: ${commandWithArgs}`)\n\n await context.emit('hook:end', {\n command,\n args,\n id,\n success: false,\n error: errorMessage,\n })\n await context.emit('error', errorMessage)\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 ({ success, error }) => {\n if (!success) {\n throw error\n }\n\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 { detectFormatter, detectLinter, formatters, linters } 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 { sources, 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, sources },\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, files, sources)\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, files, sources)\n\n // formatting\n if (config.output.format) {\n await events.emit('format:start')\n\n let formatter = config.output.format\n if (formatter === 'auto') {\n const detectedFormatter = await detectFormatter()\n if (!detectedFormatter) {\n await events.emit('warn', 'No formatter found (biome, prettier, or oxfmt). Skipping formatting.')\n } else {\n formatter = detectedFormatter\n await events.emit('info', `Auto-detected formatter: ${pc.dim(formatter)}`)\n }\n }\n\n if (formatter && formatter !== 'auto' && formatter in formatters) {\n const formatterConfig = formatters[formatter as keyof typeof formatters]\n const outputPath = path.resolve(config.root, config.output.path)\n\n try {\n const hookId = createHash('sha256').update([config.name, formatter].filter(Boolean).join('-')).digest('hex')\n await events.emit('hook:start', {\n id: hookId,\n command: formatterConfig.command,\n args: formatterConfig.args(outputPath),\n })\n\n await events.onOnce('hook:end', async ({ success, error }) => {\n if (!success) throw error\n\n await events.emit(\n 'success',\n [`Formatting with ${pc.dim(formatter)}`, logLevel >= LogLevel.info ? `on ${pc.dim(outputPath)}` : undefined, 'successfully']\n .filter(Boolean)\n .join(' '),\n )\n })\n } catch (caughtError) {\n const error = new Error(formatterConfig.errorMessage)\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 // Detect linter if set to 'auto'\n let linter = config.output.lint\n if (linter === 'auto') {\n const detectedLinter = await detectLinter()\n if (!detectedLinter) {\n await events.emit('warn', 'No linter found (biome, oxlint, or eslint). Skipping linting.')\n } else {\n linter = detectedLinter\n await events.emit('info', `Auto-detected linter: ${pc.dim(linter)}`)\n }\n }\n\n // Only proceed with linting if we have a valid linter\n if (linter && linter !== 'auto' && linter in linters) {\n const linterConfig = linters[linter as keyof typeof linters]\n const outputPath = path.resolve(config.root, config.output.path)\n\n try {\n const hookId = createHash('sha256').update([config.name, linter].filter(Boolean).join('-')).digest('hex')\n await events.emit('hook:start', {\n id: hookId,\n command: linterConfig.command,\n args: linterConfig.args(outputPath),\n })\n\n await events.onOnce('hook:end', async ({ success, error }) => {\n if (!success) throw error\n\n await events.emit(\n 'success',\n [`Linting with ${pc.dim(linter)}`, logLevel >= LogLevel.info ? `on ${pc.dim(outputPath)}` : undefined, 'successfully'].filter(Boolean).join(' '),\n )\n })\n } catch (caughtError) {\n const error = new Error(linterConfig.errorMessage)\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 { 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 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', async (type, file) => {\n console.log(pc.yellow(pc.bold(`Change detected: ${type} ${file}`)))\n\n try {\n await 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 { type CLIOptions, isInputPath, type KubbEvents, LogLevel, PromiseManager } from '@kubb/core'\nimport { AsyncEventEmitter, executeIfOnline, getConfigs } 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 { 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 await executeIfOnline(async () => {\n const latestVersion = await getLatestVersion('@kubb/cli')\n\n if (lt(version, latestVersion)) {\n await events.emit('version:new', version, latestVersion)\n }\n })\n\n try {\n const result = await getCosmiConfig('kubb', args.config)\n const configs = await getConfigs(result.config, args as CLIOptions)\n\n await events.emit('config:start')\n\n await events.emit('info', 'Config loaded', path.relative(process.cwd(), result.filepath))\n\n await events.emit('success', 'Config loaded successfully', path.relative(process.cwd(), result.filepath))\n await events.emit('config:end', configs)\n\n await events.emit('lifecycle:start', version)\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 process.exit(1)\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-C1_xRkKa.cjs');
|
|
2
|
-
const require_package = require('./package-
|
|
2
|
+
const require_package = require('./package-dw0pujbh.cjs');
|
|
3
3
|
let citty = require("citty");
|
|
4
4
|
|
|
5
5
|
//#region src/index.ts
|
|
@@ -26,16 +26,16 @@ const main = (0, citty.defineCommand)({
|
|
|
26
26
|
"agent",
|
|
27
27
|
"init"
|
|
28
28
|
].includes(rawArgs[0])) {
|
|
29
|
-
await (0, citty.runCommand)(await Promise.resolve().then(() => require("./generate-
|
|
29
|
+
await (0, citty.runCommand)(await Promise.resolve().then(() => require("./generate-DDB1uKUL.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-
|
|
34
|
+
generate: () => Promise.resolve().then(() => require("./generate-DDB1uKUL.cjs")).then((r) => r.default),
|
|
35
35
|
validate: () => Promise.resolve().then(() => require("./validate-Cvb5aOEb.cjs")).then((r) => r.default),
|
|
36
36
|
mcp: () => Promise.resolve().then(() => require("./mcp-DGyip5BX.cjs")).then((r) => r.default),
|
|
37
|
-
agent: () => Promise.resolve().then(() => require("./agent-
|
|
38
|
-
init: () => Promise.resolve().then(() => require("./init-
|
|
37
|
+
agent: () => Promise.resolve().then(() => require("./agent-CUCCncEE.cjs")).then((r) => r.default),
|
|
38
|
+
init: () => Promise.resolve().then(() => require("./init-nVbwjr1J.cjs")).then((r) => r.default)
|
|
39
39
|
}
|
|
40
40
|
});
|
|
41
41
|
async function run(_argv) {
|
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { t as __name } from "./chunk-
|
|
2
|
-
import { t as version } from "./package-
|
|
1
|
+
import { t as __name } from "./chunk-jHaXqnEa.js";
|
|
2
|
+
import { t as version } from "./package-enrPgQqs.js";
|
|
3
3
|
import { defineCommand, runCommand, runMain } from "citty";
|
|
4
4
|
|
|
5
5
|
//#region src/index.ts
|
|
@@ -26,16 +26,16 @@ const main = defineCommand({
|
|
|
26
26
|
"agent",
|
|
27
27
|
"init"
|
|
28
28
|
].includes(rawArgs[0])) {
|
|
29
|
-
await runCommand(await import("./generate-
|
|
29
|
+
await runCommand(await import("./generate-CatXFtMP.js").then((r) => r.default), { rawArgs });
|
|
30
30
|
process.exit(0);
|
|
31
31
|
}
|
|
32
32
|
},
|
|
33
33
|
subCommands: {
|
|
34
|
-
generate: () => import("./generate-
|
|
35
|
-
validate: () => import("./validate-
|
|
36
|
-
mcp: () => import("./mcp-
|
|
37
|
-
agent: () => import("./agent-
|
|
38
|
-
init: () => import("./init-
|
|
34
|
+
generate: () => import("./generate-CatXFtMP.js").then((r) => r.default),
|
|
35
|
+
validate: () => import("./validate-YI4YkVTl.js").then((r) => r.default),
|
|
36
|
+
mcp: () => import("./mcp-C-e4yatL.js").then((r) => r.default),
|
|
37
|
+
agent: () => import("./agent-C1v0TR8w.js").then((r) => r.default),
|
|
38
|
+
init: () => import("./init-DNeV1F1V.js").then((r) => r.default)
|
|
39
39
|
}
|
|
40
40
|
});
|
|
41
41
|
async function run(_argv) {
|