@shareai-lab/kode 1.1.21 → 1.1.23-dev.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -18
- package/README.zh-CN.md +0 -14
- package/dist/components/FileEditToolUpdatedMessage.js +5 -4
- package/dist/components/FileEditToolUpdatedMessage.js.map +2 -2
- package/dist/components/Logo.js +2 -1
- package/dist/components/Logo.js.map +2 -2
- package/dist/components/PromptInput.js +2 -15
- package/dist/components/PromptInput.js.map +2 -2
- package/dist/constants/models.js +6 -1
- package/dist/constants/models.js.map +2 -2
- package/dist/entrypoints/cli.js +2 -17
- package/dist/entrypoints/cli.js.map +2 -2
- package/dist/screens/Doctor.js +10 -131
- package/dist/screens/Doctor.js.map +2 -2
- package/dist/screens/REPL.js +0 -3
- package/dist/screens/REPL.js.map +2 -2
- package/dist/tools/MultiEditTool/MultiEditTool.js +18 -3
- package/dist/tools/MultiEditTool/MultiEditTool.js.map +2 -2
- package/dist/utils/autoUpdater.js +10 -261
- package/dist/utils/autoUpdater.js.map +3 -3
- package/package.json +6 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/entrypoints/cli.tsx"],
|
|
4
|
-
"sourcesContent": ["#!/usr/bin/env -S node --no-warnings=ExperimentalWarning --enable-source-maps\nimport { fileURLToPath } from 'node:url'\nimport { dirname, join } from 'node:path'\nimport { existsSync } from 'node:fs'\nimport { initSentry } from '../services/sentry'\nimport { PRODUCT_COMMAND, PRODUCT_NAME } from '../constants/product'\ninitSentry() // Initialize Sentry as early as possible\n\n// Ensure YOGA_WASM_PATH is set for Ink across run modes (wrapper/dev)\n// Resolve yoga.wasm relative to this file when missing using ESM-friendly APIs\ntry {\n if (!process.env.YOGA_WASM_PATH) {\n const __filename = fileURLToPath(import.meta.url)\n const __dirname = dirname(__filename)\n const devCandidate = join(__dirname, '../../yoga.wasm')\n const distCandidate = join(__dirname, './yoga.wasm')\n const resolved = existsSync(distCandidate)\n ? distCandidate\n : existsSync(devCandidate)\n ? devCandidate\n : undefined\n if (resolved) {\n process.env.YOGA_WASM_PATH = resolved\n }\n }\n} catch {}\n\n// XXX: Without this line (and the Object.keys, even though it seems like it does nothing!),\n// there is a bug in Bun only on Win32 that causes this import to be removed, even though\n// its use is solely because of its side-effects.\nimport * as dontcare from '@anthropic-ai/sdk/shims/node'\nObject.keys(dontcare)\n\nimport React from 'react'\nimport { ReadStream } from 'tty'\nimport { openSync } from 'fs'\n// ink and REPL are imported lazily to avoid top-level awaits during module init\nimport type { RenderOptions } from 'ink'\nimport { addToHistory } from '../history'\nimport { getContext, setContext, removeContext } from '../context'\nimport { Command } from '@commander-js/extra-typings'\nimport { ask } from '../utils/ask'\nimport { hasPermissionsToUseTool } from '../permissions'\nimport { getTools } from '../tools'\nimport {\n getGlobalConfig,\n getCurrentProjectConfig,\n saveGlobalConfig,\n saveCurrentProjectConfig,\n getCustomApiKeyStatus,\n normalizeApiKeyForConfig,\n setConfigForCLI,\n deleteConfigForCLI,\n getConfigForCLI,\n listConfigForCLI,\n enableConfigs,\n validateAndRepairAllGPT5Profiles,\n} from '../utils/config'\nimport { cwd } from 'process'\nimport { dateToFilename, logError, parseLogFilename } from '../utils/log'\nimport { initDebugLogger } from '../utils/debugLogger'\nimport { Onboarding } from '../components/Onboarding'\nimport { Doctor } from '../screens/Doctor'\nimport { ApproveApiKey } from '../components/ApproveApiKey'\nimport { TrustDialog } from '../components/TrustDialog'\nimport { checkHasTrustDialogAccepted, McpServerConfig } from '../utils/config'\nimport { isDefaultSlowAndCapableModel } from '../utils/model'\nimport { LogList } from '../screens/LogList'\nimport { ResumeConversation } from '../screens/ResumeConversation'\nimport { startMCPServer } from './mcp'\nimport { env } from '../utils/env'\nimport { getCwd, setCwd, setOriginalCwd } from '../utils/state'\nimport { omit } from 'lodash-es'\nimport { getCommands } from '../commands'\nimport { getNextAvailableLogForkNumber, loadLogList } from '../utils/log'\nimport { loadMessagesFromLog } from '../utils/conversationRecovery'\nimport { cleanupOldMessageFilesInBackground } from '../utils/cleanup'\nimport {\n handleListApprovedTools,\n handleRemoveApprovedTool,\n} from '../commands/approvedTools'\nimport {\n addMcpServer,\n getMcpServer,\n listMCPServers,\n parseEnvVars,\n removeMcpServer,\n getClients,\n ensureConfigScope,\n} from '../services/mcpClient'\nimport { handleMcprcServerApprovals } from '../services/mcpServerApproval'\nimport { checkGate, initializeStatsig, logEvent } from '../services/statsig'\nimport { getExampleCommands } from '../utils/exampleCommands'\nimport { cursorShow } from 'ansi-escapes'\nimport {\n getLatestVersion,\n installGlobalPackage,\n assertMinVersion,\n getUpdateCommandSuggestions,\n} from '../utils/autoUpdater'\nimport { gt } from 'semver'\nimport { CACHE_PATHS } from '../utils/log'\n// import { checkAndNotifyUpdate } from '../utils/autoUpdater'\nimport { PersistentShell } from '../utils/PersistentShell'\nimport { GATE_USE_EXTERNAL_UPDATER } from '../constants/betas'\nimport { clearTerminal } from '../utils/terminal'\nimport { showInvalidConfigDialog } from '../components/InvalidConfigDialog'\nimport { ConfigParseError } from '../utils/errors'\nimport { grantReadPermissionForOriginalDir } from '../utils/permissions/filesystem'\nimport { MACRO } from '../constants/macros'\nexport function completeOnboarding(): void {\n const config = getGlobalConfig()\n saveGlobalConfig({\n ...config,\n hasCompletedOnboarding: true,\n lastOnboardingVersion: MACRO.VERSION,\n })\n}\n\nasync function showSetupScreens(\n safeMode?: boolean,\n print?: boolean,\n): Promise<void> {\n if (process.env.NODE_ENV === 'test') {\n return\n }\n\n const config = getGlobalConfig()\n if (\n !config.theme ||\n !config.hasCompletedOnboarding // always show onboarding at least once\n ) {\n await clearTerminal()\n const { render } = await import('ink')\n await new Promise<void>(resolve => {\n render(\n <Onboarding\n onDone={async () => {\n completeOnboarding()\n await clearTerminal()\n resolve()\n }}\n />,\n {\n exitOnCtrlC: false,\n },\n )\n })\n }\n\n // // Check for custom API key (only allowed for ants)\n // if (process.env.ANTHROPIC_API_KEY && process.env.USER_TYPE === 'ant') {\n // const customApiKeyTruncated = normalizeApiKeyForConfig(\n // process.env.ANTHROPIC_API_KEY!,\n // )\n // const keyStatus = getCustomApiKeyStatus(customApiKeyTruncated)\n // if (keyStatus === 'new') {\n // await new Promise<void>(resolve => {\n // render(\n // <ApproveApiKey\n // customApiKeyTruncated={customApiKeyTruncated}\n // onDone={async () => {\n // await clearTerminal()\n // resolve()\n // }}\n // />,\n // {\n // exitOnCtrlC: false,\n // },\n // )\n // })\n // }\n // }\n\n // In non-interactive mode, only show trust dialog in safe mode\n if (!print && safeMode) {\n if (!checkHasTrustDialogAccepted()) {\n await new Promise<void>(resolve => {\n const onDone = () => {\n // Grant read permission to the current working directory\n grantReadPermissionForOriginalDir()\n resolve()\n }\n ;(async () => {\n const { render } = await import('ink')\n render(<TrustDialog onDone={onDone} />, {\n exitOnCtrlC: false,\n })\n })()\n })\n }\n\n // After trust dialog, check for any mcprc servers that need approval\n if (process.env.USER_TYPE === 'ant') {\n await handleMcprcServerApprovals()\n }\n }\n}\n\nfunction logStartup(): void {\n const config = getGlobalConfig()\n saveGlobalConfig({\n ...config,\n numStartups: (config.numStartups ?? 0) + 1,\n })\n}\n\nasync function setup(cwd: string, safeMode?: boolean): Promise<void> {\n // Set both current and original working directory if --cwd was provided\n if (cwd !== process.cwd()) {\n setOriginalCwd(cwd)\n }\n await setCwd(cwd)\n\n // Always grant read permissions for original working dir\n grantReadPermissionForOriginalDir()\n \n // Start watching agent configuration files for changes\n // Try ESM-friendly path first (compiled dist), then fall back to extensionless (dev/tsx)\n let agentLoader: any\n try {\n agentLoader = await import('../utils/agentLoader.js')\n } catch {\n agentLoader = await import('../utils/agentLoader')\n }\n const { startAgentWatcher, clearAgentCache } = agentLoader\n await startAgentWatcher(() => {\n // Cache is already cleared in the watcher, just log\n console.log('\u2705 Agent configurations hot-reloaded')\n })\n\n // If --safe mode is enabled, prevent root/sudo usage for security\n if (safeMode) {\n // Check if running as root/sudo on Unix-like systems\n if (\n process.platform !== 'win32' &&\n typeof process.getuid === 'function' &&\n process.getuid() === 0\n ) {\n console.error(\n `--safe mode cannot be used with root/sudo privileges for security reasons`,\n )\n process.exit(1)\n }\n }\n\n if (process.env.NODE_ENV === 'test') {\n return\n }\n\n cleanupOldMessageFilesInBackground()\n // getExampleCommands() // Pre-fetch example commands\n getContext() // Pre-fetch all context data at once\n // initializeStatsig() // Kick off statsig initialization\n\n // Migrate old iterm2KeyBindingInstalled config to new shiftEnterKeyBindingInstalled\n const globalConfig = getGlobalConfig()\n if (\n globalConfig.iterm2KeyBindingInstalled === true &&\n globalConfig.shiftEnterKeyBindingInstalled !== true\n ) {\n const updatedConfig = {\n ...globalConfig,\n shiftEnterKeyBindingInstalled: true,\n }\n // Remove the old config property\n delete updatedConfig.iterm2KeyBindingInstalled\n saveGlobalConfig(updatedConfig)\n }\n\n // Check for last session's cost and duration\n const projectConfig = getCurrentProjectConfig()\n if (\n projectConfig.lastCost !== undefined &&\n projectConfig.lastDuration !== undefined\n ) {\n logEvent('tengu_exit', {\n last_session_cost: String(projectConfig.lastCost),\n last_session_api_duration: String(projectConfig.lastAPIDuration),\n last_session_duration: String(projectConfig.lastDuration),\n last_session_id: projectConfig.lastSessionId,\n })\n // Clear the values after logging\n // saveCurrentProjectConfig({\n // ...projectConfig,\n // lastCost: undefined,\n // lastAPIDuration: undefined,\n // lastDuration: undefined,\n // lastSessionId: undefined,\n // })\n }\n\n // Check auto-updater permissions\n const autoUpdaterStatus = globalConfig.autoUpdaterStatus ?? 'not_configured'\n if (autoUpdaterStatus === 'not_configured') {\n logEvent('tengu_setup_auto_updater_not_configured', {})\n await new Promise<void>(resolve => {\n ;(async () => {\n const { render } = await import('ink')\n render(<Doctor onDone={() => resolve()} />)\n })()\n })\n }\n}\n\nasync function main() {\n // \u521D\u59CB\u5316\u8C03\u8BD5\u65E5\u5FD7\u7CFB\u7EDF\n initDebugLogger()\n\n // Validate configs are valid and enable configuration system\n try {\n enableConfigs()\n \n // \uD83D\uDD27 Validate and auto-repair GPT-5 model profiles\n try {\n const repairResult = validateAndRepairAllGPT5Profiles()\n if (repairResult.repaired > 0) {\n console.log(`\uD83D\uDD27 Auto-repaired ${repairResult.repaired} GPT-5 model configurations`)\n }\n } catch (repairError) {\n // Don't block startup if GPT-5 validation fails\n console.warn('\u26A0\uFE0F GPT-5 configuration validation failed:', repairError)\n }\n } catch (error: unknown) {\n if (error instanceof ConfigParseError) {\n // Show the invalid config dialog with the error object\n await showInvalidConfigDialog({ error })\n return // Exit after handling the config error\n }\n }\n\n // Disabled background notifier to avoid mid-screen logs during REPL\n\n let inputPrompt = ''\n let renderContext: RenderOptions | undefined = {\n exitOnCtrlC: false,\n \n onFlicker() {\n logEvent('tengu_flicker', {})\n },\n } as any\n\n if (\n !process.stdin.isTTY &&\n !process.env.CI &&\n // Input hijacking breaks MCP.\n !process.argv.includes('mcp')\n ) {\n inputPrompt = await stdin()\n if (process.platform !== 'win32') {\n try {\n const ttyFd = openSync('/dev/tty', 'r')\n renderContext = { ...renderContext, stdin: new ReadStream(ttyFd) }\n } catch (err) {\n logError(`Could not open /dev/tty: ${err}`)\n }\n }\n }\n await parseArgs(inputPrompt, renderContext)\n}\n\nasync function parseArgs(\n stdinContent: string,\n renderContext: RenderOptions | undefined,\n): Promise<Command> {\n const program = new Command()\n\n const renderContextWithExitOnCtrlC = {\n ...renderContext,\n exitOnCtrlC: true,\n }\n\n // Get the initial list of commands filtering based on user type\n const commands = await getCommands()\n\n // Format command list for help text (using same filter as in help.ts)\n const commandList = commands\n .filter(cmd => !cmd.isHidden)\n .map(cmd => `/${cmd.name} - ${cmd.description}`)\n .join('\\n')\n\n program\n .name(PRODUCT_COMMAND)\n .description(\n `${PRODUCT_NAME} - starts an interactive session by default, use -p/--print for non-interactive output\n\nSlash commands available during an interactive session:\n${commandList}`,\n )\n .argument('[prompt]', 'Your prompt', String)\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-d, --debug', 'Enable debug mode', () => true)\n .option(\n '--debug-verbose',\n 'Enable verbose debug terminal output',\n () => true,\n )\n .option(\n '--verbose',\n 'Override verbose mode setting from config',\n () => true,\n )\n .option('-e, --enable-architect', 'Enable the Architect tool', () => true)\n .option(\n '-p, --print',\n 'Print response and exit (useful for pipes)',\n () => true,\n )\n .option(\n '--safe',\n 'Enable strict permission checking mode (default is permissive)',\n () => true,\n )\n .action(\n async (prompt, { cwd, debug, verbose, enableArchitect, print, safe }) => {\n await showSetupScreens(safe, print)\n logEvent('tengu_init', {\n entrypoint: PRODUCT_COMMAND,\n hasInitialPrompt: Boolean(prompt).toString(),\n hasStdin: Boolean(stdinContent).toString(),\n enableArchitect: enableArchitect?.toString() ?? 'false',\n verbose: verbose?.toString() ?? 'false',\n debug: debug?.toString() ?? 'false',\n print: print?.toString() ?? 'false',\n })\n await setup(cwd, safe)\n\n assertMinVersion()\n\n const [tools, mcpClients] = await Promise.all([\n getTools(\n enableArchitect ?? getCurrentProjectConfig().enableArchitectTool,\n ),\n getClients(),\n ])\n // logStartup()\n const inputPrompt = [prompt, stdinContent].filter(Boolean).join('\\n')\n if (print) {\n if (!inputPrompt) {\n console.error(\n 'Error: Input must be provided either through stdin or as a prompt argument when using --print',\n )\n process.exit(1)\n }\n\n addToHistory(inputPrompt)\n const { resultText: response } = await ask({\n commands,\n hasPermissionsToUseTool,\n messageLogName: dateToFilename(new Date()),\n prompt: inputPrompt,\n cwd,\n tools,\n safeMode: safe,\n })\n console.log(response)\n process.exit(0)\n } else {\n const isDefaultModel = await isDefaultSlowAndCapableModel()\n\n // Prefetch update info before first render to place banner at top\n const updateInfo = await (async () => {\n try {\n const latest = await getLatestVersion()\n if (latest && gt(latest, MACRO.VERSION)) {\n const cmds = await getUpdateCommandSuggestions()\n return { version: latest as string, commands: cmds as string[] }\n }\n } catch {}\n return { version: null as string | null, commands: null as string[] | null }\n })()\n\n {\n const { render } = await import('ink')\n const { REPL } = await import('../screens/REPL')\n render(\n <REPL\n commands={commands}\n debug={debug}\n initialPrompt={inputPrompt}\n messageLogName={dateToFilename(new Date())}\n shouldShowPromptInput={true}\n verbose={verbose}\n tools={tools}\n safeMode={safe}\n mcpClients={mcpClients}\n isDefaultModel={isDefaultModel}\n initialUpdateVersion={updateInfo.version}\n initialUpdateCommands={updateInfo.commands}\n />,\n renderContext,\n )\n }\n }\n },\n )\n .version(MACRO.VERSION, '-v, --version')\n\n // Enable melon mode for ants if --melon is passed\n // For bun tree shaking to work, this has to be a top level --define, not inside MACRO\n // if (process.env.USER_TYPE === 'ant') {\n // program\n // .option('--melon', 'Enable melon mode')\n // .hook('preAction', async () => {\n // if ((program.opts() as { melon?: boolean }).melon) {\n // const { runMelonWrapper } = await import('../utils/melonWrapper')\n // const melonArgs = process.argv.slice(\n // process.argv.indexOf('--melon') + 1,\n // )\n // const exitCode = runMelonWrapper(melonArgs)\n // process.exit(exitCode)\n // }\n // })\n // }\n\n // claude config\n const config = program\n .command('config')\n .description(\n `Manage configuration (eg. ${PRODUCT_COMMAND} config set -g theme dark)`,\n )\n\n config\n .command('get <key>')\n .description('Get a config value')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, { cwd, global }) => {\n await setup(cwd, false)\n console.log(getConfigForCLI(key, global ?? false))\n process.exit(0)\n })\n\n config\n .command('set <key> <value>')\n .description('Set a config value')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, value, { cwd, global }) => {\n await setup(cwd, false)\n setConfigForCLI(key, value, global ?? false)\n console.log(`Set ${key} to ${value}`)\n process.exit(0)\n })\n\n config\n .command('remove <key>')\n .description('Remove a config value')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, { cwd, global }) => {\n await setup(cwd, false)\n deleteConfigForCLI(key, global ?? false)\n console.log(`Removed ${key}`)\n process.exit(0)\n })\n\n config\n .command('list')\n .description('List all config values')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config', false)\n .action(async ({ cwd, global }) => {\n await setup(cwd, false)\n console.log(\n JSON.stringify(global ? listConfigForCLI(true) : listConfigForCLI(false), null, 2),\n )\n process.exit(0)\n })\n\n // claude approved-tools\n\n const allowedTools = program\n .command('approved-tools')\n .description('Manage approved tools')\n\n allowedTools\n .command('list')\n .description('List all approved tools')\n .action(async () => {\n const result = handleListApprovedTools(getCwd())\n console.log(result)\n process.exit(0)\n })\n\n allowedTools\n .command('remove <tool>')\n .description('Remove a tool from the list of approved tools')\n .action(async (tool: string) => {\n const result = handleRemoveApprovedTool(tool)\n logEvent('tengu_approved_tool_remove', {\n tool,\n success: String(result.success),\n })\n console.log(result.message)\n process.exit(result.success ? 0 : 1)\n })\n\n // claude mcp\n\n const mcp = program\n .command('mcp')\n .description('Configure and manage MCP servers')\n\n mcp\n .command('serve')\n .description(`Start the ${PRODUCT_NAME} MCP server`)\n .action(async () => {\n const providedCwd = (program.opts() as { cwd?: string }).cwd ?? cwd()\n logEvent('tengu_mcp_start', { providedCwd })\n\n // Verify the directory exists\n if (!existsSync(providedCwd)) {\n console.error(`Error: Directory ${providedCwd} does not exist`)\n process.exit(1)\n }\n\n try {\n await setup(providedCwd, false)\n await startMCPServer(providedCwd)\n } catch (error) {\n console.error('Error: Failed to start MCP server:', error)\n process.exit(1)\n }\n })\n\n mcp\n .command('add-sse <name> <url>')\n .description('Add an SSE server')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async (name, url, options) => {\n try {\n const scope = ensureConfigScope(options.scope)\n logEvent('tengu_mcp_add', { name, type: 'sse', scope })\n\n addMcpServer(name, { type: 'sse', url }, scope)\n console.log(\n `Added SSE MCP server ${name} with URL ${url} to ${scope} config`,\n )\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('add [name] [commandOrUrl] [args...]')\n .description('Add a server (run without arguments for interactive wizard)')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .option(\n '-e, --env <env...>',\n 'Set environment variables (e.g. -e KEY=value)',\n )\n .action(async (name, commandOrUrl, args, options) => {\n try {\n // If name is not provided, start interactive wizard\n if (!name) {\n console.log('Interactive wizard mode: Enter the server details')\n const { createInterface } = await import('readline')\n const rl = createInterface({\n input: process.stdin,\n output: process.stdout,\n })\n\n const question = (query: string) =>\n new Promise<string>(resolve => rl.question(query, resolve))\n\n // Get server name\n const serverName = await question('Server name: ')\n if (!serverName) {\n console.error('Error: Server name is required')\n rl.close()\n process.exit(1)\n }\n\n // Get server type\n const serverType = await question(\n 'Server type (stdio or sse) [stdio]: ',\n )\n const type =\n serverType && ['stdio', 'sse'].includes(serverType)\n ? serverType\n : 'stdio'\n\n // Get command or URL\n const prompt = type === 'stdio' ? 'Command: ' : 'URL: '\n const commandOrUrlValue = await question(prompt)\n if (!commandOrUrlValue) {\n console.error(\n `Error: ${type === 'stdio' ? 'Command' : 'URL'} is required`,\n )\n rl.close()\n process.exit(1)\n }\n\n // Get args and env if stdio\n let serverArgs: string[] = []\n let serverEnv: Record<string, string> = {}\n\n if (type === 'stdio') {\n const argsStr = await question(\n 'Command arguments (space-separated): ',\n )\n serverArgs = argsStr ? argsStr.split(' ').filter(Boolean) : []\n\n const envStr = await question(\n 'Environment variables (format: KEY1=value1,KEY2=value2): ',\n )\n if (envStr) {\n const envPairs = envStr.split(',').map(pair => pair.trim())\n serverEnv = parseEnvVars(envPairs.map(pair => pair))\n }\n }\n\n // Get scope\n const scopeStr = await question(\n 'Configuration scope (project or global) [project]: ',\n )\n const serverScope = ensureConfigScope(scopeStr || 'project')\n\n rl.close()\n\n // Add the server\n if (type === 'sse') {\n logEvent('tengu_mcp_add', {\n name: serverName,\n type: 'sse',\n scope: serverScope,\n })\n addMcpServer(\n serverName,\n { type: 'sse', url: commandOrUrlValue },\n serverScope,\n )\n console.log(\n `Added SSE MCP server ${serverName} with URL ${commandOrUrlValue} to ${serverScope} config`,\n )\n } else {\n logEvent('tengu_mcp_add', {\n name: serverName,\n type: 'stdio',\n scope: serverScope,\n })\n addMcpServer(\n serverName,\n {\n type: 'stdio',\n command: commandOrUrlValue,\n args: serverArgs,\n env: serverEnv,\n },\n serverScope,\n )\n\n console.log(\n `Added stdio MCP server ${serverName} with command: ${commandOrUrlValue} ${serverArgs.join(' ')} to ${serverScope} config`,\n )\n }\n } else if (name && commandOrUrl) {\n // Regular non-interactive flow\n const scope = ensureConfigScope(options.scope)\n\n // Check if it's an SSE URL (starts with http:// or https://)\n if (commandOrUrl.match(/^https?:\\/\\//)) {\n logEvent('tengu_mcp_add', { name, type: 'sse', scope })\n addMcpServer(name, { type: 'sse', url: commandOrUrl }, scope)\n console.log(\n `Added SSE MCP server ${name} with URL ${commandOrUrl} to ${scope} config`,\n )\n } else {\n logEvent('tengu_mcp_add', { name, type: 'stdio', scope })\n const env = parseEnvVars(options.env)\n addMcpServer(\n name,\n { type: 'stdio', command: commandOrUrl, args: args || [], env },\n scope,\n )\n\n console.log(\n `Added stdio MCP server ${name} with command: ${commandOrUrl} ${(args || []).join(' ')} to ${scope} config`,\n )\n }\n } else {\n console.error(\n 'Error: Missing required arguments. Either provide no arguments for interactive mode or specify name and command/URL.',\n )\n process.exit(1)\n }\n\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n mcp\n .command('remove <name>')\n .description('Remove an MCP server')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project, global, or mcprc)',\n 'project',\n )\n .action(async (name: string, options: { scope?: string }) => {\n try {\n const scope = ensureConfigScope(options.scope)\n logEvent('tengu_mcp_delete', { name, scope })\n\n removeMcpServer(name, scope)\n console.log(`Removed MCP server ${name} from ${scope} config`)\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('list')\n .description('List configured MCP servers')\n .action(() => {\n logEvent('tengu_mcp_list', {})\n const servers = listMCPServers()\n if (Object.keys(servers).length === 0) {\n console.log(\n `No MCP servers configured. Use \\`${PRODUCT_COMMAND} mcp add\\` to add a server.`,\n )\n } else {\n for (const [name, server] of Object.entries(servers)) {\n if (server.type === 'sse') {\n console.log(`${name}: ${server.url} (SSE)`)\n } else {\n console.log(`${name}: ${server.command} ${server.args.join(' ')}`)\n }\n }\n }\n process.exit(0)\n })\n\n mcp\n .command('add-json <name> <json>')\n .description('Add an MCP server (stdio or SSE) with a JSON string')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async (name, jsonStr, options) => {\n try {\n const scope = ensureConfigScope(options.scope)\n\n // Parse JSON string\n let serverConfig\n try {\n serverConfig = JSON.parse(jsonStr)\n } catch (e) {\n console.error('Error: Invalid JSON string')\n process.exit(1)\n }\n\n // Validate the server config\n if (\n !serverConfig.type ||\n !['stdio', 'sse'].includes(serverConfig.type)\n ) {\n console.error('Error: Server type must be \"stdio\" or \"sse\"')\n process.exit(1)\n }\n\n if (serverConfig.type === 'sse' && !serverConfig.url) {\n console.error('Error: SSE server must have a URL')\n process.exit(1)\n }\n\n if (serverConfig.type === 'stdio' && !serverConfig.command) {\n console.error('Error: stdio server must have a command')\n process.exit(1)\n }\n\n // Add server with the provided config\n logEvent('tengu_mcp_add_json', { name, type: serverConfig.type, scope })\n addMcpServer(name, serverConfig, scope)\n\n if (serverConfig.type === 'sse') {\n console.log(\n `Added SSE MCP server ${name} with URL ${serverConfig.url} to ${scope} config`,\n )\n } else {\n console.log(\n `Added stdio MCP server ${name} with command: ${serverConfig.command} ${(\n serverConfig.args || []\n ).join(' ')} to ${scope} config`,\n )\n }\n\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('get <name>')\n .description('Get details about an MCP server')\n .action((name: string) => {\n logEvent('tengu_mcp_get', { name })\n const server = getMcpServer(name)\n if (!server) {\n console.error(`No MCP server found with name: ${name}`)\n process.exit(1)\n }\n console.log(`${name}:`)\n console.log(` Scope: ${server.scope}`)\n if (server.type === 'sse') {\n console.log(` Type: sse`)\n console.log(` URL: ${server.url}`)\n } else {\n console.log(` Type: stdio`)\n console.log(` Command: ${server.command}`)\n console.log(` Args: ${server.args.join(' ')}`)\n if (server.env) {\n console.log(' Environment:')\n for (const [key, value] of Object.entries(server.env)) {\n console.log(` ${key}=${value}`)\n }\n }\n }\n process.exit(0)\n })\n\n // Import servers from Claude Desktop\n mcp\n .command('add-from-claude-desktop')\n .description(\n 'Import MCP servers from Claude Desktop (Mac, Windows and WSL)',\n )\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async options => {\n try {\n const scope = ensureConfigScope(options.scope)\n const platform = process.platform\n\n // Import fs and path modules\n const { existsSync, readFileSync } = await import('fs')\n const { join } = await import('path')\n const { exec } = await import('child_process')\n\n // Determine if running in WSL\n const isWSL =\n platform === 'linux' &&\n existsSync('/proc/version') &&\n readFileSync('/proc/version', 'utf-8')\n .toLowerCase()\n .includes('microsoft')\n\n if (platform !== 'darwin' && platform !== 'win32' && !isWSL) {\n console.error(\n 'Error: This command is only supported on macOS, Windows, and WSL',\n )\n process.exit(1)\n }\n\n // Get Claude Desktop config path\n let configPath\n if (platform === 'darwin') {\n configPath = join(\n process.env.HOME || '~',\n 'Library/Application Support/Claude/claude_desktop_config.json',\n )\n } else if (platform === 'win32') {\n configPath = join(\n process.env.APPDATA || '',\n 'Claude/claude_desktop_config.json',\n )\n } else if (isWSL) {\n // Get Windows username\n const whoamiCommand = await new Promise<string>((resolve, reject) => {\n exec(\n 'powershell.exe -Command \"whoami\"',\n (err: Error, stdout: string) => {\n if (err) reject(err)\n else resolve(stdout.trim().split('\\\\').pop() || '')\n },\n )\n })\n\n configPath = `/mnt/c/Users/${whoamiCommand}/AppData/Roaming/Claude/claude_desktop_config.json`\n }\n\n // Check if config file exists\n if (!existsSync(configPath)) {\n console.error(\n `Error: Claude Desktop config file not found at ${configPath}`,\n )\n process.exit(1)\n }\n\n // Read config file\n let config\n try {\n const configContent = readFileSync(configPath, 'utf-8')\n config = JSON.parse(configContent)\n } catch (err) {\n console.error(`Error reading config file: ${err}`)\n process.exit(1)\n }\n\n // Extract MCP servers\n const mcpServers = config.mcpServers || {}\n const serverNames = Object.keys(mcpServers)\n const numServers = serverNames.length\n\n if (numServers === 0) {\n console.log('No MCP servers found in Claude Desktop config')\n process.exit(0)\n }\n\n // Create server information for display\n const serversInfo = serverNames.map(name => {\n const server = mcpServers[name]\n let description = ''\n\n if (server.type === 'sse') {\n description = `SSE: ${server.url}`\n } else {\n description = `stdio: ${server.command} ${(server.args || []).join(' ')}`\n }\n\n return { name, description, server }\n })\n\n // First import all required modules outside the component\n // Import modules separately to avoid any issues\n const ink = await import('ink')\n const reactModule = await import('react')\n const inkjsui = await import('@inkjs/ui')\n const utilsTheme = await import('../utils/theme')\n\n const { render } = ink\n const React = reactModule // React is already the default export when imported this way\n const { MultiSelect } = inkjsui\n const { Box, Text } = ink\n const { getTheme } = utilsTheme\n\n // Use Ink to render a nice UI for selection\n await new Promise<void>(resolve => {\n // Create a component for the server selection\n function ClaudeDesktopImport() {\n const { useState } = reactModule\n const [isFinished, setIsFinished] = useState(false)\n const [importResults, setImportResults] = useState([] as { name: string; success: boolean }[])\n const [isImporting, setIsImporting] = useState(false)\n const theme = getTheme()\n\n // Function to import selected servers\n const importServers = async (selectedServers: string[]) => {\n setIsImporting(true)\n const results = []\n\n for (const name of selectedServers) {\n try {\n const server = mcpServers[name]\n\n // Check if server already exists\n const existingServer = getMcpServer(name)\n if (existingServer) {\n // Skip duplicates - we'll handle them in the confirmation step\n continue\n }\n\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n setImportResults(results)\n setIsImporting(false)\n setIsFinished(true)\n\n // Give time to show results\n setTimeout(() => {\n resolve()\n }, 1000)\n }\n\n // Handle confirmation of selections\n const handleConfirm = async (selectedServers: string[]) => {\n // Check for existing servers and confirm overwrite\n const existingServers = selectedServers.filter(name =>\n getMcpServer(name),\n )\n\n if (existingServers.length > 0) {\n // We'll just handle it directly since we have a simple UI\n const results = []\n\n // Process non-existing servers first\n const newServers = selectedServers.filter(\n name => !getMcpServer(name),\n )\n for (const name of newServers) {\n try {\n const server = mcpServers[name]\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n // Now handle existing servers by prompting for each one\n for (const name of existingServers) {\n try {\n const server = mcpServers[name]\n // Overwrite existing server - in a real interactive UI you'd prompt here\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n setImportResults(results)\n setIsImporting(false)\n setIsFinished(true)\n\n // Give time to show results before resolving\n setTimeout(() => {\n resolve()\n }, 1000)\n } else {\n // No existing servers, proceed with import\n await importServers(selectedServers)\n }\n }\n\n return (\n <Box flexDirection=\"column\" padding={1}>\n <Box\n flexDirection=\"column\"\n borderStyle=\"round\"\n borderColor={theme.kode}\n padding={1}\n width={'100%'}\n >\n <Text bold color={theme.kode}>\n Import MCP Servers from Claude Desktop\n </Text>\n\n <Box marginY={1}>\n <Text>\n Found {numServers} MCP servers in Claude Desktop.\n </Text>\n </Box>\n\n <Text>Please select the servers you want to import:</Text>\n\n <Box marginTop={1}>\n <MultiSelect\n options={serverNames.map(name => ({\n label: name,\n value: name,\n }))}\n defaultValue={serverNames}\n onSubmit={handleConfirm}\n />\n </Box>\n </Box>\n\n <Box marginTop={0} marginLeft={3}>\n <Text dimColor>\n Space to select \u00B7 Enter to confirm \u00B7 Esc to cancel\n </Text>\n </Box>\n\n {isFinished && (\n <Box marginTop={1}>\n <Text color={theme.success}>\n Successfully imported{' '}\n {importResults.filter(r => r.success).length} MCP server\n to local config.\n </Text>\n </Box>\n )}\n </Box>\n )\n }\n\n // Render the component\n const { unmount } = render(<ClaudeDesktopImport />)\n\n // Clean up when done\n setTimeout(() => {\n unmount()\n resolve()\n }, 30000) // Timeout after 30 seconds as a fallback\n })\n\n process.exit(0)\n } catch (error) {\n console.error(`Error: ${(error as Error).message}`)\n process.exit(1)\n }\n })\n\n // Function to reset MCP server choices\n const resetMcpChoices = () => {\n const config = getCurrentProjectConfig()\n saveCurrentProjectConfig({\n ...config,\n approvedMcprcServers: [],\n rejectedMcprcServers: [],\n })\n console.log('All .mcprc server approvals and rejections have been reset.')\n console.log(\n `You will be prompted for approval next time you start ${PRODUCT_NAME}.`,\n )\n process.exit(0)\n }\n\n // New command name to match Kode\n mcp\n .command('reset-project-choices')\n .description(\n 'Reset all approved and rejected project-scoped (.mcp.json) servers within this project',\n )\n .action(() => {\n logEvent('tengu_mcp_reset_project_choices', {})\n resetMcpChoices()\n })\n\n // Keep old command for backward compatibility (visible only to ants)\n if (process.env.USER_TYPE === 'ant') {\n mcp\n .command('reset-mcprc-choices')\n .description(\n 'Reset all approved and rejected .mcprc servers for this project',\n )\n .action(() => {\n logEvent('tengu_mcp_reset_mcprc_choices', {})\n resetMcpChoices()\n })\n }\n\n // Doctor command - check installation health\n program\n .command('doctor')\n .description(`Check the health of your ${PRODUCT_NAME} auto-updater`)\n .action(async () => {\n logEvent('tengu_doctor_command', {})\n\n await new Promise<void>(resolve => {\n ;(async () => {\n const { render } = await import('ink')\n render(<Doctor onDone={() => resolve()} doctorMode={true} />)\n })()\n })\n process.exit(0)\n })\n\n // ant-only commands\n\n // claude update\n program\n .command('update')\n .description('Show manual upgrade commands (no auto-install)')\n .action(async () => {\n logEvent('tengu_update_check', {})\n console.log(`Current version: ${MACRO.VERSION}`)\n console.log('Checking for updates...')\n\n const latestVersion = await getLatestVersion()\n\n if (!latestVersion) {\n console.error('Failed to check for updates')\n process.exit(1)\n }\n\n if (latestVersion === MACRO.VERSION) {\n console.log(`${PRODUCT_NAME} is up to date`)\n process.exit(0)\n }\n\n console.log(`New version available: ${latestVersion}`)\n const { getUpdateCommandSuggestions } = await import('../utils/autoUpdater')\n const cmds = await getUpdateCommandSuggestions()\n console.log('\\nRun one of the following commands to update:')\n for (const c of cmds) console.log(` ${c}`)\n if (process.platform !== 'win32') {\n console.log('\\nNote: you may need to prefix with \"sudo\" on macOS/Linux.')\n }\n process.exit(0)\n })\n\n // claude log\n program\n .command('log')\n .description('Manage conversation logs.')\n .argument(\n '[number]',\n 'A number (0, 1, 2, etc.) to display a specific log',\n parseInt,\n )\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (number, { cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_view_logs', { number: number?.toString() ?? '' })\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { unmount } = render(\n <LogList context={context} type=\"messages\" logNumber={number} />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n })\n\n // claude resume\n program\n .command('resume')\n .description(\n 'Resume a previous conversation. Optionally provide a number (0, 1, 2, etc.) or file path to resume a specific conversation.',\n )\n .argument(\n '[identifier]',\n 'A number (0, 1, 2, etc.) or file path to resume a specific conversation',\n )\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-e, --enable-architect', 'Enable the Architect tool', () => true)\n .option('-v, --verbose', 'Do not truncate message output', () => true)\n .option(\n '--safe',\n 'Enable strict permission checking mode (default is permissive)',\n () => true,\n )\n .action(async (identifier, { cwd, enableArchitect, safe, verbose }) => {\n await setup(cwd, safe)\n assertMinVersion()\n\n const [tools, commands, logs, mcpClients] = await Promise.all([\n getTools(\n enableArchitect ?? getCurrentProjectConfig().enableArchitectTool,\n ),\n getCommands(),\n loadLogList(CACHE_PATHS.messages()),\n getClients(),\n ])\n // logStartup()\n\n // If a specific conversation is requested, load and resume it directly\n if (identifier !== undefined) {\n // Check if identifier is a number or a file path\n const number = Math.abs(parseInt(identifier))\n const isNumber = !isNaN(number)\n let messages, date, forkNumber\n try {\n if (isNumber) {\n logEvent('tengu_resume', { number: number.toString() })\n const log = logs[number]\n if (!log) {\n console.error('No conversation found at index', number)\n process.exit(1)\n }\n messages = await loadMessagesFromLog(log.fullPath, tools)\n ;({ date, forkNumber } = log)\n } else {\n // Handle file path case\n logEvent('tengu_resume', { filePath: identifier })\n if (!existsSync(identifier)) {\n console.error('File does not exist:', identifier)\n process.exit(1)\n }\n messages = await loadMessagesFromLog(identifier, tools)\n const pathSegments = identifier.split('/')\n const filename = pathSegments[pathSegments.length - 1] ?? 'unknown'\n ;({ date, forkNumber } = parseLogFilename(filename))\n }\n const fork = getNextAvailableLogForkNumber(date, forkNumber ?? 1, 0)\n const isDefaultModel = await isDefaultSlowAndCapableModel()\n {\n const { render } = await import('ink')\n const { REPL } = await import('../screens/REPL')\n render(\n <REPL\n initialPrompt=\"\"\n messageLogName={date}\n initialForkNumber={fork}\n shouldShowPromptInput={true}\n verbose={verbose}\n commands={commands}\n tools={tools}\n safeMode={safe}\n initialMessages={messages}\n mcpClients={mcpClients}\n isDefaultModel={isDefaultModel}\n />,\n { exitOnCtrlC: false },\n )\n }\n } catch (error) {\n logError(`Failed to load conversation: ${error}`)\n process.exit(1)\n }\n } else {\n // Show the conversation selector UI\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { unmount } = render(\n <ResumeConversation\n context={context}\n commands={commands}\n logs={logs}\n tools={tools}\n verbose={verbose}\n />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n }\n })\n\n // claude error\n program\n .command('error')\n .description(\n 'View error logs. Optionally provide a number (0, -1, -2, etc.) to display a specific log.',\n )\n .argument(\n '[number]',\n 'A number (0, 1, 2, etc.) to display a specific log',\n parseInt,\n )\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (number, { cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_view_errors', { number: number?.toString() ?? '' })\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { unmount } = render(\n <LogList context={context} type=\"errors\" logNumber={number} />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n })\n\n // claude context (TODO: deprecate)\n const context = program\n .command('context')\n .description(\n `Set static context (eg. ${PRODUCT_COMMAND} context add-file ./src/*.py)`,\n )\n\n context\n .command('get <key>')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .description('Get a value from context')\n .action(async (key, { cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_context_get', { key })\n const context = omit(\n await getContext(),\n 'codeStyle',\n 'directoryStructure',\n )\n console.log(context[key])\n process.exit(0)\n })\n\n context\n .command('set <key> <value>')\n .description('Set a value in context')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (key, value, { cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_context_set', { key })\n setContext(key, value)\n console.log(`Set context.${key} to \"${value}\"`)\n process.exit(0)\n })\n\n context\n .command('list')\n .description('List all context values')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async ({ cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_context_list', {})\n const context = omit(\n await getContext(),\n 'codeStyle',\n 'directoryStructure',\n 'gitStatus',\n )\n console.log(JSON.stringify(context, null, 2))\n process.exit(0)\n })\n\n context\n .command('remove <key>')\n .description('Remove a value from context')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (key, { cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_context_delete', { key })\n removeContext(key)\n console.log(`Removed context.${key}`)\n process.exit(0)\n })\n\n await program.parseAsync(process.argv)\n return program\n}\n\n// TODO: stream?\nasync function stdin() {\n if (process.stdin.isTTY) {\n return ''\n }\n\n let data = ''\n for await (const chunk of process.stdin) data += chunk\n return data\n}\n\nprocess.on('exit', () => {\n resetCursor()\n PersistentShell.getInstance().close()\n})\n\nfunction gracefulExit(code = 0) {\n try { resetCursor() } catch {}\n try { PersistentShell.getInstance().close() } catch {}\n process.exit(code)\n}\n\nprocess.on('SIGINT', () => gracefulExit(0))\nprocess.on('SIGTERM', () => gracefulExit(0))\n// Windows CTRL+BREAK\nprocess.on('SIGBREAK', () => gracefulExit(0))\nprocess.on('unhandledRejection', err => {\n console.error('Unhandled rejection:', err)\n gracefulExit(1)\n})\nprocess.on('uncaughtException', err => {\n console.error('Uncaught exception:', err)\n gracefulExit(1)\n})\n\nfunction resetCursor() {\n const terminal = process.stderr.isTTY\n ? process.stderr\n : process.stdout.isTTY\n ? process.stdout\n : undefined\n terminal?.write(`\\u001B[?25h${cursorShow}`)\n}\n\nmain()\n"],
|
|
5
|
-
"mappings": ";AACA,SAAS,qBAAqB;AAC9B,SAAS,SAAS,YAAY;AAC9B,SAAS,kBAAkB;AAC3B,SAAS,kBAAkB;AAC3B,SAAS,iBAAiB,oBAAoB;AAC9C,WAAW;AAIX,IAAI;AACF,MAAI,CAAC,QAAQ,IAAI,gBAAgB;AAC/B,UAAM,aAAa,cAAc,YAAY,GAAG;AAChD,UAAM,YAAY,QAAQ,UAAU;AACpC,UAAM,eAAe,KAAK,WAAW,iBAAiB;AACtD,UAAM,gBAAgB,KAAK,WAAW,aAAa;AACnD,UAAM,WAAW,WAAW,aAAa,IACrC,gBACA,WAAW,YAAY,IACrB,eACA;AACN,QAAI,UAAU;AACZ,cAAQ,IAAI,iBAAiB;AAAA,IAC/B;AAAA,EACF;AACF,QAAQ;AAAC;AAKT,YAAY,cAAc;AAC1B,OAAO,KAAK,QAAQ;AAEpB,OAAO,WAAW;AAClB,SAAS,kBAAkB;AAC3B,SAAS,gBAAgB;AAGzB,SAAS,oBAAoB;AAC7B,SAAS,YAAY,YAAY,qBAAqB;AACtD,SAAS,eAAe;AACxB,SAAS,WAAW;AACpB,SAAS,+BAA+B;AACxC,SAAS,gBAAgB;AACzB;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAGA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,WAAW;AACpB,SAAS,gBAAgB,UAAU,wBAAwB;AAC3D,SAAS,uBAAuB;AAChC,SAAS,kBAAkB;AAC3B,SAAS,cAAc;AAEvB,SAAS,mBAAmB;AAC5B,SAAS,mCAAoD;AAC7D,SAAS,oCAAoC;AAC7C,SAAS,eAAe;AACxB,SAAS,0BAA0B;AACnC,SAAS,sBAAsB;AAE/B,SAAS,QAAQ,QAAQ,sBAAsB;AAC/C,SAAS,YAAY;AACrB,SAAS,mBAAmB;AAC5B,SAAS,+BAA+B,mBAAmB;AAC3D,SAAS,2BAA2B;AACpC,SAAS,0CAA0C;AACnD;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,kCAAkC;AAC3C,SAAuC,gBAAgB;AAEvD,SAAS,kBAAkB;AAC3B;AAAA,EACE;AAAA,EAEA;AAAA,EACA;AAAA,OACK;AACP,SAAS,UAAU;AACnB,SAAS,mBAAmB;AAE5B,SAAS,uBAAuB;AAEhC,SAAS,qBAAqB;AAC9B,SAAS,+BAA+B;AACxC,SAAS,wBAAwB;AACjC,SAAS,yCAAyC;AAClD,SAAS,aAAa;AACf,SAAS,qBAA2B;AACzC,QAAM,SAAS,gBAAgB;AAC/B,mBAAiB;AAAA,IACf,GAAG;AAAA,IACH,wBAAwB;AAAA,IACxB,uBAAuB,MAAM;AAAA,EAC/B,CAAC;AACH;AAEA,eAAe,iBACb,UACA,OACe;AACf,MAAI,QAAQ,IAAI,aAAa,QAAQ;AACnC;AAAA,EACF;AAEA,QAAM,SAAS,gBAAgB;AAC/B,MACE,CAAC,OAAO,SACR,CAAC,OAAO,wBACR;AACA,UAAM,cAAc;AACpB,UAAM,EAAE,OAAO,IAAI,MAAM,OAAO,KAAK;AACrC,UAAM,IAAI,QAAc,aAAW;AACjC;AAAA,QACE;AAAA,UAAC;AAAA;AAAA,YACC,QAAQ,YAAY;AAClB,iCAAmB;AACnB,oBAAM,cAAc;AACpB,sBAAQ;AAAA,YACV;AAAA;AAAA,QACF;AAAA,QACA;AAAA,UACE,aAAa;AAAA,QACf;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACH;AA2BA,MAAI,CAAC,SAAS,UAAU;AACtB,QAAI,CAAC,4BAA4B,GAAG;AAClC,YAAM,IAAI,QAAc,aAAW;AACjC,cAAM,SAAS,MAAM;AAEnB,4CAAkC;AAClC,kBAAQ;AAAA,QACV;AACC,SAAC,YAAY;AACZ,gBAAM,EAAE,OAAO,IAAI,MAAM,OAAO,KAAK;AACrC,iBAAO,oCAAC,eAAY,QAAgB,GAAI;AAAA,YACtC,aAAa;AAAA,UACf,CAAC;AAAA,QACH,GAAG;AAAA,MACL,CAAC;AAAA,IACH;AAGA,QAAI,QAAQ,IAAI,cAAc,OAAO;AACnC,YAAM,2BAA2B;AAAA,IACnC;AAAA,EACF;AACF;AAEA,SAAS,aAAmB;AAC1B,QAAM,SAAS,gBAAgB;AAC/B,mBAAiB;AAAA,IACf,GAAG;AAAA,IACH,cAAc,OAAO,eAAe,KAAK;AAAA,EAC3C,CAAC;AACH;AAEA,eAAe,MAAMA,MAAa,UAAmC;AAEnE,MAAIA,SAAQ,QAAQ,IAAI,GAAG;AACzB,mBAAeA,IAAG;AAAA,EACpB;AACA,QAAM,OAAOA,IAAG;AAGhB,oCAAkC;AAIlC,MAAI;AACJ,MAAI;AACF,kBAAc,MAAM,OAAO,yBAAyB;AAAA,EACtD,QAAQ;AACN,kBAAc,MAAM,OAAO,sBAAsB;AAAA,EACnD;AACA,QAAM,EAAE,mBAAmB,gBAAgB,IAAI;AAC/C,QAAM,kBAAkB,MAAM;AAE5B,YAAQ,IAAI,0CAAqC;AAAA,EACnD,CAAC;AAGD,MAAI,UAAU;AAEZ,QACE,QAAQ,aAAa,WACrB,OAAO,QAAQ,WAAW,cAC1B,QAAQ,OAAO,MAAM,GACrB;AACA,cAAQ;AAAA,QACN;AAAA,MACF;AACA,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF;AAEA,MAAI,QAAQ,IAAI,aAAa,QAAQ;AACnC;AAAA,EACF;AAEA,qCAAmC;AAEnC,aAAW;AAIX,QAAM,eAAe,gBAAgB;AACrC,MACE,aAAa,8BAA8B,QAC3C,aAAa,kCAAkC,MAC/C;AACA,UAAM,gBAAgB;AAAA,MACpB,GAAG;AAAA,MACH,+BAA+B;AAAA,IACjC;AAEA,WAAO,cAAc;AACrB,qBAAiB,aAAa;AAAA,EAChC;AAGA,QAAM,gBAAgB,wBAAwB;AAC9C,MACE,cAAc,aAAa,UAC3B,cAAc,iBAAiB,QAC/B;AACA,aAAS,cAAc;AAAA,MACrB,mBAAmB,OAAO,cAAc,QAAQ;AAAA,MAChD,2BAA2B,OAAO,cAAc,eAAe;AAAA,MAC/D,uBAAuB,OAAO,cAAc,YAAY;AAAA,MACxD,iBAAiB,cAAc;AAAA,IACjC,CAAC;AAAA,EASH;AAGA,QAAM,oBAAoB,aAAa,qBAAqB;AAC5D,MAAI,sBAAsB,kBAAkB;AAC1C,aAAS,2CAA2C,CAAC,CAAC;AACtD,UAAM,IAAI,QAAc,aAAW;AACjC;AAAC,OAAC,YAAY;AACZ,cAAM,EAAE,OAAO,IAAI,MAAM,OAAO,KAAK;AACrC,eAAO,oCAAC,UAAO,QAAQ,MAAM,QAAQ,GAAG,CAAE;AAAA,MAC5C,GAAG;AAAA,IACL,CAAC;AAAA,EACH;AACF;AAEA,eAAe,OAAO;AAEpB,kBAAgB;AAGhB,MAAI;AACF,kBAAc;AAGd,QAAI;AACF,YAAM,eAAe,iCAAiC;AACtD,UAAI,aAAa,WAAW,GAAG;AAC7B,gBAAQ,IAAI,2BAAoB,aAAa,QAAQ,6BAA6B;AAAA,MACpF;AAAA,IACF,SAAS,aAAa;AAEpB,cAAQ,KAAK,uDAA6C,WAAW;AAAA,IACvE;AAAA,EACF,SAAS,OAAgB;AACvB,QAAI,iBAAiB,kBAAkB;AAErC,YAAM,wBAAwB,EAAE,MAAM,CAAC;AACvC;AAAA,IACF;AAAA,EACF;AAIA,MAAI,cAAc;AAClB,MAAI,gBAA2C;AAAA,IAC7C,aAAa;AAAA,IAEb,YAAY;AACV,eAAS,iBAAiB,CAAC,CAAC;AAAA,IAC9B;AAAA,EACF;AAEA,MACE,CAAC,QAAQ,MAAM,SACf,CAAC,QAAQ,IAAI;AAAA,EAEb,CAAC,QAAQ,KAAK,SAAS,KAAK,GAC5B;AACA,kBAAc,MAAM,MAAM;AAC1B,QAAI,QAAQ,aAAa,SAAS;AAChC,UAAI;AACF,cAAM,QAAQ,SAAS,YAAY,GAAG;AACtC,wBAAgB,EAAE,GAAG,eAAe,OAAO,IAAI,WAAW,KAAK,EAAE;AAAA,MACnE,SAAS,KAAK;AACZ,iBAAS,4BAA4B,GAAG,EAAE;AAAA,MAC5C;AAAA,IACF;AAAA,EACF;AACA,QAAM,UAAU,aAAa,aAAa;AAC5C;AAEA,eAAe,UACb,cACA,eACkB;AAClB,QAAM,UAAU,IAAI,QAAQ;AAE5B,QAAM,+BAA+B;AAAA,IACnC,GAAG;AAAA,IACH,aAAa;AAAA,EACf;AAGA,QAAM,WAAW,MAAM,YAAY;AAGnC,QAAM,cAAc,SACjB,OAAO,SAAO,CAAC,IAAI,QAAQ,EAC3B,IAAI,SAAO,IAAI,IAAI,IAAI,MAAM,IAAI,WAAW,EAAE,EAC9C,KAAK,IAAI;AAEZ,UACG,KAAK,eAAe,EACpB;AAAA,IACC,GAAG,YAAY;AAAA;AAAA;AAAA,EAGnB,WAAW;AAAA,EACT,EACC,SAAS,YAAY,eAAe,MAAM,EAC1C,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,OAAO,eAAe,qBAAqB,MAAM,IAAI,EACrD;AAAA,IACC;AAAA,IACA;AAAA,IACA,MAAM;AAAA,EACR,EACC;AAAA,IACC;AAAA,IACA;AAAA,IACA,MAAM;AAAA,EACR,EACC,OAAO,0BAA0B,6BAA6B,MAAM,IAAI,EACxE;AAAA,IACC;AAAA,IACA;AAAA,IACA,MAAM;AAAA,EACR,EACC;AAAA,IACC;AAAA,IACA;AAAA,IACA,MAAM;AAAA,EACR,EACC;AAAA,IACC,OAAO,QAAQ,EAAE,KAAAA,MAAK,OAAO,SAAS,iBAAiB,OAAO,KAAK,MAAM;AACvE,YAAM,iBAAiB,MAAM,KAAK;AAClC,eAAS,cAAc;AAAA,QACrB,YAAY;AAAA,QACZ,kBAAkB,QAAQ,MAAM,EAAE,SAAS;AAAA,QAC3C,UAAU,QAAQ,YAAY,EAAE,SAAS;AAAA,QACzC,iBAAiB,iBAAiB,SAAS,KAAK;AAAA,QAChD,SAAS,SAAS,SAAS,KAAK;AAAA,QAChC,OAAO,OAAO,SAAS,KAAK;AAAA,QAC5B,OAAO,OAAO,SAAS,KAAK;AAAA,MAC9B,CAAC;AACD,YAAM,MAAMA,MAAK,IAAI;AAErB,uBAAiB;AAEjB,YAAM,CAAC,OAAO,UAAU,IAAI,MAAM,QAAQ,IAAI;AAAA,QAC5C;AAAA,UACE,mBAAmB,wBAAwB,EAAE;AAAA,QAC/C;AAAA,QACA,WAAW;AAAA,MACb,CAAC;AAED,YAAM,cAAc,CAAC,QAAQ,YAAY,EAAE,OAAO,OAAO,EAAE,KAAK,IAAI;AACpE,UAAI,OAAO;AACT,YAAI,CAAC,aAAa;AAChB,kBAAQ;AAAA,YACN;AAAA,UACF;AACA,kBAAQ,KAAK,CAAC;AAAA,QAChB;AAEA,qBAAa,WAAW;AACxB,cAAM,EAAE,YAAY,SAAS,IAAI,MAAM,IAAI;AAAA,UACzC;AAAA,UACA;AAAA,UACA,gBAAgB,eAAe,oBAAI,KAAK,CAAC;AAAA,UACzC,QAAQ;AAAA,UACR,KAAAA;AAAA,UACA;AAAA,UACA,UAAU;AAAA,QACZ,CAAC;AACD,gBAAQ,IAAI,QAAQ;AACpB,gBAAQ,KAAK,CAAC;AAAA,MAChB,OAAO;AACL,cAAM,iBAAiB,MAAM,6BAA6B;AAG1D,cAAM,aAAa,OAAO,YAAY;AACpC,cAAI;AACF,kBAAM,SAAS,MAAM,iBAAiB;AACtC,gBAAI,UAAU,GAAG,QAAQ,MAAM,OAAO,GAAG;AACvC,oBAAM,OAAO,MAAM,4BAA4B;AAC/C,qBAAO,EAAE,SAAS,QAAkB,UAAU,KAAiB;AAAA,YACjE;AAAA,UACF,QAAQ;AAAA,UAAC;AACT,iBAAO,EAAE,SAAS,MAAuB,UAAU,KAAwB;AAAA,QAC7E,GAAG;AAEH;AACE,gBAAM,EAAE,OAAO,IAAI,MAAM,OAAO,KAAK;AACrC,gBAAM,EAAE,KAAK,IAAI,MAAM,OAAO,iBAAiB;AAC/C;AAAA,YACE;AAAA,cAAC;AAAA;AAAA,gBACD;AAAA,gBACA;AAAA,gBACA,eAAe;AAAA,gBACf,gBAAgB,eAAe,oBAAI,KAAK,CAAC;AAAA,gBACzC,uBAAuB;AAAA,gBACvB;AAAA,gBACA;AAAA,gBACA,UAAU;AAAA,gBACV;AAAA,gBACA;AAAA,gBACA,sBAAsB,WAAW;AAAA,gBACjC,uBAAuB,WAAW;AAAA;AAAA,YACpC;AAAA,YACA;AAAA,UACA;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF,EACC,QAAQ,MAAM,SAAS,eAAe;AAoBzC,QAAM,SAAS,QACZ,QAAQ,QAAQ,EAChB;AAAA,IACC,6BAA6B,eAAe;AAAA,EAC9C;AAEF,SACG,QAAQ,WAAW,EACnB,YAAY,oBAAoB,EAChC,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,OAAO,gBAAgB,mBAAmB,EAC1C,OAAO,OAAO,KAAK,EAAE,KAAAA,MAAK,OAAO,MAAM;AACtC,UAAM,MAAMA,MAAK,KAAK;AACtB,YAAQ,IAAI,gBAAgB,KAAK,UAAU,KAAK,CAAC;AACjD,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAEH,SACG,QAAQ,mBAAmB,EAC3B,YAAY,oBAAoB,EAChC,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,OAAO,gBAAgB,mBAAmB,EAC1C,OAAO,OAAO,KAAK,OAAO,EAAE,KAAAA,MAAK,OAAO,MAAM;AAC7C,UAAM,MAAMA,MAAK,KAAK;AACtB,oBAAgB,KAAK,OAAO,UAAU,KAAK;AAC3C,YAAQ,IAAI,OAAO,GAAG,OAAO,KAAK,EAAE;AACpC,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAEH,SACG,QAAQ,cAAc,EACtB,YAAY,uBAAuB,EACnC,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,OAAO,gBAAgB,mBAAmB,EAC1C,OAAO,OAAO,KAAK,EAAE,KAAAA,MAAK,OAAO,MAAM;AACtC,UAAM,MAAMA,MAAK,KAAK;AACtB,uBAAmB,KAAK,UAAU,KAAK;AACvC,YAAQ,IAAI,WAAW,GAAG,EAAE;AAC5B,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAEH,SACG,QAAQ,MAAM,EACd,YAAY,wBAAwB,EACpC,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,OAAO,gBAAgB,qBAAqB,KAAK,EACjD,OAAO,OAAO,EAAE,KAAAA,MAAK,OAAO,MAAM;AACjC,UAAM,MAAMA,MAAK,KAAK;AACtB,YAAQ;AAAA,MACN,KAAK,UAAU,SAAS,iBAAiB,IAAI,IAAI,iBAAiB,KAAK,GAAG,MAAM,CAAC;AAAA,IACnF;AACA,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAIH,QAAM,eAAe,QAClB,QAAQ,gBAAgB,EACxB,YAAY,uBAAuB;AAEtC,eACG,QAAQ,MAAM,EACd,YAAY,yBAAyB,EACrC,OAAO,YAAY;AAClB,UAAM,SAAS,wBAAwB,OAAO,CAAC;AAC/C,YAAQ,IAAI,MAAM;AAClB,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAEH,eACG,QAAQ,eAAe,EACvB,YAAY,+CAA+C,EAC3D,OAAO,OAAO,SAAiB;AAC9B,UAAM,SAAS,yBAAyB,IAAI;AAC5C,aAAS,8BAA8B;AAAA,MACrC;AAAA,MACA,SAAS,OAAO,OAAO,OAAO;AAAA,IAChC,CAAC;AACD,YAAQ,IAAI,OAAO,OAAO;AAC1B,YAAQ,KAAK,OAAO,UAAU,IAAI,CAAC;AAAA,EACrC,CAAC;AAIH,QAAM,MAAM,QACT,QAAQ,KAAK,EACb,YAAY,kCAAkC;AAEjD,MACG,QAAQ,OAAO,EACf,YAAY,aAAa,YAAY,aAAa,EAClD,OAAO,YAAY;AAClB,UAAM,cAAe,QAAQ,KAAK,EAAuB,OAAO,IAAI;AACpE,aAAS,mBAAmB,EAAE,YAAY,CAAC;AAG3C,QAAI,CAAC,WAAW,WAAW,GAAG;AAC5B,cAAQ,MAAM,oBAAoB,WAAW,iBAAiB;AAC9D,cAAQ,KAAK,CAAC;AAAA,IAChB;AAEA,QAAI;AACF,YAAM,MAAM,aAAa,KAAK;AAC9B,YAAM,eAAe,WAAW;AAAA,IAClC,SAAS,OAAO;AACd,cAAQ,MAAM,sCAAsC,KAAK;AACzD,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AAEH,MACG,QAAQ,sBAAsB,EAC9B,YAAY,mBAAmB,EAC/B;AAAA,IACC;AAAA,IACA;AAAA,IACA;AAAA,EACF,EACC,OAAO,OAAO,MAAM,KAAK,YAAY;AACpC,QAAI;AACF,YAAM,QAAQ,kBAAkB,QAAQ,KAAK;AAC7C,eAAS,iBAAiB,EAAE,MAAM,MAAM,OAAO,MAAM,CAAC;AAEtD,mBAAa,MAAM,EAAE,MAAM,OAAO,IAAI,GAAG,KAAK;AAC9C,cAAQ;AAAA,QACN,wBAAwB,IAAI,aAAa,GAAG,OAAO,KAAK;AAAA,MAC1D;AACA,cAAQ,KAAK,CAAC;AAAA,IAChB,SAAS,OAAO;AACd,cAAQ,MAAO,MAAgB,OAAO;AACtC,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AAEH,MACG,QAAQ,qCAAqC,EAC7C,YAAY,6DAA6D,EACzE;AAAA,IACC;AAAA,IACA;AAAA,IACA;AAAA,EACF,EACC;AAAA,IACC;AAAA,IACA;AAAA,EACF,EACC,OAAO,OAAO,MAAM,cAAc,MAAM,YAAY;AACnD,QAAI;AAEF,UAAI,CAAC,MAAM;AACT,gBAAQ,IAAI,mDAAmD;AAC/D,cAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,UAAU;AACnD,cAAM,KAAK,gBAAgB;AAAA,UACzB,OAAO,QAAQ;AAAA,UACf,QAAQ,QAAQ;AAAA,QAClB,CAAC;AAED,cAAM,WAAW,CAAC,UAChB,IAAI,QAAgB,aAAW,GAAG,SAAS,OAAO,OAAO,CAAC;AAG5D,cAAM,aAAa,MAAM,SAAS,eAAe;AACjD,YAAI,CAAC,YAAY;AACf,kBAAQ,MAAM,gCAAgC;AAC9C,aAAG,MAAM;AACT,kBAAQ,KAAK,CAAC;AAAA,QAChB;AAGA,cAAM,aAAa,MAAM;AAAA,UACvB;AAAA,QACF;AACA,cAAM,OACJ,cAAc,CAAC,SAAS,KAAK,EAAE,SAAS,UAAU,IAC9C,aACA;AAGN,cAAM,SAAS,SAAS,UAAU,cAAc;AAChD,cAAM,oBAAoB,MAAM,SAAS,MAAM;AAC/C,YAAI,CAAC,mBAAmB;AACtB,kBAAQ;AAAA,YACN,UAAU,SAAS,UAAU,YAAY,KAAK;AAAA,UAChD;AACA,aAAG,MAAM;AACT,kBAAQ,KAAK,CAAC;AAAA,QAChB;AAGA,YAAI,aAAuB,CAAC;AAC5B,YAAI,YAAoC,CAAC;AAEzC,YAAI,SAAS,SAAS;AACpB,gBAAM,UAAU,MAAM;AAAA,YACpB;AAAA,UACF;AACA,uBAAa,UAAU,QAAQ,MAAM,GAAG,EAAE,OAAO,OAAO,IAAI,CAAC;AAE7D,gBAAM,SAAS,MAAM;AAAA,YACnB;AAAA,UACF;AACA,cAAI,QAAQ;AACV,kBAAM,WAAW,OAAO,MAAM,GAAG,EAAE,IAAI,UAAQ,KAAK,KAAK,CAAC;AAC1D,wBAAY,aAAa,SAAS,IAAI,UAAQ,IAAI,CAAC;AAAA,UACrD;AAAA,QACF;AAGA,cAAM,WAAW,MAAM;AAAA,UACrB;AAAA,QACF;AACA,cAAM,cAAc,kBAAkB,YAAY,SAAS;AAE3D,WAAG,MAAM;AAGT,YAAI,SAAS,OAAO;AAClB,mBAAS,iBAAiB;AAAA,YACxB,MAAM;AAAA,YACN,MAAM;AAAA,YACN,OAAO;AAAA,UACT,CAAC;AACD;AAAA,YACE;AAAA,YACA,EAAE,MAAM,OAAO,KAAK,kBAAkB;AAAA,YACtC;AAAA,UACF;AACA,kBAAQ;AAAA,YACN,wBAAwB,UAAU,aAAa,iBAAiB,OAAO,WAAW;AAAA,UACpF;AAAA,QACF,OAAO;AACL,mBAAS,iBAAiB;AAAA,YACxB,MAAM;AAAA,YACN,MAAM;AAAA,YACN,OAAO;AAAA,UACT,CAAC;AACD;AAAA,YACE;AAAA,YACA;AAAA,cACE,MAAM;AAAA,cACN,SAAS;AAAA,cACT,MAAM;AAAA,cACN,KAAK;AAAA,YACP;AAAA,YACA;AAAA,UACF;AAEA,kBAAQ;AAAA,YACN,0BAA0B,UAAU,kBAAkB,iBAAiB,IAAI,WAAW,KAAK,GAAG,CAAC,OAAO,WAAW;AAAA,UACnH;AAAA,QACF;AAAA,MACF,WAAW,QAAQ,cAAc;AAE/B,cAAM,QAAQ,kBAAkB,QAAQ,KAAK;AAG7C,YAAI,aAAa,MAAM,cAAc,GAAG;AACtC,mBAAS,iBAAiB,EAAE,MAAM,MAAM,OAAO,MAAM,CAAC;AACtD,uBAAa,MAAM,EAAE,MAAM,OAAO,KAAK,aAAa,GAAG,KAAK;AAC5D,kBAAQ;AAAA,YACN,wBAAwB,IAAI,aAAa,YAAY,OAAO,KAAK;AAAA,UACnE;AAAA,QACF,OAAO;AACL,mBAAS,iBAAiB,EAAE,MAAM,MAAM,SAAS,MAAM,CAAC;AACxD,gBAAMC,OAAM,aAAa,QAAQ,GAAG;AACpC;AAAA,YACE;AAAA,YACA,EAAE,MAAM,SAAS,SAAS,cAAc,MAAM,QAAQ,CAAC,GAAG,KAAAA,KAAI;AAAA,YAC9D;AAAA,UACF;AAEA,kBAAQ;AAAA,YACN,0BAA0B,IAAI,kBAAkB,YAAY,KAAK,QAAQ,CAAC,GAAG,KAAK,GAAG,CAAC,OAAO,KAAK;AAAA,UACpG;AAAA,QACF;AAAA,MACF,OAAO;AACL,gBAAQ;AAAA,UACN;AAAA,QACF;AACA,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAEA,cAAQ,KAAK,CAAC;AAAA,IAChB,SAAS,OAAO;AACd,cAAQ,MAAO,MAAgB,OAAO;AACtC,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AACH,MACG,QAAQ,eAAe,EACvB,YAAY,sBAAsB,EAClC;AAAA,IACC;AAAA,IACA;AAAA,IACA;AAAA,EACF,EACC,OAAO,OAAO,MAAc,YAAgC;AAC3D,QAAI;AACF,YAAM,QAAQ,kBAAkB,QAAQ,KAAK;AAC7C,eAAS,oBAAoB,EAAE,MAAM,MAAM,CAAC;AAE5C,sBAAgB,MAAM,KAAK;AAC3B,cAAQ,IAAI,sBAAsB,IAAI,SAAS,KAAK,SAAS;AAC7D,cAAQ,KAAK,CAAC;AAAA,IAChB,SAAS,OAAO;AACd,cAAQ,MAAO,MAAgB,OAAO;AACtC,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AAEH,MACG,QAAQ,MAAM,EACd,YAAY,6BAA6B,EACzC,OAAO,MAAM;AACZ,aAAS,kBAAkB,CAAC,CAAC;AAC7B,UAAM,UAAU,eAAe;AAC/B,QAAI,OAAO,KAAK,OAAO,EAAE,WAAW,GAAG;AACrC,cAAQ;AAAA,QACN,oCAAoC,eAAe;AAAA,MACrD;AAAA,IACF,OAAO;AACL,iBAAW,CAAC,MAAM,MAAM,KAAK,OAAO,QAAQ,OAAO,GAAG;AACpD,YAAI,OAAO,SAAS,OAAO;AACzB,kBAAQ,IAAI,GAAG,IAAI,KAAK,OAAO,GAAG,QAAQ;AAAA,QAC5C,OAAO;AACL,kBAAQ,IAAI,GAAG,IAAI,KAAK,OAAO,OAAO,IAAI,OAAO,KAAK,KAAK,GAAG,CAAC,EAAE;AAAA,QACnE;AAAA,MACF;AAAA,IACF;AACA,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAEH,MACG,QAAQ,wBAAwB,EAChC,YAAY,qDAAqD,EACjE;AAAA,IACC;AAAA,IACA;AAAA,IACA;AAAA,EACF,EACC,OAAO,OAAO,MAAM,SAAS,YAAY;AACxC,QAAI;AACF,YAAM,QAAQ,kBAAkB,QAAQ,KAAK;AAG7C,UAAI;AACJ,UAAI;AACF,uBAAe,KAAK,MAAM,OAAO;AAAA,MACnC,SAAS,GAAG;AACV,gBAAQ,MAAM,4BAA4B;AAC1C,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAGA,UACE,CAAC,aAAa,QACd,CAAC,CAAC,SAAS,KAAK,EAAE,SAAS,aAAa,IAAI,GAC5C;AACA,gBAAQ,MAAM,6CAA6C;AAC3D,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAEA,UAAI,aAAa,SAAS,SAAS,CAAC,aAAa,KAAK;AACpD,gBAAQ,MAAM,mCAAmC;AACjD,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAEA,UAAI,aAAa,SAAS,WAAW,CAAC,aAAa,SAAS;AAC1D,gBAAQ,MAAM,yCAAyC;AACvD,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAGA,eAAS,sBAAsB,EAAE,MAAM,MAAM,aAAa,MAAM,MAAM,CAAC;AACvE,mBAAa,MAAM,cAAc,KAAK;AAEtC,UAAI,aAAa,SAAS,OAAO;AAC/B,gBAAQ;AAAA,UACN,wBAAwB,IAAI,aAAa,aAAa,GAAG,OAAO,KAAK;AAAA,QACvE;AAAA,MACF,OAAO;AACL,gBAAQ;AAAA,UACN,0BAA0B,IAAI,kBAAkB,aAAa,OAAO,KAClE,aAAa,QAAQ,CAAC,GACtB,KAAK,GAAG,CAAC,OAAO,KAAK;AAAA,QACzB;AAAA,MACF;AAEA,cAAQ,KAAK,CAAC;AAAA,IAChB,SAAS,OAAO;AACd,cAAQ,MAAO,MAAgB,OAAO;AACtC,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AAEH,MACG,QAAQ,YAAY,EACpB,YAAY,iCAAiC,EAC7C,OAAO,CAAC,SAAiB;AACxB,aAAS,iBAAiB,EAAE,KAAK,CAAC;AAClC,UAAM,SAAS,aAAa,IAAI;AAChC,QAAI,CAAC,QAAQ;AACX,cAAQ,MAAM,kCAAkC,IAAI,EAAE;AACtD,cAAQ,KAAK,CAAC;AAAA,IAChB;AACA,YAAQ,IAAI,GAAG,IAAI,GAAG;AACtB,YAAQ,IAAI,YAAY,OAAO,KAAK,EAAE;AACtC,QAAI,OAAO,SAAS,OAAO;AACzB,cAAQ,IAAI,aAAa;AACzB,cAAQ,IAAI,UAAU,OAAO,GAAG,EAAE;AAAA,IACpC,OAAO;AACL,cAAQ,IAAI,eAAe;AAC3B,cAAQ,IAAI,cAAc,OAAO,OAAO,EAAE;AAC1C,cAAQ,IAAI,WAAW,OAAO,KAAK,KAAK,GAAG,CAAC,EAAE;AAC9C,UAAI,OAAO,KAAK;AACd,gBAAQ,IAAI,gBAAgB;AAC5B,mBAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,OAAO,GAAG,GAAG;AACrD,kBAAQ,IAAI,OAAO,GAAG,IAAI,KAAK,EAAE;AAAA,QACnC;AAAA,MACF;AAAA,IACF;AACA,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAGH,MACG,QAAQ,yBAAyB,EACjC;AAAA,IACC;AAAA,EACF,EACC;AAAA,IACC;AAAA,IACA;AAAA,IACA;AAAA,EACF,EACC,OAAO,OAAM,YAAW;AACvB,QAAI;AACF,YAAM,QAAQ,kBAAkB,QAAQ,KAAK;AAC7C,YAAM,WAAW,QAAQ;AAGzB,YAAM,EAAE,YAAAC,aAAY,aAAa,IAAI,MAAM,OAAO,IAAI;AACtD,YAAM,EAAE,MAAAC,MAAK,IAAI,MAAM,OAAO,MAAM;AACpC,YAAM,EAAE,KAAK,IAAI,MAAM,OAAO,eAAe;AAG7C,YAAM,QACJ,aAAa,WACbD,YAAW,eAAe,KAC1B,aAAa,iBAAiB,OAAO,EAClC,YAAY,EACZ,SAAS,WAAW;AAEzB,UAAI,aAAa,YAAY,aAAa,WAAW,CAAC,OAAO;AAC3D,gBAAQ;AAAA,UACN;AAAA,QACF;AACA,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAGA,UAAI;AACJ,UAAI,aAAa,UAAU;AACzB,qBAAaC;AAAA,UACX,QAAQ,IAAI,QAAQ;AAAA,UACpB;AAAA,QACF;AAAA,MACF,WAAW,aAAa,SAAS;AAC/B,qBAAaA;AAAA,UACX,QAAQ,IAAI,WAAW;AAAA,UACvB;AAAA,QACF;AAAA,MACF,WAAW,OAAO;AAEhB,cAAM,gBAAgB,MAAM,IAAI,QAAgB,CAAC,SAAS,WAAW;AACnE;AAAA,YACE;AAAA,YACA,CAAC,KAAY,WAAmB;AAC9B,kBAAI,IAAK,QAAO,GAAG;AAAA,kBACd,SAAQ,OAAO,KAAK,EAAE,MAAM,IAAI,EAAE,IAAI,KAAK,EAAE;AAAA,YACpD;AAAA,UACF;AAAA,QACF,CAAC;AAED,qBAAa,gBAAgB,aAAa;AAAA,MAC5C;AAGA,UAAI,CAACD,YAAW,UAAU,GAAG;AAC3B,gBAAQ;AAAA,UACN,kDAAkD,UAAU;AAAA,QAC9D;AACA,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAGA,UAAIE;AACJ,UAAI;AACF,cAAM,gBAAgB,aAAa,YAAY,OAAO;AACtD,QAAAA,UAAS,KAAK,MAAM,aAAa;AAAA,MACnC,SAAS,KAAK;AACZ,gBAAQ,MAAM,8BAA8B,GAAG,EAAE;AACjD,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAGA,YAAM,aAAaA,QAAO,cAAc,CAAC;AACzC,YAAM,cAAc,OAAO,KAAK,UAAU;AAC1C,YAAM,aAAa,YAAY;AAE/B,UAAI,eAAe,GAAG;AACpB,gBAAQ,IAAI,+CAA+C;AAC3D,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAGA,YAAM,cAAc,YAAY,IAAI,UAAQ;AAC1C,cAAM,SAAS,WAAW,IAAI;AAC9B,YAAI,cAAc;AAElB,YAAI,OAAO,SAAS,OAAO;AACzB,wBAAc,QAAQ,OAAO,GAAG;AAAA,QAClC,OAAO;AACL,wBAAc,UAAU,OAAO,OAAO,KAAK,OAAO,QAAQ,CAAC,GAAG,KAAK,GAAG,CAAC;AAAA,QACzE;AAEA,eAAO,EAAE,MAAM,aAAa,OAAO;AAAA,MACrC,CAAC;AAID,YAAM,MAAM,MAAM,OAAO,KAAK;AAC9B,YAAM,cAAc,MAAM,OAAO,OAAO;AACxC,YAAM,UAAU,MAAM,OAAO,WAAW;AACxC,YAAM,aAAa,MAAM,OAAO,gBAAgB;AAEhD,YAAM,EAAE,OAAO,IAAI;AACnB,YAAMC,SAAQ;AACd,YAAM,EAAE,YAAY,IAAI;AACxB,YAAM,EAAE,KAAK,KAAK,IAAI;AACtB,YAAM,EAAE,SAAS,IAAI;AAGrB,YAAM,IAAI,QAAc,aAAW;AAEjC,iBAAS,sBAAsB;AAC7B,gBAAM,EAAE,SAAS,IAAI;AACrB,gBAAM,CAAC,YAAY,aAAa,IAAI,SAAS,KAAK;AAClD,gBAAM,CAAC,eAAe,gBAAgB,IAAI,SAAS,CAAC,CAAyC;AAC7F,gBAAM,CAAC,aAAa,cAAc,IAAI,SAAS,KAAK;AACpD,gBAAM,QAAQ,SAAS;AAGvB,gBAAM,gBAAgB,OAAO,oBAA8B;AACzD,2BAAe,IAAI;AACnB,kBAAM,UAAU,CAAC;AAEjB,uBAAW,QAAQ,iBAAiB;AAClC,kBAAI;AACF,sBAAM,SAAS,WAAW,IAAI;AAG9B,sBAAM,iBAAiB,aAAa,IAAI;AACxC,oBAAI,gBAAgB;AAElB;AAAA,gBACF;AAEA,6BAAa,MAAM,QAA2B,KAAK;AACnD,wBAAQ,KAAK,EAAE,MAAM,SAAS,KAAK,CAAC;AAAA,cACtC,SAAS,KAAK;AACZ,wBAAQ,KAAK,EAAE,MAAM,SAAS,MAAM,CAAC;AAAA,cACvC;AAAA,YACF;AAEA,6BAAiB,OAAO;AACxB,2BAAe,KAAK;AACpB,0BAAc,IAAI;AAGlB,uBAAW,MAAM;AACf,sBAAQ;AAAA,YACV,GAAG,GAAI;AAAA,UACT;AAGA,gBAAM,gBAAgB,OAAO,oBAA8B;AAEzD,kBAAM,kBAAkB,gBAAgB;AAAA,cAAO,UAC7C,aAAa,IAAI;AAAA,YACnB;AAEA,gBAAI,gBAAgB,SAAS,GAAG;AAE9B,oBAAM,UAAU,CAAC;AAGjB,oBAAM,aAAa,gBAAgB;AAAA,gBACjC,UAAQ,CAAC,aAAa,IAAI;AAAA,cAC5B;AACA,yBAAW,QAAQ,YAAY;AAC7B,oBAAI;AACF,wBAAM,SAAS,WAAW,IAAI;AAC9B,+BAAa,MAAM,QAA2B,KAAK;AACnD,0BAAQ,KAAK,EAAE,MAAM,SAAS,KAAK,CAAC;AAAA,gBACtC,SAAS,KAAK;AACZ,0BAAQ,KAAK,EAAE,MAAM,SAAS,MAAM,CAAC;AAAA,gBACvC;AAAA,cACF;AAGA,yBAAW,QAAQ,iBAAiB;AAClC,oBAAI;AACF,wBAAM,SAAS,WAAW,IAAI;AAE9B,+BAAa,MAAM,QAA2B,KAAK;AACnD,0BAAQ,KAAK,EAAE,MAAM,SAAS,KAAK,CAAC;AAAA,gBACtC,SAAS,KAAK;AACZ,0BAAQ,KAAK,EAAE,MAAM,SAAS,MAAM,CAAC;AAAA,gBACvC;AAAA,cACF;AAEA,+BAAiB,OAAO;AACxB,6BAAe,KAAK;AACpB,4BAAc,IAAI;AAGlB,yBAAW,MAAM;AACf,wBAAQ;AAAA,cACV,GAAG,GAAI;AAAA,YACT,OAAO;AAEL,oBAAM,cAAc,eAAe;AAAA,YACrC;AAAA,UACF;AAEA,iBACE,gBAAAA,OAAA,cAAC,OAAI,eAAc,UAAS,SAAS,KACnC,gBAAAA,OAAA;AAAA,YAAC;AAAA;AAAA,cACC,eAAc;AAAA,cACd,aAAY;AAAA,cACd,aAAa,MAAM;AAAA,cACjB,SAAS;AAAA,cACT,OAAO;AAAA;AAAA,YAEP,gBAAAA,OAAA,cAAC,QAAK,MAAI,MAAC,OAAO,MAAM,QAAM,wCAE9B;AAAA,YAEA,gBAAAA,OAAA,cAAC,OAAI,SAAS,KACZ,gBAAAA,OAAA,cAAC,YAAK,UACG,YAAW,iCACpB,CACF;AAAA,YAEA,gBAAAA,OAAA,cAAC,YAAK,+CAA6C;AAAA,YAEnD,gBAAAA,OAAA,cAAC,OAAI,WAAW,KACd,gBAAAA,OAAA;AAAA,cAAC;AAAA;AAAA,gBACC,SAAS,YAAY,IAAI,WAAS;AAAA,kBAChC,OAAO;AAAA,kBACP,OAAO;AAAA,gBACT,EAAE;AAAA,gBACF,cAAc;AAAA,gBACd,UAAU;AAAA;AAAA,YACZ,CACF;AAAA,UACF,GAEA,gBAAAA,OAAA,cAAC,OAAI,WAAW,GAAG,YAAY,KAC7B,gBAAAA,OAAA,cAAC,QAAK,UAAQ,QAAC,0DAEf,CACF,GAEC,cACC,gBAAAA,OAAA,cAAC,OAAI,WAAW,KACd,gBAAAA,OAAA,cAAC,QAAK,OAAO,MAAM,WAAS,yBACJ,KACrB,cAAc,OAAO,OAAK,EAAE,OAAO,EAAE,QAAO,8BAE/C,CACF,CAEJ;AAAA,QAEJ;AAGA,cAAM,EAAE,QAAQ,IAAI,OAAO,gBAAAA,OAAA,cAAC,yBAAoB,CAAE;AAGlD,mBAAW,MAAM;AACf,kBAAQ;AACR,kBAAQ;AAAA,QACV,GAAG,GAAK;AAAA,MACV,CAAC;AAED,cAAQ,KAAK,CAAC;AAAA,IAChB,SAAS,OAAO;AACd,cAAQ,MAAM,UAAW,MAAgB,OAAO,EAAE;AAClD,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,CAAC;AAGH,QAAM,kBAAkB,MAAM;AAC5B,UAAMD,UAAS,wBAAwB;AACvC,6BAAyB;AAAA,MACvB,GAAGA;AAAA,MACH,sBAAsB,CAAC;AAAA,MACvB,sBAAsB,CAAC;AAAA,IACzB,CAAC;AACD,YAAQ,IAAI,6DAA6D;AACzE,YAAQ;AAAA,MACN,yDAAyD,YAAY;AAAA,IACvE;AACA,YAAQ,KAAK,CAAC;AAAA,EAChB;AAGA,MACG,QAAQ,uBAAuB,EAC/B;AAAA,IACC;AAAA,EACF,EACC,OAAO,MAAM;AACZ,aAAS,mCAAmC,CAAC,CAAC;AAC9C,oBAAgB;AAAA,EAClB,CAAC;AAGH,MAAI,QAAQ,IAAI,cAAc,OAAO;AACnC,QACG,QAAQ,qBAAqB,EAC7B;AAAA,MACC;AAAA,IACF,EACC,OAAO,MAAM;AACZ,eAAS,iCAAiC,CAAC,CAAC;AAC5C,sBAAgB;AAAA,IAClB,CAAC;AAAA,EACL;AAGA,UACG,QAAQ,QAAQ,EAChB,YAAY,4BAA4B,YAAY,eAAe,EACnE,OAAO,YAAY;AAClB,aAAS,wBAAwB,CAAC,CAAC;AAEnC,UAAM,IAAI,QAAc,aAAW;AACjC;AAAC,OAAC,YAAY;AACZ,cAAM,EAAE,OAAO,IAAI,MAAM,OAAO,KAAK;AACrC,eAAO,oCAAC,UAAO,QAAQ,MAAM,QAAQ,GAAG,YAAY,MAAM,CAAE;AAAA,MAC9D,GAAG;AAAA,IACL,CAAC;AACD,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAKH,UACG,QAAQ,QAAQ,EAChB,YAAY,gDAAgD,EAC5D,OAAO,YAAY;AAClB,aAAS,sBAAsB,CAAC,CAAC;AACjC,YAAQ,IAAI,oBAAoB,MAAM,OAAO,EAAE;AAC/C,YAAQ,IAAI,yBAAyB;AAErC,UAAM,gBAAgB,MAAM,iBAAiB;AAE7C,QAAI,CAAC,eAAe;AAClB,cAAQ,MAAM,6BAA6B;AAC3C,cAAQ,KAAK,CAAC;AAAA,IAChB;AAEA,QAAI,kBAAkB,MAAM,SAAS;AACnC,cAAQ,IAAI,GAAG,YAAY,gBAAgB;AAC3C,cAAQ,KAAK,CAAC;AAAA,IAChB;AAEA,YAAQ,IAAI,0BAA0B,aAAa,EAAE;AACrD,UAAM,EAAE,6BAAAE,6BAA4B,IAAI,MAAM,OAAO,sBAAsB;AAC3E,UAAM,OAAO,MAAMA,6BAA4B;AAC/C,YAAQ,IAAI,gDAAgD;AAC5D,eAAW,KAAK,KAAM,SAAQ,IAAI,KAAK,CAAC,EAAE;AAC1C,QAAI,QAAQ,aAAa,SAAS;AAChC,cAAQ,IAAI,4DAA4D;AAAA,IAC1E;AACA,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAGH,UACG,QAAQ,KAAK,EACb,YAAY,2BAA2B,EACvC;AAAA,IACC;AAAA,IACA;AAAA,IACA;AAAA,EACF,EACC,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,OAAO,OAAO,QAAQ,EAAE,KAAAN,KAAI,MAAM;AACjC,UAAM,MAAMA,MAAK,KAAK;AACtB,aAAS,mBAAmB,EAAE,QAAQ,QAAQ,SAAS,KAAK,GAAG,CAAC;AAChE,UAAMO,WAAoC,CAAC;AAC1C,KAAC,YAAY;AACZ,YAAM,EAAE,OAAO,IAAI,MAAM,OAAO,KAAK;AACrC,YAAM,EAAE,QAAQ,IAAI;AAAA,QAClB,oCAAC,WAAQ,SAASA,UAAS,MAAK,YAAW,WAAW,QAAQ;AAAA,QAC9D;AAAA,MACF;AACA,MAAAA,SAAQ,UAAU;AAAA,IACpB,GAAG;AAAA,EACL,CAAC;AAGH,UACG,QAAQ,QAAQ,EAChB;AAAA,IACC;AAAA,EACF,EACC;AAAA,IACC;AAAA,IACA;AAAA,EACF,EACC,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,OAAO,0BAA0B,6BAA6B,MAAM,IAAI,EACxE,OAAO,iBAAiB,kCAAkC,MAAM,IAAI,EACpE;AAAA,IACC;AAAA,IACA;AAAA,IACA,MAAM;AAAA,EACR,EACC,OAAO,OAAO,YAAY,EAAE,KAAAP,MAAK,iBAAiB,MAAM,QAAQ,MAAM;AACrE,UAAM,MAAMA,MAAK,IAAI;AACrB,qBAAiB;AAEjB,UAAM,CAAC,OAAOQ,WAAU,MAAM,UAAU,IAAI,MAAM,QAAQ,IAAI;AAAA,MAC5D;AAAA,QACE,mBAAmB,wBAAwB,EAAE;AAAA,MAC/C;AAAA,MACA,YAAY;AAAA,MACZ,YAAY,YAAY,SAAS,CAAC;AAAA,MAClC,WAAW;AAAA,IACb,CAAC;AAID,QAAI,eAAe,QAAW;AAE5B,YAAM,SAAS,KAAK,IAAI,SAAS,UAAU,CAAC;AAC5C,YAAM,WAAW,CAAC,MAAM,MAAM;AAC9B,UAAI,UAAU,MAAM;AACpB,UAAI;AACF,YAAI,UAAU;AACZ,mBAAS,gBAAgB,EAAE,QAAQ,OAAO,SAAS,EAAE,CAAC;AACtD,gBAAM,MAAM,KAAK,MAAM;AACvB,cAAI,CAAC,KAAK;AACR,oBAAQ,MAAM,kCAAkC,MAAM;AACtD,oBAAQ,KAAK,CAAC;AAAA,UAChB;AACA,qBAAW,MAAM,oBAAoB,IAAI,UAAU,KAAK;AACvD,WAAC,EAAE,MAAM,WAAW,IAAI;AAAA,QAC3B,OAAO;AAEL,mBAAS,gBAAgB,EAAE,UAAU,WAAW,CAAC;AACjD,cAAI,CAAC,WAAW,UAAU,GAAG;AAC3B,oBAAQ,MAAM,wBAAwB,UAAU;AAChD,oBAAQ,KAAK,CAAC;AAAA,UAChB;AACA,qBAAW,MAAM,oBAAoB,YAAY,KAAK;AACtD,gBAAM,eAAe,WAAW,MAAM,GAAG;AACzC,gBAAM,WAAW,aAAa,aAAa,SAAS,CAAC,KAAK;AACzD,WAAC,EAAE,MAAM,WAAW,IAAI,iBAAiB,QAAQ;AAAA,QACpD;AACA,cAAM,OAAO,8BAA8B,MAAM,cAAc,GAAG,CAAC;AACnE,cAAM,iBAAiB,MAAM,6BAA6B;AAC1D;AACE,gBAAM,EAAE,OAAO,IAAI,MAAM,OAAO,KAAK;AACrC,gBAAM,EAAE,KAAK,IAAI,MAAM,OAAO,iBAAiB;AAC/C;AAAA,YACE;AAAA,cAAC;AAAA;AAAA,gBACD,eAAc;AAAA,gBACd,gBAAgB;AAAA,gBAChB,mBAAmB;AAAA,gBACnB,uBAAuB;AAAA,gBACvB;AAAA,gBACA,UAAUA;AAAA,gBACV;AAAA,gBACA,UAAU;AAAA,gBACV,iBAAiB;AAAA,gBACjB;AAAA,gBACA;AAAA;AAAA,YACF;AAAA,YACA,EAAE,aAAa,MAAM;AAAA,UACrB;AAAA,QACF;AAAA,MACF,SAAS,OAAO;AACd,iBAAS,gCAAgC,KAAK,EAAE;AAChD,gBAAQ,KAAK,CAAC;AAAA,MAChB;AAAA,IACF,OAAO;AAEL,YAAMD,WAAoC,CAAC;AAC1C,OAAC,YAAY;AACZ,cAAM,EAAE,OAAO,IAAI,MAAM,OAAO,KAAK;AACrC,cAAM,EAAE,QAAQ,IAAI;AAAA,UAClB;AAAA,YAAC;AAAA;AAAA,cACC,SAASA;AAAA,cACT,UAAUC;AAAA,cACV;AAAA,cACA;AAAA,cACA;AAAA;AAAA,UACF;AAAA,UACA;AAAA,QACF;AACA,QAAAD,SAAQ,UAAU;AAAA,MACpB,GAAG;AAAA,IACL;AAAA,EACF,CAAC;AAGH,UACG,QAAQ,OAAO,EACf;AAAA,IACC;AAAA,EACF,EACC;AAAA,IACC;AAAA,IACA;AAAA,IACA;AAAA,EACF,EACC,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,OAAO,OAAO,QAAQ,EAAE,KAAAP,KAAI,MAAM;AACjC,UAAM,MAAMA,MAAK,KAAK;AACtB,aAAS,qBAAqB,EAAE,QAAQ,QAAQ,SAAS,KAAK,GAAG,CAAC;AAClE,UAAMO,WAAoC,CAAC;AAC1C,KAAC,YAAY;AACZ,YAAM,EAAE,OAAO,IAAI,MAAM,OAAO,KAAK;AACrC,YAAM,EAAE,QAAQ,IAAI;AAAA,QAClB,oCAAC,WAAQ,SAASA,UAAS,MAAK,UAAS,WAAW,QAAQ;AAAA,QAC5D;AAAA,MACF;AACA,MAAAA,SAAQ,UAAU;AAAA,IACpB,GAAG;AAAA,EACL,CAAC;AAGH,QAAM,UAAU,QACb,QAAQ,SAAS,EACjB;AAAA,IACC,2BAA2B,eAAe;AAAA,EAC5C;AAEF,UACG,QAAQ,WAAW,EACnB,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,YAAY,0BAA0B,EACtC,OAAO,OAAO,KAAK,EAAE,KAAAP,KAAI,MAAM;AAC9B,UAAM,MAAMA,MAAK,KAAK;AACtB,aAAS,qBAAqB,EAAE,IAAI,CAAC;AACrC,UAAMO,WAAU;AAAA,MACd,MAAM,WAAW;AAAA,MACjB;AAAA,MACA;AAAA,IACF;AACA,YAAQ,IAAIA,SAAQ,GAAG,CAAC;AACxB,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAEH,UACG,QAAQ,mBAAmB,EAC3B,YAAY,wBAAwB,EACpC,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,OAAO,OAAO,KAAK,OAAO,EAAE,KAAAP,KAAI,MAAM;AACrC,UAAM,MAAMA,MAAK,KAAK;AACtB,aAAS,qBAAqB,EAAE,IAAI,CAAC;AACrC,eAAW,KAAK,KAAK;AACrB,YAAQ,IAAI,eAAe,GAAG,QAAQ,KAAK,GAAG;AAC9C,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAEH,UACG,QAAQ,MAAM,EACd,YAAY,yBAAyB,EACrC,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,OAAO,OAAO,EAAE,KAAAA,KAAI,MAAM;AACzB,UAAM,MAAMA,MAAK,KAAK;AACtB,aAAS,sBAAsB,CAAC,CAAC;AACjC,UAAMO,WAAU;AAAA,MACd,MAAM,WAAW;AAAA,MACjB;AAAA,MACA;AAAA,MACA;AAAA,IACF;AACA,YAAQ,IAAI,KAAK,UAAUA,UAAS,MAAM,CAAC,CAAC;AAC5C,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAEH,UACG,QAAQ,cAAc,EACtB,YAAY,6BAA6B,EACzC,OAAO,mBAAmB,iCAAiC,QAAQ,IAAI,CAAC,EACxE,OAAO,OAAO,KAAK,EAAE,KAAAP,KAAI,MAAM;AAC9B,UAAM,MAAMA,MAAK,KAAK;AACtB,aAAS,wBAAwB,EAAE,IAAI,CAAC;AACxC,kBAAc,GAAG;AACjB,YAAQ,IAAI,mBAAmB,GAAG,EAAE;AACpC,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AAEH,QAAM,QAAQ,WAAW,QAAQ,IAAI;AACrC,SAAO;AACT;AAGA,eAAe,QAAQ;AACrB,MAAI,QAAQ,MAAM,OAAO;AACvB,WAAO;AAAA,EACT;AAEA,MAAI,OAAO;AACX,mBAAiB,SAAS,QAAQ,MAAO,SAAQ;AACjD,SAAO;AACT;AAEA,QAAQ,GAAG,QAAQ,MAAM;AACvB,cAAY;AACZ,kBAAgB,YAAY,EAAE,MAAM;AACtC,CAAC;AAED,SAAS,aAAa,OAAO,GAAG;AAC9B,MAAI;AAAE,gBAAY;AAAA,EAAE,QAAQ;AAAA,EAAC;AAC7B,MAAI;AAAE,oBAAgB,YAAY,EAAE,MAAM;AAAA,EAAE,QAAQ;AAAA,EAAC;AACrD,UAAQ,KAAK,IAAI;AACnB;AAEA,QAAQ,GAAG,UAAU,MAAM,aAAa,CAAC,CAAC;AAC1C,QAAQ,GAAG,WAAW,MAAM,aAAa,CAAC,CAAC;AAE3C,QAAQ,GAAG,YAAY,MAAM,aAAa,CAAC,CAAC;AAC5C,QAAQ,GAAG,sBAAsB,SAAO;AACtC,UAAQ,MAAM,wBAAwB,GAAG;AACzC,eAAa,CAAC;AAChB,CAAC;AACD,QAAQ,GAAG,qBAAqB,SAAO;AACrC,UAAQ,MAAM,uBAAuB,GAAG;AACxC,eAAa,CAAC;AAChB,CAAC;AAED,SAAS,cAAc;AACrB,QAAM,WAAW,QAAQ,OAAO,QAC5B,QAAQ,SACR,QAAQ,OAAO,QACb,QAAQ,SACR;AACN,YAAU,MAAM,YAAc,UAAU,EAAE;AAC5C;AAEA,KAAK;",
|
|
4
|
+
"sourcesContent": ["#!/usr/bin/env -S node --no-warnings=ExperimentalWarning --enable-source-maps\nimport { fileURLToPath } from 'node:url'\nimport { dirname, join } from 'node:path'\nimport { existsSync } from 'node:fs'\nimport { initSentry } from '../services/sentry'\nimport { PRODUCT_COMMAND, PRODUCT_NAME } from '../constants/product'\ninitSentry() // Initialize Sentry as early as possible\n\n// Ensure YOGA_WASM_PATH is set for Ink across run modes (wrapper/dev)\n// Resolve yoga.wasm relative to this file when missing using ESM-friendly APIs\ntry {\n if (!process.env.YOGA_WASM_PATH) {\n const __filename = fileURLToPath(import.meta.url)\n const __dirname = dirname(__filename)\n const devCandidate = join(__dirname, '../../yoga.wasm')\n const distCandidate = join(__dirname, './yoga.wasm')\n const resolved = existsSync(distCandidate)\n ? distCandidate\n : existsSync(devCandidate)\n ? devCandidate\n : undefined\n if (resolved) {\n process.env.YOGA_WASM_PATH = resolved\n }\n }\n} catch {}\n\n// XXX: Without this line (and the Object.keys, even though it seems like it does nothing!),\n// there is a bug in Bun only on Win32 that causes this import to be removed, even though\n// its use is solely because of its side-effects.\nimport * as dontcare from '@anthropic-ai/sdk/shims/node'\nObject.keys(dontcare)\n\nimport React from 'react'\nimport { ReadStream } from 'tty'\nimport { openSync } from 'fs'\n// ink and REPL are imported lazily to avoid top-level awaits during module init\nimport type { RenderOptions } from 'ink'\nimport { addToHistory } from '../history'\nimport { getContext, setContext, removeContext } from '../context'\nimport { Command } from '@commander-js/extra-typings'\nimport { ask } from '../utils/ask'\nimport { hasPermissionsToUseTool } from '../permissions'\nimport { getTools } from '../tools'\nimport {\n getGlobalConfig,\n getCurrentProjectConfig,\n saveGlobalConfig,\n saveCurrentProjectConfig,\n getCustomApiKeyStatus,\n normalizeApiKeyForConfig,\n setConfigForCLI,\n deleteConfigForCLI,\n getConfigForCLI,\n listConfigForCLI,\n enableConfigs,\n validateAndRepairAllGPT5Profiles,\n} from '../utils/config'\nimport { cwd } from 'process'\nimport { dateToFilename, logError, parseLogFilename } from '../utils/log'\nimport { initDebugLogger } from '../utils/debugLogger'\nimport { Onboarding } from '../components/Onboarding'\nimport { Doctor } from '../screens/Doctor'\nimport { ApproveApiKey } from '../components/ApproveApiKey'\nimport { TrustDialog } from '../components/TrustDialog'\nimport { checkHasTrustDialogAccepted, McpServerConfig } from '../utils/config'\nimport { isDefaultSlowAndCapableModel } from '../utils/model'\nimport { LogList } from '../screens/LogList'\nimport { ResumeConversation } from '../screens/ResumeConversation'\nimport { startMCPServer } from './mcp'\nimport { env } from '../utils/env'\nimport { getCwd, setCwd, setOriginalCwd } from '../utils/state'\nimport { omit } from 'lodash-es'\nimport { getCommands } from '../commands'\nimport { getNextAvailableLogForkNumber, loadLogList } from '../utils/log'\nimport { loadMessagesFromLog } from '../utils/conversationRecovery'\nimport { cleanupOldMessageFilesInBackground } from '../utils/cleanup'\nimport {\n handleListApprovedTools,\n handleRemoveApprovedTool,\n} from '../commands/approvedTools'\nimport {\n addMcpServer,\n getMcpServer,\n listMCPServers,\n parseEnvVars,\n removeMcpServer,\n getClients,\n ensureConfigScope,\n} from '../services/mcpClient'\nimport { handleMcprcServerApprovals } from '../services/mcpServerApproval'\nimport { checkGate, initializeStatsig, logEvent } from '../services/statsig'\nimport { getExampleCommands } from '../utils/exampleCommands'\nimport { cursorShow } from 'ansi-escapes'\nimport { getLatestVersion, assertMinVersion, getUpdateCommandSuggestions } from '../utils/autoUpdater'\nimport { gt } from 'semver'\nimport { CACHE_PATHS } from '../utils/log'\n// import { checkAndNotifyUpdate } from '../utils/autoUpdater'\nimport { PersistentShell } from '../utils/PersistentShell'\nimport { GATE_USE_EXTERNAL_UPDATER } from '../constants/betas'\nimport { clearTerminal } from '../utils/terminal'\nimport { showInvalidConfigDialog } from '../components/InvalidConfigDialog'\nimport { ConfigParseError } from '../utils/errors'\nimport { grantReadPermissionForOriginalDir } from '../utils/permissions/filesystem'\nimport { MACRO } from '../constants/macros'\nexport function completeOnboarding(): void {\n const config = getGlobalConfig()\n saveGlobalConfig({\n ...config,\n hasCompletedOnboarding: true,\n lastOnboardingVersion: MACRO.VERSION,\n })\n}\n\nasync function showSetupScreens(\n safeMode?: boolean,\n print?: boolean,\n): Promise<void> {\n if (process.env.NODE_ENV === 'test') {\n return\n }\n\n const config = getGlobalConfig()\n if (\n !config.theme ||\n !config.hasCompletedOnboarding // always show onboarding at least once\n ) {\n await clearTerminal()\n const { render } = await import('ink')\n await new Promise<void>(resolve => {\n render(\n <Onboarding\n onDone={async () => {\n completeOnboarding()\n await clearTerminal()\n resolve()\n }}\n />,\n {\n exitOnCtrlC: false,\n },\n )\n })\n }\n\n // // Check for custom API key (only allowed for ants)\n // if (process.env.ANTHROPIC_API_KEY && process.env.USER_TYPE === 'ant') {\n // const customApiKeyTruncated = normalizeApiKeyForConfig(\n // process.env.ANTHROPIC_API_KEY!,\n // )\n // const keyStatus = getCustomApiKeyStatus(customApiKeyTruncated)\n // if (keyStatus === 'new') {\n // await new Promise<void>(resolve => {\n // render(\n // <ApproveApiKey\n // customApiKeyTruncated={customApiKeyTruncated}\n // onDone={async () => {\n // await clearTerminal()\n // resolve()\n // }}\n // />,\n // {\n // exitOnCtrlC: false,\n // },\n // )\n // })\n // }\n // }\n\n // In non-interactive mode, only show trust dialog in safe mode\n if (!print && safeMode) {\n if (!checkHasTrustDialogAccepted()) {\n await new Promise<void>(resolve => {\n const onDone = () => {\n // Grant read permission to the current working directory\n grantReadPermissionForOriginalDir()\n resolve()\n }\n ;(async () => {\n const { render } = await import('ink')\n render(<TrustDialog onDone={onDone} />, {\n exitOnCtrlC: false,\n })\n })()\n })\n }\n\n // After trust dialog, check for any mcprc servers that need approval\n if (process.env.USER_TYPE === 'ant') {\n await handleMcprcServerApprovals()\n }\n }\n}\n\nfunction logStartup(): void {\n const config = getGlobalConfig()\n saveGlobalConfig({\n ...config,\n numStartups: (config.numStartups ?? 0) + 1,\n })\n}\n\nasync function setup(cwd: string, safeMode?: boolean): Promise<void> {\n // Set both current and original working directory if --cwd was provided\n if (cwd !== process.cwd()) {\n setOriginalCwd(cwd)\n }\n await setCwd(cwd)\n\n // Always grant read permissions for original working dir\n grantReadPermissionForOriginalDir()\n \n // Start watching agent configuration files for changes\n // Try ESM-friendly path first (compiled dist), then fall back to extensionless (dev/tsx)\n let agentLoader: any\n try {\n agentLoader = await import('../utils/agentLoader.js')\n } catch {\n agentLoader = await import('../utils/agentLoader')\n }\n const { startAgentWatcher, clearAgentCache } = agentLoader\n await startAgentWatcher(() => {\n // Cache is already cleared in the watcher, just log\n console.log('\u2705 Agent configurations hot-reloaded')\n })\n\n // If --safe mode is enabled, prevent root/sudo usage for security\n if (safeMode) {\n // Check if running as root/sudo on Unix-like systems\n if (\n process.platform !== 'win32' &&\n typeof process.getuid === 'function' &&\n process.getuid() === 0\n ) {\n console.error(\n `--safe mode cannot be used with root/sudo privileges for security reasons`,\n )\n process.exit(1)\n }\n }\n\n if (process.env.NODE_ENV === 'test') {\n return\n }\n\n cleanupOldMessageFilesInBackground()\n // getExampleCommands() // Pre-fetch example commands\n getContext() // Pre-fetch all context data at once\n // initializeStatsig() // Kick off statsig initialization\n\n // Migrate old iterm2KeyBindingInstalled config to new shiftEnterKeyBindingInstalled\n const globalConfig = getGlobalConfig()\n if (\n globalConfig.iterm2KeyBindingInstalled === true &&\n globalConfig.shiftEnterKeyBindingInstalled !== true\n ) {\n const updatedConfig = {\n ...globalConfig,\n shiftEnterKeyBindingInstalled: true,\n }\n // Remove the old config property\n delete updatedConfig.iterm2KeyBindingInstalled\n saveGlobalConfig(updatedConfig)\n }\n\n // Check for last session's cost and duration\n const projectConfig = getCurrentProjectConfig()\n if (\n projectConfig.lastCost !== undefined &&\n projectConfig.lastDuration !== undefined\n ) {\n logEvent('tengu_exit', {\n last_session_cost: String(projectConfig.lastCost),\n last_session_api_duration: String(projectConfig.lastAPIDuration),\n last_session_duration: String(projectConfig.lastDuration),\n last_session_id: projectConfig.lastSessionId,\n })\n // Clear the values after logging\n // saveCurrentProjectConfig({\n // ...projectConfig,\n // lastCost: undefined,\n // lastAPIDuration: undefined,\n // lastDuration: undefined,\n // lastSessionId: undefined,\n // })\n }\n\n // Skip interactive auto-updater permission prompts during startup\n // Users can still run the doctor command manually if desired.\n}\n\nasync function main() {\n // \u521D\u59CB\u5316\u8C03\u8BD5\u65E5\u5FD7\u7CFB\u7EDF\n initDebugLogger()\n\n // Validate configs are valid and enable configuration system\n try {\n enableConfigs()\n \n // \uD83D\uDD27 Validate and auto-repair GPT-5 model profiles\n try {\n const repairResult = validateAndRepairAllGPT5Profiles()\n if (repairResult.repaired > 0) {\n console.log(`\uD83D\uDD27 Auto-repaired ${repairResult.repaired} GPT-5 model configurations`)\n }\n } catch (repairError) {\n // Don't block startup if GPT-5 validation fails\n console.warn('\u26A0\uFE0F GPT-5 configuration validation failed:', repairError)\n }\n } catch (error: unknown) {\n if (error instanceof ConfigParseError) {\n // Show the invalid config dialog with the error object\n await showInvalidConfigDialog({ error })\n return // Exit after handling the config error\n }\n }\n\n // Disabled background notifier to avoid mid-screen logs during REPL\n\n let inputPrompt = ''\n let renderContext: RenderOptions | undefined = {\n exitOnCtrlC: false,\n \n onFlicker() {\n logEvent('tengu_flicker', {})\n },\n } as any\n\n if (\n !process.stdin.isTTY &&\n !process.env.CI &&\n // Input hijacking breaks MCP.\n !process.argv.includes('mcp')\n ) {\n inputPrompt = await stdin()\n if (process.platform !== 'win32') {\n try {\n const ttyFd = openSync('/dev/tty', 'r')\n renderContext = { ...renderContext, stdin: new ReadStream(ttyFd) }\n } catch (err) {\n logError(`Could not open /dev/tty: ${err}`)\n }\n }\n }\n await parseArgs(inputPrompt, renderContext)\n}\n\nasync function parseArgs(\n stdinContent: string,\n renderContext: RenderOptions | undefined,\n): Promise<Command> {\n const program = new Command()\n\n const renderContextWithExitOnCtrlC = {\n ...renderContext,\n exitOnCtrlC: true,\n }\n\n // Get the initial list of commands filtering based on user type\n const commands = await getCommands()\n\n // Format command list for help text (using same filter as in help.ts)\n const commandList = commands\n .filter(cmd => !cmd.isHidden)\n .map(cmd => `/${cmd.name} - ${cmd.description}`)\n .join('\\n')\n\n program\n .name(PRODUCT_COMMAND)\n .description(\n `${PRODUCT_NAME} - starts an interactive session by default, use -p/--print for non-interactive output\n\nSlash commands available during an interactive session:\n${commandList}`,\n )\n .argument('[prompt]', 'Your prompt', String)\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-d, --debug', 'Enable debug mode', () => true)\n .option(\n '--debug-verbose',\n 'Enable verbose debug terminal output',\n () => true,\n )\n .option(\n '--verbose',\n 'Override verbose mode setting from config',\n () => true,\n )\n .option('-e, --enable-architect', 'Enable the Architect tool', () => true)\n .option(\n '-p, --print',\n 'Print response and exit (useful for pipes)',\n () => true,\n )\n .option(\n '--safe',\n 'Enable strict permission checking mode (default is permissive)',\n () => true,\n )\n .action(\n async (prompt, { cwd, debug, verbose, enableArchitect, print, safe }) => {\n await showSetupScreens(safe, print)\n logEvent('tengu_init', {\n entrypoint: PRODUCT_COMMAND,\n hasInitialPrompt: Boolean(prompt).toString(),\n hasStdin: Boolean(stdinContent).toString(),\n enableArchitect: enableArchitect?.toString() ?? 'false',\n verbose: verbose?.toString() ?? 'false',\n debug: debug?.toString() ?? 'false',\n print: print?.toString() ?? 'false',\n })\n await setup(cwd, safe)\n\n assertMinVersion()\n\n const [tools, mcpClients] = await Promise.all([\n getTools(\n enableArchitect ?? getCurrentProjectConfig().enableArchitectTool,\n ),\n getClients(),\n ])\n // logStartup()\n const inputPrompt = [prompt, stdinContent].filter(Boolean).join('\\n')\n if (print) {\n if (!inputPrompt) {\n console.error(\n 'Error: Input must be provided either through stdin or as a prompt argument when using --print',\n )\n process.exit(1)\n }\n\n addToHistory(inputPrompt)\n const { resultText: response } = await ask({\n commands,\n hasPermissionsToUseTool,\n messageLogName: dateToFilename(new Date()),\n prompt: inputPrompt,\n cwd,\n tools,\n safeMode: safe,\n })\n console.log(response)\n process.exit(0)\n } else {\n const isDefaultModel = await isDefaultSlowAndCapableModel()\n\n // Prefetch update info before first render to place banner at top\n const updateInfo = await (async () => {\n try {\n const latest = await getLatestVersion()\n if (latest && gt(latest, MACRO.VERSION)) {\n const cmds = await getUpdateCommandSuggestions()\n return { version: latest as string, commands: cmds as string[] }\n }\n } catch {}\n return { version: null as string | null, commands: null as string[] | null }\n })()\n\n {\n const { render } = await import('ink')\n const { REPL } = await import('../screens/REPL')\n render(\n <REPL\n commands={commands}\n debug={debug}\n initialPrompt={inputPrompt}\n messageLogName={dateToFilename(new Date())}\n shouldShowPromptInput={true}\n verbose={verbose}\n tools={tools}\n safeMode={safe}\n mcpClients={mcpClients}\n isDefaultModel={isDefaultModel}\n initialUpdateVersion={updateInfo.version}\n initialUpdateCommands={updateInfo.commands}\n />,\n renderContext,\n )\n }\n }\n },\n )\n .version(MACRO.VERSION, '-v, --version')\n\n // Enable melon mode for ants if --melon is passed\n // For bun tree shaking to work, this has to be a top level --define, not inside MACRO\n // if (process.env.USER_TYPE === 'ant') {\n // program\n // .option('--melon', 'Enable melon mode')\n // .hook('preAction', async () => {\n // if ((program.opts() as { melon?: boolean }).melon) {\n // const { runMelonWrapper } = await import('../utils/melonWrapper')\n // const melonArgs = process.argv.slice(\n // process.argv.indexOf('--melon') + 1,\n // )\n // const exitCode = runMelonWrapper(melonArgs)\n // process.exit(exitCode)\n // }\n // })\n // }\n\n // claude config\n const config = program\n .command('config')\n .description(\n `Manage configuration (eg. ${PRODUCT_COMMAND} config set -g theme dark)`,\n )\n\n config\n .command('get <key>')\n .description('Get a config value')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, { cwd, global }) => {\n await setup(cwd, false)\n console.log(getConfigForCLI(key, global ?? false))\n process.exit(0)\n })\n\n config\n .command('set <key> <value>')\n .description('Set a config value')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, value, { cwd, global }) => {\n await setup(cwd, false)\n setConfigForCLI(key, value, global ?? false)\n console.log(`Set ${key} to ${value}`)\n process.exit(0)\n })\n\n config\n .command('remove <key>')\n .description('Remove a config value')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config')\n .action(async (key, { cwd, global }) => {\n await setup(cwd, false)\n deleteConfigForCLI(key, global ?? false)\n console.log(`Removed ${key}`)\n process.exit(0)\n })\n\n config\n .command('list')\n .description('List all config values')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-g, --global', 'Use global config', false)\n .action(async ({ cwd, global }) => {\n await setup(cwd, false)\n console.log(\n JSON.stringify(global ? listConfigForCLI(true) : listConfigForCLI(false), null, 2),\n )\n process.exit(0)\n })\n\n // claude approved-tools\n\n const allowedTools = program\n .command('approved-tools')\n .description('Manage approved tools')\n\n allowedTools\n .command('list')\n .description('List all approved tools')\n .action(async () => {\n const result = handleListApprovedTools(getCwd())\n console.log(result)\n process.exit(0)\n })\n\n allowedTools\n .command('remove <tool>')\n .description('Remove a tool from the list of approved tools')\n .action(async (tool: string) => {\n const result = handleRemoveApprovedTool(tool)\n logEvent('tengu_approved_tool_remove', {\n tool,\n success: String(result.success),\n })\n console.log(result.message)\n process.exit(result.success ? 0 : 1)\n })\n\n // claude mcp\n\n const mcp = program\n .command('mcp')\n .description('Configure and manage MCP servers')\n\n mcp\n .command('serve')\n .description(`Start the ${PRODUCT_NAME} MCP server`)\n .action(async () => {\n const providedCwd = (program.opts() as { cwd?: string }).cwd ?? cwd()\n logEvent('tengu_mcp_start', { providedCwd })\n\n // Verify the directory exists\n if (!existsSync(providedCwd)) {\n console.error(`Error: Directory ${providedCwd} does not exist`)\n process.exit(1)\n }\n\n try {\n await setup(providedCwd, false)\n await startMCPServer(providedCwd)\n } catch (error) {\n console.error('Error: Failed to start MCP server:', error)\n process.exit(1)\n }\n })\n\n mcp\n .command('add-sse <name> <url>')\n .description('Add an SSE server')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async (name, url, options) => {\n try {\n const scope = ensureConfigScope(options.scope)\n logEvent('tengu_mcp_add', { name, type: 'sse', scope })\n\n addMcpServer(name, { type: 'sse', url }, scope)\n console.log(\n `Added SSE MCP server ${name} with URL ${url} to ${scope} config`,\n )\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('add [name] [commandOrUrl] [args...]')\n .description('Add a server (run without arguments for interactive wizard)')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .option(\n '-e, --env <env...>',\n 'Set environment variables (e.g. -e KEY=value)',\n )\n .action(async (name, commandOrUrl, args, options) => {\n try {\n // If name is not provided, start interactive wizard\n if (!name) {\n console.log('Interactive wizard mode: Enter the server details')\n const { createInterface } = await import('readline')\n const rl = createInterface({\n input: process.stdin,\n output: process.stdout,\n })\n\n const question = (query: string) =>\n new Promise<string>(resolve => rl.question(query, resolve))\n\n // Get server name\n const serverName = await question('Server name: ')\n if (!serverName) {\n console.error('Error: Server name is required')\n rl.close()\n process.exit(1)\n }\n\n // Get server type\n const serverType = await question(\n 'Server type (stdio or sse) [stdio]: ',\n )\n const type =\n serverType && ['stdio', 'sse'].includes(serverType)\n ? serverType\n : 'stdio'\n\n // Get command or URL\n const prompt = type === 'stdio' ? 'Command: ' : 'URL: '\n const commandOrUrlValue = await question(prompt)\n if (!commandOrUrlValue) {\n console.error(\n `Error: ${type === 'stdio' ? 'Command' : 'URL'} is required`,\n )\n rl.close()\n process.exit(1)\n }\n\n // Get args and env if stdio\n let serverArgs: string[] = []\n let serverEnv: Record<string, string> = {}\n\n if (type === 'stdio') {\n const argsStr = await question(\n 'Command arguments (space-separated): ',\n )\n serverArgs = argsStr ? argsStr.split(' ').filter(Boolean) : []\n\n const envStr = await question(\n 'Environment variables (format: KEY1=value1,KEY2=value2): ',\n )\n if (envStr) {\n const envPairs = envStr.split(',').map(pair => pair.trim())\n serverEnv = parseEnvVars(envPairs.map(pair => pair))\n }\n }\n\n // Get scope\n const scopeStr = await question(\n 'Configuration scope (project or global) [project]: ',\n )\n const serverScope = ensureConfigScope(scopeStr || 'project')\n\n rl.close()\n\n // Add the server\n if (type === 'sse') {\n logEvent('tengu_mcp_add', {\n name: serverName,\n type: 'sse',\n scope: serverScope,\n })\n addMcpServer(\n serverName,\n { type: 'sse', url: commandOrUrlValue },\n serverScope,\n )\n console.log(\n `Added SSE MCP server ${serverName} with URL ${commandOrUrlValue} to ${serverScope} config`,\n )\n } else {\n logEvent('tengu_mcp_add', {\n name: serverName,\n type: 'stdio',\n scope: serverScope,\n })\n addMcpServer(\n serverName,\n {\n type: 'stdio',\n command: commandOrUrlValue,\n args: serverArgs,\n env: serverEnv,\n },\n serverScope,\n )\n\n console.log(\n `Added stdio MCP server ${serverName} with command: ${commandOrUrlValue} ${serverArgs.join(' ')} to ${serverScope} config`,\n )\n }\n } else if (name && commandOrUrl) {\n // Regular non-interactive flow\n const scope = ensureConfigScope(options.scope)\n\n // Check if it's an SSE URL (starts with http:// or https://)\n if (commandOrUrl.match(/^https?:\\/\\//)) {\n logEvent('tengu_mcp_add', { name, type: 'sse', scope })\n addMcpServer(name, { type: 'sse', url: commandOrUrl }, scope)\n console.log(\n `Added SSE MCP server ${name} with URL ${commandOrUrl} to ${scope} config`,\n )\n } else {\n logEvent('tengu_mcp_add', { name, type: 'stdio', scope })\n const env = parseEnvVars(options.env)\n addMcpServer(\n name,\n { type: 'stdio', command: commandOrUrl, args: args || [], env },\n scope,\n )\n\n console.log(\n `Added stdio MCP server ${name} with command: ${commandOrUrl} ${(args || []).join(' ')} to ${scope} config`,\n )\n }\n } else {\n console.error(\n 'Error: Missing required arguments. Either provide no arguments for interactive mode or specify name and command/URL.',\n )\n process.exit(1)\n }\n\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n mcp\n .command('remove <name>')\n .description('Remove an MCP server')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project, global, or mcprc)',\n 'project',\n )\n .action(async (name: string, options: { scope?: string }) => {\n try {\n const scope = ensureConfigScope(options.scope)\n logEvent('tengu_mcp_delete', { name, scope })\n\n removeMcpServer(name, scope)\n console.log(`Removed MCP server ${name} from ${scope} config`)\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('list')\n .description('List configured MCP servers')\n .action(() => {\n logEvent('tengu_mcp_list', {})\n const servers = listMCPServers()\n if (Object.keys(servers).length === 0) {\n console.log(\n `No MCP servers configured. Use \\`${PRODUCT_COMMAND} mcp add\\` to add a server.`,\n )\n } else {\n for (const [name, server] of Object.entries(servers)) {\n if (server.type === 'sse') {\n console.log(`${name}: ${server.url} (SSE)`)\n } else {\n console.log(`${name}: ${server.command} ${server.args.join(' ')}`)\n }\n }\n }\n process.exit(0)\n })\n\n mcp\n .command('add-json <name> <json>')\n .description('Add an MCP server (stdio or SSE) with a JSON string')\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async (name, jsonStr, options) => {\n try {\n const scope = ensureConfigScope(options.scope)\n\n // Parse JSON string\n let serverConfig\n try {\n serverConfig = JSON.parse(jsonStr)\n } catch (e) {\n console.error('Error: Invalid JSON string')\n process.exit(1)\n }\n\n // Validate the server config\n if (\n !serverConfig.type ||\n !['stdio', 'sse'].includes(serverConfig.type)\n ) {\n console.error('Error: Server type must be \"stdio\" or \"sse\"')\n process.exit(1)\n }\n\n if (serverConfig.type === 'sse' && !serverConfig.url) {\n console.error('Error: SSE server must have a URL')\n process.exit(1)\n }\n\n if (serverConfig.type === 'stdio' && !serverConfig.command) {\n console.error('Error: stdio server must have a command')\n process.exit(1)\n }\n\n // Add server with the provided config\n logEvent('tengu_mcp_add_json', { name, type: serverConfig.type, scope })\n addMcpServer(name, serverConfig, scope)\n\n if (serverConfig.type === 'sse') {\n console.log(\n `Added SSE MCP server ${name} with URL ${serverConfig.url} to ${scope} config`,\n )\n } else {\n console.log(\n `Added stdio MCP server ${name} with command: ${serverConfig.command} ${(\n serverConfig.args || []\n ).join(' ')} to ${scope} config`,\n )\n }\n\n process.exit(0)\n } catch (error) {\n console.error((error as Error).message)\n process.exit(1)\n }\n })\n\n mcp\n .command('get <name>')\n .description('Get details about an MCP server')\n .action((name: string) => {\n logEvent('tengu_mcp_get', { name })\n const server = getMcpServer(name)\n if (!server) {\n console.error(`No MCP server found with name: ${name}`)\n process.exit(1)\n }\n console.log(`${name}:`)\n console.log(` Scope: ${server.scope}`)\n if (server.type === 'sse') {\n console.log(` Type: sse`)\n console.log(` URL: ${server.url}`)\n } else {\n console.log(` Type: stdio`)\n console.log(` Command: ${server.command}`)\n console.log(` Args: ${server.args.join(' ')}`)\n if (server.env) {\n console.log(' Environment:')\n for (const [key, value] of Object.entries(server.env)) {\n console.log(` ${key}=${value}`)\n }\n }\n }\n process.exit(0)\n })\n\n // Import servers from Claude Desktop\n mcp\n .command('add-from-claude-desktop')\n .description(\n 'Import MCP servers from Claude Desktop (Mac, Windows and WSL)',\n )\n .option(\n '-s, --scope <scope>',\n 'Configuration scope (project or global)',\n 'project',\n )\n .action(async options => {\n try {\n const scope = ensureConfigScope(options.scope)\n const platform = process.platform\n\n // Import fs and path modules\n const { existsSync, readFileSync } = await import('fs')\n const { join } = await import('path')\n const { exec } = await import('child_process')\n\n // Determine if running in WSL\n const isWSL =\n platform === 'linux' &&\n existsSync('/proc/version') &&\n readFileSync('/proc/version', 'utf-8')\n .toLowerCase()\n .includes('microsoft')\n\n if (platform !== 'darwin' && platform !== 'win32' && !isWSL) {\n console.error(\n 'Error: This command is only supported on macOS, Windows, and WSL',\n )\n process.exit(1)\n }\n\n // Get Claude Desktop config path\n let configPath\n if (platform === 'darwin') {\n configPath = join(\n process.env.HOME || '~',\n 'Library/Application Support/Claude/claude_desktop_config.json',\n )\n } else if (platform === 'win32') {\n configPath = join(\n process.env.APPDATA || '',\n 'Claude/claude_desktop_config.json',\n )\n } else if (isWSL) {\n // Get Windows username\n const whoamiCommand = await new Promise<string>((resolve, reject) => {\n exec(\n 'powershell.exe -Command \"whoami\"',\n (err: Error, stdout: string) => {\n if (err) reject(err)\n else resolve(stdout.trim().split('\\\\').pop() || '')\n },\n )\n })\n\n configPath = `/mnt/c/Users/${whoamiCommand}/AppData/Roaming/Claude/claude_desktop_config.json`\n }\n\n // Check if config file exists\n if (!existsSync(configPath)) {\n console.error(\n `Error: Claude Desktop config file not found at ${configPath}`,\n )\n process.exit(1)\n }\n\n // Read config file\n let config\n try {\n const configContent = readFileSync(configPath, 'utf-8')\n config = JSON.parse(configContent)\n } catch (err) {\n console.error(`Error reading config file: ${err}`)\n process.exit(1)\n }\n\n // Extract MCP servers\n const mcpServers = config.mcpServers || {}\n const serverNames = Object.keys(mcpServers)\n const numServers = serverNames.length\n\n if (numServers === 0) {\n console.log('No MCP servers found in Claude Desktop config')\n process.exit(0)\n }\n\n // Create server information for display\n const serversInfo = serverNames.map(name => {\n const server = mcpServers[name]\n let description = ''\n\n if (server.type === 'sse') {\n description = `SSE: ${server.url}`\n } else {\n description = `stdio: ${server.command} ${(server.args || []).join(' ')}`\n }\n\n return { name, description, server }\n })\n\n // First import all required modules outside the component\n // Import modules separately to avoid any issues\n const ink = await import('ink')\n const reactModule = await import('react')\n const inkjsui = await import('@inkjs/ui')\n const utilsTheme = await import('../utils/theme')\n\n const { render } = ink\n const React = reactModule // React is already the default export when imported this way\n const { MultiSelect } = inkjsui\n const { Box, Text } = ink\n const { getTheme } = utilsTheme\n\n // Use Ink to render a nice UI for selection\n await new Promise<void>(resolve => {\n // Create a component for the server selection\n function ClaudeDesktopImport() {\n const { useState } = reactModule\n const [isFinished, setIsFinished] = useState(false)\n const [importResults, setImportResults] = useState([] as { name: string; success: boolean }[])\n const [isImporting, setIsImporting] = useState(false)\n const theme = getTheme()\n\n // Function to import selected servers\n const importServers = async (selectedServers: string[]) => {\n setIsImporting(true)\n const results = []\n\n for (const name of selectedServers) {\n try {\n const server = mcpServers[name]\n\n // Check if server already exists\n const existingServer = getMcpServer(name)\n if (existingServer) {\n // Skip duplicates - we'll handle them in the confirmation step\n continue\n }\n\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n setImportResults(results)\n setIsImporting(false)\n setIsFinished(true)\n\n // Give time to show results\n setTimeout(() => {\n resolve()\n }, 1000)\n }\n\n // Handle confirmation of selections\n const handleConfirm = async (selectedServers: string[]) => {\n // Check for existing servers and confirm overwrite\n const existingServers = selectedServers.filter(name =>\n getMcpServer(name),\n )\n\n if (existingServers.length > 0) {\n // We'll just handle it directly since we have a simple UI\n const results = []\n\n // Process non-existing servers first\n const newServers = selectedServers.filter(\n name => !getMcpServer(name),\n )\n for (const name of newServers) {\n try {\n const server = mcpServers[name]\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n // Now handle existing servers by prompting for each one\n for (const name of existingServers) {\n try {\n const server = mcpServers[name]\n // Overwrite existing server - in a real interactive UI you'd prompt here\n addMcpServer(name, server as McpServerConfig, scope)\n results.push({ name, success: true })\n } catch (err) {\n results.push({ name, success: false })\n }\n }\n\n setImportResults(results)\n setIsImporting(false)\n setIsFinished(true)\n\n // Give time to show results before resolving\n setTimeout(() => {\n resolve()\n }, 1000)\n } else {\n // No existing servers, proceed with import\n await importServers(selectedServers)\n }\n }\n\n return (\n <Box flexDirection=\"column\" padding={1}>\n <Box\n flexDirection=\"column\"\n borderStyle=\"round\"\n borderColor={theme.kode}\n padding={1}\n width={'100%'}\n >\n <Text bold color={theme.kode}>\n Import MCP Servers from Claude Desktop\n </Text>\n\n <Box marginY={1}>\n <Text>\n Found {numServers} MCP servers in Claude Desktop.\n </Text>\n </Box>\n\n <Text>Please select the servers you want to import:</Text>\n\n <Box marginTop={1}>\n <MultiSelect\n options={serverNames.map(name => ({\n label: name,\n value: name,\n }))}\n defaultValue={serverNames}\n onSubmit={handleConfirm}\n />\n </Box>\n </Box>\n\n <Box marginTop={0} marginLeft={3}>\n <Text dimColor>\n Space to select \u00B7 Enter to confirm \u00B7 Esc to cancel\n </Text>\n </Box>\n\n {isFinished && (\n <Box marginTop={1}>\n <Text color={theme.success}>\n Successfully imported{' '}\n {importResults.filter(r => r.success).length} MCP server\n to local config.\n </Text>\n </Box>\n )}\n </Box>\n )\n }\n\n // Render the component\n const { unmount } = render(<ClaudeDesktopImport />)\n\n // Clean up when done\n setTimeout(() => {\n unmount()\n resolve()\n }, 30000) // Timeout after 30 seconds as a fallback\n })\n\n process.exit(0)\n } catch (error) {\n console.error(`Error: ${(error as Error).message}`)\n process.exit(1)\n }\n })\n\n // Function to reset MCP server choices\n const resetMcpChoices = () => {\n const config = getCurrentProjectConfig()\n saveCurrentProjectConfig({\n ...config,\n approvedMcprcServers: [],\n rejectedMcprcServers: [],\n })\n console.log('All .mcprc server approvals and rejections have been reset.')\n console.log(\n `You will be prompted for approval next time you start ${PRODUCT_NAME}.`,\n )\n process.exit(0)\n }\n\n // New command name to match Kode\n mcp\n .command('reset-project-choices')\n .description(\n 'Reset all approved and rejected project-scoped (.mcp.json) servers within this project',\n )\n .action(() => {\n logEvent('tengu_mcp_reset_project_choices', {})\n resetMcpChoices()\n })\n\n // Keep old command for backward compatibility (visible only to ants)\n if (process.env.USER_TYPE === 'ant') {\n mcp\n .command('reset-mcprc-choices')\n .description(\n 'Reset all approved and rejected .mcprc servers for this project',\n )\n .action(() => {\n logEvent('tengu_mcp_reset_mcprc_choices', {})\n resetMcpChoices()\n })\n }\n\n // Doctor command - simple installation health check (no auto-update)\n program\n .command('doctor')\n .description(`Check the health of your ${PRODUCT_NAME} installation`)\n .action(async () => {\n logEvent('tengu_doctor_command', {})\n\n await new Promise<void>(resolve => {\n ;(async () => {\n const { render } = await import('ink')\n render(<Doctor onDone={() => resolve()} doctorMode={true} />)\n })()\n })\n process.exit(0)\n })\n\n // ant-only commands\n\n // claude update\n program\n .command('update')\n .description('Show manual upgrade commands (no auto-install)')\n .action(async () => {\n logEvent('tengu_update_check', {})\n console.log(`Current version: ${MACRO.VERSION}`)\n console.log('Checking for updates...')\n\n const latestVersion = await getLatestVersion()\n\n if (!latestVersion) {\n console.error('Failed to check for updates')\n process.exit(1)\n }\n\n if (latestVersion === MACRO.VERSION) {\n console.log(`${PRODUCT_NAME} is up to date`)\n process.exit(0)\n }\n\n console.log(`New version available: ${latestVersion}`)\n const { getUpdateCommandSuggestions } = await import('../utils/autoUpdater')\n const cmds = await getUpdateCommandSuggestions()\n console.log('\\nRun one of the following commands to update:')\n for (const c of cmds) console.log(` ${c}`)\n if (process.platform !== 'win32') {\n console.log('\\nNote: you may need to prefix with \"sudo\" on macOS/Linux.')\n }\n process.exit(0)\n })\n\n // claude log\n program\n .command('log')\n .description('Manage conversation logs.')\n .argument(\n '[number]',\n 'A number (0, 1, 2, etc.) to display a specific log',\n parseInt,\n )\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (number, { cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_view_logs', { number: number?.toString() ?? '' })\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { unmount } = render(\n <LogList context={context} type=\"messages\" logNumber={number} />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n })\n\n // claude resume\n program\n .command('resume')\n .description(\n 'Resume a previous conversation. Optionally provide a number (0, 1, 2, etc.) or file path to resume a specific conversation.',\n )\n .argument(\n '[identifier]',\n 'A number (0, 1, 2, etc.) or file path to resume a specific conversation',\n )\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .option('-e, --enable-architect', 'Enable the Architect tool', () => true)\n .option('-v, --verbose', 'Do not truncate message output', () => true)\n .option(\n '--safe',\n 'Enable strict permission checking mode (default is permissive)',\n () => true,\n )\n .action(async (identifier, { cwd, enableArchitect, safe, verbose }) => {\n await setup(cwd, safe)\n assertMinVersion()\n\n const [tools, commands, logs, mcpClients] = await Promise.all([\n getTools(\n enableArchitect ?? getCurrentProjectConfig().enableArchitectTool,\n ),\n getCommands(),\n loadLogList(CACHE_PATHS.messages()),\n getClients(),\n ])\n // logStartup()\n\n // If a specific conversation is requested, load and resume it directly\n if (identifier !== undefined) {\n // Check if identifier is a number or a file path\n const number = Math.abs(parseInt(identifier))\n const isNumber = !isNaN(number)\n let messages, date, forkNumber\n try {\n if (isNumber) {\n logEvent('tengu_resume', { number: number.toString() })\n const log = logs[number]\n if (!log) {\n console.error('No conversation found at index', number)\n process.exit(1)\n }\n messages = await loadMessagesFromLog(log.fullPath, tools)\n ;({ date, forkNumber } = log)\n } else {\n // Handle file path case\n logEvent('tengu_resume', { filePath: identifier })\n if (!existsSync(identifier)) {\n console.error('File does not exist:', identifier)\n process.exit(1)\n }\n messages = await loadMessagesFromLog(identifier, tools)\n const pathSegments = identifier.split('/')\n const filename = pathSegments[pathSegments.length - 1] ?? 'unknown'\n ;({ date, forkNumber } = parseLogFilename(filename))\n }\n const fork = getNextAvailableLogForkNumber(date, forkNumber ?? 1, 0)\n const isDefaultModel = await isDefaultSlowAndCapableModel()\n {\n const { render } = await import('ink')\n const { REPL } = await import('../screens/REPL')\n render(\n <REPL\n initialPrompt=\"\"\n messageLogName={date}\n initialForkNumber={fork}\n shouldShowPromptInput={true}\n verbose={verbose}\n commands={commands}\n tools={tools}\n safeMode={safe}\n initialMessages={messages}\n mcpClients={mcpClients}\n isDefaultModel={isDefaultModel}\n />,\n { exitOnCtrlC: false },\n )\n }\n } catch (error) {\n logError(`Failed to load conversation: ${error}`)\n process.exit(1)\n }\n } else {\n // Show the conversation selector UI\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { unmount } = render(\n <ResumeConversation\n context={context}\n commands={commands}\n logs={logs}\n tools={tools}\n verbose={verbose}\n />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n }\n })\n\n // claude error\n program\n .command('error')\n .description(\n 'View error logs. Optionally provide a number (0, -1, -2, etc.) to display a specific log.',\n )\n .argument(\n '[number]',\n 'A number (0, 1, 2, etc.) to display a specific log',\n parseInt,\n )\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (number, { cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_view_errors', { number: number?.toString() ?? '' })\n const context: { unmount?: () => void } = {}\n ;(async () => {\n const { render } = await import('ink')\n const { unmount } = render(\n <LogList context={context} type=\"errors\" logNumber={number} />,\n renderContextWithExitOnCtrlC,\n )\n context.unmount = unmount\n })()\n })\n\n // claude context (TODO: deprecate)\n const context = program\n .command('context')\n .description(\n `Set static context (eg. ${PRODUCT_COMMAND} context add-file ./src/*.py)`,\n )\n\n context\n .command('get <key>')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .description('Get a value from context')\n .action(async (key, { cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_context_get', { key })\n const context = omit(\n await getContext(),\n 'codeStyle',\n 'directoryStructure',\n )\n console.log(context[key])\n process.exit(0)\n })\n\n context\n .command('set <key> <value>')\n .description('Set a value in context')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (key, value, { cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_context_set', { key })\n setContext(key, value)\n console.log(`Set context.${key} to \"${value}\"`)\n process.exit(0)\n })\n\n context\n .command('list')\n .description('List all context values')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async ({ cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_context_list', {})\n const context = omit(\n await getContext(),\n 'codeStyle',\n 'directoryStructure',\n 'gitStatus',\n )\n console.log(JSON.stringify(context, null, 2))\n process.exit(0)\n })\n\n context\n .command('remove <key>')\n .description('Remove a value from context')\n .option('-c, --cwd <cwd>', 'The current working directory', String, cwd())\n .action(async (key, { cwd }) => {\n await setup(cwd, false)\n logEvent('tengu_context_delete', { key })\n removeContext(key)\n console.log(`Removed context.${key}`)\n process.exit(0)\n })\n\n await program.parseAsync(process.argv)\n return program\n}\n\n// TODO: stream?\nasync function stdin() {\n if (process.stdin.isTTY) {\n return ''\n }\n\n let data = ''\n for await (const chunk of process.stdin) data += chunk\n return data\n}\n\nprocess.on('exit', () => {\n resetCursor()\n PersistentShell.getInstance().close()\n})\n\nfunction gracefulExit(code = 0) {\n try { resetCursor() } catch {}\n try { PersistentShell.getInstance().close() } catch {}\n process.exit(code)\n}\n\nprocess.on('SIGINT', () => gracefulExit(0))\nprocess.on('SIGTERM', () => gracefulExit(0))\n// Windows CTRL+BREAK\nprocess.on('SIGBREAK', () => gracefulExit(0))\nprocess.on('unhandledRejection', err => {\n console.error('Unhandled rejection:', err)\n gracefulExit(1)\n})\nprocess.on('uncaughtException', err => {\n console.error('Uncaught exception:', err)\n gracefulExit(1)\n})\n\nfunction resetCursor() {\n const terminal = process.stderr.isTTY\n ? process.stderr\n : process.stdout.isTTY\n ? process.stdout\n : undefined\n terminal?.write(`\\u001B[?25h${cursorShow}`)\n}\n\nmain()\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["cwd", "env", "existsSync", "join", "config", "React", "getUpdateCommandSuggestions", "context", "commands"]
|
|
7
7
|
}
|
package/dist/screens/Doctor.js
CHANGED
|
@@ -1,141 +1,20 @@
|
|
|
1
|
-
import React, {
|
|
1
|
+
import React, { useEffect, useState } from "react";
|
|
2
2
|
import { Box, Text, useInput } from "ink";
|
|
3
|
-
import { Select } from "../components/CustomSelect/select.js";
|
|
4
3
|
import { getTheme } from "../utils/theme.js";
|
|
5
|
-
import { ConfigureNpmPrefix } from "./ConfigureNpmPrefix.js";
|
|
6
|
-
import { platform } from "process";
|
|
7
|
-
import {
|
|
8
|
-
checkNpmPermissions,
|
|
9
|
-
getDefaultNpmPrefix,
|
|
10
|
-
getPermissionsCommand
|
|
11
|
-
} from "../utils/autoUpdater.js";
|
|
12
|
-
import { saveGlobalConfig, getGlobalConfig } from "../utils/config.js";
|
|
13
|
-
import { logEvent } from "../services/statsig.js";
|
|
14
|
-
import { PRODUCT_NAME } from "../constants/product.js";
|
|
15
4
|
import { PressEnterToContinue } from "../components/PressEnterToContinue.js";
|
|
16
5
|
function Doctor({ onDone, doctorMode = false }) {
|
|
17
|
-
const [
|
|
18
|
-
const [npmPrefix, setNpmPrefix] = useState(null);
|
|
19
|
-
const [selectedOption, setSelectedOption] = useState(
|
|
20
|
-
null
|
|
21
|
-
);
|
|
22
|
-
const [customPrefix, setCustomPrefix] = useState(
|
|
23
|
-
getDefaultNpmPrefix()
|
|
24
|
-
);
|
|
6
|
+
const [checked, setChecked] = useState(false);
|
|
25
7
|
const theme = getTheme();
|
|
26
|
-
const [showingPermissionsMessage, setShowingPermissionsMessage] = useState(false);
|
|
27
|
-
const options = [
|
|
28
|
-
{
|
|
29
|
-
label: `Manually fix permissions on current npm prefix (Recommended)`,
|
|
30
|
-
value: "manual",
|
|
31
|
-
description: platform === "win32" ? "Uses icacls to grant write permissions" : "Uses sudo to change ownership"
|
|
32
|
-
},
|
|
33
|
-
{
|
|
34
|
-
label: "Create new npm prefix directory",
|
|
35
|
-
value: "auto",
|
|
36
|
-
description: "Creates a new directory for global npm packages in your home directory"
|
|
37
|
-
},
|
|
38
|
-
{
|
|
39
|
-
label: "Skip configuration until next session",
|
|
40
|
-
value: "ignore",
|
|
41
|
-
description: "Skip this warning (you will be reminded again later)"
|
|
42
|
-
}
|
|
43
|
-
];
|
|
44
|
-
const checkPermissions = useCallback(async () => {
|
|
45
|
-
const result = await checkNpmPermissions();
|
|
46
|
-
logEvent("tengu_auto_updater_permissions_check", {
|
|
47
|
-
hasPermissions: result.hasPermissions.toString(),
|
|
48
|
-
npmPrefix: result.npmPrefix ?? "null"
|
|
49
|
-
});
|
|
50
|
-
setHasPermissions(result.hasPermissions);
|
|
51
|
-
if (result.npmPrefix) {
|
|
52
|
-
setNpmPrefix(result.npmPrefix);
|
|
53
|
-
}
|
|
54
|
-
if (result.hasPermissions) {
|
|
55
|
-
const config = getGlobalConfig();
|
|
56
|
-
saveGlobalConfig({
|
|
57
|
-
...config,
|
|
58
|
-
autoUpdaterStatus: "enabled"
|
|
59
|
-
});
|
|
60
|
-
if (!doctorMode) {
|
|
61
|
-
onDone();
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
}, [onDone, doctorMode]);
|
|
65
8
|
useEffect(() => {
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
}
|
|
74
|
-
},
|
|
75
|
-
{
|
|
76
|
-
isActive: showingPermissionsMessage || doctorMode && hasPermissions === true
|
|
77
|
-
}
|
|
78
|
-
);
|
|
79
|
-
if (hasPermissions === null) {
|
|
80
|
-
return /* @__PURE__ */ React.createElement(Box, { paddingX: 1, paddingTop: 1 }, /* @__PURE__ */ React.createElement(Text, { color: theme.secondaryText }, "Checking npm permissions\u2026"));
|
|
9
|
+
setChecked(true);
|
|
10
|
+
}, []);
|
|
11
|
+
useInput((_input, key) => {
|
|
12
|
+
if (key.return) onDone();
|
|
13
|
+
});
|
|
14
|
+
if (!checked) {
|
|
15
|
+
return /* @__PURE__ */ React.createElement(Box, { paddingX: 1, paddingTop: 1 }, /* @__PURE__ */ React.createElement(Text, { color: theme.secondaryText }, "Running checks\u2026"));
|
|
81
16
|
}
|
|
82
|
-
|
|
83
|
-
if (doctorMode) {
|
|
84
|
-
return /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", gap: 1, paddingX: 1, paddingTop: 1 }, /* @__PURE__ */ React.createElement(Text, { color: theme.success }, "\u2713 npm permissions: OK"), /* @__PURE__ */ React.createElement(Text, null, "Your installation is healthy and ready for auto-updates."), /* @__PURE__ */ React.createElement(PressEnterToContinue, null));
|
|
85
|
-
}
|
|
86
|
-
return /* @__PURE__ */ React.createElement(Box, { paddingX: 1, paddingTop: 1 }, /* @__PURE__ */ React.createElement(Text, { color: theme.success }, "\u2713 Auto-updates enabled"));
|
|
87
|
-
}
|
|
88
|
-
return /* @__PURE__ */ React.createElement(
|
|
89
|
-
Box,
|
|
90
|
-
{
|
|
91
|
-
borderColor: theme.permission,
|
|
92
|
-
borderStyle: "round",
|
|
93
|
-
flexDirection: "column",
|
|
94
|
-
gap: 1,
|
|
95
|
-
paddingX: 1,
|
|
96
|
-
paddingTop: 1
|
|
97
|
-
},
|
|
98
|
-
/* @__PURE__ */ React.createElement(Text, { bold: true, color: theme.permission }, "Enable automatic updates?"),
|
|
99
|
-
/* @__PURE__ */ React.createElement(Text, null, PRODUCT_NAME, " can't update itself because it doesn't have permissions. Do you want to fix this to get automatic updates?"),
|
|
100
|
-
/* @__PURE__ */ React.createElement(Box, { flexDirection: "column" }, !selectedOption && /* @__PURE__ */ React.createElement(Box, { marginLeft: 2 }, /* @__PURE__ */ React.createElement(Text, null, "Select an option below to fix the permissions issue:"), /* @__PURE__ */ React.createElement(
|
|
101
|
-
Select,
|
|
102
|
-
{
|
|
103
|
-
options,
|
|
104
|
-
onChange: (value) => {
|
|
105
|
-
if (value !== "auto" && value !== "manual" && value !== "ignore")
|
|
106
|
-
return;
|
|
107
|
-
setSelectedOption(value);
|
|
108
|
-
logEvent("tengu_auto_updater_config_option_selected", {
|
|
109
|
-
option: value,
|
|
110
|
-
npmPrefix: npmPrefix ?? "null"
|
|
111
|
-
});
|
|
112
|
-
if (value === "manual") {
|
|
113
|
-
const config = getGlobalConfig();
|
|
114
|
-
saveGlobalConfig({
|
|
115
|
-
...config,
|
|
116
|
-
autoUpdaterStatus: "not_configured"
|
|
117
|
-
});
|
|
118
|
-
setShowingPermissionsMessage(true);
|
|
119
|
-
} else if (value === "ignore") {
|
|
120
|
-
const config = getGlobalConfig();
|
|
121
|
-
saveGlobalConfig({
|
|
122
|
-
...config,
|
|
123
|
-
autoUpdaterStatus: "not_configured"
|
|
124
|
-
});
|
|
125
|
-
onDone();
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
)), selectedOption === "auto" && /* @__PURE__ */ React.createElement(Box, { marginLeft: 2 }, /* @__PURE__ */ React.createElement(
|
|
130
|
-
ConfigureNpmPrefix,
|
|
131
|
-
{
|
|
132
|
-
customPrefix,
|
|
133
|
-
onCustomPrefixChange: setCustomPrefix,
|
|
134
|
-
onSuccess: checkPermissions,
|
|
135
|
-
onCancel: onDone
|
|
136
|
-
}
|
|
137
|
-
)), selectedOption === "manual" && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(Box, { marginLeft: 4, flexDirection: "column" }, /* @__PURE__ */ React.createElement(Text, null, "Run this command in your terminal:"), /* @__PURE__ */ React.createElement(Box, { flexDirection: "row", gap: 1 }, /* @__PURE__ */ React.createElement(Text, { color: theme.warning }, getPermissionsCommand(npmPrefix ?? ""))), /* @__PURE__ */ React.createElement(Box, { flexDirection: "row", gap: 1 }, /* @__PURE__ */ React.createElement(Text, { color: theme.suggestion }, "After running the command, restart ", PRODUCT_NAME))), /* @__PURE__ */ React.createElement(PressEnterToContinue, null)))
|
|
138
|
-
);
|
|
17
|
+
return /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", gap: 1, paddingX: 1, paddingTop: 1 }, /* @__PURE__ */ React.createElement(Text, { color: theme.success }, "\u2713 Installation checks passed"), /* @__PURE__ */ React.createElement(Text, { dimColor: true }, "Note: Auto-update is disabled by design. Use npm/bun to update."), /* @__PURE__ */ React.createElement(PressEnterToContinue, null));
|
|
139
18
|
}
|
|
140
19
|
export {
|
|
141
20
|
Doctor
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/screens/Doctor.tsx"],
|
|
4
|
-
"sourcesContent": ["import React, {
|
|
5
|
-
"mappings": "AAAA,OAAO,SAAS,
|
|
4
|
+
"sourcesContent": ["import React, { useEffect, useState } from 'react'\nimport { Box, Text, useInput } from 'ink'\nimport { getTheme } from '../utils/theme'\n// Removed autoUpdater usage; Doctor is now a simple health check\nimport { PressEnterToContinue } from '../components/PressEnterToContinue'\n\ntype Props = {\n onDone: () => void\n doctorMode?: boolean\n}\n\n// Interactive options removed; simplified status-only doctor\n\nexport function Doctor({ onDone, doctorMode = false }: Props): React.ReactNode {\n // Fully remove auto-update configuration; only show a quick health check\n const [checked, setChecked] = useState(false)\n const theme = getTheme()\n\n useEffect(() => {\n setChecked(true)\n }, [])\n\n // Close on Enter\n useInput((_input, key) => {\n if (key.return) onDone()\n })\n\n if (!checked) {\n return (\n <Box paddingX={1} paddingTop={1}>\n <Text color={theme.secondaryText}>Running checks\u2026</Text>\n </Box>\n )\n }\n return (\n <Box flexDirection=\"column\" gap={1} paddingX={1} paddingTop={1}>\n <Text color={theme.success}>\u2713 Installation checks passed</Text>\n <Text dimColor>Note: Auto-update is disabled by design. Use npm/bun to update.</Text>\n <PressEnterToContinue />\n </Box>\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,OAAO,SAAS,WAAW,gBAAgB;AAC3C,SAAS,KAAK,MAAM,gBAAgB;AACpC,SAAS,gBAAgB;AAEzB,SAAS,4BAA4B;AAS9B,SAAS,OAAO,EAAE,QAAQ,aAAa,MAAM,GAA2B;AAE7E,QAAM,CAAC,SAAS,UAAU,IAAI,SAAS,KAAK;AAC5C,QAAM,QAAQ,SAAS;AAEvB,YAAU,MAAM;AACd,eAAW,IAAI;AAAA,EACjB,GAAG,CAAC,CAAC;AAGL,WAAS,CAAC,QAAQ,QAAQ;AACxB,QAAI,IAAI,OAAQ,QAAO;AAAA,EACzB,CAAC;AAED,MAAI,CAAC,SAAS;AACZ,WACE,oCAAC,OAAI,UAAU,GAAG,YAAY,KAC5B,oCAAC,QAAK,OAAO,MAAM,iBAAe,sBAAe,CACnD;AAAA,EAEJ;AACA,SACE,oCAAC,OAAI,eAAc,UAAS,KAAK,GAAG,UAAU,GAAG,YAAY,KAC3D,oCAAC,QAAK,OAAO,MAAM,WAAS,mCAA4B,GACxD,oCAAC,QAAK,UAAQ,QAAC,iEAA+D,GAC9E,oCAAC,0BAAqB,CACxB;AAEJ;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
package/dist/screens/REPL.js
CHANGED
|
@@ -82,7 +82,6 @@ function REPL({
|
|
|
82
82
|
] = useState(null);
|
|
83
83
|
const [abortController, setAbortController] = useState(null);
|
|
84
84
|
const [isLoading, setIsLoading] = useState(false);
|
|
85
|
-
const [autoUpdaterResult, setAutoUpdaterResult] = useState(null);
|
|
86
85
|
const [toolJSX, setToolJSX] = useState(null);
|
|
87
86
|
const [toolUseConfirm, setToolUseConfirm] = useState(
|
|
88
87
|
null
|
|
@@ -514,8 +513,6 @@ function REPL({
|
|
|
514
513
|
verbose,
|
|
515
514
|
messages,
|
|
516
515
|
setToolJSX,
|
|
517
|
-
onAutoUpdaterResult: setAutoUpdaterResult,
|
|
518
|
-
autoUpdaterResult,
|
|
519
516
|
input: inputValue,
|
|
520
517
|
onInputChange: setInputValue,
|
|
521
518
|
mode: inputMode,
|