@kubb/cli 4.29.0 → 4.31.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/dist/{agent-BzD6f3mV.js → agent-CGYnHRU4.js} +2 -2
  2. package/dist/{agent-BzD6f3mV.js.map → agent-CGYnHRU4.js.map} +1 -1
  3. package/dist/{agent-NAhMf2ot.cjs → agent-kU5gLqqn.cjs} +2 -2
  4. package/dist/{agent-NAhMf2ot.cjs.map → agent-kU5gLqqn.cjs.map} +1 -1
  5. package/dist/{generate-CnKaIwc7.js → generate-DvoKuzJW.js} +31 -6
  6. package/dist/{generate-CnKaIwc7.js.map → generate-DvoKuzJW.js.map} +1 -1
  7. package/dist/{generate-C8gS4Z2F.cjs → generate-G4sRCtYd.cjs} +31 -6
  8. package/dist/generate-G4sRCtYd.cjs.map +1 -0
  9. package/dist/index.cjs +7 -7
  10. package/dist/index.js +7 -7
  11. package/dist/{init-B5qnw1XS.js → init-Cp7PS6R5.js} +3 -36
  12. package/dist/init-Cp7PS6R5.js.map +1 -0
  13. package/dist/{init-BDWQO7I8.cjs → init-XsLQVNk3.cjs} +5 -38
  14. package/dist/init-XsLQVNk3.cjs.map +1 -0
  15. package/dist/{mcp-Jboea6xH.js → mcp-CD0ZKRHG.js} +18 -2
  16. package/dist/mcp-CD0ZKRHG.js.map +1 -0
  17. package/dist/{mcp-97TXkJVX.cjs → mcp-DCjAEKzU.cjs} +20 -3
  18. package/dist/mcp-DCjAEKzU.cjs.map +1 -0
  19. package/dist/package-BYVzWUJV.js +6 -0
  20. package/dist/package-BYVzWUJV.js.map +1 -0
  21. package/dist/{package-oo3QhWS5.cjs → package-BqKkzL1A.cjs} +2 -2
  22. package/dist/package-BqKkzL1A.cjs.map +1 -0
  23. package/dist/{start-lrn1-P52.cjs → start-BN1ikd53.cjs} +17 -2
  24. package/dist/start-BN1ikd53.cjs.map +1 -0
  25. package/dist/{start-CYuU23PX.js → start-VN4IxBaM.js} +17 -2
  26. package/dist/{start-CYuU23PX.js.map → start-VN4IxBaM.js.map} +1 -1
  27. package/dist/telemetry-Ccka73zO.js +149 -0
  28. package/dist/telemetry-Ccka73zO.js.map +1 -0
  29. package/dist/telemetry-DxyJ2d4j.cjs +162 -0
  30. package/dist/telemetry-DxyJ2d4j.cjs.map +1 -0
  31. package/dist/{validate-BgYhe_55.cjs → validate-BbVY6zQM.cjs} +16 -1
  32. package/dist/validate-BbVY6zQM.cjs.map +1 -0
  33. package/dist/{validate-DOeZKiGx.js → validate-zO3bvm66.js} +16 -1
  34. package/dist/validate-zO3bvm66.js.map +1 -0
  35. package/package.json +8 -7
  36. package/src/commands/agent/start.ts +6 -1
  37. package/src/commands/generate.ts +3 -0
  38. package/src/commands/init.ts +2 -1
  39. package/src/commands/mcp.ts +7 -1
  40. package/src/commands/validate.ts +5 -0
  41. package/src/runners/generate.ts +28 -2
  42. package/src/utils/packageManager.ts +2 -60
  43. package/src/utils/telemetry.ts +278 -0
  44. package/dist/generate-C8gS4Z2F.cjs.map +0 -1
  45. package/dist/init-B5qnw1XS.js.map +0 -1
  46. package/dist/init-BDWQO7I8.cjs.map +0 -1
  47. package/dist/mcp-97TXkJVX.cjs.map +0 -1
  48. package/dist/mcp-Jboea6xH.js.map +0 -1
  49. package/dist/package-oo3QhWS5.cjs.map +0 -1
  50. package/dist/package-veMf5zNr.js +0 -6
  51. package/dist/package-veMf5zNr.js.map +0 -1
  52. package/dist/start-lrn1-P52.cjs.map +0 -1
  53. package/dist/validate-BgYhe_55.cjs.map +0 -1
  54. package/dist/validate-DOeZKiGx.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-G4sRCtYd.cjs","names":["path","Writable","LogLevel","process","clack","LogLevel","LogLevel","LogLevel","process","LogLevel","sendTelemetry","buildTelemetryEvent","version","formatters","path","linters","AsyncEventEmitter","PromiseManager","LogLevel","version","path","process"],"sources":["../src/utils/formatMsWithColor.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 { styleText } from 'node:util'\nimport { formatMs } from '@kubb/core/utils'\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 styleText('green', formatted)\n }\n\n if (ms <= 1000) {\n return styleText('yellow', formatted)\n }\n\n return styleText('red', formatted)\n}\n","import { styleText } from 'node:util'\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 */\nfunction 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\nfunction hexToRgb(color: string) {\n const c = color.replace('#', '')\n return { r: Number.parseInt(c.slice(0, 2), 16), g: Number.parseInt(c.slice(2, 4), 16), b: Number.parseInt(c.slice(4, 6), 16) }\n}\n\nfunction gradient(colors: string[]) {\n return (text: string) => {\n const chars = [...text]\n return chars\n .map((char, i) => {\n const t = chars.length <= 1 ? 0 : i / (chars.length - 1)\n const seg = Math.min(Math.floor(t * (colors.length - 1)), colors.length - 2)\n const lt = t * (colors.length - 1) - seg\n const from = hexToRgb(colors[seg]!)\n const to = hexToRgb(colors[seg + 1]!)\n const r = Math.round(from.r + (to.r - from.r) * lt)\n const g = Math.round(from.g + (to.g - from.g) * lt)\n const b = Math.round(from.b + (to.b - from.b) * lt)\n return `\\x1b[38;2;${r};${g};${b}m${char}\\x1b[0m`\n })\n .join('')\n }\n}\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 = gradient(['#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(' █')} ${styleText('gray', title)}\n ${colors.woodMid('█ ')}${eyeBottom}${colors.woodMid(' ')}${colors.blush('◡')}${colors.woodMid(' ')}${eyeBottom}${colors.woodMid(' █')} ${styleText('yellow', '➜')} ${styleText('white', description)}\n ${colors.woodBase('▀▀▀▀▀▀▀▀▀▀▀▀▀')}\n`\n}\n","import { createHash } from 'node:crypto'\nimport { styleText } from 'node:util'\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 const index = createHash('sha256').update(text).digest().readUInt32BE(0) % defaultColors.length\n\n return defaultColors[index] ?? 'white'\n}\n\nexport function randomCliColor(text?: string): string {\n if (!text) {\n return ''\n }\n\n const color = randomColor(text)\n\n return styleText(color, text)\n}\n","import path from 'node:path'\nimport { styleText } from 'node:util'\nimport type { Config, Plugin } from '@kubb/core'\nimport { formatHrtime } from '@kubb/core/utils'\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 ? `${styleText('green', `${successCount} successful`)}, ${pluginsCount} total`\n : `${styleText('green', `${successCount} successful`)}, ${styleText('red', `${failedPlugins.size} failed`)}, ${pluginsCount} total`,\n pluginsFailed: status === 'failed' ? [...failedPlugins]?.map(({ plugin }) => randomCliColor(plugin.name))?.join(', ') : undefined,\n filesCreated: filesCreated,\n time: styleText('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 = styleText('dim', '█'.repeat(barLength))\n\n summaryLines.push(`${styleText('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 { styleText } from 'node:util'\nimport type * as clack from '@clack/prompts'\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(`${styleText('dim', chunk?.toString())}`)\n callback()\n }\n}\n","import { relative } from 'node:path'\nimport process from 'node:process'\nimport { styleText } from 'node:util'\nimport * as clack from '@clack/prompts'\nimport { defineLogger, LogLevel } from '@kubb/core'\nimport { formatHrtime, formatMs } from '@kubb/core/utils'\nimport { type NonZeroExitError, x } from 'tinyexec'\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 ${styleText('green', state.completedPlugins.toString())}/${state.totalPlugins} ${styleText('red', `(${state.failedPlugins} failed)`)}`\n : `Plugins ${styleText('green', state.completedPlugins.toString())}/${state.totalPlugins}`\n parts.push(pluginStr)\n }\n\n if (state.totalFiles > 0) {\n parts.push(`Files ${styleText('green', state.processedFiles.toString())}/${state.totalFiles}`)\n }\n\n if (parts.length > 0) {\n parts.push(`${styleText('green', duration)} elapsed`)\n clack.log.step(getMessage(parts.join(styleText('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 [styleText('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([styleText('blue', 'ℹ'), message, styleText('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([styleText('blue', '✓'), message, logLevel >= LogLevel.info ? styleText('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(\n [styleText('yellow', '⚠'), message, logLevel >= LogLevel.info && info ? styleText('dim', info) : undefined].filter(Boolean).join(' '),\n )\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 = [styleText('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(styleText('dim', frame.trim())))\n }\n\n if (caused?.stack) {\n clack.log.message(styleText('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(` ${styleText('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: (s: string) => styleText('yellow', s),\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 ${styleText('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 ${styleText('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\n ? `${styleText('bold', plugin.name)} completed in ${durationStr}`\n : `${styleText('bold', plugin.name)} failed in ${styleText('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 ${styleText('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 ${styleText('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 x(command, [...(args ?? [])], {\n nodeOptions: { detached: true },\n throwOnError: true,\n })\n\n await context.emit('debug', {\n date: new Date(),\n logs: [result.stdout.trimEnd()],\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 NonZeroExitError\n const stderr = error.output?.stderr ?? ''\n const stdout = error.output?.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 ? styleText('dim', commandWithArgs) : undefined].filter(Boolean).join(' ')),\n })\n\n const writable = new ClackWritable(logger)\n\n try {\n const proc = x(command, [...(args ?? [])], {\n nodeOptions: { detached: true },\n throwOnError: true,\n })\n\n for await (const line of proc) {\n writable.write(line)\n }\n\n const result = await proc\n\n await context.emit('debug', {\n date: new Date(),\n logs: [result.stdout.trimEnd()],\n })\n\n await context.emit('hook:end', { command, args, id, success: true, error: null })\n } catch (err) {\n const error = err as NonZeroExitError\n const stderr = error.output?.stderr ?? ''\n const stdout = error.output?.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 ${styleText('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: (s: string) => styleText('green', s),\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: (s: string) => styleText('red', s),\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 { styleText } from 'node:util'\nimport { type Config, defineLogger, LogLevel } from '@kubb/core'\nimport { formatHrtime, formatMs } from '@kubb/core/utils'\nimport { type NonZeroExitError, x } from 'tinyexec'\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 ${styleText('green', state.completedPlugins.toString())}/${state.totalPlugins} ${styleText('red', `(${state.failedPlugins} failed)`)}`\n : `Plugins ${styleText('green', state.completedPlugins.toString())}/${state.totalPlugins}`\n parts.push(pluginStr)\n }\n\n if (state.totalFiles > 0) {\n parts.push(`Files ${styleText('green', state.processedFiles.toString())}/${state.totalFiles}`)\n }\n\n if (parts.length > 0) {\n parts.push(`${styleText('green', duration)} elapsed`)\n console.log(getMessage(parts.join(styleText('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 [styleText('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([styleText('blue', 'ℹ'), message, styleText('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([styleText('blue', '✓'), message, logLevel >= LogLevel.info ? styleText('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([styleText('yellow', '⚠'), message, logLevel >= LogLevel.info ? styleText('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(styleText('dim', frame.trim())))\n }\n\n if (caused?.stack) {\n console.log(styleText('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(` ${styleText('dim', frame.trim())}`))\n }\n }\n }\n })\n\n context.on('lifecycle:start', (version) => {\n console.log(styleText('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 ${styleText('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 ${styleText('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\n ? `${styleText('bold', plugin.name)} completed in ${durationStr}`\n : `${styleText('bold', plugin.name)} failed in ${styleText('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(\n config.name ? `${styleText('blue', '✓')} Generation completed for ${styleText('dim', config.name)}` : `${styleText('blue', '✓')} Generation completed`,\n )\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 ${styleText('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 x(command, [...(args ?? [])], {\n nodeOptions: { detached: true },\n throwOnError: true,\n })\n\n await context.emit('debug', {\n date: new Date(),\n logs: [result.stdout.trimEnd()],\n })\n\n if (logLevel > LogLevel.silent) {\n console.log(result.stdout.trimEnd())\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 NonZeroExitError\n const stderr = error.output?.stderr ?? ''\n const stdout = error.output?.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 ${styleText('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: ${styleText('blue', '✓')} ${`${successCount} successful`}, ${pluginsCount} total, ${styleText('green', duration)}`\n : `Kubb Summary: ${styleText('blue', '✓')} ${`${successCount} successful`}, ✗ ${`${failedPlugins.size} failed`}, ${pluginsCount} total, ${styleText('green', duration)}`,\n )\n\n if (state.currentConfigs.length > 1) {\n closeGroup(config.name ? `Generation for ${styleText('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 NonZeroExitError, x } from 'tinyexec'\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 x(command, [...(args ?? [])], {\n nodeOptions: { detached: true },\n throwOnError: true,\n })\n\n await context.emit('debug', {\n date: new Date(),\n logs: [result.stdout.trimEnd()],\n })\n\n if (logLevel > LogLevel.silent) {\n console.log(result.stdout.trimEnd())\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 NonZeroExitError\n const stderr = error.output?.stderr ?? ''\n const stdout = error.output?.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 { styleText } from 'node:util'\nimport type { Config, KubbEvents } from '@kubb/core'\nimport type { AsyncEventEmitter } from '@kubb/core/utils'\nimport { tokenize } from '@kubb/core/utils'\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] = tokenize(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', `${styleText('dim', command)} successfully executed`)\n })\n }\n}\n","import { createHash } from 'node:crypto'\nimport path from 'node:path'\nimport process from 'node:process'\nimport { styleText } from 'node:util'\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 { version } from '../../package.json'\nimport { executeHooks } from '../utils/executeHooks.ts'\nimport { buildTelemetryEvent, sendTelemetry } from '../utils/telemetry.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 ${styleText('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 ${styleText('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: 'failed',\n hrStart,\n pluginTimings: logLevel >= LogLevel.verbose ? pluginTimings : undefined,\n })\n\n await sendTelemetry(\n buildTelemetryEvent({\n command: 'generate',\n kubbVersion: version,\n plugins: pluginManager.plugins.map((p) => ({ name: p.name, options: p.options as Record<string, unknown> })),\n hrStart,\n filesCreated: files.length,\n status: 'failed',\n }),\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: ${styleText('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 ${styleText('dim', formatter)}`, logLevel >= LogLevel.info ? `on ${styleText('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: ${styleText('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 ${styleText('dim', linter)}`, logLevel >= LogLevel.info ? `on ${styleText('dim', outputPath)}` : undefined, 'successfully']\n .filter(Boolean)\n .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 const generationStatus = failedPlugins.size > 0 || error ? 'failed' : 'success'\n\n await events.emit('generation:summary', config, {\n failedPlugins,\n filesCreated: files.length,\n status: generationStatus,\n hrStart,\n pluginTimings,\n })\n\n const telemetryEvent = buildTelemetryEvent({\n command: 'generate',\n kubbVersion: version,\n plugins: pluginManager.plugins.map((p) => ({ name: p.name, options: p.options as Record<string, unknown> })),\n hrStart,\n filesCreated: files.length,\n status: generationStatus,\n })\n\n await sendTelemetry(telemetryEvent)\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 { styleText } from 'node:util'\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(styleText('yellow', styleText('bold', `Change detected: ${type} ${file}`)))\n\n try {\n await cb(path)\n } catch (_e) {\n console.log(styleText('red', 'Watcher failed'))\n }\n })\n}\n","import path from 'node:path'\nimport * as process from 'node:process'\nimport { styleText } from 'node:util'\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 { 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 try {\n const res = await fetch('https://registry.npmjs.org/@kubb/cli/latest')\n const data = (await res.json()) as { version: string }\n const latestVersion = data.version\n\n if (latestVersion && version < latestVersion) {\n await events.emit('version:new', version, latestVersion)\n }\n } catch {\n // Ignore network errors for version check\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 // remove to avoid duplicate listeners after each change\n events.removeAll()\n\n await generate({\n input,\n config,\n logLevel,\n events,\n })\n\n clack.log.step(styleText('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":";;;;;;;;;;;;;;;;;;;;;;;;;;;AASA,SAAgB,kBAAkB,IAAoB;CACpD,MAAM,2CAAqB,GAAG;AAE9B,KAAI,MAAM,IACR,iCAAiB,SAAS,UAAU;AAGtC,KAAI,MAAM,IACR,iCAAiB,UAAU,UAAU;AAGvC,iCAAiB,OAAO,UAAU;;;;;;;;;;;;;;ACRpC,SAAS,IAAI,OAAyC;CACpD,MAAM,WAAW,MAAM,QAAQ,KAAK,GAAG;CACvC,MAAM,IAAI,OAAO,SAAS,SAAS,MAAM,GAAG,EAAE,EAAE,GAAG;CACnD,MAAM,IAAI,OAAO,SAAS,SAAS,MAAM,GAAG,EAAE,EAAE,GAAG;CACnD,MAAM,IAAI,OAAO,SAAS,SAAS,MAAM,GAAG,EAAE,EAAE,GAAG;CAGnD,MAAM,QAAQ,OAAO,MAAM,EAAE,GAAG,MAAM;CACtC,MAAM,QAAQ,OAAO,MAAM,EAAE,GAAG,MAAM;CACtC,MAAM,QAAQ,OAAO,MAAM,EAAE,GAAG,MAAM;AAEtC,SAAQ,SAAiB,aAAa,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,KAAK;;AAGxE,SAAS,SAAS,OAAe;CAC/B,MAAM,IAAI,MAAM,QAAQ,KAAK,GAAG;AAChC,QAAO;EAAE,GAAG,OAAO,SAAS,EAAE,MAAM,GAAG,EAAE,EAAE,GAAG;EAAE,GAAG,OAAO,SAAS,EAAE,MAAM,GAAG,EAAE,EAAE,GAAG;EAAE,GAAG,OAAO,SAAS,EAAE,MAAM,GAAG,EAAE,EAAE,GAAG;EAAE;;AAGhI,SAAS,SAAS,QAAkB;AAClC,SAAQ,SAAiB;EACvB,MAAM,QAAQ,CAAC,GAAG,KAAK;AACvB,SAAO,MACJ,KAAK,MAAM,MAAM;GAChB,MAAM,IAAI,MAAM,UAAU,IAAI,IAAI,KAAK,MAAM,SAAS;GACtD,MAAM,MAAM,KAAK,IAAI,KAAK,MAAM,KAAK,OAAO,SAAS,GAAG,EAAE,OAAO,SAAS,EAAE;GAC5E,MAAM,KAAK,KAAK,OAAO,SAAS,KAAK;GACrC,MAAM,OAAO,SAAS,OAAO,KAAM;GACnC,MAAM,KAAK,SAAS,OAAO,MAAM,GAAI;AAIrC,UAAO,aAHG,KAAK,MAAM,KAAK,KAAK,GAAG,IAAI,KAAK,KAAK,GAAG,CAG7B,GAFZ,KAAK,MAAM,KAAK,KAAK,GAAG,IAAI,KAAK,KAAK,GAAG,CAExB,GADjB,KAAK,MAAM,KAAK,KAAK,GAAG,IAAI,KAAK,KAAK,GAAG,CACnB,GAAG,KAAK;IACxC,CACD,KAAK,GAAG;;;AAKf,MAAM,SAAS;CACb,KAAK,IAAI,UAAU;CACnB,SAAS,IAAI,UAAU;CACvB,SAAS,IAAI,UAAU;CACvB,UAAU,IAAI,UAAU;CACxB,KAAK,IAAI,UAAU;CACnB,WAAW,IAAI,UAAU;CACzB,OAAO,IAAI,UAAU;CACtB;;;;;;AAOD,SAAgB,SAAS,EAAE,OAAO,aAAa,SAAS,eAAsG;CAE5J,MAAM,cAAc,SAAS;EAAC;EAAW;EAAW;EAAU,CAAC,CAAC,SAAS,UAAU;CAEnF,MAAM,SAAS,cAAc,OAAO,IAAI,MAAM,GAAG,OAAO,IAAI,MAAM;CAClE,MAAM,YAAY,cAAc,OAAO,IAAI,MAAM,GAAG,OAAO,IAAI,MAAM;AAErE,QAAO;KACJ,OAAO,IAAI,gBAAgB,CAAC;IAC7B,OAAO,QAAQ,MAAM,GAAG,OAAO,UAAU,KAAK,GAAG,OAAO,QAAQ,QAAQ,GAAG,OAAO,UAAU,KAAK,GAAG,OAAO,QAAQ,MAAM,CAAC,IAAI,YAAY;IAC1I,OAAO,QAAQ,KAAK,GAAG,SAAS,OAAO,QAAQ,QAAQ,GAAG,SAAS,OAAO,QAAQ,KAAK,CAAC,6BAAc,QAAQ,MAAM,CAAC;IACrH,OAAO,QAAQ,KAAK,GAAG,YAAY,OAAO,QAAQ,KAAK,GAAG,OAAO,MAAM,IAAI,GAAG,OAAO,QAAQ,KAAK,GAAG,YAAY,OAAO,QAAQ,KAAK,CAAC,6BAAc,UAAU,IAAI,CAAC,4BAAa,SAAS,YAAY,CAAC;KACrM,OAAO,SAAS,gBAAgB,CAAC;;;;;;AC3EtC,SAAgB,YAAY,MAAsG;AAChI,KAAI,CAAC,KACH,QAAO;CAGT,MAAM,gBAAgB;EAAC;EAAS;EAAO;EAAS;EAAU;EAAQ;EAAO;EAAS;EAAW;EAAQ;EAAO;AAG5G,QAAO,0CAFkB,SAAS,CAAC,OAAO,KAAK,CAAC,QAAQ,CAAC,aAAa,EAAE,GAAG,cAAc,WAE1D;;AAGjC,SAAgB,eAAe,MAAuB;AACpD,KAAI,CAAC,KACH,QAAO;AAKT,iCAFc,YAAY,KAAK,EAEP,KAAK;;;;;ACN/B,SAAgB,WAAW,EAAE,eAAe,cAAc,QAAQ,SAAS,QAAQ,iBAAyC;CAC1H,MAAM,8CAAwB,QAAQ;CAEtC,MAAM,eAAe,OAAO,SAAS,UAAU;CAC/C,MAAM,eAAe,eAAe,cAAc;CAElD,MAAM,OAAO;EACX,SACE,WAAW,YACP,4BAAa,SAAS,GAAG,aAAa,aAAa,CAAC,IAAI,aAAa,UACrE,4BAAa,SAAS,GAAG,aAAa,aAAa,CAAC,6BAAc,OAAO,GAAG,cAAc,KAAK,SAAS,CAAC,IAAI,aAAa;EAChI,eAAe,WAAW,WAAW,CAAC,GAAG,cAAc,EAAE,KAAK,EAAE,aAAa,eAAe,OAAO,KAAK,CAAC,EAAE,KAAK,KAAK,GAAG;EAC1G;EACd,+BAAgB,SAAS,SAAS;EAClC,QAAQA,kBAAK,WAAW,OAAO,KAAK,GAAGA,kBAAK,QAAQ,OAAO,MAAM,OAAO,OAAO,KAAK,GAAG,OAAO;EAC/F;CAED,MAAM,SAAS;EACb,SAAS;EACT,QAAQ;EACR,WAAW;EACX,eAAe;EACf,QAAQ;EACT;CACD,MAAM,YAAY,KAAK,IAAI,GAAG,GAAG,CAAC,GAAG,OAAO,OAAO,OAAO,EAAE,GAAI,gBAAgB,MAAM,KAAK,cAAc,MAAM,CAAC,GAAG,EAAE,CAAE,CAAC,KAAK,MAAM,EAAE,OAAO,CAAC;CAE7I,MAAM,eAAyB,EAAE;AACjC,cAAa,KAAK,GAAG,OAAO,QAAQ,OAAO,YAAY,EAAE,CAAC,GAAG,KAAK,UAAU;AAE5E,KAAI,KAAK,cACP,cAAa,KAAK,GAAG,OAAO,OAAO,OAAO,YAAY,EAAE,CAAC,GAAG,KAAK,gBAAgB;AAGnF,cAAa,KAAK,GAAG,OAAO,UAAU,OAAO,YAAY,EAAE,CAAC,GAAG,KAAK,aAAa,YAAY,KAAK,OAAO;AAEzG,KAAI,iBAAiB,cAAc,OAAO,GAAG;EAC3C,MAAM,qBAAqB;EAC3B,MAAM,iBAAiB;EAEvB,MAAM,gBAAgB,MAAM,KAAK,cAAc,SAAS,CAAC,CAAC,MAAM,GAAG,MAAM,EAAE,KAAK,EAAE,GAAG;AAErF,MAAI,cAAc,SAAS,GAAG;AAC5B,gBAAa,KAAK,GAAG,OAAO,gBAAgB;AAE5C,iBAAc,SAAS,CAAC,MAAM,UAAU;IACtC,MAAM,UAAU,QAAQ,MAAO,IAAI,OAAO,KAAM,QAAQ,EAAE,CAAC,KAAK,GAAG,KAAK,MAAM,KAAK,CAAC;IACpF,MAAM,YAAY,KAAK,IAAI,KAAK,KAAK,OAAO,mBAAmB,EAAE,eAAe;IAChF,MAAM,+BAAgB,OAAO,IAAI,OAAO,UAAU,CAAC;AAEnD,iBAAa,KAAK,4BAAa,OAAO,IAAI,CAAC,GAAG,KAAK,OAAO,YAAY,EAAE,GAAG,IAAI,GAAG,UAAU;KAC5F;;;AAIN,cAAa,KAAK,GAAG,OAAO,OAAO,OAAO,YAAY,EAAE,CAAC,GAAG,KAAK,SAAS;AAE1E,QAAO;;;;;AClET,IAAa,gBAAb,cAAmCC,qBAAS;CAC1C;CACA,YAAY,SAA2C,MAAwB;AAC7E,QAAM,KAAK;AAEX,OAAK,UAAU;;CAEjB,OAAO,OAAY,WAA2B,UAAgD;AAC5F,OAAK,QAAQ,QAAQ,4BAAa,OAAO,OAAO,UAAU,CAAC,GAAG;AAC9D,YAAU;;;;;;;;;;ACEd,MAAa,2CAA2B;CACtC,MAAM;CACN,QAAQ,SAAS,SAAS;EACxB,MAAM,WAAW,SAAS,YAAYC,oBAAS;EAC/C,MAAM,QAAQ;GACZ,cAAc;GACd,kBAAkB;GAClB,eAAe;GACf,YAAY;GACZ,gBAAgB;GAChB,SAASC,qBAAQ,QAAQ;GACzB,SAASC,eAAM,SAAS;GACxB,YAAY;GACZ,gCAAgB,IAAI,KAA+E;GACpG;EAED,SAAS,QAAQ;AACf,QAAK,MAAM,CAAC,MAAM,WAAW,MAAM,gBAAgB;AACjD,QAAI,OAAO,SACT,eAAc,OAAO,SAAS;AAEhC,WAAO,aAAa,MAAM;;AAG5B,SAAM,eAAe;AACrB,SAAM,mBAAmB;AACzB,SAAM,gBAAgB;AACtB,SAAM,aAAa;AACnB,SAAM,iBAAiB;AACvB,SAAM,UAAUD,qBAAQ,QAAQ;AAChC,SAAM,UAAUC,eAAM,SAAS;AAC/B,SAAM,aAAa;AACnB,SAAM,eAAe,OAAO;;EAG9B,SAAS,mBAAmB;AAC1B,OAAI,YAAYF,oBAAS,OACvB;GAGF,MAAM,QAAkB,EAAE;GAC1B,MAAM,8CAAwB,MAAM,QAAQ;AAE5C,OAAI,MAAM,eAAe,GAAG;IAC1B,MAAM,YACJ,MAAM,gBAAgB,IAClB,oCAAqB,SAAS,MAAM,iBAAiB,UAAU,CAAC,CAAC,GAAG,MAAM,aAAa,4BAAa,OAAO,IAAI,MAAM,cAAc,UAAU,KAC7I,oCAAqB,SAAS,MAAM,iBAAiB,UAAU,CAAC,CAAC,GAAG,MAAM;AAChF,UAAM,KAAK,UAAU;;AAGvB,OAAI,MAAM,aAAa,EACrB,OAAM,KAAK,kCAAmB,SAAS,MAAM,eAAe,UAAU,CAAC,CAAC,GAAG,MAAM,aAAa;AAGhG,OAAI,MAAM,SAAS,GAAG;AACpB,UAAM,KAAK,4BAAa,SAAS,SAAS,CAAC,UAAU;AACrD,mBAAM,IAAI,KAAK,WAAW,MAAM,8BAAe,OAAO,MAAM,CAAC,CAAC,CAAC;;;EAInE,SAAS,WAAW,SAAyB;AAC3C,OAAI,YAAYA,oBAAS,QAQvB,QAAO,0BAAW,OAAO,qBAPP,IAAI,MAAM,EAAC,mBAAmB,SAAS;IACvD,QAAQ;IACR,MAAM;IACN,QAAQ;IACR,QAAQ;IACT,CAAC,CAEqC,GAAG,EAAE,QAAQ,CAAC,KAAK,IAAI;AAGhE,UAAO;;EAGT,SAAS,aAAa,MAAe;AACnC,SAAM,QAAQ,MAAM,KAAK;AACzB,SAAM,aAAa;;EAGrB,SAAS,YAAY,MAAe;AAClC,SAAM,QAAQ,KAAK,KAAK;AACxB,SAAM,aAAa;;AAGrB,UAAQ,GAAG,SAAS,SAAS,OAAO,OAAO;AACzC,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW;6BAAW,QAAQ,IAAI;IAAE;6BAAmB,OAAO,KAAK;IAAC,CAAC,KAAK,IAAI,CAAC;AAE5F,OAAI,MAAM,WACR,OAAM,QAAQ,QAAQ,KAAK;OAE3B,gBAAM,IAAI,KAAK,KAAK;IAEtB;AAEF,UAAQ,GAAG,YAAY,SAAS,OAAO,OAAO;AAC5C,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW;6BAAW,QAAQ,IAAI;IAAE;IAAS,YAAYA,oBAAS,gCAAiB,OAAO,KAAK,GAAG;IAAU,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI,CAAC;AAEpJ,OAAI,MAAM,WACR,aAAY,KAAK;OAEjB,gBAAM,IAAI,QAAQ,KAAK;IAEzB;AAEF,UAAQ,GAAG,SAAS,SAAS,SAAS;AACpC,OAAI,WAAWA,oBAAS,KACtB;GAGF,MAAM,OAAO,WACX;6BAAW,UAAU,IAAI;IAAE;IAAS,YAAYA,oBAAS,QAAQ,gCAAiB,OAAO,KAAK,GAAG;IAAU,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI,CACtI;AAED,kBAAM,IAAI,KAAK,KAAK;IACpB;AAEF,UAAQ,GAAG,UAAU,UAAU;GAC7B,MAAM,SAAS,MAAM;GAErB,MAAM,OAAO,0BAAW,OAAO,IAAI,EAAE,MAAM,QAAQ,CAAC,KAAK,IAAI;AAE7D,OAAI,MAAM,WACR,aAAY,WAAW,KAAK,CAAC;OAE7B,gBAAM,IAAI,MAAM,WAAW,KAAK,CAAC;AAInC,OAAI,YAAYA,oBAAS,SAAS,MAAM,OAAO;IAC7C,MAAM,SAAS,MAAM,MAAM,MAAM,KAAK,CAAC,MAAM,GAAG,EAAE;AAClD,SAAK,MAAM,SAAS,OAClB,gBAAM,IAAI,QAAQ,oCAAqB,OAAO,MAAM,MAAM,CAAC,CAAC,CAAC;AAG/D,QAAI,QAAQ,OAAO;AACjB,oBAAM,IAAI,iCAAkB,OAAO,gBAAgB,OAAO,UAAU,CAAC;KAErE,MAAM,SAAS,OAAO,MAAM,MAAM,KAAK,CAAC,MAAM,GAAG,EAAE;AACnD,UAAK,MAAM,SAAS,OAClB,gBAAM,IAAI,QAAQ,WAAW,gCAAiB,OAAO,MAAM,MAAM,CAAC,GAAG,CAAC;;;IAI5E;AAEF,UAAQ,GAAG,gBAAgB,SAAS,kBAAkB;AACpD,OAAI,YAAYA,oBAAS,OACvB;AAGF,kBAAM,IACJ,MAAM,QAAQ,UAAU,cAAc;6CAEtC,+BACA;IACE,OAAO;IACP,eAAe,+BAAwB,UAAU,EAAE;IACnD,SAAS;IACT,WAAW;IACX,cAAc;IACd,YAAY;IACb,CACF;IACD;AAEF,UAAQ,GAAG,mBAAmB,OAAO,YAAY;AAC/C,WAAQ,IAAI,KAAK,SAAS;IAAE,OAAO;IAA8C,aAAa;IAAkB;IAAS,aAAa;IAAM,CAAC,CAAC,IAAI;AAElJ,UAAO;IACP;AAEF,UAAQ,GAAG,sBAAsB;AAC/B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,wBAAwB;AAEhD,kBAAM,MAAM,KAAK;AACjB,gBAAa,WAAW,wBAAwB,CAAC;IACjD;AAEF,UAAQ,GAAG,eAAe,aAAa;AACrC,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,0BAA0B;AAElD,kBAAM,MAAM,KAAK;IACjB;AAEF,UAAQ,GAAG,qBAAqB,WAAW;AAEzC,SAAM,eAAe,OAAO,SAAS,UAAU;GAE/C,MAAM,OAAO,WAAW,CAAC,sBAAsB,OAAO,OAAO,gCAAiB,OAAO,OAAO,KAAK,KAAK,OAAU,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI,CAAC;AAE3I,kBAAM,MAAM,KAAK;AACjB,UAAO;IACP;AAEF,UAAQ,GAAG,iBAAiB,WAAW;AACrC,OAAI,YAAYA,oBAAS,OACvB;AAGF,gBAAa;GAEb,MAAM,cAAcE,eAAM,SAAS;IACjC,OAAO;IACP,KAAK;IACL,MAAM;IACP,CAAC;GACF,MAAM,OAAO,WAAW,uCAAwB,QAAQ,OAAO,KAAK,GAAG;AACvE,eAAY,MAAM,KAAK;GAEvB,MAAM,WAAW,kBAAkB;AACjC,gBAAY,SAAS;MACpB,IAAI;AAEP,SAAM,eAAe,IAAI,OAAO,MAAM;IAAE;IAAa;IAAU,CAAC;IAChE;AAEF,UAAQ,GAAG,eAAe,QAAQ,EAAE,UAAU,cAAc;AAC1D,gBAAa;GAEb,MAAM,SAAS,MAAM,eAAe,IAAI,OAAO,KAAK;AAEpD,OAAI,CAAC,UAAU,aAAaF,oBAAS,OACnC;AAGF,iBAAc,OAAO,SAAS;AAE9B,OAAI,QACF,OAAM;OAEN,OAAM;GAGR,MAAM,cAAc,kBAAkB,SAAS;GAC/C,MAAM,OAAO,WACX,UACI,4BAAa,QAAQ,OAAO,KAAK,CAAC,gBAAgB,gBAClD,4BAAa,QAAQ,OAAO,KAAK,CAAC,sCAAuB,sCAAgB,SAAS,CAAC,GACxF;AAED,UAAO,YAAY,KAAK,KAAK;AAC7B,SAAM,eAAe,OAAO,OAAO,KAAK;AAGxC,qBAAkB;IAClB;AAEF,UAAQ,GAAG,2BAA2B,UAAU;AAC9C,OAAI,YAAYA,oBAAS,OACvB;AAGF,gBAAa;AAEb,SAAM,aAAa,MAAM;AACzB,SAAM,iBAAiB;GAEvB,MAAM,OAAO,WAAW,MAAM,OAAO;GACrC,MAAM,cAAcE,eAAM,SAAS;IACjC,OAAO;IACP,KAAK,MAAM;IACX,MAAM;IACP,CAAC;AAEF,WAAQ,KAAK,QAAQ,KAAK;AAC1B,eAAY,MAAM,WAAW,KAAK,CAAC;AACnC,SAAM,eAAe,IAAI,SAAS,EAAE,aAAa,CAAC;IAClD;AAEF,UAAQ,GAAG,2BAA2B,EAAE,MAAM,aAAa;AACzD,OAAI,YAAYF,oBAAS,OACvB;AAGF,gBAAa;AAEb,SAAM;GAEN,MAAM,OAAO,mCAAoB,OAAO,MAAM,KAAK,KAAK;GACxD,MAAM,SAAS,MAAM,eAAe,IAAI,QAAQ;AAEhD,OAAI,CAAC,OACH;AAGF,UAAO,YAAY,QAAQ,QAAW,KAAK;IAC3C;AACF,UAAQ,GAAG,8BAA8B;AACvC,OAAI,YAAYA,oBAAS,OACvB;AAGF,gBAAa;GAEb,MAAM,OAAO,WAAW,6BAA6B;GACrD,MAAM,SAAS,MAAM,eAAe,IAAI,QAAQ;AAEhD,OAAI,CAAC,OACH;AAGF,UAAO,YAAY,KAAK,KAAK;AAC7B,SAAM,eAAe,OAAO,QAAQ;AAGpC,qBAAkB;IAClB;AAEF,UAAQ,GAAG,mBAAmB,WAAW;GACvC,MAAM,OAAO,WAAW,OAAO,OAAO,qDAAsC,OAAO,OAAO,KAAK,KAAK,uBAAuB;AAE3H,kBAAM,MAAM,KAAK;IACjB;AAEF,UAAQ,GAAG,sBAAsB;AAC/B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,iBAAiB;AAEzC,kBAAM,MAAM,KAAK;IACjB;AAEF,UAAQ,GAAG,oBAAoB;AAC7B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,mBAAmB;AAE3C,kBAAM,MAAM,KAAK;IACjB;AAEF,UAAQ,GAAG,oBAAoB;AAC7B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,eAAe;AAEvC,kBAAM,MAAM,KAAK;IACjB;AAEF,UAAQ,GAAG,kBAAkB;AAC3B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,iBAAiB;AAEzC,kBAAM,MAAM,KAAK;IACjB;AAEF,UAAQ,GAAG,cAAc,OAAO,EAAE,IAAI,SAAS,WAAW;GACxD,MAAM,kBAAkB,MAAM,SAAS,GAAG,QAAQ,GAAG,KAAK,KAAK,IAAI,KAAK;GACxE,MAAM,OAAO,WAAW,iCAAkB,OAAO,gBAAgB,CAAC,UAAU;AAG5E,OAAI,CAAC,GACH;AAGF,OAAI,YAAYA,oBAAS,QAAQ;AAC/B,QAAI;KACF,MAAM,SAAS,sBAAQ,SAAS,CAAC,GAAI,QAAQ,EAAE,CAAE,EAAE;MACjD,aAAa,EAAE,UAAU,MAAM;MAC/B,cAAc;MACf,CAAC;AAEF,WAAM,QAAQ,KAAK,SAAS;MAC1B,sBAAM,IAAI,MAAM;MAChB,MAAM,CAAC,OAAO,OAAO,SAAS,CAAC;MAChC,CAAC;AAEF,WAAM,QAAQ,KAAK,YAAY;MAC7B;MACA;MACA;MACA,SAAS;MACT,OAAO;MACR,CAAC;aACK,KAAK;KACZ,MAAM,QAAQ;KACd,MAAM,SAAS,MAAM,QAAQ,UAAU;KACvC,MAAM,SAAS,MAAM,QAAQ,UAAU;AAEvC,WAAM,QAAQ,KAAK,SAAS;MAC1B,sBAAM,IAAI,MAAM;MAChB,MAAM,CAAC,QAAQ,OAAO,CAAC,OAAO,QAAQ;MACvC,CAAC;AAEF,SAAI,OACF,SAAQ,MAAM,OAAO;AAEvB,SAAI,OACF,SAAQ,IAAI,OAAO;KAGrB,MAAM,+BAAe,IAAI,MAAM,wBAAwB,kBAAkB;AAEzE,WAAM,QAAQ,KAAK,YAAY;MAC7B;MACA;MACA;MACA,SAAS;MACT,OAAO;MACR,CAAC;AACF,WAAM,QAAQ,KAAK,SAAS,aAAa;;AAG3C;;AAGF,kBAAM,MAAM,KAAK;GAEjB,MAAM,SAASE,eAAM,QAAQ,EAC3B,OAAO,WAAW,CAAC,kBAAkB,YAAYF,oBAAS,gCAAiB,OAAO,gBAAgB,GAAG,OAAU,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI,CAAC,EAC3I,CAAC;GAEF,MAAM,WAAW,IAAI,cAAc,OAAO;AAE1C,OAAI;IACF,MAAM,uBAAS,SAAS,CAAC,GAAI,QAAQ,EAAE,CAAE,EAAE;KACzC,aAAa,EAAE,UAAU,MAAM;KAC/B,cAAc;KACf,CAAC;AAEF,eAAW,MAAM,QAAQ,KACvB,UAAS,MAAM,KAAK;IAGtB,MAAM,SAAS,MAAM;AAErB,UAAM,QAAQ,KAAK,SAAS;KAC1B,sBAAM,IAAI,MAAM;KAChB,MAAM,CAAC,OAAO,OAAO,SAAS,CAAC;KAChC,CAAC;AAEF,UAAM,QAAQ,KAAK,YAAY;KAAE;KAAS;KAAM;KAAI,SAAS;KAAM,OAAO;KAAM,CAAC;YAC1E,KAAK;IACZ,MAAM,QAAQ;IACd,MAAM,SAAS,MAAM,QAAQ,UAAU;IACvC,MAAM,SAAS,MAAM,QAAQ,UAAU;AAEvC,UAAM,QAAQ,KAAK,SAAS;KAC1B,sBAAM,IAAI,MAAM;KAChB,MAAM,CAAC,QAAQ,OAAO,CAAC,OAAO,QAAQ;KACvC,CAAC;AAEF,QAAI,OACF,QAAO,MAAM,OAAO;AAEtB,QAAI,OACF,QAAO,QAAQ,OAAO;IAGxB,MAAM,+BAAe,IAAI,MAAM,wBAAwB,kBAAkB;AAEzE,UAAM,QAAQ,KAAK,YAAY;KAAE;KAAS;KAAM;KAAI,SAAS;KAAO,OAAO;KAAc,CAAC;AAC1F,UAAM,QAAQ,KAAK,SAAS,aAAa;;IAE3C;AAEF,UAAQ,GAAG,aAAa,EAAE,SAAS,WAAW;AAC5C,OAAI,YAAYA,oBAAS,OACvB;GAIF,MAAM,OAAO,WAAW,iCAAkB,OADlB,MAAM,SAAS,GAAG,QAAQ,GAAG,KAAK,KAAK,IAAI,KAAK,QACP,CAAC,wBAAwB;AAE1F,kBAAM,MAAM,KAAK;IACjB;AAEF,UAAQ,GAAG,uBAAuB,QAAQ,EAAE,eAAe,eAAe,cAAc,QAAQ,cAAc;GAC5G,MAAM,UAAU,WAAW;IACzB;IACA;IACA;IACA;IACA;IACA,eAAe,YAAYA,oBAAS,UAAU,gBAAgB;IAC/D,CAAC;GACF,MAAM,QAAQ,OAAO,QAAQ;AAE7B,WAAQ,QAAQ,KAAK;AACrB,WAAQ,KAAK,KAAK;AAElB,OAAI,WAAW,WAAW;AACxB,mBAAM,IAAI,QAAQ,KAAK,KAAK,EAAE,WAAW,MAAM,EAAE;KAC/C,OAAO;KACP,eAAe,+BAAwB,SAAS,EAAE;KAClD,SAAS;KACT,WAAW;KACX,cAAc;KACd,YAAY;KACb,CAAC;AAEF;;AAGF,kBAAM,IAAI,QAAQ,KAAK,KAAK,EAAE,WAAW,MAAM,EAAE;IAC/C,OAAO;IACP,eAAe,+BAAwB,OAAO,EAAE;IAChD,SAAS;IACT,WAAW;IACX,cAAc;IACd,YAAY;IACb,CAAC;IACF;AAEF,UAAQ,GAAG,uBAAuB;AAChC,UAAO;IACP;;CAEL,CAAC;;;;;;;ACniBF,SAAgB,kBAA2B;AACzC,QAAO,CAAC,CAAC,QAAQ,IAAI;;;;;AAMvB,SAAgB,kBAA2B;AACzC,QAAO,CAAC,EACN,QAAQ,IAAI,MACZ,QAAQ,IAAI,kBACZ,QAAQ,IAAI,aACZ,QAAQ,IAAI,YACZ,QAAQ,IAAI,UACZ,QAAQ,IAAI,eACZ,QAAQ,IAAI;;;;;AAOhB,SAAgB,YAAqB;AACnC,QAAO,CAAC,CAAC,QAAQ,OAAO,SAAS,CAAC,iBAAiB;;;;;;;;;;;;ACRrD,MAAa,gDAAgC;CAC3C,MAAM;CACN,QAAQ,SAAS;EACf,MAAM,QAAQ;GACZ,4BAAY,IAAI,KAAkB;GAClC,WAAW,KAAK,KAAK;GACtB;EAED,SAAS,QAAQ;AACf,SAAM,6BAAa,IAAI,KAAkB;AACzC,SAAM,YAAY,KAAK,KAAK;;EAG9B,eAAe,UAAU,MAAe;AACtC,OAAI,MAAM,WAAW,SAAS,EAC5B,QAAO,EAAE;GAGX,MAAM,QAAkC,EAAE;AAE1C,QAAK,MAAM,OAAO,MAAM,YAAY;IAClC,MAAM,WAAW,IAAI,YAAY,GAAG;KAAC;KAAQ;KAAM,MAAM;KAAU,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI,CAAC;IAC9F,MAAM,kCAAmB,QAAQ,KAAK,EAAE,SAAS,SAAS;AAE1D,QAAI,CAAC,MAAM,UACT,OAAM,YAAY,EAAE;AAGtB,QAAI,IAAI,KAAK,SAAS,GAAG;KACvB,MAAM,YAAY,IAAI,KAAK,gBAAgB;AAC3C,WAAM,UAAU,KAAK,IAAI,UAAU,KAAK,IAAI,KAAK,KAAK,KAAK,GAAG;;;AAIlE,SAAM,QAAQ,IACZ,OAAO,QAAQ,MAAM,CAAC,IAAI,OAAO,CAAC,UAAU,UAAU;AACpD,oCAAa,UAAU,KAAK,KAAK,OAAO,CAAC;KACzC,CACH;AAED,UAAO,OAAO,KAAK,MAAM;;AAG3B,UAAQ,GAAG,SAAS,SAAS,SAAS;AACpC,SAAM,WAAW,IAAI;IACnB,sBAAM,IAAI,MAAM;IAChB,MAAM,CAAC,KAAK,QAAQ,GAAG,OAAO;IAC9B,UAAU;IACX,CAAC;IACF;AAEF,UAAQ,GAAG,YAAY,SAAS,SAAS;AACvC,SAAM,WAAW,IAAI;IACnB,sBAAM,IAAI,MAAM;IAChB,MAAM,CAAC,KAAK,QAAQ,GAAG,OAAO;IAC9B,UAAU;IACX,CAAC;IACF;AAEF,UAAQ,GAAG,SAAS,SAAS,SAAS;AACpC,SAAM,WAAW,IAAI;IACnB,sBAAM,IAAI,MAAM;IAChB,MAAM,CAAC,KAAK,QAAQ,GAAG,OAAO;IAC9B,UAAU;IACX,CAAC;IACF;AAEF,UAAQ,GAAG,UAAU,UAAU;AAC7B,SAAM,WAAW,IAAI;IACnB,sBAAM,IAAI,MAAM;IAChB,MAAM,CAAC,KAAK,MAAM,WAAW,MAAM,SAAS,gBAAgB;IAC5D,UAAU;IACX,CAAC;IACF;AAEF,UAAQ,GAAG,UAAU,YAAY;AAC/B,SAAM,WAAW,IAAI;IACnB,sBAAM,IAAI,MAAM;IAChB,MAAM,QAAQ;IACd,UAAU;IACX,CAAC;IACF;AAEF,UAAQ,GAAG,iBAAiB,WAAW;AACrC,SAAM,WAAW,IAAI;IACnB,sBAAM,IAAI,MAAM;IAChB,MAAM,CAAC,cAAc,OAAO,OAAO;IACnC,UAAU;IACX,CAAC;IACF;AAEF,UAAQ,GAAG,eAAe,QAAQ,EAAE,UAAU,cAAc;GAC1D,MAAM,6CAAuB,SAAS;AAEtC,SAAM,WAAW,IAAI;IACnB,sBAAM,IAAI,MAAM;IAChB,MAAM,CAAC,UAAU,GAAG,OAAO,KAAK,gBAAgB,gBAAgB,GAAG,OAAO,KAAK,aAAa,cAAc;IAC1G,UAAU;IACX,CAAC;IACF;AAEF,UAAQ,GAAG,2BAA2B,UAAU;AAC9C,SAAM,WAAW,IAAI;IACnB,sBAAM,IAAI,MAAM;IAChB,MAAM,CAAC,SAAS,MAAM,OAAO,YAAY,GAAG,MAAM,KAAK,SAAS,KAAK,KAAK,CAAC;IAC3E,UAAU;IACX,CAAC;IACF;AAEF,UAAQ,GAAG,kBAAkB,OAAO,WAAW;GAC7C,MAAM,mBAAmB,MAAM,UAAU,OAAO,KAAK;AACrD,OAAI,iBAAiB,SAAS,GAAG;IAC/B,MAAM,QAAQ,iBAAiB,KAAK,8BAAe,QAAQ,KAAK,EAAE,EAAE,CAAC;AACrE,UAAM,QAAQ,KAAK,QAAQ,2BAA2B,MAAM,KAAK,KAAK,CAAC;;AAEzE,UAAO;IACP;AAEF,UAAQ,GAAG,iBAAiB,YAAY,GAEtC;EAGF,MAAM,oBAAoB;AAExB,OAAI,MAAM,WAAW,OAAO,EAC1B,YAAW,CAAC,YAAY,GAEtB;;AAIN,UAAQ,KAAK,QAAQ,YAAY;AACjC,UAAQ,KAAK,UAAU,YAAY;AACnC,UAAQ,KAAK,WAAW,YAAY;;CAEvC,CAAC;;;;;;;;AChJF,MAAa,mDAAmC;CAC9C,MAAM;CACN,QAAQ,SAAS,SAAS;EACxB,MAAM,WAAW,SAAS,YAAYG,oBAAS;EAC/C,MAAM,QAAQ;GACZ,cAAc;GACd,kBAAkB;GAClB,eAAe;GACf,YAAY;GACZ,gBAAgB;GAChB,SAAS,QAAQ,QAAQ;GACzB,gBAAgB,EAAE;GACnB;EAED,SAAS,QAAQ;AACf,SAAM,eAAe;AACrB,SAAM,mBAAmB;AACzB,SAAM,gBAAgB;AACtB,SAAM,aAAa;AACnB,SAAM,iBAAiB;AACvB,SAAM,UAAU,QAAQ,QAAQ;;EAGlC,SAAS,mBAAmB;AAC1B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,QAAkB,EAAE;GAC1B,MAAM,8CAAwB,MAAM,QAAQ;AAE5C,OAAI,MAAM,eAAe,GAAG;IAC1B,MAAM,YACJ,MAAM,gBAAgB,IAClB,oCAAqB,SAAS,MAAM,iBAAiB,UAAU,CAAC,CAAC,GAAG,MAAM,aAAa,4BAAa,OAAO,IAAI,MAAM,cAAc,UAAU,KAC7I,oCAAqB,SAAS,MAAM,iBAAiB,UAAU,CAAC,CAAC,GAAG,MAAM;AAChF,UAAM,KAAK,UAAU;;AAGvB,OAAI,MAAM,aAAa,EACrB,OAAM,KAAK,kCAAmB,SAAS,MAAM,eAAe,UAAU,CAAC,CAAC,GAAG,MAAM,aAAa;AAGhG,OAAI,MAAM,SAAS,GAAG;AACpB,UAAM,KAAK,4BAAa,SAAS,SAAS,CAAC,UAAU;AACrD,YAAQ,IAAI,WAAW,MAAM,8BAAe,OAAO,MAAM,CAAC,CAAC,CAAC;;;EAIhE,SAAS,WAAW,SAAyB;AAC3C,OAAI,YAAYA,oBAAS,QAQvB,QAAO,0BAAW,OAAO,qBAPP,IAAI,MAAM,EAAC,mBAAmB,SAAS;IACvD,QAAQ;IACR,MAAM;IACN,QAAQ;IACR,QAAQ;IACT,CAAC,CAEqC,GAAG,EAAE,QAAQ,CAAC,KAAK,IAAI;AAGhE,UAAO;;EAGT,SAAS,UAAU,MAAc;AAC/B,WAAQ,IAAI,YAAY,OAAO;;EAGjC,SAAS,WAAW,OAAe;AACjC,WAAQ,IAAI,eAAe;;AAG7B,UAAQ,GAAG,SAAS,SAAS,OAAO,OAAO;AACzC,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW;6BAAW,QAAQ,IAAI;IAAE;6BAAmB,OAAO,KAAK;IAAC,CAAC,KAAK,IAAI,CAAC;AAE5F,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,YAAY,SAAS,OAAO,OAAO;AAC5C,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW;6BAAW,QAAQ,IAAI;IAAE;IAAS,YAAYA,oBAAS,gCAAiB,OAAO,KAAK,GAAG;IAAU,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI,CAAC;AAEpJ,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,SAAS,SAAS,OAAO,OAAO;AACzC,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW;6BAAW,UAAU,IAAI;IAAE;IAAS,YAAYA,oBAAS,gCAAiB,OAAO,KAAK,GAAG;IAAU,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI,CAAC;AAEtJ,WAAQ,KAAK,cAAc,OAAO;IAClC;AAEF,UAAQ,GAAG,UAAU,UAAU;GAC7B,MAAM,SAAS,MAAM;AAErB,OAAI,YAAYA,oBAAS,OACvB;GAEF,MAAM,UAAU,MAAM,WAAW,OAAO,MAAM;AAC9C,WAAQ,MAAM,YAAY,UAAU;AAGpC,OAAI,YAAYA,oBAAS,SAAS,MAAM,OAAO;IAC7C,MAAM,SAAS,MAAM,MAAM,MAAM,KAAK,CAAC,MAAM,GAAG,EAAE;AAClD,SAAK,MAAM,SAAS,OAClB,SAAQ,IAAI,oCAAqB,OAAO,MAAM,MAAM,CAAC,CAAC,CAAC;AAGzD,QAAI,QAAQ,OAAO;AACjB,aAAQ,6BAAc,OAAO,gBAAgB,OAAO,UAAU,CAAC;KAE/D,MAAM,SAAS,OAAO,MAAM,MAAM,KAAK,CAAC,MAAM,GAAG,EAAE;AACnD,UAAK,MAAM,SAAS,OAClB,SAAQ,IAAI,WAAW,gCAAiB,OAAO,MAAM,MAAM,CAAC,GAAG,CAAC;;;IAItE;AAEF,UAAQ,GAAG,oBAAoB,YAAY;AACzC,WAAQ,6BAAc,UAAU,QAAQ,QAAQ,KAAK,CAAC;AACtD,UAAO;IACP;AAEF,UAAQ,GAAG,sBAAsB;AAC/B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,wBAAwB;AAEhD,aAAU,gBAAgB;AAE1B,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,eAAe,YAAY;AACpC,SAAM,iBAAiB;AAEvB,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,0BAA0B;AAElD,WAAQ,IAAI,KAAK;AAEjB,cAAW,gBAAgB;IAC3B;AAEF,UAAQ,GAAG,qBAAqB,WAAW;AAEzC,SAAM,eAAe,OAAO,SAAS,UAAU;GAE/C,MAAM,OAAO,OAAO,OAAO,2CAA4B,QAAQ,OAAO,KAAK,KAAK;AAEhF,OAAI,MAAM,eAAe,SAAS,EAChC,WAAU,KAAK;AAGjB,OAAI,MAAM,eAAe,WAAW,EAClC,SAAQ,IAAI,WAAW,KAAK,CAAC;AAG/B,UAAO;IACP;AAEF,UAAQ,GAAG,iBAAiB,WAAW;AACrC,OAAI,YAAYA,oBAAS,OACvB;GAEF,MAAM,OAAO,WAAW,uCAAwB,QAAQ,OAAO,KAAK,GAAG;AAEvE,OAAI,MAAM,eAAe,WAAW,EAClC,WAAU,WAAW,OAAO,OAAO;AAGrC,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,eAAe,QAAQ,EAAE,UAAU,cAAc;AAC1D,OAAI,YAAYA,oBAAS,OACvB;AAGF,OAAI,QACF,OAAM;OAEN,OAAM;GAGR,MAAM,cAAc,kBAAkB,SAAS;GAC/C,MAAM,OAAO,WACX,UACI,4BAAa,QAAQ,OAAO,KAAK,CAAC,gBAAgB,gBAClD,4BAAa,QAAQ,OAAO,KAAK,CAAC,sCAAuB,sCAAgB,SAAS,CAAC,GACxF;AAED,WAAQ,IAAI,KAAK;AACjB,OAAI,MAAM,eAAe,SAAS,EAChC,SAAQ,IAAI,IAAI;AAGlB,OAAI,MAAM,eAAe,WAAW,EAClC,YAAW,WAAW,OAAO,OAAO;AAItC,qBAAkB;IAClB;AAEF,UAAQ,GAAG,2BAA2B,UAAU;AAC9C,OAAI,YAAYA,oBAAS,OACvB;AAGF,SAAM,aAAa,MAAM;AACzB,SAAM,iBAAiB;AAEvB,OAAI,MAAM,eAAe,WAAW,EAClC,WAAU,kBAAkB;GAE9B,MAAM,OAAO,WAAW,WAAW,MAAM,OAAO,QAAQ;AAExD,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,8BAA8B;AACvC,OAAI,YAAYA,oBAAS,OACvB;GAEF,MAAM,OAAO,WAAW,6BAA6B;AAErD,WAAQ,IAAI,KAAK;AAEjB,OAAI,MAAM,eAAe,WAAW,EAClC,YAAW,kBAAkB;IAE/B;AAEF,UAAQ,GAAG,gCAAgC;AACzC,OAAI,YAAYA,oBAAS,OACvB;AAGF,SAAM;IACN;AAEF,UAAQ,GAAG,8BAA8B;AACvC,OAAI,YAAYA,oBAAS,OACvB;AAIF,qBAAkB;IAClB;AAEF,UAAQ,GAAG,mBAAmB,WAAW;GACvC,MAAM,OAAO,WACX,OAAO,OAAO,4BAAa,QAAQ,IAAI,CAAC,qDAAsC,OAAO,OAAO,KAAK,KAAK,4BAAa,QAAQ,IAAI,CAAC,uBACjI;AAED,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,sBAAsB;AAC/B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,iBAAiB;AAEzC,OAAI,MAAM,eAAe,WAAW,EAClC,WAAU,aAAa;AAGzB,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,oBAAoB;AAC7B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,mBAAmB;AAE3C,WAAQ,IAAI,KAAK;AAEjB,OAAI,MAAM,eAAe,WAAW,EAClC,YAAW,aAAa;IAE1B;AAEF,UAAQ,GAAG,oBAAoB;AAC7B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,eAAe;AAEvC,OAAI,MAAM,eAAe,WAAW,EAClC,WAAU,UAAU;AAGtB,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,kBAAkB;AAC3B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,iBAAiB;AAEzC,WAAQ,IAAI,KAAK;AAEjB,OAAI,MAAM,eAAe,WAAW,EAClC,YAAW,UAAU;IAEvB;AAEF,UAAQ,GAAG,cAAc,OAAO,EAAE,IAAI,SAAS,WAAW;GACxD,MAAM,kBAAkB,MAAM,SAAS,GAAG,QAAQ,GAAG,KAAK,KAAK,IAAI,KAAK;GACxE,MAAM,OAAO,WAAW,iCAAkB,OAAO,gBAAgB,CAAC,UAAU;AAE5E,OAAI,WAAWA,oBAAS,QAAQ;AAC9B,QAAI,MAAM,eAAe,WAAW,EAClC,WAAU,QAAQ,kBAAkB;AAGtC,YAAQ,IAAI,KAAK;;AAInB,OAAI,CAAC,GACH;AAGF,OAAI;IACF,MAAM,SAAS,sBAAQ,SAAS,CAAC,GAAI,QAAQ,EAAE,CAAE,EAAE;KACjD,aAAa,EAAE,UAAU,MAAM;KAC/B,cAAc;KACf,CAAC;AAEF,UAAM,QAAQ,KAAK,SAAS;KAC1B,sBAAM,IAAI,MAAM;KAChB,MAAM,CAAC,OAAO,OAAO,SAAS,CAAC;KAChC,CAAC;AAEF,QAAI,WAAWA,oBAAS,OACtB,SAAQ,IAAI,OAAO,OAAO,SAAS,CAAC;AAGtC,UAAM,QAAQ,KAAK,YAAY;KAC7B;KACA;KACA;KACA,SAAS;KACT,OAAO;KACR,CAAC;YACK,KAAK;IACZ,MAAM,QAAQ;IACd,MAAM,SAAS,MAAM,QAAQ,UAAU;IACvC,MAAM,SAAS,MAAM,QAAQ,UAAU;AAEvC,UAAM,QAAQ,KAAK,SAAS;KAC1B,sBAAM,IAAI,MAAM;KAChB,MAAM,CAAC,QAAQ,OAAO,CAAC,OAAO,QAAQ;KACvC,CAAC;AAGF,QAAI,OACF,SAAQ,MAAM,YAAY,SAAS;AAErC,QAAI,OACF,SAAQ,IAAI,OAAO;IAGrB,MAAM,+BAAe,IAAI,MAAM,wBAAwB,kBAAkB;AAEzE,UAAM,QAAQ,KAAK,YAAY;KAC7B;KACA;KACA;KACA,SAAS;KACT,OAAO;KACR,CAAC;AACF,UAAM,QAAQ,KAAK,SAAS,aAAa;;IAE3C;AAEF,UAAQ,GAAG,aAAa,EAAE,SAAS,WAAW;AAC5C,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,kBAAkB,MAAM,SAAS,GAAG,QAAQ,GAAG,KAAK,KAAK,IAAI,KAAK;GACxE,MAAM,OAAO,WAAW,iCAAkB,OAAO,gBAAgB,CAAC,YAAY;AAE9E,WAAQ,IAAI,KAAK;AAEjB,OAAI,MAAM,eAAe,WAAW,EAClC,YAAW,QAAQ,kBAAkB;IAEvC;AAEF,UAAQ,GAAG,uBAAuB,QAAQ,EAAE,QAAQ,SAAS,oBAAoB;GAC/E,MAAM,eAAe,OAAO,SAAS,UAAU;GAC/C,MAAM,eAAe,eAAe,cAAc;GAClD,MAAM,8CAAwB,QAAQ;AAEtC,OAAI,MAAM,eAAe,SAAS,EAChC,SAAQ,IAAI,IAAI;AAGlB,WAAQ,IACN,WAAW,YACP,0CAA2B,QAAQ,IAAI,CAAC,GAAG,GAAG,aAAa,aAAa,IAAI,aAAa,mCAAoB,SAAS,SAAS,KAC/H,0CAA2B,QAAQ,IAAI,CAAC,GAAG,GAAG,aAAa,aAAa,MAAM,GAAG,cAAc,KAAK,SAAS,IAAI,aAAa,mCAAoB,SAAS,SAAS,GACzK;AAED,OAAI,MAAM,eAAe,SAAS,EAChC,YAAW,OAAO,OAAO,2CAA4B,QAAQ,OAAO,KAAK,KAAK,aAAa;IAE7F;;CAEL,CAAC;;;;;;;;ACpbF,MAAa,2CAA2B;CACtC,MAAM;CACN,QAAQ,SAAS,SAAS;EACxB,MAAM,WAAW,SAAS,YAAY;EAEtC,SAAS,WAAW,SAAyB;AAC3C,OAAI,YAAYC,oBAAS,QAQvB,QAAO,CAAC,qBAPU,IAAI,MAAM,EAAC,mBAAmB,SAAS;IACvD,QAAQ;IACR,MAAM;IACN,QAAQ;IACR,QAAQ;IACT,CAAC,CAEoB,IAAI,QAAQ,CAAC,KAAK,IAAI;AAG9C,UAAO;;AAGT,UAAQ,GAAG,SAAS,SAAS,SAAS;AACpC,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW;IAAC;IAAK;IAAS;IAAK,CAAC,KAAK,IAAI,CAAC;AAEvD,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,YAAY,SAAS,OAAO,OAAO;AAC5C,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW;IAAC;IAAK;IAAS,YAAYA,oBAAS,OAAO,OAAO;IAAU,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI,CAAC;AAE/G,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,SAAS,SAAS,SAAS;AACpC,OAAI,WAAWA,oBAAS,KACtB;GAGF,MAAM,OAAO,WAAW;IAAC;IAAK;IAAS,YAAYA,oBAAS,OAAO,OAAO;IAAU,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI,CAAC;AAE/G,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,UAAU,UAAU;GAC7B,MAAM,SAAS,MAAM;GAErB,MAAM,OAAO,WAAW,CAAC,KAAK,MAAM,QAAQ,CAAC,KAAK,IAAI,CAAC;AAEvD,WAAQ,IAAI,KAAK;AAGjB,OAAI,YAAYA,oBAAS,SAAS,MAAM,OAAO;IAC7C,MAAM,SAAS,MAAM,MAAM,MAAM,KAAK,CAAC,MAAM,GAAG,EAAE;AAClD,SAAK,MAAM,SAAS,OAClB,SAAQ,IAAI,WAAW,MAAM,MAAM,CAAC,CAAC;AAGvC,QAAI,QAAQ,OAAO;AACjB,aAAQ,IAAI,gBAAgB,OAAO,UAAU;KAE7C,MAAM,SAAS,OAAO,MAAM,MAAM,KAAK,CAAC,MAAM,GAAG,EAAE;AACnD,UAAK,MAAM,SAAS,OAClB,SAAQ,IAAI,WAAW,OAAO,MAAM,MAAM,GAAG,CAAC;;;IAIpD;AAEF,UAAQ,GAAG,yBAAyB;AAClC,WAAQ,IAAI,cAAc;IAC1B;AAEF,UAAQ,GAAG,sBAAsB;AAC/B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,wBAAwB;AAEhD,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,oBAAoB;AAC7B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,0BAA0B;AAElD,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,0BAA0B;GACnC,MAAM,OAAO,WAAW,wBAAwB;AAEhD,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,iBAAiB,WAAW;AACrC,OAAI,YAAYA,oBAAS,OACvB;GAEF,MAAM,OAAO,WAAW,cAAc,OAAO,OAAO;AAEpD,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,eAAe,QAAQ,EAAE,UAAU,cAAc;AAC1D,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,6CAAuB,SAAS;GACtC,MAAM,OAAO,WAAW,UAAU,GAAG,OAAO,KAAK,gBAAgB,gBAAgB,GAAG,OAAO,KAAK,aAAa,cAAc;AAE3H,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,2BAA2B,UAAU;AAC9C,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,WAAW,MAAM,OAAO,QAAQ;AAExD,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,2BAA2B,EAAE,MAAM,aAAa;AACzD,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,mCAAoB,OAAO,MAAM,KAAK,KAAK,GAAG;AAEtE,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,8BAA8B;AACvC,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,6BAA6B;AAErD,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,mBAAmB,WAAW;GACvC,MAAM,OAAO,WAAW,OAAO,OAAO,4BAA4B,OAAO,SAAS,uBAAuB;AAEzG,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,sBAAsB;AAC/B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,iBAAiB;AAEzC,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,oBAAoB;AAC7B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,mBAAmB;AAE3C,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,oBAAoB;AAC7B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,eAAe;AAEvC,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,kBAAkB;AAC3B,OAAI,YAAYA,oBAAS,OACvB;GAGF,MAAM,OAAO,WAAW,iBAAiB;AAEzC,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,cAAc,OAAO,EAAE,IAAI,SAAS,WAAW;GACxD,MAAM,kBAAkB,MAAM,SAAS,GAAG,QAAQ,GAAG,KAAK,KAAK,IAAI,KAAK;GACxE,MAAM,OAAO,WAAW,QAAQ,gBAAgB,UAAU;AAE1D,OAAI,WAAWA,oBAAS,OACtB,SAAQ,IAAI,KAAK;AAInB,OAAI,CAAC,GACH;AAGF,OAAI;IACF,MAAM,SAAS,sBAAQ,SAAS,CAAC,GAAI,QAAQ,EAAE,CAAE,EAAE;KACjD,aAAa,EAAE,UAAU,MAAM;KAC/B,cAAc;KACf,CAAC;AAEF,UAAM,QAAQ,KAAK,SAAS;KAC1B,sBAAM,IAAI,MAAM;KAChB,MAAM,CAAC,OAAO,OAAO,SAAS,CAAC;KAChC,CAAC;AAEF,QAAI,WAAWA,oBAAS,OACtB,SAAQ,IAAI,OAAO,OAAO,SAAS,CAAC;AAGtC,UAAM,QAAQ,KAAK,YAAY;KAC7B;KACA;KACA;KACA,SAAS;KACT,OAAO;KACR,CAAC;YACK,KAAK;IACZ,MAAM,QAAQ;IACd,MAAM,SAAS,MAAM,QAAQ,UAAU;IACvC,MAAM,SAAS,MAAM,QAAQ,UAAU;AAEvC,UAAM,QAAQ,KAAK,SAAS;KAC1B,sBAAM,IAAI,MAAM;KAChB,MAAM,CAAC,QAAQ,OAAO,CAAC,OAAO,QAAQ;KACvC,CAAC;AAEF,QAAI,OACF,SAAQ,MAAM,OAAO;AAEvB,QAAI,OACF,SAAQ,IAAI,OAAO;IAGrB,MAAM,+BAAe,IAAI,MAAM,wBAAwB,kBAAkB;AAEzE,UAAM,QAAQ,KAAK,YAAY;KAC7B;KACA;KACA;KACA,SAAS;KACT,OAAO;KACR,CAAC;AACF,UAAM,QAAQ,KAAK,SAAS,aAAa;;IAE3C;AAEF,UAAQ,GAAG,aAAa,EAAE,SAAS,WAAW;AAC5C,OAAI,YAAYA,oBAAS,OACvB;GAIF,MAAM,OAAO,WAAW,QADA,MAAM,SAAS,GAAG,QAAQ,GAAG,KAAK,KAAK,IAAI,KAAK,QACxB,YAAY;AAE5D,WAAQ,IAAI,KAAK;IACjB;AAEF,UAAQ,GAAG,uBAAuB,QAAQ,EAAE,eAAe,QAAQ,SAAS,eAAe,mBAAmB;GAC5G,MAAM,UAAU,WAAW;IACzB;IACA;IACA;IACA;IACA;IACA,eAAe,YAAYA,oBAAS,UAAU,gBAAgB;IAC/D,CAAC;AAEF,WAAQ,IAAI,8BAA8B;AAC1C,WAAQ,IAAI,QAAQ,KAAK,KAAK,CAAC;AAC/B,WAAQ,IAAI,8BAA8B;IAC1C;;CAEL,CAAC;;;;ACrSF,SAAgB,eAA2B;AACzC,KAAI,iBAAiB,CACnB,QAAO;AAET,KAAI,WAAW,CACb,QAAO;AAET,QAAO;;AAGT,MAAM,YAAY;CAChB,OAAO;CACP,OAAO;CACP,kBAAkB;CACnB;AAED,eAAsB,YAAY,SAAwB,EAAE,YAA0C;CACpG,MAAM,OAAO,cAAc;CAE3B,MAAM,SAAS,UAAU;AAEzB,KAAI,CAAC,OACH,OAAM,IAAI,MAAM,yBAAyB,OAAO;CAIlD,MAAM,UAAU,MAAM,OAAO,QAAQ,SAAS,EAAE,UAAU,CAAC;AAE3D,KAAI,YAAYC,oBAAS,MACvB,OAAM,iBAAiB,QAAQ,SAAS,EAAE,UAAU,CAAC;AAGvD,QAAO;;;;;AC9BT,eAAsB,aAAa,EAAE,OAAO,UAA8C;CACxF,MAAM,WAAW,MAAM,QAAQ,MAAM,KAAK,GAAG,MAAM,OAAO,CAAC,MAAM,KAAK,CAAC,OAAO,QAAQ;AAEtF,MAAK,MAAM,WAAW,UAAU;EAC9B,MAAM,CAAC,KAAK,GAAG,uCAAiB,QAAQ;AAExC,MAAI,CAAC,IACH;EAGF,MAAM,qCAAoB,SAAS,CAAC,OAAO,QAAQ,CAAC,OAAO,MAAM;AACjE,QAAM,OAAO,KAAK,cAAc;GAAE,IAAI;GAAQ,SAAS;GAAK;GAAM,CAAC;AAEnE,QAAM,OAAO,OAAO,YAAY,OAAO,EAAE,SAAS,YAAY;AAC5D,OAAI,CAAC,QACH,OAAM;AAGR,SAAM,OAAO,KAAK,WAAW,4BAAa,OAAO,QAAQ,CAAC,wBAAwB;IAClF;;;;;;ACZN,eAAsB,SAAS,EAAE,OAAO,QAAQ,YAAY,QAAQ,YAA0C;CAC5G,MAAM,YAAY,UAAU,UAAU,WAAW,QAAQ,WAAW,MAAM,OAAO;CACjF,MAAM,UAAUC,qBAAQ,QAAQ;CAEhC,MAAM,SAAiB;EACrB,GAAG;EACH,MAAM,WAAW,QAAQA,qBAAQ,KAAK;EACtC,OAAO,YACH;GACE,GAAG,WAAW;GACd,MAAM;GACP,GACD,WAAW;EACf,QAAQ;GACN,OAAO;GACP,YAAY;GACZ,WAAW,EACT,OAAO,OACR;GACD,QAAQ;GACR,GAAG,WAAW;GACf;EACF;AAED,OAAM,OAAO,KAAK,oBAAoB,OAAO;AAE7C,OAAM,OAAO,KAAK,QAAQ,OAAO,OAAO,6CAA8B,QAAQ,OAAO,KAAK,KAAK,oBAAoB,UAAU;CAE7H,MAAM,EAAE,SAAS,QAAQ,kBAAkB,4BAAY;EACrD;EACA;EACD,CAAC;AAEF,OAAM,OAAO,KAAK,QAAQ,OAAO,OAAO,6CAA8B,QAAQ,OAAO,KAAK,KAAK,oBAAoB,UAAU;CAE7H,MAAM,EAAE,OAAO,eAAe,eAAe,UAAU,gCACrD;EACE;EACA;EACD,EACD;EAAE;EAAe;EAAQ;EAAQ;EAAS,CAC3C;AAED,OAAM,OAAO,KAAK,QAAQ,eAAe;AAKzC,KADoB,cAAc,OAAO,KAAK,OAC7B;AASf,EAP2B,CACzB,OACA,GAAG,MAAM,KAAK,cAAc,CACzB,QAAQ,OAAO,GAAG,MAAM,CACxB,KAAK,OAAO,GAAG,MAAM,CACzB,CAAC,OAAO,QAAQ,CAEP,SAAS,QAAQ;AACzB,UAAO,KAAK,SAAS,IAAI;IACzB;AAEF,QAAM,OAAO,KAAK,kBAAkB,QAAQ,OAAO,QAAQ;AAE3D,QAAM,OAAO,KAAK,sBAAsB,QAAQ;GAC9C;GACA,cAAc,MAAM;GACpB,QAAQ;GACR;GACA,eAAe,YAAYC,oBAAS,UAAU,gBAAgB;GAC/D,CAAC;AAEF,QAAMC,gCACJC,sCAAoB;GAClB,SAAS;GACT,aAAaC;GACb,SAAS,cAAc,QAAQ,KAAK,OAAO;IAAE,MAAM,EAAE;IAAM,SAAS,EAAE;IAAoC,EAAE;GAC5G;GACA,cAAc,MAAM;GACpB,QAAQ;GACT,CAAC,CACH;AAED,uBAAQ,KAAK,EAAE;;AAGjB,OAAM,OAAO,KAAK,WAAW,2BAA2B,UAAU;AAClE,OAAM,OAAO,KAAK,kBAAkB,QAAQ,OAAO,QAAQ;AAG3D,KAAI,OAAO,OAAO,QAAQ;AACxB,QAAM,OAAO,KAAK,eAAe;EAEjC,IAAI,YAAY,OAAO,OAAO;AAC9B,MAAI,cAAc,QAAQ;GACxB,MAAM,oBAAoB,6CAAuB;AACjD,OAAI,CAAC,kBACH,OAAM,OAAO,KAAK,QAAQ,uEAAuE;QAC5F;AACL,gBAAY;AACZ,UAAM,OAAO,KAAK,QAAQ,qDAAsC,OAAO,UAAU,GAAG;;;AAIxF,MAAI,aAAa,cAAc,UAAU,aAAaC,6BAAY;GAChE,MAAM,kBAAkBA,4BAAW;GACnC,MAAM,aAAaC,kBAAK,QAAQ,OAAO,MAAM,OAAO,OAAO,KAAK;AAEhE,OAAI;IACF,MAAM,qCAAoB,SAAS,CAAC,OAAO,CAAC,OAAO,MAAM,UAAU,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI,CAAC,CAAC,OAAO,MAAM;AAC5G,UAAM,OAAO,KAAK,cAAc;KAC9B,IAAI;KACJ,SAAS,gBAAgB;KACzB,MAAM,gBAAgB,KAAK,WAAW;KACvC,CAAC;AAEF,UAAM,OAAO,OAAO,YAAY,OAAO,EAAE,SAAS,YAAY;AAC5D,SAAI,CAAC,QAAS,OAAM;AAEpB,WAAM,OAAO,KACX,WACA;MAAC,4CAA6B,OAAO,UAAU;MAAI,YAAYL,oBAAS,OAAO,+BAAgB,OAAO,WAAW,KAAK;MAAW;MAAe,CAC7I,OAAO,QAAQ,CACf,KAAK,IAAI,CACb;MACD;YACK,aAAa;IACpB,MAAM,QAAQ,IAAI,MAAM,gBAAgB,aAAa;AACrD,UAAM,QAAQ;AACd,UAAM,OAAO,KAAK,SAAS,MAAM;;;AAIrC,QAAM,OAAO,KAAK,aAAa;;AAIjC,KAAI,OAAO,OAAO,MAAM;AACtB,QAAM,OAAO,KAAK,aAAa;EAG/B,IAAI,SAAS,OAAO,OAAO;AAC3B,MAAI,WAAW,QAAQ;GACrB,MAAM,iBAAiB,0CAAoB;AAC3C,OAAI,CAAC,eACH,OAAM,OAAO,KAAK,QAAQ,gEAAgE;QACrF;AACL,aAAS;AACT,UAAM,OAAO,KAAK,QAAQ,kDAAmC,OAAO,OAAO,GAAG;;;AAKlF,MAAI,UAAU,WAAW,UAAU,UAAUM,0BAAS;GACpD,MAAM,eAAeA,yBAAQ;GAC7B,MAAM,aAAaD,kBAAK,QAAQ,OAAO,MAAM,OAAO,OAAO,KAAK;AAEhE,OAAI;IACF,MAAM,qCAAoB,SAAS,CAAC,OAAO,CAAC,OAAO,MAAM,OAAO,CAAC,OAAO,QAAQ,CAAC,KAAK,IAAI,CAAC,CAAC,OAAO,MAAM;AACzG,UAAM,OAAO,KAAK,cAAc;KAC9B,IAAI;KACJ,SAAS,aAAa;KACtB,MAAM,aAAa,KAAK,WAAW;KACpC,CAAC;AAEF,UAAM,OAAO,OAAO,YAAY,OAAO,EAAE,SAAS,YAAY;AAC5D,SAAI,CAAC,QAAS,OAAM;AAEpB,WAAM,OAAO,KACX,WACA;MAAC,yCAA0B,OAAO,OAAO;MAAI,YAAYL,oBAAS,OAAO,+BAAgB,OAAO,WAAW,KAAK;MAAW;MAAe,CACvI,OAAO,QAAQ,CACf,KAAK,IAAI,CACb;MACD;YACK,aAAa;IACpB,MAAM,QAAQ,IAAI,MAAM,aAAa,aAAa;AAClD,UAAM,QAAQ;AACd,UAAM,OAAO,KAAK,SAAS,MAAM;;;AAIrC,QAAM,OAAO,KAAK,WAAW;;AAG/B,KAAI,OAAO,OAAO;AAChB,QAAM,OAAO,KAAK,cAAc;AAChC,QAAM,aAAa;GAAE,OAAO,OAAO;GAAO;GAAQ,CAAC;AAEnD,QAAM,OAAO,KAAK,YAAY;;CAGhC,MAAM,mBAAmB,cAAc,OAAO,KAAK,QAAQ,WAAW;AAEtE,OAAM,OAAO,KAAK,sBAAsB,QAAQ;EAC9C;EACA,cAAc,MAAM;EACpB,QAAQ;EACR;EACA;EACD,CAAC;AAWF,OAAMC,gCATiBC,sCAAoB;EACzC,SAAS;EACT,aAAaC;EACb,SAAS,cAAc,QAAQ,KAAK,OAAO;GAAE,MAAM,EAAE;GAAM,SAAS,EAAE;GAAoC,EAAE;EAC5G;EACA,cAAc,MAAM;EACpB,QAAQ;EACT,CAAC,CAEiC;;;;;AC1NrC,MAAM,WAAW,OAAO,eAAuB;AAY7C,QAFY,0EAT6B;EACvC,KAAK;GACH,SAAS;GACT,cAAc;GACf;EACD,YAAY;EACZ,gBAAgB;EACjB,CAAC,CAEqB,OAAO,YAAY,EAAE,SAAS,MAAM,CAAC;;AAK9D,eAAsB,eAAe,YAAoB,QAA6C;CACpG,IAAI;CACJ,MAAM,eAAe;EACnB;EACA,IAAI,WAAW;EACf,IAAI,WAAW;EACf,IAAI,WAAW;EACf,IAAI,WAAW;EAEf,IAAI,WAAW;EACf,IAAI,WAAW;EACf,IAAI,WAAW;EACf,IAAI,WAAW;EAEf,GAAG,WAAW;EACd,GAAG,WAAW;EACd,GAAG,WAAW;EACd,GAAG,WAAW;EACf;CACD,MAAM,wCAAuB,YAAY;EACvC,OAAO;EACP,cAAc;GACZ,GAAG,aAAa,KAAK,gBAAgB;AACnC,WAAO,WAAW;KAClB;GACF,GAAG,aAAa,KAAK,gBAAgB;AACnC,WAAO,WAAW;KAClB;GACF,GAAG;GACJ;EACD,SAAS,EACP,OAAO,UACR;EACF,CAAC;AAEF,KAAI;AACF,WAAS,SAAW,MAAM,SAAS,KAAK,OAAO,GAA4B,MAAM,SAAS,QAAQ;UAC3F,OAAO;AACd,QAAM,IAAI,MAAM,yBAAyB,EAAE,OAAO,OAAO,CAAC;;AAG5D,KAAI,QAAQ,WAAW,CAAC,UAAU,CAAC,OAAO,OACxC,OAAM,IAAI,MAAM,mGAAmG;AAGrH,QAAO;;;;;ACpET,eAAsB,aAAa,MAAgB,IAAsD;CACvG,MAAM,EAAE,UAAU,MAAM,OAAO;AAQ/B,CAJgB,MAAM,MAAM;EAC1B,wBAAwB;EACxB,SAJc;EAKf,CAAC,CACM,GAAG,OAAO,OAAO,MAAM,SAAS;AACtC,UAAQ,6BAAc,mCAAoB,QAAQ,oBAAoB,KAAK,GAAG,OAAO,CAAC,CAAC;AAEvF,MAAI;AACF,SAAM,GAAG,KAAK;WACP,IAAI;AACX,WAAQ,6BAAc,OAAO,iBAAiB,CAAC;;GAEjD;;;;;AC0CJ,MAAM,mCAAwB;CAC5B,MAAM;EACJ,MAAM;EACN,aAAa;EACd;CACD,MApDW;EACX,QAAQ;GACN,MAAM;GACN,aAAa;GACb,OAAO;GACR;EACD,UAAU;GACR,MAAM;GACN,aAAa;GACb,OAAO;GACP,SAAS;GACT,WAAW;GACZ;EACD,OAAO;GACL,MAAM;GACN,aAAa;GACb,OAAO;GACP,SAAS;GACV;EACD,OAAO;GACL,MAAM;GACN,aAAa;GACb,OAAO;GACP,SAAS;GACV;EACD,SAAS;GACP,MAAM;GACN,aAAa;GACb,OAAO;GACP,SAAS;GACV;EACD,QAAQ;GACN,MAAM;GACN,aAAa;GACb,OAAO;GACP,SAAS;GACV;EACD,MAAM;GACJ,MAAM;GACN,aAAa;GACb,OAAO;GACP,SAAS;GACV;EACF;CAUC,MAAM,IAAI,gBAAgB;EACxB,MAAM,EAAE,SAAS;EACjB,MAAM,QAAQ,KAAK,EAAE;EACrB,MAAM,SAAS,IAAII,oCAA+B;EAClD,MAAM,iBAAiB,IAAIC,2BAAgB;AAE3C,MAAI,KAAK,KACP,6BAAiB,QAAQ;AAG3B,MAAI,KAAK,MACP,MAAK,WAAW;AAGlB,MAAI,KAAK,QACP,MAAK,WAAW;AAGlB,MAAI,KAAK,OACP,MAAK,WAAW;EAGlB,MAAM,WAAWC,oBAAS,KAAK,aAAsC;AAErE,QAAM,YAAY,QAAQ,EAAE,UAAU,CAAC;AAEvC,8CAAsB,YAAY;AAChC,OAAI;IAGF,MAAM,iBADQ,OADF,MAAM,MAAM,8CAA8C,EAC9C,MAAM,EACH;AAE3B,QAAI,iBAAiBC,0BAAU,cAC7B,OAAM,OAAO,KAAK,eAAeA,yBAAS,cAAc;WAEpD;IAGR;AAEF,MAAI;GACF,MAAM,SAAS,MAAM,eAAe,QAAQ,KAAK,OAAO;GACxD,MAAM,UAAU,uCAAiB,OAAO,QAAQ,KAAmB;AAEnE,SAAM,OAAO,KAAK,eAAe;AAEjC,SAAM,OAAO,KAAK,QAAQ,iBAAiBC,kBAAK,SAASC,aAAQ,KAAK,EAAE,OAAO,SAAS,CAAC;AAEzF,SAAM,OAAO,KAAK,WAAW,8BAA8BD,kBAAK,SAASC,aAAQ,KAAK,EAAE,OAAO,SAAS,CAAC;AACzG,SAAM,OAAO,KAAK,cAAc,QAAQ;AAExC,SAAM,OAAO,KAAK,mBAAmBF,wBAAQ;GAE7C,MAAM,WAAW,QAAQ,KAAK,WAAW;AACvC,WAAO,YAAY;AACjB,qCAAgB,OAAO,IAAI,KAAK,OAAO;AACrC,YAAM,aAAa,CAAC,SAAS,OAAO,MAAM,KAAK,EAAE,OAAO,UAAU;AAEhE,cAAO,WAAW;AAElB,aAAM,SAAS;QACb;QACA;QACA;QACA;QACD,CAAC;AAEF,sBAAM,IAAI,8BAAe,UAAU,2BAA2B,MAAM,KAAK,QAAQ,GAAG,CAAC;QACrF;AAEF;;AAGF,WAAM,SAAS;MACb;MACA;MACA;MACA;MACD,CAAC;;KAEJ;AAEF,SAAM,eAAe,IAAI,OAAO,SAAS;AAEzC,SAAM,OAAO,KAAK,gBAAgB;WAC3B,OAAO;AACd,SAAM,OAAO,KAAK,SAAS,MAAe;AAC1C,gBAAQ,KAAK,EAAE;;;CAGpB,CAAC"}
package/dist/index.cjs CHANGED
@@ -1,6 +1,6 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
2
  const require_chunk = require('./chunk-CNbaEX1y.cjs');
3
- const require_package = require('./package-oo3QhWS5.cjs');
3
+ const require_package = require('./package-BqKkzL1A.cjs');
4
4
  let citty = require("citty");
5
5
 
6
6
  //#region src/index.ts
@@ -27,16 +27,16 @@ const main = (0, citty.defineCommand)({
27
27
  "agent",
28
28
  "init"
29
29
  ].includes(rawArgs[0])) {
30
- await (0, citty.runCommand)(await Promise.resolve().then(() => require("./generate-C8gS4Z2F.cjs")).then((r) => r.default), { rawArgs });
30
+ await (0, citty.runCommand)(await Promise.resolve().then(() => require("./generate-G4sRCtYd.cjs")).then((r) => r.default), { rawArgs });
31
31
  process.exit(0);
32
32
  }
33
33
  },
34
34
  subCommands: {
35
- generate: () => Promise.resolve().then(() => require("./generate-C8gS4Z2F.cjs")).then((r) => r.default),
36
- validate: () => Promise.resolve().then(() => require("./validate-BgYhe_55.cjs")).then((r) => r.default),
37
- mcp: () => Promise.resolve().then(() => require("./mcp-97TXkJVX.cjs")).then((r) => r.default),
38
- agent: () => Promise.resolve().then(() => require("./agent-NAhMf2ot.cjs")).then((r) => r.default),
39
- init: () => Promise.resolve().then(() => require("./init-BDWQO7I8.cjs")).then((r) => r.default)
35
+ generate: () => Promise.resolve().then(() => require("./generate-G4sRCtYd.cjs")).then((r) => r.default),
36
+ validate: () => Promise.resolve().then(() => require("./validate-BbVY6zQM.cjs")).then((r) => r.default),
37
+ mcp: () => Promise.resolve().then(() => require("./mcp-DCjAEKzU.cjs")).then((r) => r.default),
38
+ agent: () => Promise.resolve().then(() => require("./agent-kU5gLqqn.cjs")).then((r) => r.default),
39
+ init: () => Promise.resolve().then(() => require("./init-XsLQVNk3.cjs")).then((r) => r.default)
40
40
  }
41
41
  });
42
42
  async function run(_argv) {
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { t as __name } from "./chunk-DKWOrOAv.js";
2
- import { t as version } from "./package-veMf5zNr.js";
2
+ import { t as version } from "./package-BYVzWUJV.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-CnKaIwc7.js").then((r) => r.default), { rawArgs });
29
+ await runCommand(await import("./generate-DvoKuzJW.js").then((r) => r.default), { rawArgs });
30
30
  process.exit(0);
31
31
  }
32
32
  },
33
33
  subCommands: {
34
- generate: () => import("./generate-CnKaIwc7.js").then((r) => r.default),
35
- validate: () => import("./validate-DOeZKiGx.js").then((r) => r.default),
36
- mcp: () => import("./mcp-Jboea6xH.js").then((r) => r.default),
37
- agent: () => import("./agent-BzD6f3mV.js").then((r) => r.default),
38
- init: () => import("./init-B5qnw1XS.js").then((r) => r.default)
34
+ generate: () => import("./generate-DvoKuzJW.js").then((r) => r.default),
35
+ validate: () => import("./validate-zO3bvm66.js").then((r) => r.default),
36
+ mcp: () => import("./mcp-CD0ZKRHG.js").then((r) => r.default),
37
+ agent: () => import("./agent-CGYnHRU4.js").then((r) => r.default),
38
+ init: () => import("./init-Cp7PS6R5.js").then((r) => r.default)
39
39
  }
40
40
  });
41
41
  async function run(_argv) {
@@ -1,48 +1,15 @@
1
1
  import { t as __name } from "./chunk-DKWOrOAv.js";
2
- import { t as version } from "./package-veMf5zNr.js";
2
+ import { t as version } from "./package-BYVzWUJV.js";
3
3
  import { defineCommand } from "citty";
4
4
  import { spawn } from "node:child_process";
5
5
  import path from "node:path";
6
6
  import process$1 from "node:process";
7
7
  import { styleText } from "node:util";
8
8
  import * as clack from "@clack/prompts";
9
+ import { detectPackageManager } from "@kubb/core";
9
10
  import fs from "node:fs";
10
11
 
11
12
  //#region src/utils/packageManager.ts
12
- const packageManagers = {
13
- pnpm: {
14
- name: "pnpm",
15
- lockFile: "pnpm-lock.yaml",
16
- installCommand: ["add", "-D"]
17
- },
18
- yarn: {
19
- name: "yarn",
20
- lockFile: "yarn.lock",
21
- installCommand: ["add", "-D"]
22
- },
23
- bun: {
24
- name: "bun",
25
- lockFile: "bun.lockb",
26
- installCommand: ["add", "-d"]
27
- },
28
- npm: {
29
- name: "npm",
30
- lockFile: "package-lock.json",
31
- installCommand: ["install", "--save-dev"]
32
- }
33
- };
34
- function detectPackageManager(cwd = process.cwd()) {
35
- const packageJsonPath = path.join(cwd, "package.json");
36
- if (fs.existsSync(packageJsonPath)) try {
37
- const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, "utf-8"));
38
- if (packageJson.packageManager) {
39
- const [name] = packageJson.packageManager.split("@");
40
- if (name in packageManagers) return packageManagers[name];
41
- }
42
- } catch {}
43
- for (const pm of Object.values(packageManagers)) if (fs.existsSync(path.join(cwd, pm.lockFile))) return pm;
44
- return packageManagers.npm;
45
- }
46
13
  function hasPackageJson(cwd = process.cwd()) {
47
14
  return fs.existsSync(path.join(cwd, "package.json"));
48
15
  }
@@ -336,4 +303,4 @@ const command = defineCommand({
336
303
 
337
304
  //#endregion
338
305
  export { command as default };
339
- //# sourceMappingURL=init-B5qnw1XS.js.map
306
+ //# sourceMappingURL=init-Cp7PS6R5.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init-Cp7PS6R5.js","names":["process"],"sources":["../src/utils/packageManager.ts","../src/commands/init.ts"],"sourcesContent":["import { spawn } from 'node:child_process'\nimport fs from 'node:fs'\nimport path from 'node:path'\nimport type { PackageManagerInfo, PackageManagerName } from '@kubb/core'\n\nexport function hasPackageJson(cwd: string = process.cwd()): boolean {\n return fs.existsSync(path.join(cwd, 'package.json'))\n}\n\nexport async function initPackageJson(cwd: string, packageManager: PackageManagerInfo): Promise<void> {\n const commands: Record<PackageManagerName, string[]> = {\n npm: ['init', '-y'],\n pnpm: ['init'],\n yarn: ['init', '-y'],\n bun: ['init', '-y'],\n }\n\n spawn(packageManager.name, commands[packageManager.name], { stdio: 'inherit', cwd })\n}\n\nexport async function installPackages(packages: string[], packageManager: PackageManagerInfo, cwd: string = process.cwd()): Promise<void> {\n spawn(packageManager.name, [...packageManager.installCommand, ...packages], { stdio: 'inherit', cwd })\n}\n","import fs from 'node:fs'\nimport path from 'node:path'\nimport process from 'node:process'\nimport { styleText } from 'node:util'\nimport * as clack from '@clack/prompts'\nimport { detectPackageManager, type PackageManagerInfo } from '@kubb/core'\nimport { defineCommand } from 'citty'\nimport { version } from '../../package.json'\nimport { hasPackageJson, initPackageJson, installPackages } from '../utils/packageManager.ts'\n\ntype PluginOption = {\n value: string\n label: string\n hint?: string\n packageName: string\n importName: string\n category: 'core' | 'typescript' | 'query' | 'validation' | 'testing' | 'mocking' | 'docs'\n}\n\nconst plugins: PluginOption[] = [\n {\n value: 'plugin-oas',\n label: 'OpenAPI Parser',\n hint: 'Required',\n packageName: '@kubb/plugin-oas',\n importName: 'pluginOas',\n category: 'core',\n },\n {\n value: 'plugin-ts',\n label: 'TypeScript',\n hint: 'Recommended',\n packageName: '@kubb/plugin-ts',\n importName: 'pluginTs',\n category: 'typescript',\n },\n {\n value: 'plugin-client',\n label: 'Client (Fetch/Axios)',\n packageName: '@kubb/plugin-client',\n importName: 'pluginClient',\n category: 'typescript',\n },\n {\n value: 'plugin-react-query',\n label: 'React Query / TanStack Query',\n packageName: '@kubb/plugin-react-query',\n importName: 'pluginReactQuery',\n category: 'query',\n },\n {\n value: 'plugin-solid-query',\n label: 'Solid Query',\n packageName: '@kubb/plugin-solid-query',\n importName: 'pluginSolidQuery',\n category: 'query',\n },\n {\n value: 'plugin-svelte-query',\n label: 'Svelte Query',\n packageName: '@kubb/plugin-svelte-query',\n importName: 'pluginSvelteQuery',\n category: 'query',\n },\n {\n value: 'plugin-vue-query',\n label: 'Vue Query',\n packageName: '@kubb/plugin-vue-query',\n importName: 'pluginVueQuery',\n category: 'query',\n },\n {\n value: 'plugin-swr',\n label: 'SWR',\n packageName: '@kubb/plugin-swr',\n importName: 'pluginSwr',\n category: 'query',\n },\n {\n value: 'plugin-zod',\n label: 'Zod Schemas',\n packageName: '@kubb/plugin-zod',\n importName: 'pluginZod',\n category: 'validation',\n },\n {\n value: 'plugin-faker',\n label: 'Faker.js Mocks',\n packageName: '@kubb/plugin-faker',\n importName: 'pluginFaker',\n category: 'mocking',\n },\n {\n value: 'plugin-msw',\n label: 'MSW Handlers',\n packageName: '@kubb/plugin-msw',\n importName: 'pluginMsw',\n category: 'mocking',\n },\n {\n value: 'plugin-cypress',\n label: 'Cypress Tests',\n packageName: '@kubb/plugin-cypress',\n importName: 'pluginCypress',\n category: 'testing',\n },\n {\n value: 'plugin-redoc',\n label: 'ReDoc Documentation',\n packageName: '@kubb/plugin-redoc',\n importName: 'pluginRedoc',\n category: 'docs',\n },\n]\n\nfunction generateConfigFile(selectedPlugins: PluginOption[], inputPath: string, outputPath: string): string {\n const imports = selectedPlugins.map((plugin) => `import { ${plugin.importName} } from '${plugin.packageName}'`).join('\\n')\n\n const pluginConfigs = selectedPlugins\n .map((plugin) => {\n if (plugin.value === 'plugin-oas') {\n return ' pluginOas(),'\n }\n if (plugin.value === 'plugin-ts') {\n return ` pluginTs({\\n output: {\\n path: 'models',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-client') {\n return ` pluginClient({\\n output: {\\n path: 'clients',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-react-query') {\n return ` pluginReactQuery({\\n output: {\\n path: 'hooks',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-zod') {\n return ` pluginZod({\\n output: {\\n path: 'zod',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-faker') {\n return ` pluginFaker({\\n output: {\\n path: 'mocks',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-msw') {\n return ` pluginMsw({\\n output: {\\n path: 'msw',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-swr') {\n return ` pluginSwr({\\n output: {\\n path: 'hooks',\\n },\\n }),`\n }\n // Default config for other plugins\n return ` ${plugin.importName}(),`\n })\n .join('\\n')\n\n return `import { defineConfig } from '@kubb/core'\n${imports}\n\nexport default defineConfig({\n root: '.',\n input: {\n path: '${inputPath}',\n },\n output: {\n path: '${outputPath}',\n clean: true,\n },\n plugins: [\n${pluginConfigs}\n ],\n})\n`\n}\n\nconst DEFAULT_INPUT_PATH = './openapi.yaml'\nconst DEFAULT_OUTPUT_PATH = './src/gen'\nconst DEFAULT_PLUGINS = ['plugin-oas', 'plugin-ts']\n\nconst command = defineCommand({\n meta: {\n name: 'init',\n description: 'Initialize a new Kubb project with interactive setup',\n },\n args: {\n yes: {\n type: 'boolean',\n alias: 'y',\n description: 'Skip prompts and use default options',\n default: false,\n },\n },\n async run({ args }) {\n const cwd = process.cwd()\n const yes = args.yes\n\n clack.intro(styleText('bgCyan', styleText('black', ' Kubb Init ')))\n\n try {\n // Check/create package.json\n let packageManager: PackageManagerInfo\n if (!hasPackageJson(cwd)) {\n if (!yes) {\n const shouldInit = await clack.confirm({\n message: 'No package.json found. Would you like to create one?',\n initialValue: true,\n })\n\n if (clack.isCancel(shouldInit) || !shouldInit) {\n clack.cancel('Operation cancelled.')\n process.exit(0)\n }\n }\n\n // Detect package manager before initializing\n packageManager = detectPackageManager(cwd)\n\n const spinner = clack.spinner()\n spinner.start(`Initializing package.json with ${packageManager.name}`)\n\n await initPackageJson(cwd, packageManager)\n\n spinner.stop(`Created package.json with ${packageManager.name}`)\n } else {\n packageManager = detectPackageManager(cwd)\n clack.log.info(`Detected package manager: ${styleText('cyan', packageManager.name)}`)\n }\n\n // Prompt for OpenAPI spec path\n let inputPath: string\n if (yes) {\n inputPath = DEFAULT_INPUT_PATH\n clack.log.info(`Using input path: ${styleText('cyan', inputPath)}`)\n } else {\n const inputPathResult = await clack.text({\n message: 'Where is your OpenAPI specification located?',\n placeholder: DEFAULT_INPUT_PATH,\n defaultValue: DEFAULT_INPUT_PATH,\n validate: (value) => {\n if (!value) return 'Input path is required'\n },\n })\n\n if (clack.isCancel(inputPathResult)) {\n clack.cancel('Operation cancelled.')\n process.exit(0)\n }\n inputPath = inputPathResult as string\n }\n\n // Prompt for output directory\n let outputPath: string\n if (yes) {\n outputPath = DEFAULT_OUTPUT_PATH\n clack.log.info(`Using output path: ${styleText('cyan', outputPath)}`)\n } else {\n const outputPathResult = await clack.text({\n message: 'Where should the generated files be output?',\n placeholder: DEFAULT_OUTPUT_PATH,\n defaultValue: DEFAULT_OUTPUT_PATH,\n validate: (value) => {\n if (!value) return 'Output path is required'\n },\n })\n\n if (clack.isCancel(outputPathResult)) {\n clack.cancel('Operation cancelled.')\n process.exit(0)\n }\n outputPath = outputPathResult as string\n }\n\n // Plugin selection\n let selectedPlugins: PluginOption[]\n if (yes) {\n selectedPlugins = plugins.filter((plugin) => DEFAULT_PLUGINS.includes(plugin.value))\n clack.log.info(`Using plugins: ${styleText('cyan', selectedPlugins.map((p) => p.label).join(', '))}`)\n } else {\n const selectedPluginValues = await clack.multiselect({\n message: 'Select plugins to use:',\n options: plugins.map((plugin) => ({\n value: plugin.value,\n label: plugin.label,\n hint: plugin.hint,\n })),\n initialValues: DEFAULT_PLUGINS,\n required: true,\n })\n\n if (clack.isCancel(selectedPluginValues)) {\n clack.cancel('Operation cancelled.')\n process.exit(0)\n }\n\n selectedPlugins = plugins.filter((plugin) => (selectedPluginValues as string[]).includes(plugin.value))\n }\n\n // Ensure plugin-oas is always included\n if (!selectedPlugins.find((p) => p.value === 'plugin-oas')) {\n selectedPlugins.unshift(plugins.find((p) => p.value === 'plugin-oas')!)\n }\n\n // Install packages\n const packagesToInstall = ['@kubb/core', '@kubb/cli', '@kubb/agent', ...selectedPlugins.map((p) => p.packageName)]\n\n const spinner = clack.spinner()\n spinner.start(`Installing ${packagesToInstall.length} packages with ${packageManager.name}`)\n\n try {\n await installPackages(packagesToInstall, packageManager, cwd)\n spinner.stop(`Installed ${packagesToInstall.length} packages`)\n } catch (error) {\n spinner.stop('Installation failed')\n throw error\n }\n\n // Generate config file\n const configSpinner = clack.spinner()\n configSpinner.start('Creating kubb.config.ts')\n\n const configContent = generateConfigFile(selectedPlugins, inputPath, outputPath)\n const configPath = path.join(cwd, 'kubb.config.ts')\n\n // Check if config already exists\n if (fs.existsSync(configPath)) {\n configSpinner.stop('kubb.config.ts already exists')\n\n if (!yes) {\n const shouldOverwrite = await clack.confirm({\n message: 'kubb.config.ts already exists. Overwrite?',\n initialValue: false,\n })\n\n if (clack.isCancel(shouldOverwrite) || !shouldOverwrite) {\n clack.cancel('Keeping existing configuration. Packages have been installed.')\n process.exit(0)\n }\n }\n\n configSpinner.start('Overwriting kubb.config.ts')\n }\n\n fs.writeFileSync(configPath, configContent, 'utf-8')\n\n configSpinner.stop('Created kubb.config.ts')\n\n // Success message\n clack.outro(\n styleText('green', '✓ All set!') +\n '\\n\\n' +\n styleText('dim', 'Next steps:') +\n '\\n' +\n styleText('cyan', ` 1. Make sure your OpenAPI spec is at: ${inputPath}`) +\n '\\n' +\n styleText('cyan', ' 2. Generate code with: npx kubb generate') +\n '\\n' +\n styleText('cyan', ' Or start a stream server with: npx kubb start') +\n '\\n' +\n styleText('cyan', ` 3. Find generated files in: ${outputPath}`) +\n '\\n\\n' +\n styleText('dim', `Using ${packageManager.name} • Kubb v${version}`),\n )\n } catch (error) {\n clack.log.error(styleText('red', 'An error occurred during initialization'))\n if (error instanceof Error) {\n clack.log.error(error.message)\n }\n process.exit(1)\n }\n },\n})\n\nexport default command\n"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  const require_chunk = require('./chunk-CNbaEX1y.cjs');
2
- const require_package = require('./package-oo3QhWS5.cjs');
2
+ const require_package = require('./package-BqKkzL1A.cjs');
3
3
  let citty = require("citty");
4
4
  let node_child_process = require("node:child_process");
5
5
  let node_path = require("node:path");
@@ -9,44 +9,11 @@ node_process = require_chunk.__toESM(node_process);
9
9
  let node_util = require("node:util");
10
10
  let _clack_prompts = require("@clack/prompts");
11
11
  _clack_prompts = require_chunk.__toESM(_clack_prompts);
12
+ let _kubb_core = require("@kubb/core");
12
13
  let node_fs = require("node:fs");
13
14
  node_fs = require_chunk.__toESM(node_fs);
14
15
 
15
16
  //#region src/utils/packageManager.ts
16
- const packageManagers = {
17
- pnpm: {
18
- name: "pnpm",
19
- lockFile: "pnpm-lock.yaml",
20
- installCommand: ["add", "-D"]
21
- },
22
- yarn: {
23
- name: "yarn",
24
- lockFile: "yarn.lock",
25
- installCommand: ["add", "-D"]
26
- },
27
- bun: {
28
- name: "bun",
29
- lockFile: "bun.lockb",
30
- installCommand: ["add", "-d"]
31
- },
32
- npm: {
33
- name: "npm",
34
- lockFile: "package-lock.json",
35
- installCommand: ["install", "--save-dev"]
36
- }
37
- };
38
- function detectPackageManager(cwd = process.cwd()) {
39
- const packageJsonPath = node_path.default.join(cwd, "package.json");
40
- if (node_fs.default.existsSync(packageJsonPath)) try {
41
- const packageJson = JSON.parse(node_fs.default.readFileSync(packageJsonPath, "utf-8"));
42
- if (packageJson.packageManager) {
43
- const [name] = packageJson.packageManager.split("@");
44
- if (name in packageManagers) return packageManagers[name];
45
- }
46
- } catch {}
47
- for (const pm of Object.values(packageManagers)) if (node_fs.default.existsSync(node_path.default.join(cwd, pm.lockFile))) return pm;
48
- return packageManagers.npm;
49
- }
50
17
  function hasPackageJson(cwd = process.cwd()) {
51
18
  return node_fs.default.existsSync(node_path.default.join(cwd, "package.json"));
52
19
  }
@@ -225,13 +192,13 @@ const command = (0, citty.defineCommand)({
225
192
  node_process.default.exit(0);
226
193
  }
227
194
  }
228
- packageManager = detectPackageManager(cwd);
195
+ packageManager = (0, _kubb_core.detectPackageManager)(cwd);
229
196
  const spinner = _clack_prompts.spinner();
230
197
  spinner.start(`Initializing package.json with ${packageManager.name}`);
231
198
  await initPackageJson(cwd, packageManager);
232
199
  spinner.stop(`Created package.json with ${packageManager.name}`);
233
200
  } else {
234
- packageManager = detectPackageManager(cwd);
201
+ packageManager = (0, _kubb_core.detectPackageManager)(cwd);
235
202
  _clack_prompts.log.info(`Detected package manager: ${(0, node_util.styleText)("cyan", packageManager.name)}`);
236
203
  }
237
204
  let inputPath;
@@ -340,4 +307,4 @@ const command = (0, citty.defineCommand)({
340
307
 
341
308
  //#endregion
342
309
  exports.default = command;
343
- //# sourceMappingURL=init-BDWQO7I8.cjs.map
310
+ //# sourceMappingURL=init-XsLQVNk3.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init-XsLQVNk3.cjs","names":["fs","path","process","clack","path","fs","version"],"sources":["../src/utils/packageManager.ts","../src/commands/init.ts"],"sourcesContent":["import { spawn } from 'node:child_process'\nimport fs from 'node:fs'\nimport path from 'node:path'\nimport type { PackageManagerInfo, PackageManagerName } from '@kubb/core'\n\nexport function hasPackageJson(cwd: string = process.cwd()): boolean {\n return fs.existsSync(path.join(cwd, 'package.json'))\n}\n\nexport async function initPackageJson(cwd: string, packageManager: PackageManagerInfo): Promise<void> {\n const commands: Record<PackageManagerName, string[]> = {\n npm: ['init', '-y'],\n pnpm: ['init'],\n yarn: ['init', '-y'],\n bun: ['init', '-y'],\n }\n\n spawn(packageManager.name, commands[packageManager.name], { stdio: 'inherit', cwd })\n}\n\nexport async function installPackages(packages: string[], packageManager: PackageManagerInfo, cwd: string = process.cwd()): Promise<void> {\n spawn(packageManager.name, [...packageManager.installCommand, ...packages], { stdio: 'inherit', cwd })\n}\n","import fs from 'node:fs'\nimport path from 'node:path'\nimport process from 'node:process'\nimport { styleText } from 'node:util'\nimport * as clack from '@clack/prompts'\nimport { detectPackageManager, type PackageManagerInfo } from '@kubb/core'\nimport { defineCommand } from 'citty'\nimport { version } from '../../package.json'\nimport { hasPackageJson, initPackageJson, installPackages } from '../utils/packageManager.ts'\n\ntype PluginOption = {\n value: string\n label: string\n hint?: string\n packageName: string\n importName: string\n category: 'core' | 'typescript' | 'query' | 'validation' | 'testing' | 'mocking' | 'docs'\n}\n\nconst plugins: PluginOption[] = [\n {\n value: 'plugin-oas',\n label: 'OpenAPI Parser',\n hint: 'Required',\n packageName: '@kubb/plugin-oas',\n importName: 'pluginOas',\n category: 'core',\n },\n {\n value: 'plugin-ts',\n label: 'TypeScript',\n hint: 'Recommended',\n packageName: '@kubb/plugin-ts',\n importName: 'pluginTs',\n category: 'typescript',\n },\n {\n value: 'plugin-client',\n label: 'Client (Fetch/Axios)',\n packageName: '@kubb/plugin-client',\n importName: 'pluginClient',\n category: 'typescript',\n },\n {\n value: 'plugin-react-query',\n label: 'React Query / TanStack Query',\n packageName: '@kubb/plugin-react-query',\n importName: 'pluginReactQuery',\n category: 'query',\n },\n {\n value: 'plugin-solid-query',\n label: 'Solid Query',\n packageName: '@kubb/plugin-solid-query',\n importName: 'pluginSolidQuery',\n category: 'query',\n },\n {\n value: 'plugin-svelte-query',\n label: 'Svelte Query',\n packageName: '@kubb/plugin-svelte-query',\n importName: 'pluginSvelteQuery',\n category: 'query',\n },\n {\n value: 'plugin-vue-query',\n label: 'Vue Query',\n packageName: '@kubb/plugin-vue-query',\n importName: 'pluginVueQuery',\n category: 'query',\n },\n {\n value: 'plugin-swr',\n label: 'SWR',\n packageName: '@kubb/plugin-swr',\n importName: 'pluginSwr',\n category: 'query',\n },\n {\n value: 'plugin-zod',\n label: 'Zod Schemas',\n packageName: '@kubb/plugin-zod',\n importName: 'pluginZod',\n category: 'validation',\n },\n {\n value: 'plugin-faker',\n label: 'Faker.js Mocks',\n packageName: '@kubb/plugin-faker',\n importName: 'pluginFaker',\n category: 'mocking',\n },\n {\n value: 'plugin-msw',\n label: 'MSW Handlers',\n packageName: '@kubb/plugin-msw',\n importName: 'pluginMsw',\n category: 'mocking',\n },\n {\n value: 'plugin-cypress',\n label: 'Cypress Tests',\n packageName: '@kubb/plugin-cypress',\n importName: 'pluginCypress',\n category: 'testing',\n },\n {\n value: 'plugin-redoc',\n label: 'ReDoc Documentation',\n packageName: '@kubb/plugin-redoc',\n importName: 'pluginRedoc',\n category: 'docs',\n },\n]\n\nfunction generateConfigFile(selectedPlugins: PluginOption[], inputPath: string, outputPath: string): string {\n const imports = selectedPlugins.map((plugin) => `import { ${plugin.importName} } from '${plugin.packageName}'`).join('\\n')\n\n const pluginConfigs = selectedPlugins\n .map((plugin) => {\n if (plugin.value === 'plugin-oas') {\n return ' pluginOas(),'\n }\n if (plugin.value === 'plugin-ts') {\n return ` pluginTs({\\n output: {\\n path: 'models',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-client') {\n return ` pluginClient({\\n output: {\\n path: 'clients',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-react-query') {\n return ` pluginReactQuery({\\n output: {\\n path: 'hooks',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-zod') {\n return ` pluginZod({\\n output: {\\n path: 'zod',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-faker') {\n return ` pluginFaker({\\n output: {\\n path: 'mocks',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-msw') {\n return ` pluginMsw({\\n output: {\\n path: 'msw',\\n },\\n }),`\n }\n if (plugin.value === 'plugin-swr') {\n return ` pluginSwr({\\n output: {\\n path: 'hooks',\\n },\\n }),`\n }\n // Default config for other plugins\n return ` ${plugin.importName}(),`\n })\n .join('\\n')\n\n return `import { defineConfig } from '@kubb/core'\n${imports}\n\nexport default defineConfig({\n root: '.',\n input: {\n path: '${inputPath}',\n },\n output: {\n path: '${outputPath}',\n clean: true,\n },\n plugins: [\n${pluginConfigs}\n ],\n})\n`\n}\n\nconst DEFAULT_INPUT_PATH = './openapi.yaml'\nconst DEFAULT_OUTPUT_PATH = './src/gen'\nconst DEFAULT_PLUGINS = ['plugin-oas', 'plugin-ts']\n\nconst command = defineCommand({\n meta: {\n name: 'init',\n description: 'Initialize a new Kubb project with interactive setup',\n },\n args: {\n yes: {\n type: 'boolean',\n alias: 'y',\n description: 'Skip prompts and use default options',\n default: false,\n },\n },\n async run({ args }) {\n const cwd = process.cwd()\n const yes = args.yes\n\n clack.intro(styleText('bgCyan', styleText('black', ' Kubb Init ')))\n\n try {\n // Check/create package.json\n let packageManager: PackageManagerInfo\n if (!hasPackageJson(cwd)) {\n if (!yes) {\n const shouldInit = await clack.confirm({\n message: 'No package.json found. Would you like to create one?',\n initialValue: true,\n })\n\n if (clack.isCancel(shouldInit) || !shouldInit) {\n clack.cancel('Operation cancelled.')\n process.exit(0)\n }\n }\n\n // Detect package manager before initializing\n packageManager = detectPackageManager(cwd)\n\n const spinner = clack.spinner()\n spinner.start(`Initializing package.json with ${packageManager.name}`)\n\n await initPackageJson(cwd, packageManager)\n\n spinner.stop(`Created package.json with ${packageManager.name}`)\n } else {\n packageManager = detectPackageManager(cwd)\n clack.log.info(`Detected package manager: ${styleText('cyan', packageManager.name)}`)\n }\n\n // Prompt for OpenAPI spec path\n let inputPath: string\n if (yes) {\n inputPath = DEFAULT_INPUT_PATH\n clack.log.info(`Using input path: ${styleText('cyan', inputPath)}`)\n } else {\n const inputPathResult = await clack.text({\n message: 'Where is your OpenAPI specification located?',\n placeholder: DEFAULT_INPUT_PATH,\n defaultValue: DEFAULT_INPUT_PATH,\n validate: (value) => {\n if (!value) return 'Input path is required'\n },\n })\n\n if (clack.isCancel(inputPathResult)) {\n clack.cancel('Operation cancelled.')\n process.exit(0)\n }\n inputPath = inputPathResult as string\n }\n\n // Prompt for output directory\n let outputPath: string\n if (yes) {\n outputPath = DEFAULT_OUTPUT_PATH\n clack.log.info(`Using output path: ${styleText('cyan', outputPath)}`)\n } else {\n const outputPathResult = await clack.text({\n message: 'Where should the generated files be output?',\n placeholder: DEFAULT_OUTPUT_PATH,\n defaultValue: DEFAULT_OUTPUT_PATH,\n validate: (value) => {\n if (!value) return 'Output path is required'\n },\n })\n\n if (clack.isCancel(outputPathResult)) {\n clack.cancel('Operation cancelled.')\n process.exit(0)\n }\n outputPath = outputPathResult as string\n }\n\n // Plugin selection\n let selectedPlugins: PluginOption[]\n if (yes) {\n selectedPlugins = plugins.filter((plugin) => DEFAULT_PLUGINS.includes(plugin.value))\n clack.log.info(`Using plugins: ${styleText('cyan', selectedPlugins.map((p) => p.label).join(', '))}`)\n } else {\n const selectedPluginValues = await clack.multiselect({\n message: 'Select plugins to use:',\n options: plugins.map((plugin) => ({\n value: plugin.value,\n label: plugin.label,\n hint: plugin.hint,\n })),\n initialValues: DEFAULT_PLUGINS,\n required: true,\n })\n\n if (clack.isCancel(selectedPluginValues)) {\n clack.cancel('Operation cancelled.')\n process.exit(0)\n }\n\n selectedPlugins = plugins.filter((plugin) => (selectedPluginValues as string[]).includes(plugin.value))\n }\n\n // Ensure plugin-oas is always included\n if (!selectedPlugins.find((p) => p.value === 'plugin-oas')) {\n selectedPlugins.unshift(plugins.find((p) => p.value === 'plugin-oas')!)\n }\n\n // Install packages\n const packagesToInstall = ['@kubb/core', '@kubb/cli', '@kubb/agent', ...selectedPlugins.map((p) => p.packageName)]\n\n const spinner = clack.spinner()\n spinner.start(`Installing ${packagesToInstall.length} packages with ${packageManager.name}`)\n\n try {\n await installPackages(packagesToInstall, packageManager, cwd)\n spinner.stop(`Installed ${packagesToInstall.length} packages`)\n } catch (error) {\n spinner.stop('Installation failed')\n throw error\n }\n\n // Generate config file\n const configSpinner = clack.spinner()\n configSpinner.start('Creating kubb.config.ts')\n\n const configContent = generateConfigFile(selectedPlugins, inputPath, outputPath)\n const configPath = path.join(cwd, 'kubb.config.ts')\n\n // Check if config already exists\n if (fs.existsSync(configPath)) {\n configSpinner.stop('kubb.config.ts already exists')\n\n if (!yes) {\n const shouldOverwrite = await clack.confirm({\n message: 'kubb.config.ts already exists. Overwrite?',\n initialValue: false,\n })\n\n if (clack.isCancel(shouldOverwrite) || !shouldOverwrite) {\n clack.cancel('Keeping existing configuration. Packages have been installed.')\n process.exit(0)\n }\n }\n\n configSpinner.start('Overwriting kubb.config.ts')\n }\n\n fs.writeFileSync(configPath, configContent, 'utf-8')\n\n configSpinner.stop('Created kubb.config.ts')\n\n // Success message\n clack.outro(\n styleText('green', '✓ All set!') +\n '\\n\\n' +\n styleText('dim', 'Next steps:') +\n '\\n' +\n styleText('cyan', ` 1. Make sure your OpenAPI spec is at: ${inputPath}`) +\n '\\n' +\n styleText('cyan', ' 2. Generate code with: npx kubb generate') +\n '\\n' +\n styleText('cyan', ' Or start a stream server with: npx kubb start') +\n '\\n' +\n styleText('cyan', ` 3. Find generated files in: ${outputPath}`) +\n '\\n\\n' +\n styleText('dim', `Using ${packageManager.name} • Kubb v${version}`),\n )\n } catch (error) {\n clack.log.error(styleText('red', 'An error occurred during initialization'))\n if (error instanceof Error) {\n clack.log.error(error.message)\n }\n process.exit(1)\n }\n },\n})\n\nexport default command\n"],"mappings":"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"}
@@ -1,5 +1,8 @@
1
1
  import { t as __name } from "./chunk-DKWOrOAv.js";
2
+ import { t as version } from "./package-BYVzWUJV.js";
3
+ import { n as sendTelemetry, t as buildTelemetryEvent } from "./telemetry-Ccka73zO.js";
2
4
  import { defineCommand, showUsage } from "citty";
5
+ import process from "node:process";
3
6
  import { styleText } from "node:util";
4
7
  import { createJiti } from "jiti";
5
8
 
@@ -27,11 +30,24 @@ const command = defineCommand({
27
30
  process.exit(1);
28
31
  }
29
32
  const { run } = mod;
33
+ const hrStart = process.hrtime();
30
34
  try {
31
35
  console.log("⏳ Starting MCP server...");
32
36
  console.warn(styleText("yellow", "This feature is still under development — use with caution"));
33
- await run();
37
+ run();
38
+ await sendTelemetry(buildTelemetryEvent({
39
+ command: "mcp",
40
+ kubbVersion: version,
41
+ hrStart,
42
+ status: "success"
43
+ }));
34
44
  } catch (error) {
45
+ await sendTelemetry(buildTelemetryEvent({
46
+ command: "mcp",
47
+ kubbVersion: version,
48
+ hrStart,
49
+ status: "failed"
50
+ }));
35
51
  console.error(error?.message);
36
52
  }
37
53
  }
@@ -39,4 +55,4 @@ const command = defineCommand({
39
55
 
40
56
  //#endregion
41
57
  export { command as default };
42
- //# sourceMappingURL=mcp-Jboea6xH.js.map
58
+ //# sourceMappingURL=mcp-CD0ZKRHG.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mcp-CD0ZKRHG.js","names":[],"sources":["../src/commands/mcp.ts"],"sourcesContent":["import process from 'node:process'\nimport { styleText } from 'node:util'\nimport type { ArgsDef } from 'citty'\nimport { defineCommand, showUsage } from 'citty'\nimport { createJiti } from 'jiti'\nimport { version } from '../../package.json'\nimport { buildTelemetryEvent, sendTelemetry } from '../utils/telemetry.ts'\n\nconst jiti = createJiti(import.meta.url, {\n sourceMaps: true,\n})\n\nconst args = {\n help: {\n type: 'boolean',\n description: 'Show help',\n alias: 'h',\n default: false,\n },\n} as const satisfies ArgsDef\n\nconst command = defineCommand({\n meta: {\n name: 'mcp',\n description: 'Start the server to enable the MCP client to interact with the LLM.',\n },\n args,\n async run(commandContext) {\n const { args } = commandContext\n\n if (args.help) {\n return showUsage(command)\n }\n\n let mod: any\n try {\n mod = await jiti.import('@kubb/mcp', { default: true })\n } catch (_e) {\n console.error(`Import of '@kubb/mcp' is required to start the MCP server`)\n process.exit(1)\n }\n\n const { run } = mod\n const hrStart = process.hrtime()\n try {\n console.log('⏳ Starting MCP server...')\n console.warn(styleText('yellow', 'This feature is still under development — use with caution'))\n run()\n await sendTelemetry(buildTelemetryEvent({ command: 'mcp', kubbVersion: version, hrStart, status: 'success' }))\n } catch (error) {\n await sendTelemetry(buildTelemetryEvent({ command: 'mcp', kubbVersion: version, hrStart, status: 'failed' }))\n console.error((error as Error)?.message)\n }\n },\n})\n\nexport default command\n"],"mappings":";;;;;;;;;AAQA,MAAM,OAAO,WAAW,OAAO,KAAK,KAAK,EACvC,YAAY,MACb,CAAC;AAWF,MAAM,UAAU,cAAc;CAC5B,MAAM;EACJ,MAAM;EACN,aAAa;EACd;CACD,MAdW,EACX,MAAM;EACJ,MAAM;EACN,aAAa;EACb,OAAO;EACP,SAAS;EACV,EACF;CAQC,MAAM,IAAI,gBAAgB;EACxB,MAAM,EAAE,SAAS;AAEjB,MAAI,KAAK,KACP,QAAO,UAAU,QAAQ;EAG3B,IAAI;AACJ,MAAI;AACF,SAAM,MAAM,KAAK,OAAO,aAAa,EAAE,SAAS,MAAM,CAAC;WAChD,IAAI;AACX,WAAQ,MAAM,4DAA4D;AAC1E,WAAQ,KAAK,EAAE;;EAGjB,MAAM,EAAE,QAAQ;EAChB,MAAM,UAAU,QAAQ,QAAQ;AAChC,MAAI;AACF,WAAQ,IAAI,2BAA2B;AACvC,WAAQ,KAAK,UAAU,UAAU,6DAA6D,CAAC;AAC/F,QAAK;AACL,SAAM,cAAc,oBAAoB;IAAE,SAAS;IAAO,aAAa;IAAS;IAAS,QAAQ;IAAW,CAAC,CAAC;WACvG,OAAO;AACd,SAAM,cAAc,oBAAoB;IAAE,SAAS;IAAO,aAAa;IAAS;IAAS,QAAQ;IAAU,CAAC,CAAC;AAC7G,WAAQ,MAAO,OAAiB,QAAQ;;;CAG7C,CAAC"}