@cleocode/adapters 2026.3.37 → 2026.3.39
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/LICENSE +21 -0
- package/README.md +503 -0
- package/dist/index.js +621 -496
- package/dist/index.js.map +4 -4
- package/package.json +12 -7
- package/src/__tests__/claude-code-adapter.test.d.ts +10 -0
- package/src/__tests__/claude-code-adapter.test.d.ts.map +1 -0
- package/src/__tests__/claude-code-adapter.test.js +192 -0
- package/src/__tests__/claude-code-adapter.test.js.map +1 -0
- package/src/__tests__/claude-code-adapter.test.ts +235 -0
- package/src/__tests__/cursor-adapter.test.d.ts +10 -0
- package/src/__tests__/cursor-adapter.test.d.ts.map +1 -0
- package/src/__tests__/cursor-adapter.test.js +196 -0
- package/src/__tests__/cursor-adapter.test.js.map +1 -0
- package/src/__tests__/cursor-adapter.test.ts +246 -0
- package/src/__tests__/opencode-adapter.test.d.ts +10 -0
- package/src/__tests__/opencode-adapter.test.d.ts.map +1 -0
- package/src/__tests__/opencode-adapter.test.js +204 -0
- package/src/__tests__/opencode-adapter.test.js.map +1 -0
- package/src/__tests__/opencode-adapter.test.ts +250 -0
- package/src/index.d.ts +28 -20
- package/src/index.d.ts.map +1 -1
- package/src/index.js +4 -19
- package/src/index.js.map +1 -1
- package/src/index.ts +25 -25
- package/src/providers/claude-code/__tests__/adapter.test.d.ts +1 -1
- package/src/providers/claude-code/__tests__/adapter.test.d.ts.map +0 -0
- package/src/providers/claude-code/__tests__/adapter.test.js +2 -2
- package/src/providers/claude-code/__tests__/adapter.test.js.map +1 -1
- package/src/providers/claude-code/__tests__/adapter.test.ts +2 -2
- package/src/providers/claude-code/adapter.d.ts +54 -50
- package/src/providers/claude-code/adapter.d.ts.map +0 -0
- package/src/providers/claude-code/adapter.js +1 -1
- package/src/providers/claude-code/adapter.js.map +1 -1
- package/src/providers/claude-code/adapter.ts +1 -1
- package/src/providers/claude-code/context-monitor.d.ts +6 -6
- package/src/providers/claude-code/context-monitor.d.ts.map +0 -0
- package/src/providers/claude-code/context-monitor.js +0 -0
- package/src/providers/claude-code/context-monitor.js.map +0 -0
- package/src/providers/claude-code/context-monitor.ts +0 -0
- package/src/providers/claude-code/hooks.d.ts +36 -36
- package/src/providers/claude-code/hooks.d.ts.map +0 -0
- package/src/providers/claude-code/hooks.js +0 -0
- package/src/providers/claude-code/hooks.js.map +0 -0
- package/src/providers/claude-code/hooks.ts +0 -0
- package/src/providers/claude-code/index.d.ts +6 -2
- package/src/providers/claude-code/index.d.ts.map +1 -1
- package/src/providers/claude-code/index.js +1 -1
- package/src/providers/claude-code/index.js.map +1 -1
- package/src/providers/claude-code/index.ts +2 -2
- package/src/providers/claude-code/install.d.ts +52 -52
- package/src/providers/claude-code/install.d.ts.map +1 -1
- package/src/providers/claude-code/install.js +1 -4
- package/src/providers/claude-code/install.js.map +1 -1
- package/src/providers/claude-code/install.ts +1 -4
- package/src/providers/claude-code/manifest.json +0 -0
- package/src/providers/claude-code/paths.d.ts +5 -5
- package/src/providers/claude-code/paths.d.ts.map +0 -0
- package/src/providers/claude-code/paths.js +0 -0
- package/src/providers/claude-code/paths.js.map +0 -0
- package/src/providers/claude-code/paths.ts +0 -0
- package/src/providers/claude-code/spawn.d.ts +37 -37
- package/src/providers/claude-code/spawn.d.ts.map +1 -1
- package/src/providers/claude-code/spawn.js +4 -0
- package/src/providers/claude-code/spawn.js.map +1 -1
- package/src/providers/claude-code/spawn.ts +5 -0
- package/src/providers/claude-code/statusline.d.ts +1 -2
- package/src/providers/claude-code/statusline.d.ts.map +0 -0
- package/src/providers/claude-code/statusline.js +2 -1
- package/src/providers/claude-code/statusline.js.map +1 -1
- package/src/providers/claude-code/statusline.ts +3 -3
- package/src/providers/claude-code/task-sync.d.ts +7 -7
- package/src/providers/claude-code/task-sync.d.ts.map +1 -1
- package/src/providers/claude-code/task-sync.js +1 -3
- package/src/providers/claude-code/task-sync.js.map +1 -1
- package/src/providers/claude-code/task-sync.ts +1 -3
- package/src/providers/claude-code/transport.d.ts +3 -3
- package/src/providers/claude-code/transport.d.ts.map +0 -0
- package/src/providers/claude-code/transport.js +0 -0
- package/src/providers/claude-code/transport.js.map +0 -0
- package/src/providers/claude-code/transport.ts +0 -0
- package/src/providers/cursor/__tests__/adapter.test.d.ts +1 -1
- package/src/providers/cursor/__tests__/adapter.test.d.ts.map +0 -0
- package/src/providers/cursor/__tests__/adapter.test.js +2 -2
- package/src/providers/cursor/__tests__/adapter.test.js.map +1 -1
- package/src/providers/cursor/__tests__/adapter.test.ts +2 -2
- package/src/providers/cursor/adapter.d.ts +44 -40
- package/src/providers/cursor/adapter.d.ts.map +0 -0
- package/src/providers/cursor/adapter.js +0 -0
- package/src/providers/cursor/adapter.js.map +0 -0
- package/src/providers/cursor/adapter.ts +0 -0
- package/src/providers/cursor/hooks.d.ts +29 -29
- package/src/providers/cursor/hooks.d.ts.map +0 -0
- package/src/providers/cursor/hooks.js +0 -0
- package/src/providers/cursor/hooks.js.map +0 -0
- package/src/providers/cursor/hooks.ts +0 -0
- package/src/providers/cursor/index.d.ts +1 -1
- package/src/providers/cursor/index.d.ts.map +0 -0
- package/src/providers/cursor/index.js +0 -0
- package/src/providers/cursor/index.js.map +0 -0
- package/src/providers/cursor/index.ts +0 -0
- package/src/providers/cursor/install.d.ts +67 -67
- package/src/providers/cursor/install.d.ts.map +1 -1
- package/src/providers/cursor/install.js +1 -4
- package/src/providers/cursor/install.js.map +1 -1
- package/src/providers/cursor/install.ts +1 -4
- package/src/providers/cursor/manifest.json +0 -0
- package/src/providers/cursor/spawn.d.ts +31 -31
- package/src/providers/cursor/spawn.d.ts.map +0 -0
- package/src/providers/cursor/spawn.js +0 -0
- package/src/providers/cursor/spawn.js.map +1 -1
- package/src/providers/cursor/spawn.ts +2 -2
- package/src/providers/opencode/__tests__/adapter.test.d.ts +1 -1
- package/src/providers/opencode/__tests__/adapter.test.d.ts.map +0 -0
- package/src/providers/opencode/__tests__/adapter.test.js +2 -2
- package/src/providers/opencode/__tests__/adapter.test.js.map +1 -1
- package/src/providers/opencode/__tests__/adapter.test.ts +2 -2
- package/src/providers/opencode/adapter.d.ts +50 -46
- package/src/providers/opencode/adapter.d.ts.map +0 -0
- package/src/providers/opencode/adapter.js +0 -0
- package/src/providers/opencode/adapter.js.map +0 -0
- package/src/providers/opencode/adapter.ts +0 -0
- package/src/providers/opencode/hooks.d.ts +36 -36
- package/src/providers/opencode/hooks.d.ts.map +0 -0
- package/src/providers/opencode/hooks.js +1 -1
- package/src/providers/opencode/hooks.js.map +1 -1
- package/src/providers/opencode/hooks.ts +1 -1
- package/src/providers/opencode/index.d.ts +2 -2
- package/src/providers/opencode/index.d.ts.map +1 -1
- package/src/providers/opencode/index.js +1 -1
- package/src/providers/opencode/index.js.map +1 -1
- package/src/providers/opencode/index.ts +1 -1
- package/src/providers/opencode/install.d.ts +46 -46
- package/src/providers/opencode/install.d.ts.map +1 -1
- package/src/providers/opencode/install.js +1 -4
- package/src/providers/opencode/install.js.map +1 -1
- package/src/providers/opencode/install.ts +1 -4
- package/src/providers/opencode/manifest.json +0 -0
- package/src/providers/opencode/spawn.d.ts +42 -39
- package/src/providers/opencode/spawn.d.ts.map +1 -1
- package/src/providers/opencode/spawn.js +0 -0
- package/src/providers/opencode/spawn.js.map +1 -1
- package/src/providers/opencode/spawn.ts +2 -7
- package/src/registry.d.ts +12 -12
- package/src/registry.d.ts.map +1 -1
- package/src/registry.js +0 -0
- package/src/registry.js.map +1 -1
- package/src/registry.ts +1 -3
- package/dist/index.d.ts +0 -27
- package/dist/index.d.ts.map +0 -1
- package/dist/providers/claude-code/adapter.d.ts +0 -75
- package/dist/providers/claude-code/adapter.d.ts.map +0 -1
- package/dist/providers/claude-code/adapter.js +0 -154
- package/dist/providers/claude-code/adapter.js.map +0 -1
- package/dist/providers/claude-code/context-monitor.d.ts +0 -24
- package/dist/providers/claude-code/context-monitor.d.ts.map +0 -1
- package/dist/providers/claude-code/context-monitor.js +0 -148
- package/dist/providers/claude-code/context-monitor.js.map +0 -1
- package/dist/providers/claude-code/hooks.d.ts +0 -59
- package/dist/providers/claude-code/hooks.d.ts.map +0 -1
- package/dist/providers/claude-code/hooks.js +0 -77
- package/dist/providers/claude-code/hooks.js.map +0 -1
- package/dist/providers/claude-code/index.d.ts +0 -24
- package/dist/providers/claude-code/index.d.ts.map +0 -1
- package/dist/providers/claude-code/index.js +0 -26
- package/dist/providers/claude-code/index.js.map +0 -1
- package/dist/providers/claude-code/install.d.ts +0 -75
- package/dist/providers/claude-code/install.d.ts.map +0 -1
- package/dist/providers/claude-code/install.js +0 -237
- package/dist/providers/claude-code/install.js.map +0 -1
- package/dist/providers/claude-code/paths.d.ts +0 -24
- package/dist/providers/claude-code/paths.d.ts.map +0 -1
- package/dist/providers/claude-code/paths.js +0 -33
- package/dist/providers/claude-code/paths.js.map +0 -1
- package/dist/providers/claude-code/spawn.d.ts +0 -60
- package/dist/providers/claude-code/spawn.d.ts.map +0 -1
- package/dist/providers/claude-code/spawn.js +0 -160
- package/dist/providers/claude-code/spawn.js.map +0 -1
- package/dist/providers/claude-code/statusline.d.ts +0 -24
- package/dist/providers/claude-code/statusline.d.ts.map +0 -1
- package/dist/providers/claude-code/statusline.js +0 -85
- package/dist/providers/claude-code/statusline.js.map +0 -1
- package/dist/providers/claude-code/task-sync.d.ts +0 -27
- package/dist/providers/claude-code/task-sync.d.ts.map +0 -1
- package/dist/providers/claude-code/task-sync.js +0 -124
- package/dist/providers/claude-code/task-sync.js.map +0 -1
- package/dist/providers/claude-code/transport.d.ts +0 -14
- package/dist/providers/claude-code/transport.d.ts.map +0 -1
- package/dist/providers/claude-code/transport.js +0 -18
- package/dist/providers/claude-code/transport.js.map +0 -1
- package/dist/providers/cursor/adapter.d.ts +0 -62
- package/dist/providers/cursor/adapter.d.ts.map +0 -1
- package/dist/providers/cursor/adapter.js +0 -124
- package/dist/providers/cursor/adapter.js.map +0 -1
- package/dist/providers/cursor/hooks.d.ts +0 -48
- package/dist/providers/cursor/hooks.d.ts.map +0 -1
- package/dist/providers/cursor/hooks.js +0 -55
- package/dist/providers/cursor/hooks.js.map +0 -1
- package/dist/providers/cursor/index.d.ts +0 -19
- package/dist/providers/cursor/index.d.ts.map +0 -1
- package/dist/providers/cursor/index.js +0 -21
- package/dist/providers/cursor/index.js.map +0 -1
- package/dist/providers/cursor/install.d.ts +0 -94
- package/dist/providers/cursor/install.d.ts.map +0 -1
- package/dist/providers/cursor/install.js +0 -241
- package/dist/providers/cursor/install.js.map +0 -1
- package/dist/providers/cursor/spawn.d.ts +0 -50
- package/dist/providers/cursor/spawn.d.ts.map +0 -1
- package/dist/providers/cursor/spawn.js +0 -59
- package/dist/providers/cursor/spawn.js.map +0 -1
- package/dist/providers/opencode/adapter.d.ts +0 -67
- package/dist/providers/opencode/adapter.d.ts.map +0 -1
- package/dist/providers/opencode/adapter.js +0 -144
- package/dist/providers/opencode/adapter.js.map +0 -1
- package/dist/providers/opencode/hooks.d.ts +0 -66
- package/dist/providers/opencode/hooks.d.ts.map +0 -1
- package/dist/providers/opencode/hooks.js +0 -89
- package/dist/providers/opencode/hooks.js.map +0 -1
- package/dist/providers/opencode/index.d.ts +0 -20
- package/dist/providers/opencode/index.d.ts.map +0 -1
- package/dist/providers/opencode/index.js +0 -22
- package/dist/providers/opencode/index.js.map +0 -1
- package/dist/providers/opencode/install.d.ts +0 -65
- package/dist/providers/opencode/install.d.ts.map +0 -1
- package/dist/providers/opencode/install.js +0 -183
- package/dist/providers/opencode/install.js.map +0 -1
- package/dist/providers/opencode/spawn.d.ts +0 -72
- package/dist/providers/opencode/spawn.d.ts.map +0 -1
- package/dist/providers/opencode/spawn.js +0 -219
- package/dist/providers/opencode/spawn.js.map +0 -1
- package/dist/registry.d.ts +0 -36
- package/dist/registry.d.ts.map +0 -1
- package/dist/registry.js +0 -55
- package/dist/registry.js.map +0 -1
package/dist/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../src/providers/claude-code/paths.ts", "../src/providers/claude-code/context-monitor.ts", "../src/providers/claude-code/hooks.ts", "../src/providers/claude-code/install.ts", "../src/providers/claude-code/spawn.ts", "../src/providers/claude-code/task-sync.ts", "../src/providers/claude-code/transport.ts", "../src/providers/claude-code/adapter.ts", "../src/providers/claude-code/statusline.ts", "../src/providers/claude-code/index.ts", "../src/providers/
|
|
4
|
-
"sourcesContent": ["/**\n * Claude Code path provider.\n *\n * Implements AdapterPathProvider with Claude Code-specific directory locations.\n *\n * @task T5240\n */\n\nimport { homedir } from 'node:os';\nimport { join } from 'node:path';\nimport type { AdapterPathProvider } from '@cleocode/contracts';\n\n/**\n * Path provider for Anthropic Claude Code CLI.\n *\n * Resolves Claude Code's standard directory layout:\n * - Config dir: ~/.claude (or CLAUDE_HOME)\n * - Settings: ~/.claude/settings.json (or CLAUDE_SETTINGS)\n * - Agents: ~/.claude/agents\n * - Memory DB: ~/.claude-mem/claude-mem.db (or CLAUDE_MEM_DB)\n */\nexport class ClaudeCodePathProvider implements AdapterPathProvider {\n getProviderDir(): string {\n return process.env['CLAUDE_HOME'] ?? join(homedir(), '.claude');\n }\n\n getSettingsPath(): string | null {\n return process.env['CLAUDE_SETTINGS'] ?? join(this.getProviderDir(), 'settings.json');\n }\n\n getAgentInstallDir(): string | null {\n return join(this.getProviderDir(), 'agents');\n }\n\n getMemoryDbPath(): string | null {\n return process.env['CLAUDE_MEM_DB'] ?? join(homedir(), '.claude-mem', 'claude-mem.db');\n }\n}\n", "/**\n * Claude Code context monitor provider.\n *\n * Implements AdapterContextMonitorProvider for Claude Code's context window\n * tracking and statusline integration.\n *\n * @task T5240\n */\n\nimport { existsSync, readFileSync, writeFileSync } from 'node:fs';\nimport { mkdir } from 'node:fs/promises';\nimport { homedir } from 'node:os';\nimport { dirname, join } from 'node:path';\nimport type { AdapterContextMonitorProvider } from '@cleocode/contracts';\nimport { ClaudeCodePathProvider } from './paths.js';\n\n/** Context window input from Claude Code. */\ninterface ContextWindowInput {\n context_window: {\n context_window_size?: number;\n current_usage?: {\n input_tokens?: number;\n output_tokens?: number;\n cache_creation_input_tokens?: number;\n cache_read_input_tokens?: number;\n };\n };\n}\n\n/** Thresholds for context window status levels. */\nconst THRESHOLDS = {\n WARNING: 50,\n CAUTION: 70,\n CRITICAL: 85,\n EMERGENCY: 95,\n} as const;\n\ntype ContextStatus = 'ok' | 'warning' | 'caution' | 'critical' | 'emergency';\n\nfunction getContextStatusFromPercentage(percentage: number): ContextStatus {\n if (percentage >= THRESHOLDS.EMERGENCY) return 'emergency';\n if (percentage >= THRESHOLDS.CRITICAL) return 'critical';\n if (percentage >= THRESHOLDS.CAUTION) return 'caution';\n if (percentage >= THRESHOLDS.WARNING) return 'warning';\n return 'ok';\n}\n\n/**\n * Context monitor provider for Claude Code.\n *\n * Processes context window JSON from Claude Code and writes state files\n * for statusline display. Also provides statusline configuration\n * and setup instructions specific to Claude Code's settings.json.\n */\nexport class ClaudeCodeContextMonitorProvider implements AdapterContextMonitorProvider {\n private pathProvider = new ClaudeCodePathProvider();\n\n async processContextInput(input: unknown, cwd?: string): Promise<string> {\n const typed = input as ContextWindowInput;\n const contextSize = typed.context_window?.context_window_size ?? 200000;\n const usage = typed.context_window?.current_usage;\n\n if (!usage) return '-- no data';\n\n const inputTokens = usage.input_tokens ?? 0;\n const outputTokens = usage.output_tokens ?? 0;\n const cacheCreate = usage.cache_creation_input_tokens ?? 0;\n\n const totalTokens = inputTokens + outputTokens + cacheCreate;\n const percentage = Math.floor((totalTokens * 100) / contextSize);\n const status = getContextStatusFromPercentage(percentage);\n\n // Write state file if CLEO dir exists\n const cleoDir = cwd ? join(cwd, '.cleo') : '.cleo';\n if (existsSync(cleoDir)) {\n const stateDir = join(cleoDir, 'context-states');\n const statePath = join(stateDir, '.context-state.json');\n\n const state = {\n $schema: 'https://cleo-dev.com/schemas/v1/context-state.schema.json',\n version: '1.0.0',\n timestamp: new Date().toISOString().replace(/\\.\\d{3}Z$/, 'Z'),\n staleAfterMs: 5000,\n contextWindow: {\n maxTokens: contextSize,\n currentTokens: totalTokens,\n percentage,\n breakdown: {\n inputTokens,\n outputTokens,\n cacheCreationTokens: cacheCreate,\n cacheReadTokens: usage.cache_read_input_tokens ?? 0,\n },\n },\n thresholds: {\n warning: THRESHOLDS.WARNING,\n caution: THRESHOLDS.CAUTION,\n critical: THRESHOLDS.CRITICAL,\n emergency: THRESHOLDS.EMERGENCY,\n },\n status,\n cleoSessionId: '',\n };\n\n try {\n await mkdir(dirname(statePath), { recursive: true });\n writeFileSync(statePath, JSON.stringify(state, null, 2));\n } catch {\n // Non-fatal\n }\n }\n\n return `${percentage}% | ${totalTokens}/${contextSize}`;\n }\n\n checkStatuslineIntegration(): 'configured' | 'not_configured' | 'custom_no_cleo' | 'no_settings' {\n const settingsPath = this.pathProvider.getSettingsPath();\n if (!settingsPath || !existsSync(settingsPath)) return 'no_settings';\n\n try {\n const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));\n const statusLine = settings.statusLine;\n\n if (!statusLine?.type) return 'not_configured';\n if (statusLine.type !== 'command') return 'custom_no_cleo';\n\n const cmd = statusLine.command ?? '';\n\n if (\n cmd.includes('context-monitor.sh') ||\n cmd.includes('cleo-statusline') ||\n cmd.includes('.context-state.json') ||\n cmd.includes('context-states')\n ) {\n return 'configured';\n }\n\n const scriptPath = cmd.startsWith('~') ? cmd.replace('~', homedir()) : cmd;\n if (existsSync(scriptPath)) {\n try {\n const content = readFileSync(scriptPath, 'utf-8');\n if (content.includes('context-state.json')) return 'configured';\n } catch {\n /* unreadable */\n }\n }\n\n return 'custom_no_cleo';\n } catch {\n return 'no_settings';\n }\n }\n\n getStatuslineConfig(): Record<string, unknown> {\n return {\n statusLine: {\n type: 'command',\n command: join(homedir(), '.cleo', 'lib', 'session', 'context-monitor.sh'),\n },\n };\n }\n\n getSetupInstructions(): string {\n const settingsPath = this.pathProvider.getSettingsPath() ?? '~/.claude/settings.json';\n\n return [\n 'To enable context monitoring, add to your Claude Code settings:',\n `File: ${settingsPath}`,\n '',\n JSON.stringify(this.getStatuslineConfig(), null, 2),\n '',\n 'This enables real-time context window tracking in the CLI.',\n ].join('\\n');\n }\n}\n", "/**\n * Claude Code Hook Provider\n *\n * Maps Claude Code's native hook events to CAAMP hook events.\n * Claude Code uses: SessionStart, PostToolUse, UserPromptSubmit, Stop\n * CAAMP defines: onSessionStart, onToolComplete, onPromptSubmit, onSessionEnd\n *\n * @task T5240\n */\n\nimport type { AdapterHookProvider } from '@cleocode/contracts';\n\n/**\n * Mapping from Claude Code native event names to CAAMP event names.\n */\nconst CLAUDE_CODE_EVENT_MAP: Record<string, string> = {\n SessionStart: 'onSessionStart',\n PostToolUse: 'onToolComplete',\n UserPromptSubmit: 'onPromptSubmit',\n Stop: 'onSessionEnd',\n};\n\n/**\n * Hook provider for Claude Code.\n *\n * Claude Code registers hooks via a plugin directory\n * with a hooks.json descriptor. The actual hook scripts are shell scripts\n * that invoke CLEO's brain observation system.\n *\n * Since hooks are registered through the plugin system (installed via\n * the install provider), registerNativeHooks and unregisterNativeHooks\n * are effectively no-ops here \u2014 the plugin installer handles registration.\n */\nexport class ClaudeCodeHookProvider implements AdapterHookProvider {\n private registered = false;\n\n /**\n * Map a Claude Code native event name to a CAAMP hook event name.\n *\n * @param providerEvent - Claude Code event name (e.g. \"SessionStart\", \"PostToolUse\")\n * @returns CAAMP event name or null if unmapped\n */\n mapProviderEvent(providerEvent: string): string | null {\n return CLAUDE_CODE_EVENT_MAP[providerEvent] ?? null;\n }\n\n /**\n * Register native hooks for a project.\n *\n * For Claude Code, hooks are registered via the plugin system\n * (hooks.json descriptor), which is handled by the\n * install provider. This method is a no-op since registration\n * is managed through the plugin install lifecycle.\n *\n * @param _projectDir - Project directory (unused; hooks are global)\n */\n async registerNativeHooks(_projectDir: string): Promise<void> {\n this.registered = true;\n }\n\n /**\n * Unregister native hooks.\n *\n * For Claude Code, this is a no-op since hooks are managed through\n * the plugin system. Unregistration happens via the install provider's\n * uninstall method.\n */\n async unregisterNativeHooks(): Promise<void> {\n this.registered = false;\n }\n\n /**\n * Check whether hooks have been registered via registerNativeHooks.\n */\n isRegistered(): boolean {\n return this.registered;\n }\n\n /**\n * Get the full event mapping for introspection/debugging.\n */\n getEventMap(): Readonly<Record<string, string>> {\n return { ...CLAUDE_CODE_EVENT_MAP };\n }\n}\n", "/**\n * Claude Code Install Provider\n *\n * Handles CLEO installation into Claude Code environments:\n * - Registers CLEO MCP server in .mcp.json\n * - Ensures CLAUDE.md has CLEO @-references\n * - Manages plugin registration in ~/.claude/settings.json\n *\n * Migrated from src/core/install/claude-plugin.ts\n *\n * @task T5240\n */\n\nimport { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';\nimport { homedir } from 'node:os';\nimport { join } from 'node:path';\nimport type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';\n\n/** Lines that should appear in CLAUDE.md to reference CLEO. */\nconst INSTRUCTION_REFERENCES = [\n '@~/.cleo/templates/CLEO-INJECTION.md',\n '@.cleo/memory-bridge.md',\n];\n\n/** MCP server registration key used in .mcp.json. */\nconst MCP_SERVER_KEY = 'cleo';\n\n/**\n * Install provider for Claude Code.\n *\n * Manages CLEO's integration with Claude Code by:\n * 1. Registering the CLEO MCP server in the project's .mcp.json\n * 2. Ensuring CLAUDE.md contains @-references to CLEO instruction files\n * 3. Registering the brain observation plugin in ~/.claude/settings.json\n */\nexport class ClaudeCodeInstallProvider implements AdapterInstallProvider {\n private installedProjectDir: string | null = null;\n\n /**\n * Install CLEO into a Claude Code project.\n *\n * @param options - Installation options including project directory and MCP server path\n * @returns Result describing what was installed\n */\n async install(options: InstallOptions): Promise<InstallResult> {\n const { projectDir, mcpServerPath } = options;\n const installedAt = new Date().toISOString();\n let instructionFileUpdated = false;\n let mcpRegistered = false;\n const details: Record<string, unknown> = {};\n\n // Step 1: Register MCP server in .mcp.json\n if (mcpServerPath) {\n mcpRegistered = this.registerMcpServer(projectDir, mcpServerPath);\n if (mcpRegistered) {\n details.mcpConfigPath = join(projectDir, '.mcp.json');\n }\n }\n\n // Step 2: Ensure CLAUDE.md has @-references\n instructionFileUpdated = this.updateInstructionFile(projectDir);\n if (instructionFileUpdated) {\n details.instructionFile = join(projectDir, 'CLAUDE.md');\n }\n\n // Step 3: Register plugin in ~/.claude/settings.json\n const pluginResult = this.registerPlugin();\n if (pluginResult) {\n details.plugin = pluginResult;\n }\n\n this.installedProjectDir = projectDir;\n\n return {\n success: true,\n installedAt,\n instructionFileUpdated,\n mcpRegistered,\n details,\n };\n }\n\n /**\n * Uninstall CLEO from the current Claude Code project.\n *\n * Removes the MCP server registration from .mcp.json.\n * Does not remove CLAUDE.md references (they are harmless if CLEO is not present).\n */\n async uninstall(): Promise<void> {\n if (!this.installedProjectDir) return;\n\n const mcpPath = join(this.installedProjectDir, '.mcp.json');\n if (existsSync(mcpPath)) {\n try {\n const raw = readFileSync(mcpPath, 'utf-8');\n const config = JSON.parse(raw) as Record<string, unknown>;\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n delete mcpServers[MCP_SERVER_KEY];\n writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n }\n } catch {\n // Ignore errors during uninstall\n }\n }\n\n this.installedProjectDir = null;\n }\n\n /**\n * Check whether CLEO is installed in the current environment.\n *\n * Checks for:\n * 1. MCP server registered in .mcp.json\n * 2. Plugin enabled in ~/.claude/settings.json\n *\n * Returns true if either condition is met (partial install counts).\n */\n async isInstalled(): Promise<boolean> {\n // Check ~/.claude/settings.json for plugin registration\n const settingsPath = join(homedir(), '.claude', 'settings.json');\n if (existsSync(settingsPath)) {\n try {\n const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));\n const plugins = settings.enabledPlugins as Record<string, boolean> | undefined;\n if (plugins && plugins['cleo@cleocode'] === true) {\n return true;\n }\n } catch {\n // Fall through\n }\n }\n\n // Check current directory for .mcp.json with cleo server\n const mcpPath = join(process.cwd(), '.mcp.json');\n if (existsSync(mcpPath)) {\n try {\n const config = JSON.parse(readFileSync(mcpPath, 'utf-8'));\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n return true;\n }\n } catch {\n // Fall through\n }\n }\n\n return false;\n }\n\n /**\n * Ensure CLAUDE.md contains @-references to CLEO instruction files.\n *\n * Creates CLAUDE.md if it does not exist. Appends any missing references.\n *\n * @param projectDir - Project root directory\n */\n async ensureInstructionReferences(projectDir: string): Promise<void> {\n this.updateInstructionFile(projectDir);\n }\n\n /**\n * Register the CLEO MCP server in .mcp.json.\n *\n * @returns true if registration was performed or updated\n */\n private registerMcpServer(projectDir: string, mcpServerPath: string): boolean {\n const mcpPath = join(projectDir, '.mcp.json');\n let config: Record<string, unknown> = {};\n\n if (existsSync(mcpPath)) {\n try {\n config = JSON.parse(readFileSync(mcpPath, 'utf-8'));\n } catch {\n // Start fresh on parse error\n }\n }\n\n if (!config.mcpServers || typeof config.mcpServers !== 'object') {\n config.mcpServers = {};\n }\n\n const mcpServers = config.mcpServers as Record<string, unknown>;\n mcpServers[MCP_SERVER_KEY] = {\n command: 'node',\n args: [mcpServerPath],\n };\n\n writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n return true;\n }\n\n /**\n * Update CLAUDE.md with CLEO @-references.\n *\n * @returns true if the file was created or modified\n */\n private updateInstructionFile(projectDir: string): boolean {\n const claudeMdPath = join(projectDir, 'CLAUDE.md');\n let content = '';\n let existed = false;\n\n if (existsSync(claudeMdPath)) {\n content = readFileSync(claudeMdPath, 'utf-8');\n existed = true;\n }\n\n const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));\n\n if (missingRefs.length === 0) {\n return false;\n }\n\n const refsBlock = missingRefs.join('\\n');\n\n if (existed) {\n // Append missing references\n const separator = content.endsWith('\\n') ? '' : '\\n';\n content = content + separator + refsBlock + '\\n';\n } else {\n // Create new CLAUDE.md with references\n content = refsBlock + '\\n';\n }\n\n writeFileSync(claudeMdPath, content, 'utf-8');\n return true;\n }\n\n /**\n * Register the CLEO brain plugin in ~/.claude/settings.json.\n *\n * @returns Description of what was registered, or null if no change needed\n */\n private registerPlugin(): string | null {\n const home = homedir();\n const settingsPath = join(home, '.claude', 'settings.json');\n\n let settings: Record<string, unknown> = {};\n if (existsSync(settingsPath)) {\n try {\n settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));\n } catch {\n // Start fresh\n }\n }\n\n const enabledPlugins = (settings.enabledPlugins as Record<string, boolean>) ?? {};\n const pluginKey = 'cleo@cleocode';\n\n if (enabledPlugins[pluginKey] === true) {\n return null;\n }\n\n // Disable old claude-mem if present\n if (enabledPlugins['claude-mem@thedotmack'] === true) {\n enabledPlugins['claude-mem@thedotmack'] = false;\n }\n\n enabledPlugins[pluginKey] = true;\n settings.enabledPlugins = enabledPlugins;\n\n mkdirSync(join(home, '.claude'), { recursive: true });\n writeFileSync(settingsPath, JSON.stringify(settings, null, 2) + '\\n', 'utf-8');\n\n return `Enabled ${pluginKey} in ~/.claude/settings.json`;\n }\n}\n", "/**\n * Claude Code Spawn Provider\n *\n * Implements AdapterSpawnProvider for Claude Code CLI.\n * Migrated from src/core/spawn/adapters/claude-code-adapter.ts\n *\n * Uses the native `claude` CLI to spawn subagent processes with prompts\n * written to temporary files. Processes run detached and are tracked\n * by PID for listing and termination.\n *\n * @task T5240\n */\n\nimport { exec, spawn as nodeSpawn } from 'node:child_process';\nimport { unlink, writeFile } from 'node:fs/promises';\nimport { promisify } from 'node:util';\nimport type { AdapterSpawnProvider, SpawnContext, SpawnResult } from '@cleocode/contracts';\n\nconst execAsync = promisify(exec);\n\n/** Internal tracking entry for a spawned process. */\ninterface TrackedProcess {\n pid: number;\n taskId: string;\n startTime: string;\n}\n\n/**\n * Spawn provider for Claude Code.\n *\n * Spawns detached Claude CLI processes for subagent execution.\n * Each spawn writes its prompt to a temporary file, then runs\n * `claude --allow-insecure --no-upgrade-check <tmpFile>` as a\n * detached, unref'd child process.\n */\nexport class ClaudeCodeSpawnProvider implements AdapterSpawnProvider {\n /** Map of instance IDs to tracked process info. */\n private processMap = new Map<string, TrackedProcess>();\n\n /**\n * Check if the Claude CLI is available in PATH.\n *\n * @returns true if `claude` is found via `which`\n */\n async canSpawn(): Promise<boolean> {\n try {\n await execAsync('which claude');\n return true;\n } catch {\n return false;\n }\n }\n\n /**\n * Spawn a subagent via Claude CLI.\n *\n * Writes the prompt to a temporary file and spawns a detached Claude\n * process. The process runs independently of the parent.\n *\n * @param context - Spawn context with taskId, prompt, and options\n * @returns Spawn result with instance ID and status\n */\n async spawn(context: SpawnContext): Promise<SpawnResult> {\n const instanceId = `claude-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;\n const startTime = new Date().toISOString();\n let tmpFile: string | undefined;\n\n try {\n tmpFile = `/tmp/claude-spawn-${instanceId}.txt`;\n await writeFile(tmpFile, context.prompt, 'utf-8');\n\n const args = ['--allow-insecure', '--no-upgrade-check', tmpFile];\n const spawnOpts: Parameters<typeof nodeSpawn>[2] = {\n detached: true,\n stdio: 'ignore',\n };\n\n if (context.workingDirectory) {\n spawnOpts.cwd = context.workingDirectory;\n }\n\n const child = nodeSpawn('claude', args, spawnOpts);\n child.unref();\n\n if (child.pid) {\n this.processMap.set(instanceId, {\n pid: child.pid,\n taskId: context.taskId,\n startTime,\n });\n }\n\n const capturedTmpFile = tmpFile;\n child.on('exit', async () => {\n this.processMap.delete(instanceId);\n try {\n await unlink(capturedTmpFile);\n } catch {\n // Ignore cleanup errors\n }\n });\n\n return {\n instanceId,\n taskId: context.taskId,\n providerId: 'claude-code',\n status: 'running',\n startTime,\n };\n } catch (error) {\n if (tmpFile) {\n try {\n await unlink(tmpFile);\n } catch {\n // Ignore cleanup errors\n }\n }\n\n return {\n instanceId,\n taskId: context.taskId,\n providerId: 'claude-code',\n status: 'failed',\n startTime,\n endTime: new Date().toISOString(),\n };\n }\n }\n\n /**\n * List currently running Claude subagent processes.\n *\n * Checks each tracked process via kill(pid, 0) to verify it is still alive.\n * Dead processes are automatically cleaned from the tracking map.\n *\n * @returns Array of spawn results for running processes\n */\n async listRunning(): Promise<SpawnResult[]> {\n const running: SpawnResult[] = [];\n\n for (const [instanceId, tracked] of this.processMap.entries()) {\n try {\n process.kill(tracked.pid, 0);\n running.push({\n instanceId,\n taskId: tracked.taskId,\n providerId: 'claude-code',\n status: 'running',\n startTime: tracked.startTime,\n });\n } catch {\n this.processMap.delete(instanceId);\n }\n }\n\n return running;\n }\n\n /**\n * Terminate a running spawn by instance ID.\n *\n * Sends SIGTERM to the tracked process. If the process is not found\n * or has already exited, this is a no-op.\n *\n * @param instanceId - ID of the spawn instance to terminate\n */\n async terminate(instanceId: string): Promise<void> {\n const tracked = this.processMap.get(instanceId);\n if (!tracked) return;\n\n try {\n process.kill(tracked.pid, 'SIGTERM');\n } catch {\n // Process may have already exited\n }\n this.processMap.delete(instanceId);\n }\n}\n", "/**\n * Claude Code TaskSyncProvider \u2014 bridges Claude's TodoWrite format\n * to the provider-agnostic reconciliation system.\n *\n * All Claude Code / TodoWrite-specific parsing lives here.\n * The core reconciliation engine never sees TodoWrite formats.\n *\n * @task T5800\n */\n\nimport { readFile, rm, stat } from 'node:fs/promises';\nimport { join } from 'node:path';\n\nimport type {\n AdapterTaskSyncProvider,\n ExternalTask,\n ExternalTaskStatus,\n} from '@cleocode/contracts';\n\n// ---------------------------------------------------------------------------\n// TodoWrite native types (Claude-specific, never exposed beyond this file)\n// ---------------------------------------------------------------------------\n\ninterface TodoWriteItem {\n content: string;\n status: 'pending' | 'in_progress' | 'completed';\n activeForm?: string;\n}\n\ninterface TodoWriteState {\n todos: TodoWriteItem[];\n}\n\n// ---------------------------------------------------------------------------\n// Parsing helpers\n// ---------------------------------------------------------------------------\n\n/**\n * Parse a CLEO task ID from TodoWrite content prefix: \"[T001] ...\" -> \"T001\".\n */\nfunction parseTaskId(content: string): string | null {\n const match = content.match(/^\\[T(\\d+)\\]/);\n return match ? `T${match[1]}` : null;\n}\n\n/**\n * Strip ID and status prefixes from content to extract the clean title.\n */\nfunction stripPrefixes(content: string): string {\n return content\n .replace(/^\\[T\\d+\\]\\s*/, '')\n .replace(/^\\[!\\]\\s*/, '')\n .replace(/^\\[BLOCKED\\]\\s*/, '');\n}\n\n/**\n * Map TodoWrite status to normalized ExternalTaskStatus.\n */\nfunction mapStatus(twStatus: TodoWriteItem['status']): ExternalTaskStatus {\n switch (twStatus) {\n case 'completed':\n return 'completed';\n case 'in_progress':\n return 'active';\n case 'pending':\n return 'pending';\n default:\n return 'pending';\n }\n}\n\n/**\n * Resolve the TodoWrite state file path.\n * Claude Code writes its TodoWrite state to a known location.\n */\nfunction getTodoWriteFilePath(projectDir: string): string {\n return join(projectDir, '.cleo', 'sync', 'todowrite-state.json');\n}\n\n// ---------------------------------------------------------------------------\n// Provider implementation\n// ---------------------------------------------------------------------------\n\n/**\n * Claude Code TaskSyncProvider.\n *\n * Reads Claude's TodoWrite JSON state, parses [T001]-prefixed task IDs\n * and status, and returns normalized ExternalTask[].\n *\n * Optional: accepts a custom file path for testing.\n */\nexport class ClaudeCodeTaskSyncProvider implements AdapterTaskSyncProvider {\n private readonly customFilePath?: string;\n\n constructor(options?: { filePath?: string }) {\n this.customFilePath = options?.filePath;\n }\n\n async getExternalTasks(projectDir: string): Promise<ExternalTask[]> {\n const filePath = this.customFilePath ?? getTodoWriteFilePath(projectDir);\n\n // Check file exists\n try {\n await stat(filePath);\n } catch {\n // No TodoWrite state \u2014 return empty (no tasks to sync)\n return [];\n }\n\n // Parse the TodoWrite JSON\n const raw = await readFile(filePath, 'utf-8');\n let state: TodoWriteState;\n try {\n state = JSON.parse(raw) as TodoWriteState;\n } catch {\n return []; // Malformed JSON \u2014 treat as empty\n }\n\n if (!state.todos || !Array.isArray(state.todos)) {\n return [];\n }\n\n const tasks: ExternalTask[] = [];\n let syntheticIndex = 0;\n\n for (const item of state.todos) {\n const cleoTaskId = parseTaskId(item.content);\n const title = cleoTaskId\n ? stripPrefixes(item.content).trim()\n : item.content.trim();\n\n if (!title) continue;\n\n tasks.push({\n externalId: cleoTaskId ?? `tw-new-${syntheticIndex++}`,\n cleoTaskId,\n title,\n status: mapStatus(item.status),\n providerMeta: {\n source: 'todowrite',\n activeForm: item.activeForm,\n rawContent: item.content,\n },\n });\n }\n\n return tasks;\n }\n\n async cleanup(projectDir: string): Promise<void> {\n const filePath = this.customFilePath ?? getTodoWriteFilePath(projectDir);\n try {\n await rm(filePath);\n } catch {\n // File may not exist \u2014 that's fine\n }\n }\n}\n", "/**\n * Transport provider for the Claude Code adapter.\n *\n * Implements AdapterTransportProvider to supply Claude Code's\n * native inter-agent transport mechanism.\n *\n * @task T5240\n */\n\nimport type { AdapterTransportProvider } from '@cleocode/contracts';\n\nexport class ClaudeCodeTransportProvider implements AdapterTransportProvider {\n readonly transportName = 'claude-code';\n\n createTransport(): unknown {\n // Returns null \u2014 actual transport creation is handled by the signaldock factory\n // which checks for this adapter's transport capability.\n // Full wiring will be completed in Phase 5.\n return null;\n }\n}\n", "/**\n * Claude Code Adapter\n *\n * Main CLEOProviderAdapter implementation for Anthropic's Claude Code CLI.\n * Provides spawn, hooks, and install capabilities for CLEO integration.\n *\n * @task T5240\n */\n\nimport { exec } from 'node:child_process';\nimport { existsSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { homedir } from 'node:os';\nimport { promisify } from 'node:util';\nimport type {\n AdapterCapabilities,\n AdapterHealthStatus,\n CLEOProviderAdapter,\n} from '@cleocode/contracts';\nimport { ClaudeCodeContextMonitorProvider } from './context-monitor.js';\nimport { ClaudeCodeHookProvider } from './hooks.js';\nimport { ClaudeCodeInstallProvider } from './install.js';\nimport { ClaudeCodePathProvider } from './paths.js';\nimport { ClaudeCodeSpawnProvider } from './spawn.js';\nimport { ClaudeCodeTaskSyncProvider } from './task-sync.js';\nimport { ClaudeCodeTransportProvider } from './transport.js';\n\nconst execAsync = promisify(exec);\n\n/**\n * CLEO provider adapter for Anthropic Claude Code CLI.\n *\n * Bridges CLEO's adapter system with Claude Code's native capabilities:\n * - Hooks: Maps Claude Code events (SessionStart, PostToolUse, etc.) to CAAMP events\n * - Spawn: Launches subagent processes via the `claude` CLI\n * - Install: Registers MCP server, instruction files, and brain observation plugin\n */\nexport class ClaudeCodeAdapter implements CLEOProviderAdapter {\n readonly id = 'claude-code';\n readonly name = 'Claude Code';\n readonly version = '1.0.0';\n\n capabilities: AdapterCapabilities = {\n supportsHooks: true,\n supportedHookEvents: [\n 'onSessionStart',\n 'onSessionEnd',\n 'onToolStart',\n 'onToolComplete',\n 'onError',\n ],\n supportsSpawn: true,\n supportsInstall: true,\n supportsMcp: true,\n supportsInstructionFiles: true,\n instructionFilePattern: 'CLAUDE.md',\n supportsContextMonitor: true,\n supportsStatusline: true,\n supportsProviderPaths: true,\n supportsTransport: true,\n supportsTaskSync: true,\n };\n\n hooks: ClaudeCodeHookProvider;\n spawn: ClaudeCodeSpawnProvider;\n install: ClaudeCodeInstallProvider;\n paths: ClaudeCodePathProvider;\n contextMonitor: ClaudeCodeContextMonitorProvider;\n transport: ClaudeCodeTransportProvider;\n taskSync: ClaudeCodeTaskSyncProvider;\n\n private projectDir: string | null = null;\n private initialized = false;\n\n constructor() {\n this.hooks = new ClaudeCodeHookProvider();\n this.spawn = new ClaudeCodeSpawnProvider();\n this.install = new ClaudeCodeInstallProvider();\n this.paths = new ClaudeCodePathProvider();\n this.contextMonitor = new ClaudeCodeContextMonitorProvider();\n this.transport = new ClaudeCodeTransportProvider();\n this.taskSync = new ClaudeCodeTaskSyncProvider();\n }\n\n /**\n * Initialize the adapter for a given project directory.\n *\n * Validates the environment by checking for the Claude CLI\n * and Claude Code configuration directory.\n *\n * @param projectDir - Root directory of the project\n */\n async initialize(projectDir: string): Promise<void> {\n this.projectDir = projectDir;\n this.initialized = true;\n }\n\n /**\n * Dispose the adapter and clean up resources.\n *\n * Unregisters hooks and releases any tracked state.\n */\n async dispose(): Promise<void> {\n if (this.hooks.isRegistered()) {\n await this.hooks.unregisterNativeHooks();\n }\n this.initialized = false;\n this.projectDir = null;\n }\n\n /**\n * Run a health check to verify Claude Code is accessible.\n *\n * Checks:\n * 1. Adapter has been initialized\n * 2. Claude CLI is available in PATH\n * 3. ~/.claude/ configuration directory exists\n *\n * @returns Health status with details about each check\n */\n async healthCheck(): Promise<AdapterHealthStatus> {\n const details: Record<string, unknown> = {};\n\n if (!this.initialized) {\n return {\n healthy: false,\n provider: this.id,\n details: { error: 'Adapter not initialized' },\n };\n }\n\n // Check Claude CLI availability\n let cliAvailable = false;\n try {\n const { stdout } = await execAsync('which claude');\n cliAvailable = stdout.trim().length > 0;\n details.cliPath = stdout.trim();\n } catch {\n details.cliAvailable = false;\n }\n\n // Check for Claude Code config directory\n const claudeConfigDir = join(homedir(), '.claude');\n const configExists = existsSync(claudeConfigDir);\n details.configDirExists = configExists;\n\n // Check for CLAUDE_CODE_ENTRYPOINT env var\n const entrypointSet = process.env.CLAUDE_CODE_ENTRYPOINT !== undefined;\n details.entrypointEnvSet = entrypointSet;\n\n // Healthy if CLI is available (primary requirement)\n const healthy = cliAvailable;\n details.cliAvailable = cliAvailable;\n\n return {\n healthy,\n provider: this.id,\n details,\n };\n }\n\n /**\n * Check whether the adapter has been initialized.\n */\n isInitialized(): boolean {\n return this.initialized;\n }\n\n /**\n * Get the project directory this adapter was initialized with.\n */\n getProjectDir(): string | null {\n return this.projectDir;\n }\n}\n", "/**\n * Statusline integration for the Claude Code adapter.\n *\n * Implements the statusline portion of AdapterContextMonitorProvider.\n * Checks and configures Claude Code status line for context monitoring.\n *\n * @task T5240\n */\n\nimport { existsSync, readFileSync } from 'node:fs';\nimport { homedir } from 'node:os';\nimport { join } from 'node:path';\n\ntype StatuslineStatus = 'configured' | 'not_configured' | 'custom_no_cleo' | 'no_settings';\n\n/**\n * Get the path to Claude Code's settings.json.\n * Respects CLAUDE_SETTINGS env var, defaults to ~/.claude/settings.json.\n */\nfunction getClaudeSettingsPath(): string {\n return process.env['CLAUDE_SETTINGS'] ?? join(\n process.env['CLAUDE_HOME'] ?? join(homedir(), '.claude'),\n 'settings.json',\n );\n}\n\n/**\n * Check if statusline integration is configured.\n * Returns the current integration status.\n */\nexport function checkStatuslineIntegration(): StatuslineStatus {\n const settingsPath = getClaudeSettingsPath();\n\n if (!existsSync(settingsPath)) return 'no_settings';\n\n try {\n const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));\n const statusLine = settings.statusLine;\n\n if (!statusLine?.type) return 'not_configured';\n if (statusLine.type !== 'command') return 'custom_no_cleo';\n\n const cmd = statusLine.command ?? '';\n\n // Check if it's a CLEO statusline integration\n if (\n cmd.includes('context-monitor.sh') ||\n cmd.includes('cleo-statusline') ||\n cmd.includes('.context-state.json') ||\n cmd.includes('context-states')\n ) {\n return 'configured';\n }\n\n // Check if the script writes to CLEO state file\n const scriptPath = cmd.startsWith('~') ? cmd.replace('~', homedir()) : cmd;\n\n if (existsSync(scriptPath)) {\n try {\n const content = readFileSync(scriptPath, 'utf-8');\n if (content.includes('context-state.json')) return 'configured';\n } catch {\n /* unreadable */\n }\n }\n\n return 'custom_no_cleo';\n } catch {\n return 'no_settings';\n }\n}\n\n/**\n * Get the statusline setup command for Claude Code settings.\n */\nexport function getStatuslineConfig(cleoHome: string): Record<string, unknown> {\n return {\n statusLine: {\n type: 'command',\n command: join(cleoHome, 'lib', 'session', 'context-monitor.sh'),\n },\n };\n}\n\n/**\n * Get human-readable setup instructions.\n */\nexport function getSetupInstructions(cleoHome: string): string {\n const settingsPath = getClaudeSettingsPath();\n\n return [\n 'To enable context monitoring, add to your Claude Code settings:',\n `File: ${settingsPath}`,\n '',\n JSON.stringify(getStatuslineConfig(cleoHome), null, 2),\n '',\n 'This enables real-time context window tracking in the CLI.',\n ].join('\\n');\n}\n", "/**\n * Claude Code provider adapter.\n *\n * CLEO provider adapter for Anthropic Claude Code CLI.\n * Default export is the adapter class for dynamic loading by AdapterManager.\n *\n * @task T5240\n */\n\nimport { ClaudeCodeAdapter } from './adapter.js';\n\nexport { ClaudeCodeAdapter } from './adapter.js';\nexport { ClaudeCodeContextMonitorProvider } from './context-monitor.js';\nexport { ClaudeCodeHookProvider } from './hooks.js';\nexport { ClaudeCodeInstallProvider } from './install.js';\nexport { ClaudeCodePathProvider } from './paths.js';\nexport { ClaudeCodeSpawnProvider } from './spawn.js';\nexport { ClaudeCodeTransportProvider } from './transport.js';\nexport {\n checkStatuslineIntegration,\n getStatuslineConfig,\n getSetupInstructions,\n} from './statusline.js';\n\nexport default ClaudeCodeAdapter;\n\n/**\n * Factory function for creating adapter instances.\n * Used by AdapterManager's dynamic import fallback.\n */\nexport function createAdapter(): ClaudeCodeAdapter {\n return new ClaudeCodeAdapter();\n}\n", "/**\n * OpenCode Hook Provider\n *\n * Maps OpenCode's native hook events to CAAMP hook events.\n * OpenCode supports 6 of 8 CAAMP events through its agent/hook system.\n *\n * OpenCode event mapping:\n * - session.start -> onSessionStart\n * - session.end -> onSessionEnd\n * - tool.start -> onToolStart\n * - tool.complete -> onToolComplete\n * - error -> onError\n * - prompt.submit -> onPromptSubmit\n *\n * @task T5240\n */\n\nimport type { AdapterHookProvider } from '@cleocode/contracts';\n\n/**\n * Mapping from OpenCode native event names to CAAMP event names.\n *\n * OpenCode uses dot-delimited event names (e.g. \"session.start\")\n * while CAAMP uses camelCase (e.g. \"onSessionStart\").\n */\nconst OPENCODE_EVENT_MAP: Record<string, string> = {\n 'session.start': 'onSessionStart',\n 'session.end': 'onSessionEnd',\n 'tool.start': 'onToolStart',\n 'tool.complete': 'onToolComplete',\n 'error': 'onError',\n 'prompt.submit': 'onPromptSubmit',\n};\n\n/**\n * Hook provider for OpenCode.\n *\n * OpenCode registers hooks via its configuration system at\n * .opencode/config.json. Hook handlers are defined as shell commands\n * or script paths that execute when the corresponding event fires.\n *\n * Since hooks are registered through the config system (managed by\n * the install provider), registerNativeHooks and unregisterNativeHooks\n * track registration state without performing filesystem operations.\n */\nexport class OpenCodeHookProvider implements AdapterHookProvider {\n private registered = false;\n\n /**\n * Map an OpenCode native event name to a CAAMP hook event name.\n *\n * @param providerEvent - OpenCode event name (e.g. \"session.start\", \"tool.complete\")\n * @returns CAAMP event name or null if unmapped\n */\n mapProviderEvent(providerEvent: string): string | null {\n return OPENCODE_EVENT_MAP[providerEvent] ?? null;\n }\n\n /**\n * Register native hooks for a project.\n *\n * For OpenCode, hooks are registered via the config system\n * (.opencode/config.json), which is handled by the install provider.\n * This method marks hooks as registered without performing\n * filesystem operations.\n *\n * @param _projectDir - Project directory (unused; config manages registration)\n */\n async registerNativeHooks(_projectDir: string): Promise<void> {\n this.registered = true;\n }\n\n /**\n * Unregister native hooks.\n *\n * For OpenCode, this is a no-op since hooks are managed through\n * the config system. Unregistration happens via the install\n * provider's uninstall method.\n */\n async unregisterNativeHooks(): Promise<void> {\n this.registered = false;\n }\n\n /**\n * Check whether hooks have been registered via registerNativeHooks.\n */\n isRegistered(): boolean {\n return this.registered;\n }\n\n /**\n * Get the full event mapping for introspection/debugging.\n */\n getEventMap(): Readonly<Record<string, string>> {\n return { ...OPENCODE_EVENT_MAP };\n }\n}\n", "/**\n * OpenCode Install Provider\n *\n * Handles CLEO installation into OpenCode environments:\n * - Registers CLEO MCP server in .opencode/config.json\n * - Ensures AGENTS.md has CLEO @-references\n *\n * @task T5240\n */\n\nimport { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';\nimport { join } from 'node:path';\nimport type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';\n\n/** Lines that should appear in AGENTS.md to reference CLEO. */\nconst INSTRUCTION_REFERENCES = [\n '@~/.cleo/templates/CLEO-INJECTION.md',\n '@.cleo/memory-bridge.md',\n];\n\n/** MCP server registration key used in OpenCode config. */\nconst MCP_SERVER_KEY = 'cleo';\n\n/**\n * Install provider for OpenCode.\n *\n * Manages CLEO's integration with OpenCode by:\n * 1. Registering the CLEO MCP server in .opencode/config.json\n * 2. Ensuring AGENTS.md contains @-references to CLEO instruction files\n */\nexport class OpenCodeInstallProvider implements AdapterInstallProvider {\n private installedProjectDir: string | null = null;\n\n /**\n * Install CLEO into an OpenCode project.\n *\n * @param options - Installation options including project directory and MCP server path\n * @returns Result describing what was installed\n */\n async install(options: InstallOptions): Promise<InstallResult> {\n const { projectDir, mcpServerPath } = options;\n const installedAt = new Date().toISOString();\n let instructionFileUpdated = false;\n let mcpRegistered = false;\n const details: Record<string, unknown> = {};\n\n // Step 1: Register MCP server in .opencode/config.json\n if (mcpServerPath) {\n mcpRegistered = this.registerMcpServer(projectDir, mcpServerPath);\n if (mcpRegistered) {\n details.mcpConfigPath = join(projectDir, '.opencode', 'config.json');\n }\n }\n\n // Step 2: Ensure AGENTS.md has @-references\n instructionFileUpdated = this.updateInstructionFile(projectDir);\n if (instructionFileUpdated) {\n details.instructionFile = join(projectDir, 'AGENTS.md');\n }\n\n this.installedProjectDir = projectDir;\n\n return {\n success: true,\n installedAt,\n instructionFileUpdated,\n mcpRegistered,\n details,\n };\n }\n\n /**\n * Uninstall CLEO from the current OpenCode project.\n *\n * Removes the MCP server registration from .opencode/config.json.\n * Does not remove AGENTS.md references (they are harmless if CLEO is not present).\n */\n async uninstall(): Promise<void> {\n if (!this.installedProjectDir) return;\n\n const configPath = join(this.installedProjectDir, '.opencode', 'config.json');\n if (existsSync(configPath)) {\n try {\n const raw = readFileSync(configPath, 'utf-8');\n const config = JSON.parse(raw) as Record<string, unknown>;\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n delete mcpServers[MCP_SERVER_KEY];\n writeFileSync(configPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n }\n } catch {\n // Ignore errors during uninstall\n }\n }\n\n this.installedProjectDir = null;\n }\n\n /**\n * Check whether CLEO is installed in the current environment.\n *\n * Checks for MCP server registered in .opencode/config.json.\n * Returns true if the CLEO MCP server entry is found.\n */\n async isInstalled(): Promise<boolean> {\n // Check current directory for .opencode/config.json with cleo server\n const configPath = join(process.cwd(), '.opencode', 'config.json');\n if (existsSync(configPath)) {\n try {\n const config = JSON.parse(readFileSync(configPath, 'utf-8'));\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n return true;\n }\n } catch {\n // Fall through\n }\n }\n\n return false;\n }\n\n /**\n * Ensure AGENTS.md contains @-references to CLEO instruction files.\n *\n * Creates AGENTS.md if it does not exist. Appends any missing references.\n *\n * @param projectDir - Project root directory\n */\n async ensureInstructionReferences(projectDir: string): Promise<void> {\n this.updateInstructionFile(projectDir);\n }\n\n /**\n * Register the CLEO MCP server in .opencode/config.json.\n *\n * OpenCode stores its MCP server configuration in .opencode/config.json\n * under the mcpServers key.\n *\n * @returns true if registration was performed or updated\n */\n private registerMcpServer(projectDir: string, mcpServerPath: string): boolean {\n const openCodeDir = join(projectDir, '.opencode');\n const configPath = join(openCodeDir, 'config.json');\n let config: Record<string, unknown> = {};\n\n mkdirSync(openCodeDir, { recursive: true });\n\n if (existsSync(configPath)) {\n try {\n config = JSON.parse(readFileSync(configPath, 'utf-8'));\n } catch {\n // Start fresh on parse error\n }\n }\n\n if (!config.mcpServers || typeof config.mcpServers !== 'object') {\n config.mcpServers = {};\n }\n\n const mcpServers = config.mcpServers as Record<string, unknown>;\n mcpServers[MCP_SERVER_KEY] = {\n command: 'node',\n args: [mcpServerPath],\n };\n\n writeFileSync(configPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n return true;\n }\n\n /**\n * Update AGENTS.md with CLEO @-references.\n *\n * @returns true if the file was created or modified\n */\n private updateInstructionFile(projectDir: string): boolean {\n const agentsMdPath = join(projectDir, 'AGENTS.md');\n let content = '';\n let existed = false;\n\n if (existsSync(agentsMdPath)) {\n content = readFileSync(agentsMdPath, 'utf-8');\n existed = true;\n }\n\n const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));\n\n if (missingRefs.length === 0) {\n return false;\n }\n\n const refsBlock = missingRefs.join('\\n');\n\n if (existed) {\n // Append missing references\n const separator = content.endsWith('\\n') ? '' : '\\n';\n content = content + separator + refsBlock + '\\n';\n } else {\n // Create new AGENTS.md with references\n content = refsBlock + '\\n';\n }\n\n writeFileSync(agentsMdPath, content, 'utf-8');\n return true;\n }\n}\n", "/**\n * OpenCode Spawn Provider\n *\n * Implements AdapterSpawnProvider for OpenCode CLI.\n * Migrated from src/core/spawn/adapters/opencode-adapter.ts\n *\n * Uses `opencode run --agent ... --format json` to spawn subagent\n * processes. Processes run detached and are tracked by PID for\n * listing and termination.\n *\n * @task T5240\n */\n\nimport { exec, spawn as nodeSpawn } from 'node:child_process';\nimport { mkdir, readFile, writeFile } from 'node:fs/promises';\nimport { join } from 'node:path';\nimport { promisify } from 'node:util';\nimport type { AdapterSpawnProvider, SpawnContext, SpawnResult } from '@cleocode/contracts';\n\nconst execAsync = promisify(exec);\n\n/** Name used for the CLEO subagent definition in OpenCode's agent directory. */\nconst OPENCODE_SUBAGENT_NAME = 'cleo-subagent';\n\n/** Fallback agent name when custom agent definition cannot be created. */\nconst OPENCODE_FALLBACK_AGENT = 'general';\n\n/** Internal tracking entry for a spawned process. */\ninterface TrackedProcess {\n pid: number;\n taskId: string;\n startTime: string;\n}\n\n/**\n * Build the markdown content for an OpenCode agent definition file.\n *\n * OpenCode agents are defined as markdown files with YAML frontmatter\n * in the .opencode/agent/ directory.\n *\n * @param description - Agent description for frontmatter\n * @param instructions - Markdown instructions body\n * @returns Complete agent definition markdown\n */\nexport function buildOpenCodeAgentMarkdown(\n description: string,\n instructions: string,\n): string {\n const normalizedDesc = description.replace(/\\s+/g, ' ').trim();\n return [\n '---',\n `description: ${JSON.stringify(normalizedDesc)}`,\n 'mode: subagent',\n 'hidden: true',\n '---',\n '',\n instructions.trim(),\n '',\n ].join('\\n');\n}\n\n/**\n * Ensure the CLEO subagent definition exists in the project's\n * .opencode/agent/ directory.\n *\n * Creates or updates the agent definition file if the content has changed.\n *\n * @param workingDirectory - Project root directory\n * @returns The agent name to use for spawning\n */\nasync function ensureSubagentDefinition(\n workingDirectory: string,\n): Promise<string> {\n const agentDir = join(workingDirectory, '.opencode', 'agent');\n const agentPath = join(agentDir, `${OPENCODE_SUBAGENT_NAME}.md`);\n const description = 'CLEO task executor with protocol compliance.';\n const instructions = [\n '# CLEO Subagent',\n '',\n 'You are a CLEO subagent executing a delegated task.',\n 'Follow the CLEO protocol and complete the assigned work.',\n '',\n '@~/.cleo/templates/CLEO-INJECTION.md',\n ].join('\\n');\n\n const content = buildOpenCodeAgentMarkdown(description, instructions);\n\n await mkdir(agentDir, { recursive: true });\n\n let existing: string | null = null;\n try {\n existing = await readFile(agentPath, 'utf-8');\n } catch {\n existing = null;\n }\n\n if (existing !== content) {\n await writeFile(agentPath, content, 'utf-8');\n }\n\n return OPENCODE_SUBAGENT_NAME;\n}\n\n/**\n * Spawn provider for OpenCode.\n *\n * Spawns detached OpenCode CLI processes for subagent execution.\n * Each spawn ensures a CLEO subagent definition exists, then runs\n * `opencode run --format json --agent <name> --title <title> <prompt>`\n * as a detached, unref'd child process.\n */\nexport class OpenCodeSpawnProvider implements AdapterSpawnProvider {\n /** Map of instance IDs to tracked process info. */\n private processMap = new Map<string, TrackedProcess>();\n\n /**\n * Check if the OpenCode CLI is available in PATH.\n *\n * @returns true if `opencode` is found via `which`\n */\n async canSpawn(): Promise<boolean> {\n try {\n await execAsync('which opencode');\n return true;\n } catch {\n return false;\n }\n }\n\n /**\n * Spawn a subagent via OpenCode CLI.\n *\n * Ensures the CLEO subagent definition exists in the project's\n * .opencode/agent/ directory, then spawns a detached OpenCode\n * process. The process runs independently of the parent.\n *\n * @param context - Spawn context with taskId, prompt, and options\n * @returns Spawn result with instance ID and status\n */\n async spawn(context: SpawnContext): Promise<SpawnResult> {\n const instanceId = `opencode-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;\n const startTime = new Date().toISOString();\n const workingDirectory = context.workingDirectory ?? process.cwd();\n\n try {\n let agentName: string;\n try {\n agentName = await ensureSubagentDefinition(workingDirectory);\n } catch {\n agentName = OPENCODE_FALLBACK_AGENT;\n }\n\n const child = nodeSpawn(\n 'opencode',\n [\n 'run',\n '--format',\n 'json',\n '--agent',\n agentName,\n '--title',\n `CLEO ${context.taskId}`,\n context.prompt,\n ],\n {\n cwd: workingDirectory,\n detached: true,\n stdio: 'ignore',\n },\n );\n\n child.unref();\n\n if (child.pid) {\n this.processMap.set(instanceId, {\n pid: child.pid,\n taskId: context.taskId,\n startTime,\n });\n }\n\n child.on('exit', () => {\n this.processMap.delete(instanceId);\n });\n\n return {\n instanceId,\n taskId: context.taskId,\n providerId: 'opencode',\n status: 'running',\n startTime,\n };\n } catch {\n return {\n instanceId,\n taskId: context.taskId,\n providerId: 'opencode',\n status: 'failed',\n startTime,\n endTime: new Date().toISOString(),\n };\n }\n }\n\n /**\n * List currently running OpenCode subagent processes.\n *\n * Checks each tracked process via kill(pid, 0) to verify it is still alive.\n * Dead processes are automatically cleaned from the tracking map.\n *\n * @returns Array of spawn results for running processes\n */\n async listRunning(): Promise<SpawnResult[]> {\n const running: SpawnResult[] = [];\n\n for (const [instanceId, tracked] of this.processMap.entries()) {\n try {\n process.kill(tracked.pid, 0);\n running.push({\n instanceId,\n taskId: tracked.taskId,\n providerId: 'opencode',\n status: 'running',\n startTime: tracked.startTime,\n });\n } catch {\n this.processMap.delete(instanceId);\n }\n }\n\n return running;\n }\n\n /**\n * Terminate a running spawn by instance ID.\n *\n * Sends SIGTERM to the tracked process. If the process is not found\n * or has already exited, this is a no-op.\n *\n * @param instanceId - ID of the spawn instance to terminate\n */\n async terminate(instanceId: string): Promise<void> {\n const tracked = this.processMap.get(instanceId);\n if (!tracked) return;\n\n try {\n process.kill(tracked.pid, 'SIGTERM');\n } catch {\n // Process may have already exited\n }\n this.processMap.delete(instanceId);\n }\n}\n", "/**\n * OpenCode Adapter\n *\n * Main CLEOProviderAdapter implementation for OpenCode AI coding assistant.\n * Provides spawn, hooks, and install capabilities for CLEO integration.\n *\n * @task T5240\n */\n\nimport { exec } from 'node:child_process';\nimport { existsSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { promisify } from 'node:util';\nimport type {\n AdapterCapabilities,\n AdapterHealthStatus,\n CLEOProviderAdapter,\n} from '@cleocode/contracts';\nimport { OpenCodeHookProvider } from './hooks.js';\nimport { OpenCodeInstallProvider } from './install.js';\nimport { OpenCodeSpawnProvider } from './spawn.js';\n\nconst execAsync = promisify(exec);\n\n/**\n * CLEO provider adapter for OpenCode AI coding assistant.\n *\n * Bridges CLEO's adapter system with OpenCode's native capabilities:\n * - Hooks: Maps OpenCode events (session.start, tool.complete, etc.) to CAAMP events\n * - Spawn: Launches subagent processes via the `opencode` CLI\n * - Install: Registers MCP server in .opencode/config.json and ensures AGENTS.md references\n */\nexport class OpenCodeAdapter implements CLEOProviderAdapter {\n readonly id = 'opencode';\n readonly name = 'OpenCode';\n readonly version = '1.0.0';\n\n capabilities: AdapterCapabilities = {\n supportsHooks: true,\n supportedHookEvents: [\n 'onSessionStart',\n 'onSessionEnd',\n 'onToolStart',\n 'onToolComplete',\n 'onError',\n 'onPromptSubmit',\n ],\n supportsSpawn: true,\n supportsInstall: true,\n supportsMcp: true,\n supportsInstructionFiles: true,\n instructionFilePattern: 'AGENTS.md',\n supportsContextMonitor: false,\n supportsStatusline: false,\n supportsProviderPaths: true,\n supportsTransport: false,\n supportsTaskSync: false,\n };\n\n hooks: OpenCodeHookProvider;\n spawn: OpenCodeSpawnProvider;\n install: OpenCodeInstallProvider;\n\n private projectDir: string | null = null;\n private initialized = false;\n\n constructor() {\n this.hooks = new OpenCodeHookProvider();\n this.spawn = new OpenCodeSpawnProvider();\n this.install = new OpenCodeInstallProvider();\n }\n\n /**\n * Initialize the adapter for a given project directory.\n *\n * Validates the environment by checking for the OpenCode CLI\n * and OpenCode configuration directory.\n *\n * @param projectDir - Root directory of the project\n */\n async initialize(projectDir: string): Promise<void> {\n this.projectDir = projectDir;\n this.initialized = true;\n }\n\n /**\n * Dispose the adapter and clean up resources.\n *\n * Unregisters hooks and releases any tracked state.\n */\n async dispose(): Promise<void> {\n if (this.hooks.isRegistered()) {\n await this.hooks.unregisterNativeHooks();\n }\n this.initialized = false;\n this.projectDir = null;\n }\n\n /**\n * Run a health check to verify OpenCode is accessible.\n *\n * Checks:\n * 1. Adapter has been initialized\n * 2. OpenCode CLI is available in PATH\n * 3. .opencode/ configuration directory exists in the project\n *\n * @returns Health status with details about each check\n */\n async healthCheck(): Promise<AdapterHealthStatus> {\n const details: Record<string, unknown> = {};\n\n if (!this.initialized) {\n return {\n healthy: false,\n provider: this.id,\n details: { error: 'Adapter not initialized' },\n };\n }\n\n // Check OpenCode CLI availability\n let cliAvailable = false;\n try {\n const { stdout } = await execAsync('which opencode');\n cliAvailable = stdout.trim().length > 0;\n details.cliPath = stdout.trim();\n } catch {\n details.cliAvailable = false;\n }\n\n // Check for OpenCode config directory in the project\n if (this.projectDir) {\n const openCodeConfigDir = join(this.projectDir, '.opencode');\n const configExists = existsSync(openCodeConfigDir);\n details.configDirExists = configExists;\n }\n\n // Check for OPENCODE_VERSION env var\n const versionEnvSet = process.env.OPENCODE_VERSION !== undefined;\n details.versionEnvSet = versionEnvSet;\n\n // Healthy if CLI is available (primary requirement)\n const healthy = cliAvailable;\n details.cliAvailable = cliAvailable;\n\n return {\n healthy,\n provider: this.id,\n details,\n };\n }\n\n /**\n * Check whether the adapter has been initialized.\n */\n isInitialized(): boolean {\n return this.initialized;\n }\n\n /**\n * Get the project directory this adapter was initialized with.\n */\n getProjectDir(): string | null {\n return this.projectDir;\n }\n}\n", "/**\n * OpenCode provider adapter.\n *\n * CLEO provider adapter for OpenCode AI coding assistant.\n * Default export is the adapter class for dynamic loading by AdapterManager.\n *\n * @task T5240\n */\n\nimport { OpenCodeAdapter } from './adapter.js';\n\nexport { OpenCodeAdapter } from './adapter.js';\nexport { OpenCodeHookProvider } from './hooks.js';\nexport { OpenCodeSpawnProvider } from './spawn.js';\nexport { OpenCodeInstallProvider } from './install.js';\n\nexport default OpenCodeAdapter;\n\n/**\n * Factory function for creating adapter instances.\n * Used by AdapterManager's dynamic import fallback.\n */\nexport function createAdapter(): OpenCodeAdapter {\n return new OpenCodeAdapter();\n}\n", "/**\n * Cursor Hook Provider\n *\n * Cursor does not have a native hook/event system for external tools.\n * This provider returns null for all event mappings and marks hooks\n * as unsupported. It exists to satisfy the AdapterHookProvider contract\n * so the adapter can be used uniformly by the AdapterManager.\n *\n * @task T5240\n */\n\nimport type { AdapterHookProvider } from '@cleocode/contracts';\n\n/**\n * Hook provider for Cursor (stub).\n *\n * Cursor lacks a hook-based lifecycle event system. All mapping\n * operations return null. Registration is a no-op.\n */\nexport class CursorHookProvider implements AdapterHookProvider {\n private registered = false;\n\n /**\n * Map a provider event name to a CAAMP hook event name.\n *\n * Always returns null since Cursor does not emit hook events.\n *\n * @param _providerEvent - Ignored; Cursor has no hook events\n * @returns null (no mapping available)\n */\n mapProviderEvent(_providerEvent: string): string | null {\n return null;\n }\n\n /**\n * Register native hooks for a project.\n *\n * No-op for Cursor since it has no hook system.\n *\n * @param _projectDir - Ignored\n */\n async registerNativeHooks(_projectDir: string): Promise<void> {\n this.registered = true;\n }\n\n /**\n * Unregister native hooks.\n *\n * No-op for Cursor since it has no hook system.\n */\n async unregisterNativeHooks(): Promise<void> {\n this.registered = false;\n }\n\n /**\n * Check whether hooks have been registered.\n */\n isRegistered(): boolean {\n return this.registered;\n }\n}\n", "/**\n * Cursor Install Provider\n *\n * Handles CLEO installation into Cursor environments:\n * - Registers CLEO MCP server in .cursor/mcp.json\n * - Ensures .cursorrules has CLEO @-references (legacy format)\n * - Creates .cursor/rules/cleo.mdc with CLEO references (modern format)\n *\n * Cursor supports two instruction file formats:\n * 1. Legacy: .cursorrules (flat file, project root)\n * 2. Modern: .cursor/rules/*.mdc (MDC format, per-rule files)\n *\n * This provider writes to both for maximum compatibility.\n *\n * @task T5240\n */\n\nimport { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';\nimport { join } from 'node:path';\nimport type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';\n\n/** Lines that should appear in instruction files to reference CLEO. */\nconst INSTRUCTION_REFERENCES = [\n '@~/.cleo/templates/CLEO-INJECTION.md',\n '@.cleo/memory-bridge.md',\n];\n\n/** MCP server registration key used in Cursor config. */\nconst MCP_SERVER_KEY = 'cleo';\n\n/**\n * Install provider for Cursor.\n *\n * Manages CLEO's integration with Cursor by:\n * 1. Registering the CLEO MCP server in .cursor/mcp.json\n * 2. Creating/updating .cursorrules with @-references (legacy)\n * 3. Creating .cursor/rules/cleo.mdc with @-references (modern)\n */\nexport class CursorInstallProvider implements AdapterInstallProvider {\n private installedProjectDir: string | null = null;\n\n /**\n * Install CLEO into a Cursor project.\n *\n * @param options - Installation options including project directory and MCP server path\n * @returns Result describing what was installed\n */\n async install(options: InstallOptions): Promise<InstallResult> {\n const { projectDir, mcpServerPath } = options;\n const installedAt = new Date().toISOString();\n let instructionFileUpdated = false;\n let mcpRegistered = false;\n const details: Record<string, unknown> = {};\n\n // Step 1: Register MCP server in .cursor/mcp.json\n if (mcpServerPath) {\n mcpRegistered = this.registerMcpServer(projectDir, mcpServerPath);\n if (mcpRegistered) {\n details.mcpConfigPath = join(projectDir, '.cursor', 'mcp.json');\n }\n }\n\n // Step 2: Ensure instruction files have @-references\n instructionFileUpdated = this.updateInstructionFiles(projectDir);\n if (instructionFileUpdated) {\n details.instructionFiles = this.getUpdatedFileList(projectDir);\n }\n\n this.installedProjectDir = projectDir;\n\n return {\n success: true,\n installedAt,\n instructionFileUpdated,\n mcpRegistered,\n details,\n };\n }\n\n /**\n * Uninstall CLEO from the current Cursor project.\n *\n * Removes the MCP server registration from .cursor/mcp.json.\n * Does not remove instruction file references (they are harmless if CLEO is not present).\n */\n async uninstall(): Promise<void> {\n if (!this.installedProjectDir) return;\n\n const mcpPath = join(this.installedProjectDir, '.cursor', 'mcp.json');\n if (existsSync(mcpPath)) {\n try {\n const raw = readFileSync(mcpPath, 'utf-8');\n const config = JSON.parse(raw) as Record<string, unknown>;\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n delete mcpServers[MCP_SERVER_KEY];\n writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n }\n } catch {\n // Ignore errors during uninstall\n }\n }\n\n this.installedProjectDir = null;\n }\n\n /**\n * Check whether CLEO is installed in the current environment.\n *\n * Checks for MCP server registered in .cursor/mcp.json.\n */\n async isInstalled(): Promise<boolean> {\n const mcpPath = join(process.cwd(), '.cursor', 'mcp.json');\n if (existsSync(mcpPath)) {\n try {\n const config = JSON.parse(readFileSync(mcpPath, 'utf-8'));\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n return true;\n }\n } catch {\n // Fall through\n }\n }\n\n return false;\n }\n\n /**\n * Ensure instruction files contain @-references to CLEO.\n *\n * Updates .cursorrules (legacy) and creates .cursor/rules/cleo.mdc (modern).\n *\n * @param projectDir - Project root directory\n */\n async ensureInstructionReferences(projectDir: string): Promise<void> {\n this.updateInstructionFiles(projectDir);\n }\n\n /**\n * Register the CLEO MCP server in .cursor/mcp.json.\n *\n * Cursor stores MCP server configuration in .cursor/mcp.json\n * under the mcpServers key.\n *\n * @returns true if registration was performed or updated\n */\n private registerMcpServer(projectDir: string, mcpServerPath: string): boolean {\n const cursorDir = join(projectDir, '.cursor');\n const mcpPath = join(cursorDir, 'mcp.json');\n let config: Record<string, unknown> = {};\n\n mkdirSync(cursorDir, { recursive: true });\n\n if (existsSync(mcpPath)) {\n try {\n config = JSON.parse(readFileSync(mcpPath, 'utf-8'));\n } catch {\n // Start fresh on parse error\n }\n }\n\n if (!config.mcpServers || typeof config.mcpServers !== 'object') {\n config.mcpServers = {};\n }\n\n const mcpServers = config.mcpServers as Record<string, unknown>;\n mcpServers[MCP_SERVER_KEY] = {\n command: 'node',\n args: [mcpServerPath],\n };\n\n writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n return true;\n }\n\n /**\n * Update instruction files with CLEO @-references.\n *\n * Handles both legacy (.cursorrules) and modern (.cursor/rules/cleo.mdc) formats.\n *\n * @returns true if any file was created or modified\n */\n private updateInstructionFiles(projectDir: string): boolean {\n let updated = false;\n\n // Update legacy .cursorrules if it exists\n if (this.updateLegacyRules(projectDir)) {\n updated = true;\n }\n\n // Create/update modern .cursor/rules/cleo.mdc\n if (this.updateModernRules(projectDir)) {\n updated = true;\n }\n\n return updated;\n }\n\n /**\n * Update legacy .cursorrules file with @-references.\n * Only modifies the file if it already exists (does not create it).\n *\n * @returns true if the file was modified\n */\n private updateLegacyRules(projectDir: string): boolean {\n const rulesPath = join(projectDir, '.cursorrules');\n if (!existsSync(rulesPath)) {\n return false;\n }\n\n let content = readFileSync(rulesPath, 'utf-8');\n const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));\n\n if (missingRefs.length === 0) {\n return false;\n }\n\n const separator = content.endsWith('\\n') ? '' : '\\n';\n content = content + separator + missingRefs.join('\\n') + '\\n';\n writeFileSync(rulesPath, content, 'utf-8');\n return true;\n }\n\n /**\n * Create or update .cursor/rules/cleo.mdc with CLEO references.\n *\n * MDC (Markdown Component) format is Cursor's modern rule file format.\n * Each .mdc file in .cursor/rules/ is loaded as a rule set.\n *\n * @returns true if the file was created or modified\n */\n private updateModernRules(projectDir: string): boolean {\n const rulesDir = join(projectDir, '.cursor', 'rules');\n const mdcPath = join(rulesDir, 'cleo.mdc');\n\n const expectedContent = [\n '---',\n 'description: CLEO task management protocol references',\n 'globs: \"**/*\"',\n 'alwaysApply: true',\n '---',\n '',\n ...INSTRUCTION_REFERENCES,\n '',\n ].join('\\n');\n\n if (existsSync(mdcPath)) {\n const existing = readFileSync(mdcPath, 'utf-8');\n if (existing === expectedContent) {\n return false;\n }\n }\n\n mkdirSync(rulesDir, { recursive: true });\n writeFileSync(mdcPath, expectedContent, 'utf-8');\n return true;\n }\n\n /**\n * Get list of instruction files that were updated.\n */\n private getUpdatedFileList(projectDir: string): string[] {\n const files: string[] = [];\n if (existsSync(join(projectDir, '.cursorrules'))) {\n files.push(join(projectDir, '.cursorrules'));\n }\n files.push(join(projectDir, '.cursor', 'rules', 'cleo.mdc'));\n return files;\n }\n}\n", "/**\n * Cursor Adapter\n *\n * Main CLEOProviderAdapter implementation for Cursor AI code editor.\n * Provides install capabilities for CLEO integration. Hooks and spawn\n * are not supported since Cursor lacks CLI-based lifecycle events\n * and subagent spawning.\n *\n * @task T5240\n */\n\nimport { existsSync } from 'node:fs';\nimport { join } from 'node:path';\nimport type {\n AdapterCapabilities,\n AdapterHealthStatus,\n CLEOProviderAdapter,\n} from '@cleocode/contracts';\nimport { CursorHookProvider } from './hooks.js';\nimport { CursorInstallProvider } from './install.js';\n\n/**\n * CLEO provider adapter for Cursor AI code editor.\n *\n * Bridges CLEO's adapter system with Cursor's capabilities:\n * - Install: Registers MCP server in .cursor/mcp.json and manages rule files\n * - Hooks: Stub provider (Cursor has no lifecycle event system)\n * - Spawn: Not supported (Cursor has no CLI for subagent spawning)\n */\nexport class CursorAdapter implements CLEOProviderAdapter {\n readonly id = 'cursor';\n readonly name = 'Cursor';\n readonly version = '1.0.0';\n\n capabilities: AdapterCapabilities = {\n supportsHooks: false,\n supportedHookEvents: [],\n supportsSpawn: false,\n supportsInstall: true,\n supportsMcp: true,\n supportsInstructionFiles: true,\n instructionFilePattern: '.cursor/rules/*.mdc',\n supportsContextMonitor: false,\n supportsStatusline: false,\n supportsProviderPaths: true,\n supportsTransport: false,\n supportsTaskSync: false,\n };\n\n hooks: CursorHookProvider;\n install: CursorInstallProvider;\n\n private projectDir: string | null = null;\n private initialized = false;\n\n constructor() {\n this.hooks = new CursorHookProvider();\n this.install = new CursorInstallProvider();\n }\n\n /**\n * Initialize the adapter for a given project directory.\n *\n * @param projectDir - Root directory of the project\n */\n async initialize(projectDir: string): Promise<void> {\n this.projectDir = projectDir;\n this.initialized = true;\n }\n\n /**\n * Dispose the adapter and clean up resources.\n */\n async dispose(): Promise<void> {\n if (this.hooks.isRegistered()) {\n await this.hooks.unregisterNativeHooks();\n }\n this.initialized = false;\n this.projectDir = null;\n }\n\n /**\n * Run a health check to verify Cursor is accessible.\n *\n * Checks:\n * 1. Adapter has been initialized\n * 2. .cursor/ configuration directory exists in the project\n * 3. CURSOR_EDITOR env var is set\n *\n * @returns Health status with details about each check\n */\n async healthCheck(): Promise<AdapterHealthStatus> {\n const details: Record<string, unknown> = {};\n\n if (!this.initialized) {\n return {\n healthy: false,\n provider: this.id,\n details: { error: 'Adapter not initialized' },\n };\n }\n\n // Check for Cursor config directory in the project\n let configExists = false;\n if (this.projectDir) {\n const cursorConfigDir = join(this.projectDir, '.cursor');\n configExists = existsSync(cursorConfigDir);\n details.configDirExists = configExists;\n }\n\n // Check for CURSOR_EDITOR env var\n const editorEnvSet = process.env.CURSOR_EDITOR !== undefined;\n details.editorEnvSet = editorEnvSet;\n\n // Check for legacy .cursorrules file\n if (this.projectDir) {\n const legacyRulesExist = existsSync(join(this.projectDir, '.cursorrules'));\n details.legacyRulesExist = legacyRulesExist;\n }\n\n // Healthy if we detect Cursor presence (config dir or env var)\n const healthy = configExists || editorEnvSet;\n details.detected = healthy;\n\n return {\n healthy,\n provider: this.id,\n details,\n };\n }\n\n /**\n * Check whether the adapter has been initialized.\n */\n isInitialized(): boolean {\n return this.initialized;\n }\n\n /**\n * Get the project directory this adapter was initialized with.\n */\n getProjectDir(): string | null {\n return this.projectDir;\n }\n}\n", "/**\n * Cursor provider adapter.\n *\n * CLEO provider adapter for Cursor AI code editor.\n * Default export is the adapter class for dynamic loading by AdapterManager.\n *\n * @task T5240\n */\n\nimport { CursorAdapter } from './adapter.js';\n\nexport { CursorAdapter } from './adapter.js';\nexport { CursorHookProvider } from './hooks.js';\nexport { CursorInstallProvider } from './install.js';\n\nexport default CursorAdapter;\n\n/**\n * Factory function for creating adapter instances.\n * Used by AdapterManager's dynamic import fallback.\n */\nexport function createAdapter(): CursorAdapter {\n return new CursorAdapter();\n}\n", "/**\n * Adapter registry \u2014 discovers and provides access to provider manifests.\n *\n * Scans the providers/ directory for manifest.json files and returns\n * the discovered adapter manifests for use by AdapterManager.\n *\n * @task T5240\n */\n\nimport { readFileSync } from 'node:fs';\nimport { dirname, join, resolve } from 'node:path';\nimport { fileURLToPath } from 'node:url';\n\n/** Minimal manifest shape for provider discovery. */\nexport interface AdapterManifest {\n id: string;\n name: string;\n version: string;\n description: string;\n provider: string;\n entryPoint: string;\n capabilities: Record<string, unknown>;\n detectionPatterns: Array<{\n type: string;\n pattern: string;\n description: string;\n }>;\n}\n\n/** Known provider IDs bundled with @cleocode/adapters. */\nconst PROVIDER_IDS = ['claude-code', 'opencode', 'cursor'] as const;\n\n/**\n * Get the manifests for all bundled provider adapters.\n *\n * @returns Array of adapter manifests\n */\nexport function getProviderManifests(): AdapterManifest[] {\n const manifests: AdapterManifest[] = [];\n const baseDir = resolve(dirname(fileURLToPath(import.meta.url)), 'providers');\n\n for (const providerId of PROVIDER_IDS) {\n try {\n const manifestPath = join(baseDir, providerId, 'manifest.json');\n const raw = readFileSync(manifestPath, 'utf-8');\n manifests.push(JSON.parse(raw) as AdapterManifest);\n } catch {\n // Skip providers whose manifests cannot be loaded\n }\n }\n\n return manifests;\n}\n\n/**\n * Discover all available provider adapters.\n *\n * Returns a map of provider ID to adapter factory function.\n */\nexport async function discoverProviders(): Promise<\n Map<string, () => Promise<unknown>>\n> {\n const providers = new Map<string, () => Promise<unknown>>();\n\n providers.set('claude-code', async () => {\n const { ClaudeCodeAdapter } = await import('./providers/claude-code/index.js');\n return new ClaudeCodeAdapter();\n });\n\n providers.set('opencode', async () => {\n const { OpenCodeAdapter } = await import('./providers/opencode/index.js');\n return new OpenCodeAdapter();\n });\n\n providers.set('cursor', async () => {\n const { CursorAdapter } = await import('./providers/cursor/index.js');\n return new CursorAdapter();\n });\n\n return providers;\n}\n", "/**\n * @cleocode/adapters\n *\n * Unified provider adapter package for CLEO.\n * Exports all provider adapters and a registry for manifest discovery.\n */\n\nexport { discoverProviders, getProviderManifests } from './registry.js';\nexport type { AdapterManifest } from './registry.js';\n\n// Re-export adapter classes for direct use\nexport { ClaudeCodeAdapter } from './providers/claude-code/index.js';\nexport { ClaudeCodeContextMonitorProvider } from './providers/claude-code/index.js';\nexport { ClaudeCodeHookProvider } from './providers/claude-code/index.js';\nexport { ClaudeCodeInstallProvider } from './providers/claude-code/index.js';\nexport { ClaudeCodePathProvider } from './providers/claude-code/index.js';\nexport { ClaudeCodeSpawnProvider } from './providers/claude-code/index.js';\nexport { ClaudeCodeTransportProvider } from './providers/claude-code/index.js';\nexport {\n checkStatuslineIntegration,\n getStatuslineConfig,\n getSetupInstructions,\n} from './providers/claude-code/index.js';\n\nexport { OpenCodeAdapter } from './providers/opencode/index.js';\nexport { OpenCodeHookProvider } from './providers/opencode/index.js';\nexport { OpenCodeSpawnProvider } from './providers/opencode/index.js';\nexport { OpenCodeInstallProvider } from './providers/opencode/index.js';\n\nexport { CursorAdapter } from './providers/cursor/index.js';\nexport { CursorHookProvider } from './providers/cursor/index.js';\nexport { CursorInstallProvider } from './providers/cursor/index.js';\n\n// Per-provider factory functions (renamed to avoid collisions)\nexport { createAdapter as createClaudeCodeAdapter } from './providers/claude-code/index.js';\nexport { createAdapter as createOpenCodeAdapter } from './providers/opencode/index.js';\nexport { createAdapter as createCursorAdapter } from './providers/cursor/index.js';\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["homedir", "join", "existsSync", "readFileSync", "writeFileSync", "homedir", "join", "join", "exec", "existsSync", "
|
|
3
|
+
"sources": ["../src/providers/claude-code/paths.ts", "../src/providers/claude-code/context-monitor.ts", "../src/providers/claude-code/hooks.ts", "../src/providers/claude-code/install.ts", "../../contracts/src/errors.ts", "../../contracts/src/exit-codes.ts", "../../contracts/src/lafs.ts", "../../contracts/src/operations/issues.ts", "../../contracts/src/operations/lifecycle.ts", "../../contracts/src/operations/orchestrate.ts", "../../contracts/src/operations/release.ts", "../../contracts/src/operations/research.ts", "../../contracts/src/operations/session.ts", "../../contracts/src/operations/skills.ts", "../../contracts/src/operations/system.ts", "../../contracts/src/operations/tasks.ts", "../../contracts/src/operations/validate.ts", "../../contracts/src/operations/index.ts", "../../contracts/src/session.ts", "../../contracts/src/status-registry.ts", "../../contracts/src/index.ts", "../src/providers/claude-code/spawn.ts", "../src/providers/claude-code/task-sync.ts", "../src/providers/claude-code/transport.ts", "../src/providers/claude-code/adapter.ts", "../src/providers/claude-code/statusline.ts", "../src/providers/claude-code/index.ts", "../src/providers/cursor/hooks.ts", "../src/providers/cursor/install.ts", "../src/providers/cursor/adapter.ts", "../src/providers/cursor/index.ts", "../src/providers/opencode/hooks.ts", "../src/providers/opencode/install.ts", "../src/providers/opencode/spawn.ts", "../src/providers/opencode/adapter.ts", "../src/providers/opencode/index.ts", "../src/index.ts", "../src/registry.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Claude Code path provider.\n *\n * Implements AdapterPathProvider with Claude Code-specific directory locations.\n *\n * @task T5240\n */\n\nimport { homedir } from 'node:os';\nimport { join } from 'node:path';\nimport type { AdapterPathProvider } from '@cleocode/contracts';\n\n/**\n * Path provider for Anthropic Claude Code CLI.\n *\n * Resolves Claude Code's standard directory layout:\n * - Config dir: ~/.claude (or CLAUDE_HOME)\n * - Settings: ~/.claude/settings.json (or CLAUDE_SETTINGS)\n * - Agents: ~/.claude/agents\n * - Memory DB: ~/.claude-mem/claude-mem.db (or CLAUDE_MEM_DB)\n */\nexport class ClaudeCodePathProvider implements AdapterPathProvider {\n getProviderDir(): string {\n return process.env['CLAUDE_HOME'] ?? join(homedir(), '.claude');\n }\n\n getSettingsPath(): string | null {\n return process.env['CLAUDE_SETTINGS'] ?? join(this.getProviderDir(), 'settings.json');\n }\n\n getAgentInstallDir(): string | null {\n return join(this.getProviderDir(), 'agents');\n }\n\n getMemoryDbPath(): string | null {\n return process.env['CLAUDE_MEM_DB'] ?? join(homedir(), '.claude-mem', 'claude-mem.db');\n }\n}\n", "/**\n * Claude Code context monitor provider.\n *\n * Implements AdapterContextMonitorProvider for Claude Code's context window\n * tracking and statusline integration.\n *\n * @task T5240\n */\n\nimport { existsSync, readFileSync, writeFileSync } from 'node:fs';\nimport { mkdir } from 'node:fs/promises';\nimport { homedir } from 'node:os';\nimport { dirname, join } from 'node:path';\nimport type { AdapterContextMonitorProvider } from '@cleocode/contracts';\nimport { ClaudeCodePathProvider } from './paths.js';\n\n/** Context window input from Claude Code. */\ninterface ContextWindowInput {\n context_window: {\n context_window_size?: number;\n current_usage?: {\n input_tokens?: number;\n output_tokens?: number;\n cache_creation_input_tokens?: number;\n cache_read_input_tokens?: number;\n };\n };\n}\n\n/** Thresholds for context window status levels. */\nconst THRESHOLDS = {\n WARNING: 50,\n CAUTION: 70,\n CRITICAL: 85,\n EMERGENCY: 95,\n} as const;\n\ntype ContextStatus = 'ok' | 'warning' | 'caution' | 'critical' | 'emergency';\n\nfunction getContextStatusFromPercentage(percentage: number): ContextStatus {\n if (percentage >= THRESHOLDS.EMERGENCY) return 'emergency';\n if (percentage >= THRESHOLDS.CRITICAL) return 'critical';\n if (percentage >= THRESHOLDS.CAUTION) return 'caution';\n if (percentage >= THRESHOLDS.WARNING) return 'warning';\n return 'ok';\n}\n\n/**\n * Context monitor provider for Claude Code.\n *\n * Processes context window JSON from Claude Code and writes state files\n * for statusline display. Also provides statusline configuration\n * and setup instructions specific to Claude Code's settings.json.\n */\nexport class ClaudeCodeContextMonitorProvider implements AdapterContextMonitorProvider {\n private pathProvider = new ClaudeCodePathProvider();\n\n async processContextInput(input: unknown, cwd?: string): Promise<string> {\n const typed = input as ContextWindowInput;\n const contextSize = typed.context_window?.context_window_size ?? 200000;\n const usage = typed.context_window?.current_usage;\n\n if (!usage) return '-- no data';\n\n const inputTokens = usage.input_tokens ?? 0;\n const outputTokens = usage.output_tokens ?? 0;\n const cacheCreate = usage.cache_creation_input_tokens ?? 0;\n\n const totalTokens = inputTokens + outputTokens + cacheCreate;\n const percentage = Math.floor((totalTokens * 100) / contextSize);\n const status = getContextStatusFromPercentage(percentage);\n\n // Write state file if CLEO dir exists\n const cleoDir = cwd ? join(cwd, '.cleo') : '.cleo';\n if (existsSync(cleoDir)) {\n const stateDir = join(cleoDir, 'context-states');\n const statePath = join(stateDir, '.context-state.json');\n\n const state = {\n $schema: 'https://cleo-dev.com/schemas/v1/context-state.schema.json',\n version: '1.0.0',\n timestamp: new Date().toISOString().replace(/\\.\\d{3}Z$/, 'Z'),\n staleAfterMs: 5000,\n contextWindow: {\n maxTokens: contextSize,\n currentTokens: totalTokens,\n percentage,\n breakdown: {\n inputTokens,\n outputTokens,\n cacheCreationTokens: cacheCreate,\n cacheReadTokens: usage.cache_read_input_tokens ?? 0,\n },\n },\n thresholds: {\n warning: THRESHOLDS.WARNING,\n caution: THRESHOLDS.CAUTION,\n critical: THRESHOLDS.CRITICAL,\n emergency: THRESHOLDS.EMERGENCY,\n },\n status,\n cleoSessionId: '',\n };\n\n try {\n await mkdir(dirname(statePath), { recursive: true });\n writeFileSync(statePath, JSON.stringify(state, null, 2));\n } catch {\n // Non-fatal\n }\n }\n\n return `${percentage}% | ${totalTokens}/${contextSize}`;\n }\n\n checkStatuslineIntegration(): 'configured' | 'not_configured' | 'custom_no_cleo' | 'no_settings' {\n const settingsPath = this.pathProvider.getSettingsPath();\n if (!settingsPath || !existsSync(settingsPath)) return 'no_settings';\n\n try {\n const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));\n const statusLine = settings.statusLine;\n\n if (!statusLine?.type) return 'not_configured';\n if (statusLine.type !== 'command') return 'custom_no_cleo';\n\n const cmd = statusLine.command ?? '';\n\n if (\n cmd.includes('context-monitor.sh') ||\n cmd.includes('cleo-statusline') ||\n cmd.includes('.context-state.json') ||\n cmd.includes('context-states')\n ) {\n return 'configured';\n }\n\n const scriptPath = cmd.startsWith('~') ? cmd.replace('~', homedir()) : cmd;\n if (existsSync(scriptPath)) {\n try {\n const content = readFileSync(scriptPath, 'utf-8');\n if (content.includes('context-state.json')) return 'configured';\n } catch {\n /* unreadable */\n }\n }\n\n return 'custom_no_cleo';\n } catch {\n return 'no_settings';\n }\n }\n\n getStatuslineConfig(): Record<string, unknown> {\n return {\n statusLine: {\n type: 'command',\n command: join(homedir(), '.cleo', 'lib', 'session', 'context-monitor.sh'),\n },\n };\n }\n\n getSetupInstructions(): string {\n const settingsPath = this.pathProvider.getSettingsPath() ?? '~/.claude/settings.json';\n\n return [\n 'To enable context monitoring, add to your Claude Code settings:',\n `File: ${settingsPath}`,\n '',\n JSON.stringify(this.getStatuslineConfig(), null, 2),\n '',\n 'This enables real-time context window tracking in the CLI.',\n ].join('\\n');\n }\n}\n", "/**\n * Claude Code Hook Provider\n *\n * Maps Claude Code's native hook events to CAAMP hook events.\n * Claude Code uses: SessionStart, PostToolUse, UserPromptSubmit, Stop\n * CAAMP defines: onSessionStart, onToolComplete, onPromptSubmit, onSessionEnd\n *\n * @task T5240\n */\n\nimport type { AdapterHookProvider } from '@cleocode/contracts';\n\n/**\n * Mapping from Claude Code native event names to CAAMP event names.\n */\nconst CLAUDE_CODE_EVENT_MAP: Record<string, string> = {\n SessionStart: 'onSessionStart',\n PostToolUse: 'onToolComplete',\n UserPromptSubmit: 'onPromptSubmit',\n Stop: 'onSessionEnd',\n};\n\n/**\n * Hook provider for Claude Code.\n *\n * Claude Code registers hooks via a plugin directory\n * with a hooks.json descriptor. The actual hook scripts are shell scripts\n * that invoke CLEO's brain observation system.\n *\n * Since hooks are registered through the plugin system (installed via\n * the install provider), registerNativeHooks and unregisterNativeHooks\n * are effectively no-ops here \u2014 the plugin installer handles registration.\n */\nexport class ClaudeCodeHookProvider implements AdapterHookProvider {\n private registered = false;\n\n /**\n * Map a Claude Code native event name to a CAAMP hook event name.\n *\n * @param providerEvent - Claude Code event name (e.g. \"SessionStart\", \"PostToolUse\")\n * @returns CAAMP event name or null if unmapped\n */\n mapProviderEvent(providerEvent: string): string | null {\n return CLAUDE_CODE_EVENT_MAP[providerEvent] ?? null;\n }\n\n /**\n * Register native hooks for a project.\n *\n * For Claude Code, hooks are registered via the plugin system\n * (hooks.json descriptor), which is handled by the\n * install provider. This method is a no-op since registration\n * is managed through the plugin install lifecycle.\n *\n * @param _projectDir - Project directory (unused; hooks are global)\n */\n async registerNativeHooks(_projectDir: string): Promise<void> {\n this.registered = true;\n }\n\n /**\n * Unregister native hooks.\n *\n * For Claude Code, this is a no-op since hooks are managed through\n * the plugin system. Unregistration happens via the install provider's\n * uninstall method.\n */\n async unregisterNativeHooks(): Promise<void> {\n this.registered = false;\n }\n\n /**\n * Check whether hooks have been registered via registerNativeHooks.\n */\n isRegistered(): boolean {\n return this.registered;\n }\n\n /**\n * Get the full event mapping for introspection/debugging.\n */\n getEventMap(): Readonly<Record<string, string>> {\n return { ...CLAUDE_CODE_EVENT_MAP };\n }\n}\n", "/**\n * Claude Code Install Provider\n *\n * Handles CLEO installation into Claude Code environments:\n * - Registers CLEO MCP server in .mcp.json\n * - Ensures CLAUDE.md has CLEO @-references\n * - Manages plugin registration in ~/.claude/settings.json\n *\n * Migrated from src/core/install/claude-plugin.ts\n *\n * @task T5240\n */\n\nimport { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';\nimport { homedir } from 'node:os';\nimport { join } from 'node:path';\nimport type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';\n\n/** Lines that should appear in CLAUDE.md to reference CLEO. */\nconst INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];\n\n/** MCP server registration key used in .mcp.json. */\nconst MCP_SERVER_KEY = 'cleo';\n\n/**\n * Install provider for Claude Code.\n *\n * Manages CLEO's integration with Claude Code by:\n * 1. Registering the CLEO MCP server in the project's .mcp.json\n * 2. Ensuring CLAUDE.md contains @-references to CLEO instruction files\n * 3. Registering the brain observation plugin in ~/.claude/settings.json\n */\nexport class ClaudeCodeInstallProvider implements AdapterInstallProvider {\n private installedProjectDir: string | null = null;\n\n /**\n * Install CLEO into a Claude Code project.\n *\n * @param options - Installation options including project directory and MCP server path\n * @returns Result describing what was installed\n */\n async install(options: InstallOptions): Promise<InstallResult> {\n const { projectDir, mcpServerPath } = options;\n const installedAt = new Date().toISOString();\n let instructionFileUpdated = false;\n let mcpRegistered = false;\n const details: Record<string, unknown> = {};\n\n // Step 1: Register MCP server in .mcp.json\n if (mcpServerPath) {\n mcpRegistered = this.registerMcpServer(projectDir, mcpServerPath);\n if (mcpRegistered) {\n details.mcpConfigPath = join(projectDir, '.mcp.json');\n }\n }\n\n // Step 2: Ensure CLAUDE.md has @-references\n instructionFileUpdated = this.updateInstructionFile(projectDir);\n if (instructionFileUpdated) {\n details.instructionFile = join(projectDir, 'CLAUDE.md');\n }\n\n // Step 3: Register plugin in ~/.claude/settings.json\n const pluginResult = this.registerPlugin();\n if (pluginResult) {\n details.plugin = pluginResult;\n }\n\n this.installedProjectDir = projectDir;\n\n return {\n success: true,\n installedAt,\n instructionFileUpdated,\n mcpRegistered,\n details,\n };\n }\n\n /**\n * Uninstall CLEO from the current Claude Code project.\n *\n * Removes the MCP server registration from .mcp.json.\n * Does not remove CLAUDE.md references (they are harmless if CLEO is not present).\n */\n async uninstall(): Promise<void> {\n if (!this.installedProjectDir) return;\n\n const mcpPath = join(this.installedProjectDir, '.mcp.json');\n if (existsSync(mcpPath)) {\n try {\n const raw = readFileSync(mcpPath, 'utf-8');\n const config = JSON.parse(raw) as Record<string, unknown>;\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n delete mcpServers[MCP_SERVER_KEY];\n writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n }\n } catch {\n // Ignore errors during uninstall\n }\n }\n\n this.installedProjectDir = null;\n }\n\n /**\n * Check whether CLEO is installed in the current environment.\n *\n * Checks for:\n * 1. MCP server registered in .mcp.json\n * 2. Plugin enabled in ~/.claude/settings.json\n *\n * Returns true if either condition is met (partial install counts).\n */\n async isInstalled(): Promise<boolean> {\n // Check ~/.claude/settings.json for plugin registration\n const settingsPath = join(homedir(), '.claude', 'settings.json');\n if (existsSync(settingsPath)) {\n try {\n const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));\n const plugins = settings.enabledPlugins as Record<string, boolean> | undefined;\n if (plugins && plugins['cleo@cleocode'] === true) {\n return true;\n }\n } catch {\n // Fall through\n }\n }\n\n // Check current directory for .mcp.json with cleo server\n const mcpPath = join(process.cwd(), '.mcp.json');\n if (existsSync(mcpPath)) {\n try {\n const config = JSON.parse(readFileSync(mcpPath, 'utf-8'));\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n return true;\n }\n } catch {\n // Fall through\n }\n }\n\n return false;\n }\n\n /**\n * Ensure CLAUDE.md contains @-references to CLEO instruction files.\n *\n * Creates CLAUDE.md if it does not exist. Appends any missing references.\n *\n * @param projectDir - Project root directory\n */\n async ensureInstructionReferences(projectDir: string): Promise<void> {\n this.updateInstructionFile(projectDir);\n }\n\n /**\n * Register the CLEO MCP server in .mcp.json.\n *\n * @returns true if registration was performed or updated\n */\n private registerMcpServer(projectDir: string, mcpServerPath: string): boolean {\n const mcpPath = join(projectDir, '.mcp.json');\n let config: Record<string, unknown> = {};\n\n if (existsSync(mcpPath)) {\n try {\n config = JSON.parse(readFileSync(mcpPath, 'utf-8'));\n } catch {\n // Start fresh on parse error\n }\n }\n\n if (!config.mcpServers || typeof config.mcpServers !== 'object') {\n config.mcpServers = {};\n }\n\n const mcpServers = config.mcpServers as Record<string, unknown>;\n mcpServers[MCP_SERVER_KEY] = {\n command: 'node',\n args: [mcpServerPath],\n };\n\n writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n return true;\n }\n\n /**\n * Update CLAUDE.md with CLEO @-references.\n *\n * @returns true if the file was created or modified\n */\n private updateInstructionFile(projectDir: string): boolean {\n const claudeMdPath = join(projectDir, 'CLAUDE.md');\n let content = '';\n let existed = false;\n\n if (existsSync(claudeMdPath)) {\n content = readFileSync(claudeMdPath, 'utf-8');\n existed = true;\n }\n\n const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));\n\n if (missingRefs.length === 0) {\n return false;\n }\n\n const refsBlock = missingRefs.join('\\n');\n\n if (existed) {\n // Append missing references\n const separator = content.endsWith('\\n') ? '' : '\\n';\n content = content + separator + refsBlock + '\\n';\n } else {\n // Create new CLAUDE.md with references\n content = refsBlock + '\\n';\n }\n\n writeFileSync(claudeMdPath, content, 'utf-8');\n return true;\n }\n\n /**\n * Register the CLEO brain plugin in ~/.claude/settings.json.\n *\n * @returns Description of what was registered, or null if no change needed\n */\n private registerPlugin(): string | null {\n const home = homedir();\n const settingsPath = join(home, '.claude', 'settings.json');\n\n let settings: Record<string, unknown> = {};\n if (existsSync(settingsPath)) {\n try {\n settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));\n } catch {\n // Start fresh\n }\n }\n\n const enabledPlugins = (settings.enabledPlugins as Record<string, boolean>) ?? {};\n const pluginKey = 'cleo@cleocode';\n\n if (enabledPlugins[pluginKey] === true) {\n return null;\n }\n\n // Disable old claude-mem if present\n if (enabledPlugins['claude-mem@thedotmack'] === true) {\n enabledPlugins['claude-mem@thedotmack'] = false;\n }\n\n enabledPlugins[pluginKey] = true;\n settings.enabledPlugins = enabledPlugins;\n\n mkdirSync(join(home, '.claude'), { recursive: true });\n writeFileSync(settingsPath, JSON.stringify(settings, null, 2) + '\\n', 'utf-8');\n\n return `Enabled ${pluginKey} in ~/.claude/settings.json`;\n }\n}\n", "/**\n * Central error utilities for CLEO.\n *\n * Provides consistent error handling patterns across the codebase.\n * DRY error formatting, normalization, and transformation utilities.\n *\n * @task T5702\n */\n\n/**\n * Normalize any thrown value into a standardized error object.\n *\n * Handles:\n * - Error instances (preserves stack trace info)\n * - Strings (wraps in Error)\n * - Objects with message property\n * - null/undefined (provides fallback)\n *\n * @param error - The thrown value to normalize\n * @param fallbackMessage - Message to use if error provides none\n * @returns Normalized error with consistent shape\n *\n * @example\n * ```typescript\n * try {\n * await riskyOperation();\n * } catch (err) {\n * const error = normalizeError(err, 'Operation failed');\n * console.error(error.message);\n * }\n * ```\n */\nexport function normalizeError(\n error: unknown,\n fallbackMessage = 'An unexpected error occurred',\n): Error {\n if (error instanceof Error) {\n return error;\n }\n\n if (typeof error === 'string') {\n return new Error(error);\n }\n\n if (\n error !== null &&\n typeof error === 'object' &&\n 'message' in error &&\n typeof error.message === 'string'\n ) {\n return new Error(error.message);\n }\n\n return new Error(fallbackMessage);\n}\n\n/**\n * Extract a human-readable message from any error value.\n *\n * Safe to use on unknown thrown values without type guards.\n *\n * @param error - The error value\n * @param fallback - Fallback message if extraction fails\n * @returns The error message string\n *\n * @example\n * ```typescript\n * const message = getErrorMessage(err, 'Unknown error');\n * ```\n */\nexport function getErrorMessage(error: unknown, fallback = 'Unknown error'): string {\n if (error instanceof Error) {\n return error.message;\n }\n\n if (typeof error === 'string') {\n return error;\n }\n\n if (\n error !== null &&\n typeof error === 'object' &&\n 'message' in error &&\n typeof error.message === 'string'\n ) {\n return error.message;\n }\n\n return fallback;\n}\n\n/**\n * Format error details for logging or display.\n *\n * Includes stack trace for Error instances when includeStack is true.\n *\n * @param error - The error to format\n * @param context - Optional context to prepend\n * @param includeStack - Whether to include stack traces (default: false)\n * @returns Formatted error string\n *\n * @example\n * ```typescript\n * console.error(formatError(err, 'Database connection'));\n * // Output: [Database connection] Connection refused\n * ```\n */\nexport function formatError(error: unknown, context?: string, includeStack = false): string {\n const message = getErrorMessage(error);\n const prefix = context ? `[${context}] ` : '';\n let result = `${prefix}${message}`;\n\n if (includeStack && error instanceof Error && error.stack) {\n result += `\\n${error.stack}`;\n }\n\n return result;\n}\n\n/**\n * Check if an error represents a specific error type by code or name.\n *\n * Useful for conditional error handling based on error types.\n *\n * @param error - The error to check\n * @param codeOrName - The error code or name to match\n * @returns True if the error matches\n *\n * @example\n * ```typescript\n * if (isErrorType(err, 'E_NOT_FOUND')) {\n * // Handle not found specifically\n * }\n * ```\n */\nexport function isErrorType(error: unknown, codeOrName: string): boolean {\n if (error instanceof Error) {\n if (error.name === codeOrName) {\n return true;\n }\n // Check for custom code property\n if ('code' in error && error.code === codeOrName) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * Create a standardized error result object.\n *\n * Common pattern for operations that return { success: boolean, error?: string }\n *\n * @param error - The error value\n * @returns Error result object\n *\n * @example\n * ```typescript\n * return createErrorResult(err);\n * // Returns: { success: false, error: \"Something went wrong\" }\n * ```\n */\nexport function createErrorResult(error: unknown): { success: false; error: string } {\n return {\n success: false,\n error: getErrorMessage(error),\n };\n}\n\n/**\n * Create a standardized success result object.\n *\n * @returns Success result object\n *\n * @example\n * ```typescript\n * return createSuccessResult();\n * // Returns: { success: true }\n * ```\n */\nexport function createSuccessResult(): { success: true } {\n return { success: true };\n}\n\n/**\n * Type guard for error results.\n *\n * @param result - The result to check\n * @returns True if the result is an error result\n *\n * @example\n * ```typescript\n * const result = await someOperation();\n * if (isErrorResult(result)) {\n * console.error(result.error);\n * }\n * ```\n */\nexport function isErrorResult(result: {\n success: boolean;\n error?: string;\n}): result is { success: false; error: string } {\n return !result.success;\n}\n", "/**\n * CLEO exit codes \u2014 canonical definitions shared across all layers.\n *\n * Ranges: 0 = success, 1-99 = errors, 100+ = special (non-error) states.\n *\n * @epic T4454\n * @task T4456\n * @task T5710\n */\n\nexport enum ExitCode {\n // === SUCCESS (0) ===\n SUCCESS = 0,\n\n // === GENERAL ERRORS (1-9) ===\n GENERAL_ERROR = 1,\n INVALID_INPUT = 2,\n FILE_ERROR = 3,\n NOT_FOUND = 4,\n DEPENDENCY_ERROR = 5,\n VALIDATION_ERROR = 6,\n LOCK_TIMEOUT = 7,\n CONFIG_ERROR = 8,\n\n // === HIERARCHY ERRORS (10-19) ===\n PARENT_NOT_FOUND = 10,\n DEPTH_EXCEEDED = 11,\n SIBLING_LIMIT = 12,\n INVALID_PARENT_TYPE = 13,\n CIRCULAR_REFERENCE = 14,\n ORPHAN_DETECTED = 15,\n HAS_CHILDREN = 16,\n TASK_COMPLETED = 17,\n CASCADE_FAILED = 18,\n HAS_DEPENDENTS = 19,\n\n // === CONCURRENCY ERRORS (20-29) ===\n CHECKSUM_MISMATCH = 20,\n CONCURRENT_MODIFICATION = 21,\n ID_COLLISION = 22,\n\n // === SESSION ERRORS (30-39) ===\n SESSION_EXISTS = 30,\n SESSION_NOT_FOUND = 31,\n SCOPE_CONFLICT = 32,\n SCOPE_INVALID = 33,\n TASK_NOT_IN_SCOPE = 34,\n TASK_CLAIMED = 35,\n SESSION_REQUIRED = 36,\n SESSION_CLOSE_BLOCKED = 37,\n ACTIVE_TASK_REQUIRED = 38,\n NOTES_REQUIRED = 39,\n\n // === VERIFICATION ERRORS (40-47) ===\n VERIFICATION_INIT_FAILED = 40,\n GATE_UPDATE_FAILED = 41,\n INVALID_GATE = 42,\n INVALID_AGENT = 43,\n MAX_ROUNDS_EXCEEDED = 44,\n GATE_DEPENDENCY = 45,\n VERIFICATION_LOCKED = 46,\n ROUND_MISMATCH = 47,\n\n // === CONTEXT SAFEGUARD (50-54) ===\n CONTEXT_WARNING = 50,\n CONTEXT_CAUTION = 51,\n CONTEXT_CRITICAL = 52,\n CONTEXT_EMERGENCY = 53,\n CONTEXT_STALE = 54,\n\n // === ORCHESTRATOR ERRORS (60-67) ===\n PROTOCOL_MISSING = 60,\n INVALID_RETURN_MESSAGE = 61,\n MANIFEST_ENTRY_MISSING = 62,\n SPAWN_VALIDATION_FAILED = 63,\n AUTONOMOUS_BOUNDARY = 64,\n HANDOFF_REQUIRED = 65,\n RESUME_FAILED = 66,\n CONCURRENT_SESSION = 67,\n\n // === NEXUS ERRORS (70-79) ===\n NEXUS_NOT_INITIALIZED = 70,\n NEXUS_PROJECT_NOT_FOUND = 71,\n NEXUS_PERMISSION_DENIED = 72,\n NEXUS_INVALID_SYNTAX = 73,\n NEXUS_SYNC_FAILED = 74,\n NEXUS_REGISTRY_CORRUPT = 75,\n NEXUS_PROJECT_EXISTS = 76,\n NEXUS_QUERY_FAILED = 77,\n NEXUS_GRAPH_ERROR = 78,\n NEXUS_RESERVED = 79,\n\n // === LIFECYCLE ENFORCEMENT (80-84) ===\n LIFECYCLE_GATE_FAILED = 80,\n AUDIT_MISSING = 81,\n CIRCULAR_VALIDATION = 82,\n LIFECYCLE_TRANSITION_INVALID = 83,\n PROVENANCE_REQUIRED = 84,\n\n // === ARTIFACT PUBLISH (85-89) ===\n ARTIFACT_TYPE_UNKNOWN = 85,\n ARTIFACT_VALIDATION_FAILED = 86,\n ARTIFACT_BUILD_FAILED = 87,\n ARTIFACT_PUBLISH_FAILED = 88,\n ARTIFACT_ROLLBACK_FAILED = 89,\n\n // === PROVENANCE (90-94) ===\n PROVENANCE_CONFIG_INVALID = 90,\n SIGNING_KEY_MISSING = 91,\n SIGNATURE_INVALID = 92,\n DIGEST_MISMATCH = 93,\n ATTESTATION_INVALID = 94,\n\n // === ADAPTER ERRORS (95-99) ===\n ADAPTER_NOT_FOUND = 95,\n ADAPTER_INIT_FAILED = 96,\n ADAPTER_HOOK_FAILED = 97,\n ADAPTER_SPAWN_FAILED = 98,\n ADAPTER_INSTALL_FAILED = 99,\n\n // === SPECIAL CODES (100+) - NOT errors ===\n NO_DATA = 100,\n ALREADY_EXISTS = 101,\n NO_CHANGE = 102,\n TESTS_SKIPPED = 103,\n}\n\n/** Check if an exit code represents an error (1-99). */\nexport function isErrorCode(code: ExitCode): boolean {\n return code >= 1 && code < 100;\n}\n\n/** Check if an exit code represents success (0 or 100+). */\nexport function isSuccessCode(code: ExitCode): boolean {\n return code === 0 || code >= 100;\n}\n\n/** Check if an exit code indicates no change (idempotent operation). */\nexport function isNoChangeCode(code: ExitCode): boolean {\n return code === ExitCode.NO_CHANGE;\n}\n\n/** Check if an exit code is recoverable (retry may succeed). */\nexport function isRecoverableCode(code: ExitCode): boolean {\n const nonRecoverable = new Set<ExitCode>([\n ExitCode.FILE_ERROR,\n ExitCode.DEPENDENCY_ERROR,\n ExitCode.CIRCULAR_REFERENCE,\n ExitCode.CASCADE_FAILED,\n ExitCode.SESSION_CLOSE_BLOCKED,\n ExitCode.VERIFICATION_LOCKED,\n ExitCode.CONTEXT_WARNING,\n ExitCode.CONTEXT_CAUTION,\n ExitCode.CONTEXT_CRITICAL,\n ExitCode.CONTEXT_EMERGENCY,\n ExitCode.CONTEXT_STALE,\n ExitCode.AUTONOMOUS_BOUNDARY,\n ExitCode.HANDOFF_REQUIRED,\n ExitCode.NEXUS_PERMISSION_DENIED,\n ExitCode.NEXUS_REGISTRY_CORRUPT,\n ExitCode.CIRCULAR_VALIDATION,\n ExitCode.LIFECYCLE_TRANSITION_INVALID,\n ExitCode.ARTIFACT_TYPE_UNKNOWN,\n ExitCode.ARTIFACT_ROLLBACK_FAILED,\n ExitCode.DIGEST_MISMATCH,\n ]);\n\n if (!isErrorCode(code)) return false;\n return !nonRecoverable.has(code);\n}\n\n/** Human-readable name for an exit code. */\nexport function getExitCodeName(code: ExitCode): string {\n return ExitCode[code] ?? 'UNKNOWN';\n}\n", "/**\n * LAFS (LLM-Agent-First Schema) unified envelope types.\n *\n * Defines canonical LAFS types inline (contracts has ZERO external dependencies).\n * In the main CLEO codebase these are re-exported from @cleocode/lafs-protocol;\n * here they are defined as plain interfaces for maximum portability.\n *\n * @epic T4654\n * @task T4655\n */\n\n// ---------------------------------------------------------------------------\n// Canonical LAFS types (inlined from @cleocode/lafs-protocol)\n// ---------------------------------------------------------------------------\n\n/** LAFS error category. */\nexport type LAFSErrorCategory =\n | 'validation'\n | 'not_found'\n | 'conflict'\n | 'authorization'\n | 'internal'\n | 'rate_limit'\n | 'timeout'\n | 'dependency';\n\n/** LAFS error object. */\nexport interface LAFSError {\n code: number | string;\n category: LAFSErrorCategory;\n message: string;\n fix?: string;\n details?: Record<string, unknown>;\n}\n\n/** LAFS warning. */\nexport interface Warning {\n code: string;\n message: string;\n}\n\n/** LAFS transport metadata. */\nexport type LAFSTransport = 'mcp' | 'cli' | 'http' | 'sdk';\n\n/** MVI (Minimal Viable Information) level. */\nexport type MVILevel = 'minimal' | 'standard' | 'full';\n\n/** LAFS page \u2014 no pagination. */\nexport interface LAFSPageNone {\n strategy: 'none';\n}\n\n/** LAFS page \u2014 offset-based pagination. */\nexport interface LAFSPageOffset {\n strategy: 'offset';\n offset: number;\n limit: number;\n total: number;\n hasMore: boolean;\n}\n\n/** LAFS page union. */\nexport type LAFSPage = LAFSPageNone | LAFSPageOffset;\n\n/** LAFS metadata block. */\nexport interface LAFSMeta {\n transport: LAFSTransport;\n mvi: MVILevel;\n page?: LAFSPage;\n warnings?: Warning[];\n durationMs?: number;\n}\n\n/** LAFS envelope (canonical protocol type). */\nexport interface LAFSEnvelope<T = unknown> {\n success: boolean;\n data?: T;\n error?: LAFSError;\n _meta?: LAFSMeta;\n}\n\n/** Flag input for conformance checks. */\nexport interface FlagInput {\n flag: string;\n value: unknown;\n}\n\n/** Conformance report. */\nexport interface ConformanceReport {\n valid: boolean;\n violations: string[];\n warnings: string[];\n}\n\n// ---------------------------------------------------------------------------\n// CLEO-specific error detail (backward compatible)\n// ---------------------------------------------------------------------------\n\n/** Actionable alternative the caller can try. */\nexport interface LafsAlternative {\n action: string;\n command: string;\n}\n\n/** LAFS error detail shared between CLI and MCP. */\nexport interface LafsErrorDetail {\n code: number | string;\n name?: string;\n message: string;\n fix?: string;\n alternatives?: LafsAlternative[];\n details?: Record<string, unknown>;\n}\n\n// ---------------------------------------------------------------------------\n// CLI envelope (base) - backward compatible\n// ---------------------------------------------------------------------------\n\n/** LAFS success envelope (CLI). */\nexport interface LafsSuccess<T = unknown> {\n success: true;\n data: T;\n message?: string;\n noChange?: boolean;\n}\n\n/** LAFS error envelope (CLI). */\nexport interface LafsError {\n success: false;\n error: LafsErrorDetail;\n}\n\n/** CLI envelope union type. */\nexport type LafsEnvelope<T = unknown> = LafsSuccess<T> | LafsError;\n\n// ---------------------------------------------------------------------------\n// MCP / gateway envelope extension (extends LAFSMeta)\n// ---------------------------------------------------------------------------\n\n/**\n * Metadata attached to every MCP gateway response.\n * Extends the canonical LAFSMeta with CLEO gateway-specific fields.\n *\n * @task T4655\n */\nexport interface GatewayMeta extends LAFSMeta {\n gateway: string;\n domain: string;\n duration_ms: number;\n}\n\n/** MCP success envelope (extends CLI base with _meta). */\nexport interface GatewaySuccess<T = unknown> extends LafsSuccess<T> {\n _meta: GatewayMeta;\n}\n\n/** MCP error envelope (extends CLI base with _meta). */\nexport interface GatewayError extends LafsError {\n _meta: GatewayMeta;\n}\n\n/** MCP envelope union type. */\nexport type GatewayEnvelope<T = unknown> = GatewaySuccess<T> | GatewayError;\n\n// ---------------------------------------------------------------------------\n// Unified envelope (covers both CLI and MCP)\n// ---------------------------------------------------------------------------\n\n/**\n * Unified CLEO response envelope.\n *\n * Every CLEO response (CLI or MCP) is a CleoResponse. MCP responses include\n * the _meta field; CLI responses do not.\n */\nexport type CleoResponse<T = unknown> = LafsEnvelope<T> | GatewayEnvelope<T>;\n\n// ---------------------------------------------------------------------------\n// Type guards\n// ---------------------------------------------------------------------------\n\n/** Type guard for success responses. */\nexport function isLafsSuccess<T>(envelope: LafsEnvelope<T>): envelope is LafsSuccess<T> {\n return envelope.success === true;\n}\n\n/** Type guard for error responses. */\nexport function isLafsError<T>(envelope: LafsEnvelope<T>): envelope is LafsError {\n return envelope.success === false;\n}\n\n/** Type guard for MCP gateway responses (has _meta). */\nexport function isGatewayEnvelope<T>(envelope: CleoResponse<T>): envelope is GatewayEnvelope<T> {\n return '_meta' in envelope && envelope._meta !== undefined;\n}\n", "/**\n * Issues Domain Operations (4 operations)\n *\n * Query operations: 1 (diagnostics)\n * Mutate operations: 3 (add.bug, add.feature, add.help)\n *\n * @task T4494\n */\n\n/**\n * Common issue types\n */\nexport type IssueSeverity = 'low' | 'medium' | 'high' | 'critical';\nexport type IssueArea = 'cli' | 'mcp' | 'docs' | 'tests' | 'other';\nexport type IssueType = 'bug' | 'feature' | 'help';\n\nexport interface Diagnostics {\n cleoVersion: string;\n bashVersion: string;\n jqVersion: string;\n os: string;\n shell: string;\n cleoHome: string;\n ghVersion: string;\n installLocation: string;\n}\n\n/**\n * Query Operations\n */\n\n// issues.diagnostics\nexport type IssuesDiagnosticsParams = Record<string, never>;\nexport interface IssuesDiagnosticsResult {\n diagnostics: Diagnostics;\n}\n\n/**\n * Mutate Operations\n */\n\n// issues.add.bug (alias: create.bug)\nexport interface IssuesCreateBugParams {\n title: string;\n body: string;\n severity?: IssueSeverity;\n area?: IssueArea;\n dryRun?: boolean;\n}\nexport interface IssuesCreateBugResult {\n type: 'bug';\n url: string;\n number: number;\n title: string;\n labels: string[];\n}\n\n// issues.add.feature (alias: create.feature)\nexport interface IssuesCreateFeatureParams {\n title: string;\n body: string;\n area?: IssueArea;\n dryRun?: boolean;\n}\nexport interface IssuesCreateFeatureResult {\n type: 'feature';\n url: string;\n number: number;\n title: string;\n labels: string[];\n}\n\n// issues.add.help (alias: create.help)\nexport interface IssuesCreateHelpParams {\n title: string;\n body: string;\n area?: IssueArea;\n dryRun?: boolean;\n}\nexport interface IssuesCreateHelpResult {\n type: 'help';\n url: string;\n number: number;\n title: string;\n labels: string[];\n}\n", "/**\n * Lifecycle Domain Operations (10 operations)\n *\n * Query operations: 5\n * Mutate operations: 5\n */\n\nimport type { StageStatus } from '../status-registry.js';\n\nexport type { StageStatus };\n\n/**\n * Common lifecycle types\n */\nexport type LifecycleStage =\n | 'research'\n | 'consensus'\n | 'architecture_decision'\n | 'specification'\n | 'decomposition'\n | 'implementation'\n | 'validation'\n | 'testing'\n | 'release';\n\nexport type GateStatus = 'passed' | 'failed' | 'blocked' | null;\n\nexport interface StageRecord {\n stage: LifecycleStage;\n status: StageStatus;\n started?: string;\n completed?: string;\n agent?: string;\n notes?: string;\n}\n\nexport interface Gate {\n name: string;\n stage: LifecycleStage;\n status: GateStatus;\n agent?: string;\n timestamp?: string;\n reason?: string;\n}\n\n/**\n * Query Operations\n */\n\n// lifecycle.check\nexport interface LifecycleCheckParams {\n taskId: string;\n targetStage: LifecycleStage;\n}\nexport interface LifecycleCheckResult {\n taskId: string;\n targetStage: LifecycleStage;\n canProceed: boolean;\n missingPrerequisites: LifecycleStage[];\n gateStatus: 'passed' | 'failed' | 'pending';\n}\n\n// lifecycle.status\nexport interface LifecycleStatusParams {\n taskId?: string;\n epicId?: string;\n}\nexport interface LifecycleStatusResult {\n id: string;\n currentStage: LifecycleStage;\n stages: StageRecord[];\n completedStages: LifecycleStage[];\n pendingStages: LifecycleStage[];\n}\n\n// lifecycle.history\nexport interface LifecycleHistoryParams {\n taskId: string;\n}\nexport interface LifecycleHistoryEntry {\n stage: LifecycleStage;\n from: StageStatus;\n to: StageStatus;\n timestamp: string;\n agent?: string;\n notes?: string;\n}\nexport type LifecycleHistoryResult = LifecycleHistoryEntry[];\n\n// lifecycle.gates\nexport interface LifecycleGatesParams {\n taskId: string;\n}\nexport type LifecycleGatesResult = Gate[];\n\n// lifecycle.prerequisites\nexport interface LifecyclePrerequisitesParams {\n targetStage: LifecycleStage;\n}\nexport interface LifecyclePrerequisitesResult {\n targetStage: LifecycleStage;\n prerequisites: LifecycleStage[];\n optional: LifecycleStage[];\n}\n\n/**\n * Mutate Operations\n */\n\n// lifecycle.progress\nexport interface LifecycleProgressParams {\n taskId: string;\n stage: LifecycleStage;\n status: StageStatus;\n notes?: string;\n}\nexport interface LifecycleProgressResult {\n taskId: string;\n stage: LifecycleStage;\n status: StageStatus;\n timestamp: string;\n}\n\n// lifecycle.skip\nexport interface LifecycleSkipParams {\n taskId: string;\n stage: LifecycleStage;\n reason: string;\n}\nexport interface LifecycleSkipResult {\n taskId: string;\n stage: LifecycleStage;\n skipped: string;\n reason: string;\n}\n\n// lifecycle.reset\nexport interface LifecycleResetParams {\n taskId: string;\n stage: LifecycleStage;\n reason: string;\n}\nexport interface LifecycleResetResult {\n taskId: string;\n stage: LifecycleStage;\n reset: string;\n reason: string;\n warning: string;\n}\n\n// lifecycle.gate.pass\nexport interface LifecycleGatePassParams {\n taskId: string;\n gateName: string;\n agent: string;\n notes?: string;\n}\nexport interface LifecycleGatePassResult {\n taskId: string;\n gateName: string;\n status: 'passed';\n timestamp: string;\n}\n\n// lifecycle.gate.fail\nexport interface LifecycleGateFailParams {\n taskId: string;\n gateName: string;\n reason: string;\n}\nexport interface LifecycleGateFailResult {\n taskId: string;\n gateName: string;\n status: 'failed';\n reason: string;\n timestamp: string;\n}\n", "/**\n * Orchestrate Domain Operations (13 operations)\n *\n * Query operations: 7\n * Mutate operations: 6\n */\n\n/**\n * Common orchestration types\n */\nexport interface Wave {\n wave: number;\n taskIds: string[];\n canRunParallel: boolean;\n dependencies: string[];\n}\n\nexport interface SkillDefinition {\n name: string;\n description: string;\n tags: string[];\n model?: string;\n protocols: string[];\n}\n\n/**\n * Query Operations\n */\n\n// orchestrate.status\nexport interface OrchestrateStatusParams {\n epicId: string;\n}\nexport interface OrchestrateStatusResult {\n epicId: string;\n totalTasks: number;\n completedTasks: number;\n pendingTasks: number;\n blockedTasks: number;\n currentWave: number;\n totalWaves: number;\n parallelCapacity: number;\n}\n\n// orchestrate.next\nexport interface OrchestrateNextParams {\n epicId: string;\n}\nexport interface OrchestrateNextResult {\n taskId: string;\n title: string;\n recommendedSkill: string;\n reasoning: string;\n}\n\n// orchestrate.ready\nexport interface OrchestrateReadyParams {\n epicId: string;\n}\nexport interface OrchestrateReadyResult {\n wave: number;\n taskIds: string[];\n parallelSafe: boolean;\n}\n\n// orchestrate.analyze\nexport interface OrchestrateAnalyzeParams {\n epicId: string;\n}\nexport interface OrchestrateAnalyzeResult {\n waves: Wave[];\n criticalPath: string[];\n estimatedParallelism: number;\n bottlenecks: string[];\n}\n\n// orchestrate.context\nexport interface OrchestrateContextParams {\n tokens?: number;\n}\nexport interface OrchestrateContextResult {\n currentTokens: number;\n maxTokens: number;\n percentUsed: number;\n level: 'safe' | 'medium' | 'high' | 'critical';\n recommendation: string;\n}\n\n// orchestrate.waves\nexport interface OrchestrateWavesParams {\n epicId: string;\n}\nexport type OrchestrateWavesResult = Wave[];\n\n// orchestrate.skill.list\nexport interface OrchestrateSkillListParams {\n filter?: string;\n}\nexport type OrchestrateSkillListResult = SkillDefinition[];\n\n// orchestrate.bootstrap\nexport interface OrchestrateBootstrapParams {\n speed?: 'fast' | 'full' | 'complete';\n}\nexport interface BrainState {\n session?: { id: string; name: string; status: string; startedAt: string };\n currentTask?: { id: string; title: string; status: string };\n nextSuggestion?: { id: string; title: string; score: number };\n recentDecisions?: Array<{ id: string; decision: string; timestamp: string }>;\n blockers?: Array<{ taskId: string; title: string; blockedBy: string[] }>;\n progress?: { total: number; done: number; active: number; blocked: number; pending: number };\n contextDrift?: { score: number; factors: string[] };\n _meta: { speed: 'fast' | 'full' | 'complete'; generatedAt: string; version: string };\n}\n\n/**\n * Mutate Operations\n */\n\n// orchestrate.startup\nexport interface OrchestrateStartupParams {\n epicId: string;\n}\nexport interface OrchestrateStartupResult {\n epicId: string;\n status: OrchestrateStatusResult;\n analysis: OrchestrateAnalyzeResult;\n firstTask: OrchestrateNextResult;\n}\n\n// orchestrate.spawn\nexport interface OrchestrateSpawnParams {\n taskId: string;\n skill?: string;\n model?: string;\n}\nexport interface OrchestrateSpawnResult {\n taskId: string;\n skill: string;\n model: string;\n prompt: string;\n metadata: {\n tokensUsed: number;\n protocolsInjected: string[];\n dependencies: string[];\n };\n}\n\n// orchestrate.handoff\nexport interface OrchestrateHandoffParams {\n taskId: string;\n protocolType: string;\n note?: string;\n nextAction?: string;\n variant?: string;\n tier?: 0 | 1 | 2;\n idempotencyKey?: string;\n}\nexport interface OrchestrateHandoffResult {\n taskId: string;\n predecessorSessionId: string;\n endedSessionId: string;\n protocolType: string;\n}\n\n// orchestrate.validate\nexport interface OrchestrateValidateParams {\n taskId: string;\n}\nexport interface OrchestrateValidateResult {\n taskId: string;\n ready: boolean;\n blockers: string[];\n lifecycleGate: 'passed' | 'failed' | 'pending';\n recommendations: string[];\n}\n\n// orchestrate.parallel.start\nexport interface OrchestrateParallelStartParams {\n epicId: string;\n wave: number;\n}\nexport interface OrchestrateParallelStartResult {\n wave: number;\n taskIds: string[];\n started: string;\n}\n\n// orchestrate.parallel.end\nexport interface OrchestrateParallelEndParams {\n epicId: string;\n wave: number;\n}\nexport interface OrchestrateParallelEndResult {\n wave: number;\n completed: number;\n failed: number;\n duration: string;\n}\n", "/**\n * Release Domain Operations (7 operations)\n *\n * All mutate operations\n */\n\n/**\n * Common release types\n */\nexport type ReleaseType = 'major' | 'minor' | 'patch';\n\nexport interface ReleaseGate {\n name: string;\n description: string;\n passed: boolean;\n reason?: string;\n}\n\nexport interface ChangelogSection {\n type: 'feat' | 'fix' | 'docs' | 'test' | 'refactor' | 'chore';\n entries: Array<{\n taskId: string;\n message: string;\n }>;\n}\n\n/**\n * Mutate Operations\n */\n\n// release.prepare\nexport interface ReleasePrepareParams {\n version: string;\n type: ReleaseType;\n}\nexport interface ReleasePrepareResult {\n version: string;\n type: ReleaseType;\n currentVersion: string;\n files: string[];\n ready: boolean;\n warnings: string[];\n}\n\n// release.changelog\nexport interface ReleaseChangelogParams {\n version: string;\n sections?: Array<'feat' | 'fix' | 'docs' | 'test' | 'refactor' | 'chore'>;\n}\nexport interface ReleaseChangelogResult {\n version: string;\n content: string;\n sections: ChangelogSection[];\n commitCount: number;\n}\n\n// release.commit\nexport interface ReleaseCommitParams {\n version: string;\n files?: string[];\n}\nexport interface ReleaseCommitResult {\n version: string;\n commitHash: string;\n message: string;\n filesCommitted: string[];\n}\n\n// release.tag\nexport interface ReleaseTagParams {\n version: string;\n message?: string;\n}\nexport interface ReleaseTagResult {\n version: string;\n tagName: string;\n created: string;\n}\n\n// release.push\nexport interface ReleasePushParams {\n version: string;\n remote?: string;\n}\nexport interface ReleasePushResult {\n version: string;\n remote: string;\n pushed: string;\n tagsPushed: string[];\n}\n\n// release.gates.run\nexport interface ReleaseGatesRunParams {\n gates?: string[];\n}\nexport interface ReleaseGatesRunResult {\n total: number;\n passed: number;\n failed: number;\n gates: ReleaseGate[];\n canRelease: boolean;\n}\n\n// release.rollback\nexport interface ReleaseRollbackParams {\n version: string;\n reason: string;\n}\nexport interface ReleaseRollbackResult {\n version: string;\n rolledBack: string;\n restoredVersion: string;\n reason: string;\n}\n", "/**\n * Research Domain Operations (legacy alias for memory domain)\n *\n * Query operations: 12 (derived from memory domain)\n * Mutate operations: 5 (derived from memory domain)\n *\n * Note: manifest.* operations moved to pipeline domain (T5241).\n * inject operation moved to session.context.inject (T5241).\n */\n\n/**\n * Common research types\n */\nexport interface ResearchEntry {\n id: string;\n taskId: string;\n title: string;\n file: string;\n date: string;\n status: 'completed' | 'partial' | 'blocked';\n agentType: string;\n topics: string[];\n keyFindings: string[];\n actionable: boolean;\n needsFollowup: string[];\n linkedTasks: string[];\n confidence?: number;\n}\n\nexport interface ManifestEntry {\n id: string;\n file: string;\n title: string;\n date: string;\n status: 'completed' | 'partial' | 'blocked';\n agent_type: string;\n topics: string[];\n key_findings: string[];\n actionable: boolean;\n needs_followup: string[];\n linked_tasks: string[];\n}\n\n/**\n * Query Operations\n */\n\n// research.show\nexport interface ResearchShowParams {\n researchId: string;\n}\nexport type ResearchShowResult = ResearchEntry;\n\n// research.list\nexport interface ResearchListParams {\n epicId?: string;\n status?: 'completed' | 'partial' | 'blocked';\n}\nexport type ResearchListResult = ResearchEntry[];\n\n// research.query\nexport interface ResearchQueryParams {\n query: string;\n confidence?: number;\n}\nexport interface ResearchQueryResult {\n entries: ResearchEntry[];\n matchCount: number;\n avgConfidence: number;\n}\n\n// research.pending\nexport interface ResearchPendingParams {\n epicId?: string;\n}\nexport type ResearchPendingResult = ResearchEntry[];\n\n// research.stats\nexport interface ResearchStatsParams {\n epicId?: string;\n}\nexport interface ResearchStatsResult {\n total: number;\n complete: number;\n partial: number;\n blocked: number;\n byAgentType: Record<string, number>;\n byTopic: Record<string, number>;\n avgConfidence: number;\n}\n\n// pipeline.manifest.list (was research.manifest.read, moved to pipeline T5241)\nexport interface ResearchManifestReadParams {\n filter?: string;\n limit?: number;\n offset?: number;\n}\nexport type ResearchManifestReadResult = ManifestEntry[];\n\n/**\n * Mutate Operations\n */\n\n// session.context.inject (was research.inject, moved to session domain T5241)\nexport interface ResearchInjectParams {\n protocolType:\n | 'research'\n | 'consensus'\n | 'specification'\n | 'decomposition'\n | 'implementation'\n | 'contribution'\n | 'release';\n taskId?: string;\n variant?: string;\n}\nexport interface ResearchInjectResult {\n protocol: string;\n content: string;\n tokensUsed: number;\n}\n\n// research.link\nexport interface ResearchLinkParams {\n researchId: string;\n taskId: string;\n relationship?: 'supports' | 'blocks' | 'references' | 'supersedes';\n}\nexport interface ResearchLinkResult {\n researchId: string;\n taskId: string;\n relationship: string;\n linked: string;\n}\n\n// pipeline.manifest.append (was research.manifest.append, moved to pipeline T5241)\nexport interface ResearchManifestAppendParams {\n entry: ManifestEntry;\n validateFile?: boolean;\n}\nexport interface ResearchManifestAppendResult {\n id: string;\n appended: string;\n validated: boolean;\n}\n\n// pipeline.manifest.archive (was research.manifest.archive, moved to pipeline T5241)\nexport interface ResearchManifestArchiveParams {\n beforeDate?: string;\n moveFiles?: boolean;\n}\nexport interface ResearchManifestArchiveResult {\n archived: number;\n entryIds: string[];\n filesMovedCount?: number;\n}\n", "/**\n * Session Domain Operations (9 operations)\n *\n * Query operations: 4\n * Mutate operations: 5\n *\n * SYNC: Canonical type definitions live in the CLI package at:\n * src/types/session.ts (Session, SessionScope, etc.)\n * These MCP operation types are the API contract (wire format).\n */\n\n/**\n * Common session types\n */\nexport interface SessionOp {\n id: string;\n name: string;\n scope: string;\n started: string;\n ended?: string;\n startedTask?: string;\n status: 'active' | 'suspended' | 'ended';\n notes?: string[];\n}\n\n/**\n * Query Operations\n */\n\n// session.status\nexport type SessionStatusParams = Record<string, never>;\nexport interface SessionStatusResult {\n current: SessionOp | null;\n hasStartedTask: boolean;\n startedTask?: string;\n}\n\n// session.list\nexport interface SessionListParams {\n active?: boolean;\n status?: string;\n limit?: number;\n offset?: number;\n}\nexport interface SessionListResult {\n sessions: SessionOp[];\n total: number;\n filtered: number;\n}\n\n// session.show\nexport interface SessionShowParams {\n sessionId: string;\n}\nexport type SessionShowResult = SessionOp;\n\n// session.history\nexport interface SessionHistoryParams {\n limit?: number;\n}\nexport interface SessionHistoryEntry {\n sessionId: string;\n name: string;\n started: string;\n ended: string;\n tasksCompleted: number;\n duration: string;\n}\nexport type SessionHistoryResult = SessionHistoryEntry[];\n\n/**\n * Mutate Operations\n */\n\n// session.start\nexport interface SessionStartParams {\n scope: string;\n name?: string;\n autoStart?: boolean;\n startTask?: string;\n}\nexport type SessionStartResult = SessionOp;\n\n// session.end\nexport interface SessionEndParams {\n notes?: string;\n}\nexport interface SessionEndResult {\n session: SessionOp;\n summary: {\n duration: string;\n tasksCompleted: number;\n tasksCreated: number;\n };\n}\n\n// session.resume\nexport interface SessionResumeParams {\n sessionId: string;\n}\nexport type SessionResumeResult = SessionOp;\n\n// session.suspend\nexport interface SessionSuspendParams {\n notes?: string;\n}\nexport interface SessionSuspendResult {\n sessionId: string;\n suspended: string;\n}\n\n// session.gc\nexport interface SessionGcParams {\n olderThan?: string;\n}\nexport interface SessionGcResult {\n cleaned: number;\n sessionIds: string[];\n}\n", "/**\n * Skills Domain Operations (12 operations)\n *\n * Query operations: 6 (list, show, find, dispatch, verify, dependencies)\n * Mutate operations: 6 (install, uninstall, enable, disable, configure, refresh)\n *\n * @task T4387\n */\n\n/**\n * Common skill types\n */\nexport type SkillCategory = 'core' | 'recommended' | 'specialist' | 'composition' | 'meta';\nexport type SkillStatus = 'active' | 'disabled' | 'deprecated' | 'missing';\nexport type DispatchStrategy = 'label' | 'type' | 'keyword' | 'fallback';\n\nexport interface SkillSummary {\n name: string;\n version: string;\n description: string;\n category: SkillCategory;\n core: boolean;\n tier: number;\n status: SkillStatus;\n protocol: string | null;\n}\n\nexport interface SkillDetail extends SkillSummary {\n path: string;\n references: string[];\n dependencies: string[];\n sharedResources: string[];\n compatibility: string[];\n license: string;\n metadata: Record<string, unknown>;\n capabilities?: {\n inputs: string[];\n outputs: string[];\n dispatch_triggers: string[];\n compatible_subagent_types: string[];\n chains_to: string[];\n dispatch_keywords: {\n primary: string[];\n secondary: string[];\n };\n };\n constraints?: {\n max_context_tokens: number;\n requires_session: boolean;\n requires_epic: boolean;\n };\n}\n\nexport interface DispatchCandidate {\n skill: string;\n score: number;\n strategy: DispatchStrategy;\n reason: string;\n}\n\nexport interface DependencyNode {\n name: string;\n version: string;\n direct: boolean;\n depth: number;\n}\n\nexport interface ValidationIssue {\n level: 'error' | 'warn';\n field: string;\n message: string;\n}\n\n/**\n * Query Operations\n */\n\n// skills.list\nexport interface SkillsListParams {\n category?: SkillCategory;\n core?: boolean;\n filter?: string;\n}\nexport type SkillsListResult = SkillSummary[];\n\n// skills.show\nexport interface SkillsShowParams {\n name: string;\n}\nexport type SkillsShowResult = SkillDetail;\n\n// skills.find\nexport interface SkillsFindParams {\n query: string;\n limit?: number;\n}\nexport interface SkillsFindResult {\n query: string;\n results: Array<SkillSummary & { score: number; matchReason: string }>;\n}\n\n// skills.dispatch\nexport interface SkillsDispatchParams {\n taskId?: string;\n taskType?: string;\n labels?: string[];\n title?: string;\n description?: string;\n}\nexport interface SkillsDispatchResult {\n selectedSkill: string;\n reason: string;\n strategy: DispatchStrategy;\n candidates: DispatchCandidate[];\n}\n\n// skills.verify\nexport interface SkillsVerifyParams {\n name?: string;\n}\nexport interface SkillsVerifyResult {\n valid: boolean;\n total: number;\n passed: number;\n failed: number;\n results: Array<{\n name: string;\n valid: boolean;\n issues: ValidationIssue[];\n }>;\n}\n\n// skills.dependencies\nexport interface SkillsDependenciesParams {\n name: string;\n transitive?: boolean;\n}\nexport interface SkillsDependenciesResult {\n name: string;\n dependencies: DependencyNode[];\n resolved: string[];\n}\n\n/**\n * Mutate Operations\n */\n\n// skills.install\nexport interface SkillsInstallParams {\n name: string;\n source?: string;\n}\nexport interface SkillsInstallResult {\n name: string;\n installed: boolean;\n version: string;\n path: string;\n}\n\n// skills.uninstall\nexport interface SkillsUninstallParams {\n name: string;\n force?: boolean;\n}\nexport interface SkillsUninstallResult {\n name: string;\n uninstalled: boolean;\n}\n\n// skills.enable\nexport interface SkillsEnableParams {\n name: string;\n}\nexport interface SkillsEnableResult {\n name: string;\n enabled: boolean;\n status: SkillStatus;\n}\n\n// skills.disable\nexport interface SkillsDisableParams {\n name: string;\n reason?: string;\n}\nexport interface SkillsDisableResult {\n name: string;\n disabled: boolean;\n status: SkillStatus;\n}\n\n// skills.configure\nexport interface SkillsConfigureParams {\n name: string;\n config: Record<string, unknown>;\n}\nexport interface SkillsConfigureResult {\n name: string;\n configured: boolean;\n config: Record<string, unknown>;\n}\n\n// skills.refresh\nexport interface SkillsRefreshParams {\n force?: boolean;\n}\nexport interface SkillsRefreshResult {\n refreshed: boolean;\n skillCount: number;\n timestamp: string;\n}\n", "/**\n * System Domain Operations (12 operations)\n *\n * Query operations: 5\n * Mutate operations: 7\n */\n\n/**\n * Common system types\n */\nexport interface HealthCheck {\n component: string;\n healthy: boolean;\n message?: string;\n}\n\nexport interface ProjectStats {\n tasks: {\n total: number;\n pending: number;\n active: number;\n blocked: number;\n done: number;\n };\n sessions: {\n total: number;\n active: number;\n };\n research: {\n total: number;\n complete: number;\n };\n}\n\n/**\n * Query Operations\n */\n\n// system.version\nexport type SystemVersionParams = Record<string, never>;\nexport interface SystemVersionResult {\n version: string;\n schemaVersion: string;\n buildDate: string;\n}\n\n// system.doctor\nexport type SystemDoctorParams = Record<string, never>;\nexport interface SystemDoctorResult {\n healthy: boolean;\n checks: HealthCheck[];\n warnings: string[];\n errors: string[];\n}\n\n// system.config.get\nexport interface SystemConfigGetParams {\n key: string;\n}\nexport interface SystemConfigGetResult {\n key: string;\n value: unknown;\n type: string;\n}\n\n// system.stats\nexport type SystemStatsParams = Record<string, never>;\nexport type SystemStatsResult = ProjectStats;\n\n// system.context\nexport type SystemContextParams = Record<string, never>;\nexport interface SystemContextResult {\n currentTokens: number;\n maxTokens: number;\n percentUsed: number;\n level: 'safe' | 'medium' | 'high' | 'critical';\n estimatedFiles: number;\n largestFile: {\n path: string;\n tokens: number;\n };\n}\n\n/**\n * Mutate Operations\n */\n\n// system.init\nexport interface SystemInitParams {\n projectType?: 'nodejs' | 'python' | 'bash' | 'typescript' | 'rust' | 'go';\n detect?: boolean;\n}\nexport interface SystemInitResult {\n initialized: boolean;\n projectType?: string;\n filesCreated: string[];\n detectedFeatures?: Record<string, boolean>;\n}\n\n// system.config.set\nexport interface SystemConfigSetParams {\n key: string;\n value: unknown;\n}\nexport interface SystemConfigSetResult {\n key: string;\n value: unknown;\n previousValue?: unknown;\n}\n\n// system.backup\nexport interface SystemBackupParams {\n type?: 'snapshot' | 'safety' | 'archive' | 'migration';\n note?: string;\n}\nexport interface SystemBackupResult {\n backupId: string;\n type: string;\n timestamp: string;\n files: string[];\n size: number;\n}\n\n// system.restore\nexport interface SystemRestoreParams {\n backupId: string;\n}\nexport interface SystemRestoreResult {\n backupId: string;\n restored: string;\n filesRestored: string[];\n}\n\n// system.migrate\nexport interface SystemMigrateParams {\n version?: string;\n dryRun?: boolean;\n}\nexport interface SystemMigrateResult {\n fromVersion: string;\n toVersion: string;\n migrations: Array<{\n name: string;\n applied: boolean;\n error?: string;\n }>;\n dryRun: boolean;\n}\n\n// system.sync\nexport interface SystemSyncParams {\n direction?: 'push' | 'pull' | 'bidirectional';\n}\nexport interface SystemSyncResult {\n direction: string;\n synced: string;\n tasksSynced: number;\n conflicts: Array<{\n taskId: string;\n resolution: string;\n }>;\n}\n\n// system.cleanup\nexport interface SystemCleanupParams {\n type: 'backups' | 'logs' | 'archive' | 'sessions';\n olderThan?: string;\n}\nexport interface SystemCleanupResult {\n type: string;\n cleaned: number;\n freed: number;\n items: string[];\n}\n", "/**\n * Tasks Domain Operations (22 operations)\n *\n * Query operations: 10\n * Mutate operations: 12\n *\n * SYNC: Canonical type definitions live in the CLI package at:\n * src/types/task.ts (TaskStatus, TaskPriority, Task, etc.)\n * These MCP operation types are the API contract (wire format).\n * Internal domain types must stay aligned with CLI definitions.\n */\n\n/**\n * Common task types (API contract \u2014 matches CLI src/types/task.ts)\n */\nimport type { TaskStatus } from '../status-registry.js';\n\nexport type { TaskStatus };\nexport type TaskPriority = 'low' | 'medium' | 'high' | 'critical';\n\nexport interface TaskOp {\n id: string;\n title: string;\n description: string;\n status: TaskStatus;\n priority?: TaskPriority;\n parent?: string;\n depends?: string[];\n labels?: string[];\n created: string;\n updated: string;\n completed?: string;\n notes?: string[];\n}\n\nexport interface MinimalTask {\n id: string;\n title: string;\n status: TaskStatus;\n parent?: string;\n}\n\n/**\n * Query Operations\n */\n\n// tasks.get\nexport interface TasksGetParams {\n taskId: string;\n}\nexport type TasksGetResult = TaskOp;\n\n// tasks.list\nexport interface TasksListParams {\n parent?: string;\n status?: TaskStatus;\n priority?: TaskPriority;\n type?: string;\n phase?: string;\n label?: string;\n children?: boolean;\n limit?: number;\n offset?: number;\n compact?: boolean;\n}\nexport interface TasksListResult {\n tasks: TaskOp[];\n total: number;\n filtered: number;\n}\n\n// tasks.find\nexport interface TasksFindParams {\n query: string;\n limit?: number;\n}\nexport type TasksFindResult = MinimalTask[];\n\n// tasks.exists\nexport interface TasksExistsParams {\n taskId: string;\n}\nexport interface TasksExistsResult {\n exists: boolean;\n taskId: string;\n}\n\n// tasks.tree\nexport interface TasksTreeParams {\n rootId?: string;\n depth?: number;\n}\nexport interface TaskTreeNode {\n task: TaskOp;\n children: TaskTreeNode[];\n depth: number;\n}\nexport type TasksTreeResult = TaskTreeNode[];\n\n// tasks.blockers\nexport interface TasksBlockersParams {\n taskId: string;\n}\nexport interface Blocker {\n taskId: string;\n title: string;\n status: TaskStatus;\n blockType: 'dependency' | 'parent' | 'gate';\n}\nexport type TasksBlockersResult = Blocker[];\n\n// tasks.deps\nexport interface TasksDepsParams {\n taskId: string;\n direction?: 'upstream' | 'downstream' | 'both';\n}\nexport interface TaskDependencyNode {\n taskId: string;\n title: string;\n status: TaskStatus;\n distance: number;\n}\nexport interface TasksDepsResult {\n taskId: string;\n upstream: TaskDependencyNode[];\n downstream: TaskDependencyNode[];\n}\n\n// tasks.analyze\nexport interface TasksAnalyzeParams {\n epicId?: string;\n}\nexport interface TriageRecommendation {\n taskId: string;\n title: string;\n priority: number;\n reason: string;\n readiness: 'ready' | 'blocked' | 'pending';\n}\nexport type TasksAnalyzeResult = TriageRecommendation[];\n\n// tasks.next\nexport interface TasksNextParams {\n epicId?: string;\n count?: number;\n}\nexport interface SuggestedTask {\n taskId: string;\n title: string;\n score: number;\n rationale: string;\n}\nexport type TasksNextResult = SuggestedTask[];\n\n/**\n * Mutate Operations\n */\n\n// tasks.create\nexport interface TasksCreateParams {\n title: string;\n description: string;\n parent?: string;\n depends?: string[];\n priority?: TaskPriority;\n labels?: string[];\n}\nexport type TasksCreateResult = TaskOp;\n\n// tasks.update\nexport interface TasksUpdateParams {\n taskId: string;\n title?: string;\n description?: string;\n status?: TaskStatus;\n priority?: TaskPriority;\n notes?: string;\n parent?: string | null; // Set parent ID, or null/\"\" to promote to root\n labels?: string[];\n addLabels?: string[];\n removeLabels?: string[];\n depends?: string[];\n addDepends?: string[];\n removeDepends?: string[];\n type?: string;\n size?: string;\n}\nexport type TasksUpdateResult = TaskOp;\n\n// tasks.complete\nexport interface TasksCompleteParams {\n taskId: string;\n notes?: string;\n archive?: boolean;\n}\nexport interface TasksCompleteResult {\n taskId: string;\n completed: string;\n archived: boolean;\n}\n\n// tasks.delete\nexport interface TasksDeleteParams {\n taskId: string;\n force?: boolean;\n}\nexport interface TasksDeleteResult {\n taskId: string;\n deleted: true;\n}\n\n// tasks.archive\nexport interface TasksArchiveParams {\n taskId?: string;\n before?: string;\n}\nexport interface TasksArchiveResult {\n archived: number;\n taskIds: string[];\n}\n\n// tasks.unarchive\nexport interface TasksUnarchiveParams {\n taskId: string;\n}\nexport type TasksUnarchiveResult = TaskOp;\n\n// tasks.reparent\nexport interface TasksReparentParams {\n taskId: string;\n newParent: string;\n}\nexport type TasksReparentResult = TaskOp;\n\n// tasks.promote\nexport interface TasksPromoteParams {\n taskId: string;\n}\nexport type TasksPromoteResult = TaskOp;\n\n// tasks.reorder\nexport interface TasksReorderParams {\n taskId: string;\n position: number;\n}\nexport interface TasksReorderResult {\n taskId: string;\n newPosition: number;\n}\n\n// tasks.restore (completed tasks) \u2014 alias: reopen\nexport interface TasksReopenParams {\n taskId: string;\n}\nexport type TasksReopenResult = TaskOp;\n\n// tasks.start (begin working on a task)\nexport interface TasksStartParams {\n taskId: string;\n}\nexport interface TasksStartResult {\n taskId: string;\n sessionId: string;\n timestamp: string;\n}\n\n// tasks.stop (stop working on current task)\nexport type TasksStopParams = Record<string, never>;\nexport interface TasksStopResult {\n stopped: true;\n previousTask?: string;\n}\n\n// tasks.current (get currently active task)\nexport type TasksCurrentParams = Record<string, never>;\nexport interface TasksCurrentResult {\n taskId: string | null;\n since?: string;\n sessionId?: string;\n}\n", "/**\n * Validate Domain Operations (11 operations)\n *\n * Query operations: 9\n * Mutate operations: 2\n */\n\n/**\n * Common validation types\n */\nexport type ValidationSeverity = 'error' | 'warning' | 'info';\n\nexport interface ValidationViolation {\n rule: string;\n severity: ValidationSeverity;\n message: string;\n field?: string;\n value?: unknown;\n expected?: unknown;\n line?: number;\n}\n\nexport interface ComplianceMetrics {\n total: number;\n passed: number;\n failed: number;\n score: number;\n byProtocol: Record<string, { passed: number; failed: number }>;\n bySeverity: Record<ValidationSeverity, number>;\n}\n\n/**\n * Query Operations\n */\n\n// validate.schema\nexport interface ValidateSchemaParams {\n fileType: 'todo' | 'config' | 'archive' | 'log' | 'manifest';\n filePath?: string;\n}\nexport interface ValidateSchemaResult {\n valid: boolean;\n schemaVersion: string;\n violations: ValidationViolation[];\n}\n\n// validate.protocol\nexport interface ValidateProtocolParams {\n taskId: string;\n protocolType:\n | 'research'\n | 'consensus'\n | 'specification'\n | 'decomposition'\n | 'implementation'\n | 'contribution'\n | 'release';\n}\nexport interface ValidateProtocolResult {\n taskId: string;\n protocol: string;\n passed: boolean;\n score: number;\n violations: ValidationViolation[];\n requirements: {\n total: number;\n met: number;\n failed: number;\n };\n}\n\n// validate.task\nexport interface ValidateTaskParams {\n taskId: string;\n checkMode: 'basic' | 'strict' | 'anti-hallucination';\n}\nexport interface ValidateTaskResult {\n taskId: string;\n valid: boolean;\n violations: ValidationViolation[];\n checks: {\n idUniqueness: boolean;\n titleDescriptionDifferent: boolean;\n validStatus: boolean;\n noFutureTimestamps: boolean;\n noDuplicateDescription: boolean;\n };\n}\n\n// validate.manifest\nexport interface ValidateManifestParams {\n entry?: string;\n taskId?: string;\n}\nexport interface ValidateManifestResult {\n valid: boolean;\n entry: {\n id: string;\n file: string;\n exists: boolean;\n };\n violations: ValidationViolation[];\n}\n\n// validate.output\nexport interface ValidateOutputParams {\n taskId: string;\n filePath: string;\n}\nexport interface ValidateOutputResult {\n taskId: string;\n filePath: string;\n valid: boolean;\n checks: {\n fileExists: boolean;\n hasTaskHeader: boolean;\n hasStatus: boolean;\n hasSummary: boolean;\n linkedToTask: boolean;\n };\n violations: ValidationViolation[];\n}\n\n// validate.compliance.summary\nexport interface ValidateComplianceSummaryParams {\n scope?: string;\n since?: string;\n}\nexport type ValidateComplianceSummaryResult = ComplianceMetrics;\n\n// validate.compliance.violations\nexport interface ValidateComplianceViolationsParams {\n severity?: ValidationSeverity;\n protocol?: string;\n}\nexport interface ValidateComplianceViolationsResult {\n violations: Array<\n ValidationViolation & {\n taskId: string;\n protocol: string;\n timestamp: string;\n }\n >;\n total: number;\n}\n\n// validate.test.status\nexport interface ValidateTestStatusParams {\n taskId?: string;\n}\nexport interface ValidateTestStatusResult {\n total: number;\n passed: number;\n failed: number;\n skipped: number;\n passRate: number;\n byTask?: Record<string, { passed: number; failed: number }>;\n}\n\n// validate.test.coverage\nexport interface ValidateTestCoverageParams {\n taskId?: string;\n}\nexport interface ValidateTestCoverageResult {\n lineCoverage: number;\n branchCoverage: number;\n functionCoverage: number;\n statementCoverage: number;\n threshold: number;\n meetsThreshold: boolean;\n}\n\n/**\n * Mutate Operations\n */\n\n// validate.compliance.record\nexport interface ValidateComplianceRecordParams {\n taskId: string;\n result: ValidateProtocolResult;\n}\nexport interface ValidateComplianceRecordResult {\n taskId: string;\n recorded: string;\n metrics: ComplianceMetrics;\n}\n\n// validate.test.run\nexport interface ValidateTestRunParams {\n scope?: string;\n pattern?: string;\n parallel?: boolean;\n}\nexport interface ValidateTestRunResult {\n status: ValidateTestStatusResult;\n coverage: ValidateTestCoverageResult;\n duration: string;\n output?: string;\n}\n", "/**\n * Operations types barrel \u2014 API wire format types for all CLEO domains.\n *\n * These are re-exported under `ops` namespace from the package root\n * to avoid name collisions with canonical domain types.\n */\n\nexport * from './issues.js';\nexport * from './lifecycle.js';\nexport * from './orchestrate.js';\nexport * from './release.js';\nexport * from './research.js';\nexport * from './session.js';\nexport * from './skills.js';\nexport * from './system.js';\nexport * from './tasks.js';\nexport * from './validate.js';\n", "/**\n * Session type definitions for CLEO V2.\n *\n * Plain TypeScript interfaces derived from the Drizzle/Zod schemas\n * in src/store/validation-schemas.ts. Contracts must not depend on Zod/Drizzle.\n *\n * @epic T4454\n */\n\nimport type { SessionStatus } from './status-registry.js';\n\nexport type { SessionStatus };\n\n/** Session scope JSON blob shape. */\nexport interface SessionScope {\n type: string;\n epicId?: string;\n rootTaskId?: string;\n includeDescendants?: boolean;\n phaseFilter?: string | null;\n labelFilter?: string[] | null;\n maxDepth?: number | null;\n explicitTaskIds?: string[] | null;\n excludeTaskIds?: string[] | null;\n computedTaskIds?: string[];\n computedAt?: string;\n}\n\n/** Session statistics. */\nexport interface SessionStats {\n tasksCompleted: number;\n tasksCreated: number;\n tasksUpdated: number;\n focusChanges: number;\n totalActiveMinutes: number;\n suspendCount: number;\n}\n\n/** Active task work state within a session. */\nexport interface SessionTaskWork {\n taskId: string | null;\n setAt: string | null;\n}\n\n/** Session domain type \u2014 plain interface aligned with Drizzle sessions table. */\nexport interface Session {\n id: string;\n name: string;\n status: SessionStatus;\n scope: SessionScope;\n taskWork: SessionTaskWork;\n startedAt: string;\n endedAt?: string;\n agent?: string;\n notes?: string[];\n tasksCompleted?: string[];\n tasksCreated?: string[];\n handoffJson?: string | null;\n previousSessionId?: string | null;\n nextSessionId?: string | null;\n agentIdentifier?: string | null;\n handoffConsumedAt?: string | null;\n handoffConsumedBy?: string | null;\n debriefJson?: string | null;\n stats?: SessionStats;\n resumeCount?: number;\n gradeMode?: boolean;\n providerId?: string | null;\n}\n\n/**\n * Result of a session start operation.\n *\n * The `sessionId` field is a convenience alias for `session.id`,\n * provided for consumers that expect it at the top level of the result.\n */\nexport interface SessionStartResult {\n session: Session;\n sessionId: string;\n}\n\n/**\n * SessionView \u2014 typed wrapper over Session[] with collection helpers.\n *\n * Provides discoverable query methods for common session lookups.\n * Does NOT change the DataAccessor interface \u2014 consumers create views from Session[].\n */\nexport class SessionView {\n private readonly _sessions: Session[];\n\n constructor(sessions: Session[]) {\n this._sessions = sessions;\n }\n\n /** Create a SessionView from a Session array. */\n static from(sessions: Session[]): SessionView {\n return new SessionView(sessions);\n }\n\n /** All sessions in the view (readonly). */\n get all(): readonly Session[] {\n return this._sessions;\n }\n\n /** Number of sessions. */\n get length(): number {\n return this._sessions.length;\n }\n\n /** Find the currently active session (if any). */\n findActive(): Session | undefined {\n return this._sessions.find((s) => s.status === 'active');\n }\n\n /** Find a session by ID. */\n findById(id: string): Session | undefined {\n return this._sessions.find((s) => s.id === id);\n }\n\n /** Filter sessions by one or more statuses. */\n filterByStatus(...statuses: SessionStatus[]): Session[] {\n return this._sessions.filter((s) => (statuses as string[]).includes(s.status));\n }\n\n /** Find sessions matching a scope type and optional rootTaskId. */\n findByScope(type: string, rootTaskId?: string): Session[] {\n return this._sessions.filter((s) => {\n if (s.scope?.type !== type) return false;\n if (rootTaskId && s.scope?.rootTaskId !== rootTaskId) return false;\n return true;\n });\n }\n\n /** Sort sessions by a date field. Returns a new array (does not mutate). */\n sortByDate(field: 'startedAt' | 'endedAt', descending = true): Session[] {\n return [...this._sessions].sort((a, b) => {\n const aDate = new Date(a[field] || '').getTime();\n const bDate = new Date(b[field] || '').getTime();\n return descending ? bDate - aDate : aDate - bDate;\n });\n }\n\n /** Get the most recently started session. */\n mostRecent(): Session | undefined {\n if (this._sessions.length === 0) return undefined;\n return this.sortByDate('startedAt', true)[0];\n }\n\n /** Convert back to a plain Session array (shallow copy). */\n toArray(): Session[] {\n return [...this._sessions];\n }\n\n /** Support for-of iteration. */\n [Symbol.iterator](): Iterator<Session> {\n return this._sessions[Symbol.iterator]();\n }\n}\n", "/**\n * Unified Status Registry \u2014 single source of truth for all status enums.\n *\n * ADR-018: All status constants and types MUST be defined here.\n * No other file may define status enum arrays as constants.\n *\n * Dependency direction:\n * status-registry.ts \u2192 schema.ts, types/task.ts, validation/engine.ts,\n * mcp/lib/security.ts, dispatch/lib/security.ts, ...\n */\n\n// === WORKFLOW NAMESPACE ===\n// Statuses for entities representing work being performed.\n\nexport const TASK_STATUSES = [\n 'pending',\n 'active',\n 'blocked',\n 'done',\n 'cancelled',\n 'archived',\n] as const;\n\nexport const SESSION_STATUSES = ['active', 'ended', 'orphaned', 'suspended'] as const;\n\nexport const LIFECYCLE_PIPELINE_STATUSES = [\n 'active',\n 'completed',\n 'blocked',\n 'failed',\n 'cancelled',\n 'aborted',\n] as const;\n\nexport const LIFECYCLE_STAGE_STATUSES = [\n 'not_started',\n 'in_progress',\n 'blocked',\n 'completed',\n 'skipped',\n 'failed',\n] as const;\n\n// === GOVERNANCE NAMESPACE ===\n// Statuses for decisions and approvals.\n\nexport const ADR_STATUSES = ['proposed', 'accepted', 'superseded', 'deprecated'] as const;\n\nexport const GATE_STATUSES = ['pending', 'passed', 'failed', 'waived'] as const;\n\n// === MANIFEST NAMESPACE ===\n// Statuses for protocol output artifacts.\n// NOTE: 'complete' was the old value \u2014 it is now 'completed' everywhere.\n\nexport const MANIFEST_STATUSES = ['completed', 'partial', 'blocked', 'archived'] as const;\n\n// === DERIVED TYPES ===\n\nexport type TaskStatus = (typeof TASK_STATUSES)[number];\nexport type SessionStatus = (typeof SESSION_STATUSES)[number];\nexport type PipelineStatus = (typeof LIFECYCLE_PIPELINE_STATUSES)[number];\nexport type StageStatus = (typeof LIFECYCLE_STAGE_STATUSES)[number];\nexport type AdrStatus = (typeof ADR_STATUSES)[number];\nexport type GateStatus = (typeof GATE_STATUSES)[number];\nexport type ManifestStatus = (typeof MANIFEST_STATUSES)[number];\n\n// === TERMINAL STATE SETS ===\n\nexport const TERMINAL_TASK_STATUSES: ReadonlySet<TaskStatus> = new Set([\n 'done',\n 'cancelled',\n 'archived',\n]);\n\nexport const TERMINAL_PIPELINE_STATUSES: ReadonlySet<PipelineStatus> = new Set([\n 'completed',\n 'failed',\n 'cancelled',\n 'aborted',\n]);\n\nexport const TERMINAL_STAGE_STATUSES: ReadonlySet<StageStatus> = new Set([\n 'completed',\n 'skipped',\n 'failed',\n]);\n\n// === REGISTRY (for runtime queryability) ===\n\nexport type EntityType =\n | 'task'\n | 'session'\n | 'lifecycle_pipeline'\n | 'lifecycle_stage'\n | 'adr'\n | 'gate'\n | 'manifest';\n\nexport const STATUS_REGISTRY: Record<EntityType, readonly string[]> = {\n task: TASK_STATUSES,\n session: SESSION_STATUSES,\n lifecycle_pipeline: LIFECYCLE_PIPELINE_STATUSES,\n lifecycle_stage: LIFECYCLE_STAGE_STATUSES,\n adr: ADR_STATUSES,\n gate: GATE_STATUSES,\n manifest: MANIFEST_STATUSES,\n} as const;\n\nexport function isValidStatus(entityType: EntityType, value: string): boolean {\n return (STATUS_REGISTRY[entityType] as readonly string[]).includes(value);\n}\n\n// === DISPLAY ICONS ===\n// Typed Record maps \u2014 exhaustiveness is enforced by the compiler.\n// All icon consumers MUST import from here instead of hardcoding comparisons.\n\n/**\n * Pipeline status \u2192 Unicode progress icon.\n * Used wherever lifecycle pipeline status is rendered to a terminal.\n */\nexport const PIPELINE_STATUS_ICONS: Record<PipelineStatus, string> = {\n active: '\\u25b6', // pipeline is running\n completed: '\\u2713', // all stages done successfully\n blocked: '\\u23f8', // cannot advance; waiting\n failed: '\\u2717', // terminal failure\n cancelled: '\\u2298', // user-initiated abandonment\n aborted: '\\u23f9', // system-forced termination\n};\n\n/**\n * Stage status \u2192 Unicode progress icon.\n * Used wherever pipeline stage status is rendered to a terminal.\n */\nexport const STAGE_STATUS_ICONS: Record<StageStatus, string> = {\n not_started: '\\u23f9', // not yet entered\n in_progress: '\\u25b6', // actively running\n blocked: '\\u23f8', // paused / waiting\n completed: '\\u2713', // finished successfully\n skipped: '\\u23ed', // intentionally bypassed\n failed: '\\u2717', // terminal failure\n};\n\n/**\n * Task status \u2192 Unicode symbol (rich terminal / Unicode-enabled).\n * Falls back to TASK_STATUS_SYMBOLS_ASCII when Unicode is unavailable.\n */\nexport const TASK_STATUS_SYMBOLS_UNICODE: Record<TaskStatus, string> = {\n pending: '\\u25cb', // \u25CB not yet started\n active: '\\u25c9', // \u25C9 in progress\n blocked: '\\u2297', // \u2297 cannot advance\n done: '\\u2713', // \u2713 complete\n cancelled: '\\u2717', // \u2717 abandoned\n archived: '\\u25a3', // \u25A3 stored, inactive\n};\n\n/**\n * Task status \u2192 ASCII fallback symbol (non-Unicode terminals, CI output).\n */\nexport const TASK_STATUS_SYMBOLS_ASCII: Record<TaskStatus, string> = {\n pending: '-',\n active: '*',\n blocked: 'x',\n done: '+',\n cancelled: '~',\n archived: '#',\n};\n", "/**\n * @cleocode/contracts \u2014 Domain types, interfaces, and contracts for the CLEO ecosystem.\n *\n * This is the LEAF package in the dependency graph \u2014 ZERO runtime dependencies.\n * All domain types (Task, Session, DataAccessor, etc.) are defined here.\n * Implementation packages (@cleocode/core, @cleocode/cleo) import from here.\n */\n\n// === Provider Adapter Contracts ===\nexport type { AdapterHealthStatus, CLEOProviderAdapter } from './adapter.js';\n// === Archive Types ===\nexport type {\n ArchiveCycleTimesReport,\n ArchiveDailyTrend,\n ArchivedTask,\n ArchiveLabelEntry,\n ArchiveMetadata,\n ArchiveMonthlyTrend,\n ArchivePhaseEntry,\n ArchivePriorityEntry,\n ArchiveReportType,\n ArchiveStatsEnvelope,\n ArchiveSummaryReport,\n ArchiveTrendsReport,\n CycleTimeDistribution,\n CycleTimePercentiles,\n} from './archive.js';\n// === Brain/Memory Types ===\nexport type {\n BrainEntryRef,\n BrainEntrySummary,\n ContradictionDetail,\n SupersededEntry,\n} from './brain.js';\nexport type { AdapterCapabilities } from './capabilities.js';\n// === Configuration Types ===\nexport type {\n BackupConfig,\n CleoConfig,\n ConfigSource,\n DateFormat,\n EnforcementProfile,\n HierarchyConfig,\n LifecycleConfig,\n LifecycleEnforcementMode,\n LoggingConfig,\n LogLevel,\n OutputConfig,\n OutputFormat,\n ResolvedValue,\n SessionConfig,\n SharingConfig,\n SharingMode,\n SignalDockConfig,\n SignalDockMode,\n} from './config.js';\nexport type { AdapterContextMonitorProvider } from './context-monitor.js';\n// === DataAccessor Interface ===\nexport type {\n ArchiveFields,\n ArchiveFile,\n DataAccessor,\n QueryTasksResult,\n TaskFieldUpdates,\n TaskQueryFilters,\n TransactionAccessor,\n} from './data-accessor.js';\nexport type { AdapterManifest, DetectionPattern } from './discovery.js';\n// === Error Utilities ===\nexport {\n createErrorResult,\n createSuccessResult,\n formatError,\n getErrorMessage,\n isErrorResult,\n isErrorType,\n normalizeError,\n} from './errors.js';\n// === Exit Codes ===\nexport {\n ExitCode,\n getExitCodeName,\n isErrorCode,\n isNoChangeCode,\n isRecoverableCode,\n isSuccessCode,\n} from './exit-codes.js';\nexport type { AdapterHookProvider } from './hooks.js';\nexport type { AdapterInstallProvider, InstallOptions, InstallResult } from './install.js';\nexport type {\n CleoResponse,\n ConformanceReport,\n FlagInput,\n GatewayEnvelope,\n GatewayError,\n GatewayMeta,\n GatewaySuccess,\n LAFSEnvelope,\n LAFSError,\n LAFSErrorCategory,\n LAFSMeta,\n LAFSPage,\n LAFSPageNone,\n LAFSPageOffset,\n LAFSTransport,\n LafsAlternative,\n LafsEnvelope,\n LafsError,\n LafsErrorDetail,\n LafsSuccess,\n MVILevel,\n Warning,\n} from './lafs.js';\n// === LAFS Envelope Types ===\nexport {\n isGatewayEnvelope,\n isLafsError,\n isLafsSuccess,\n} from './lafs.js';\nexport type {\n BridgeDecision,\n BridgeLearning,\n BridgeObservation,\n BridgePattern,\n MemoryBridgeConfig,\n MemoryBridgeContent,\n SessionSummary,\n} from './memory.js';\n// === Operations Types (API wire format, namespaced to avoid collision with domain types) ===\nexport * as ops from './operations/index.js';\n// Commonly used ops types re-exported at top level for convenience\nexport type { BrainState } from './operations/orchestrate.js';\nexport type { AdapterPathProvider } from './provider-paths.js';\n// === Result Types (Dashboard, Stats, Log, Context, Sequence, Analysis, Deps) ===\nexport type {\n BottleneckTask,\n CompleteTaskUnblocked,\n ContextResult,\n DashboardResult,\n LabelCount,\n LeveragedTask,\n LogQueryResult,\n SequenceResult,\n StatsActivityMetrics,\n StatsAllTime,\n StatsCompletionMetrics,\n StatsCurrentState,\n StatsCycleTimes,\n StatsResult,\n TaskAnalysisResult,\n TaskDepsResult,\n TaskRef,\n TaskRefPriority,\n TaskSummary,\n} from './results.js';\n// === Session Start Result ===\nexport type {\n Session,\n SessionScope,\n SessionStartResult,\n SessionStats,\n SessionTaskWork,\n} from './session.js';\n// === Session Types ===\nexport { SessionView } from './session.js';\nexport type { AdapterSpawnProvider, SpawnContext, SpawnResult } from './spawn.js';\n// === CLEO Spawn Types (distinct from adapter spawn) ===\nexport type {\n CAAMPSpawnOptions,\n CAAMPSpawnResult,\n CLEOSpawnAdapter,\n CLEOSpawnContext,\n CLEOSpawnResult,\n Provider,\n SpawnStatus,\n TokenResolution,\n} from './spawn-types.js';\n// === Status Registry (MUST be first \u2014 everything depends on this) ===\nexport {\n ADR_STATUSES,\n type AdrStatus,\n // Registry\n type EntityType,\n GATE_STATUSES,\n type GateStatus,\n isValidStatus,\n LIFECYCLE_PIPELINE_STATUSES,\n LIFECYCLE_STAGE_STATUSES,\n MANIFEST_STATUSES,\n type ManifestStatus,\n // Display icons\n PIPELINE_STATUS_ICONS,\n type PipelineStatus,\n SESSION_STATUSES,\n type SessionStatus,\n STAGE_STATUS_ICONS,\n STATUS_REGISTRY,\n type StageStatus,\n TASK_STATUS_SYMBOLS_ASCII,\n TASK_STATUS_SYMBOLS_UNICODE,\n // Constants\n TASK_STATUSES,\n // Derived types\n type TaskStatus,\n TERMINAL_PIPELINE_STATUSES,\n TERMINAL_STAGE_STATUSES,\n // Terminal state sets\n TERMINAL_TASK_STATUSES,\n} from './status-registry.js';\n// === Task Types ===\nexport type {\n CancelledTask,\n CompletedTask,\n EpicLifecycle,\n FileMeta,\n Phase,\n PhaseStatus,\n PhaseTransition,\n ProjectMeta,\n Release,\n ReleaseStatus,\n SessionNote,\n Task,\n TaskCreate,\n TaskFile,\n TaskOrigin,\n TaskPriority,\n TaskProvenance,\n TaskRelation,\n TaskSize,\n TaskType,\n TaskVerification,\n TaskWorkState,\n VerificationAgent,\n VerificationFailure,\n VerificationGate,\n} from './task.js';\n// === TaskRecord Types (string-widened for dispatch/LAFS) ===\nexport type {\n MinimalTaskRecord,\n TaskRecord,\n TaskRecordRelation,\n ValidationHistoryEntry,\n} from './task-record.js';\n// === Task Sync Types (provider-agnostic reconciliation) ===\nexport type {\n AdapterTaskSyncProvider,\n ConflictPolicy,\n ExternalTask,\n ExternalTaskStatus,\n ReconcileAction,\n ReconcileActionType,\n ReconcileOptions,\n ReconcileResult,\n SyncSessionState,\n} from './task-sync.js';\n// === Tessera Types ===\nexport type {\n TesseraInstantiationInput,\n TesseraTemplate,\n TesseraVariable,\n} from './tessera.js';\n// === TodoWrite Types (deprecated \u2014 use task-sync types) ===\nexport type {\n TodoWriteChange,\n TodoWriteChangeAction,\n TodoWriteChangeSet,\n TodoWriteItem,\n TodoWriteItemStatus,\n TodoWriteMergeResult,\n TodoWriteState,\n TodoWriteSyncSessionState,\n} from './todowrite.js';\nexport type { AdapterTransportProvider } from './transport.js';\n// === WarpChain Types ===\nexport type {\n ChainShape,\n ChainValidation,\n GateCheck,\n GateContract,\n GateName,\n GateResult,\n ProtocolType,\n WarpChain,\n WarpChainExecution,\n WarpChainInstance,\n WarpLink,\n WarpStage,\n} from './warp-chain.js';\n", "/**\n * Claude Code Spawn Provider\n *\n * Implements AdapterSpawnProvider for Claude Code CLI.\n * Migrated from src/core/spawn/adapters/claude-code-adapter.ts\n *\n * Uses the native `claude` CLI to spawn subagent processes with prompts\n * written to temporary files. Processes run detached and are tracked\n * by PID for listing and termination.\n *\n * @task T5240\n */\n\nimport { exec, spawn as nodeSpawn } from 'node:child_process';\nimport { unlink, writeFile } from 'node:fs/promises';\nimport { promisify } from 'node:util';\nimport type { AdapterSpawnProvider, SpawnContext, SpawnResult } from '@cleocode/contracts';\nimport { getErrorMessage } from '@cleocode/contracts';\n\nconst execAsync = promisify(exec);\n\n/** Internal tracking entry for a spawned process. */\ninterface TrackedProcess {\n pid: number;\n taskId: string;\n startTime: string;\n}\n\n/**\n * Spawn provider for Claude Code.\n *\n * Spawns detached Claude CLI processes for subagent execution.\n * Each spawn writes its prompt to a temporary file, then runs\n * `claude --allow-insecure --no-upgrade-check <tmpFile>` as a\n * detached, unref'd child process.\n */\nexport class ClaudeCodeSpawnProvider implements AdapterSpawnProvider {\n /** Map of instance IDs to tracked process info. */\n private processMap = new Map<string, TrackedProcess>();\n\n /**\n * Check if the Claude CLI is available in PATH.\n *\n * @returns true if `claude` is found via `which`\n */\n async canSpawn(): Promise<boolean> {\n try {\n await execAsync('which claude');\n return true;\n } catch {\n return false;\n }\n }\n\n /**\n * Spawn a subagent via Claude CLI.\n *\n * Writes the prompt to a temporary file and spawns a detached Claude\n * process. The process runs independently of the parent.\n *\n * @param context - Spawn context with taskId, prompt, and options\n * @returns Spawn result with instance ID and status\n */\n async spawn(context: SpawnContext): Promise<SpawnResult> {\n const instanceId = `claude-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;\n const startTime = new Date().toISOString();\n let tmpFile: string | undefined;\n\n try {\n tmpFile = `/tmp/claude-spawn-${instanceId}.txt`;\n await writeFile(tmpFile, context.prompt, 'utf-8');\n\n const args = ['--allow-insecure', '--no-upgrade-check', tmpFile];\n const spawnOpts: Parameters<typeof nodeSpawn>[2] = {\n detached: true,\n stdio: 'ignore',\n };\n\n if (context.workingDirectory) {\n spawnOpts.cwd = context.workingDirectory;\n }\n\n const child = nodeSpawn('claude', args, spawnOpts);\n child.unref();\n\n if (child.pid) {\n this.processMap.set(instanceId, {\n pid: child.pid,\n taskId: context.taskId,\n startTime,\n });\n }\n\n const capturedTmpFile = tmpFile;\n child.on('exit', async () => {\n this.processMap.delete(instanceId);\n try {\n await unlink(capturedTmpFile);\n } catch {\n // Ignore cleanup errors\n }\n });\n\n return {\n instanceId,\n taskId: context.taskId,\n providerId: 'claude-code',\n status: 'running',\n startTime,\n };\n } catch (error) {\n // Log spawn failure for debugging\n console.error(`[ClaudeCodeSpawnProvider] Failed to spawn: ${getErrorMessage(error)}`);\n\n if (tmpFile) {\n try {\n await unlink(tmpFile);\n } catch {\n // Ignore cleanup errors\n }\n }\n\n return {\n instanceId,\n taskId: context.taskId,\n providerId: 'claude-code',\n status: 'failed',\n startTime,\n endTime: new Date().toISOString(),\n error: getErrorMessage(error),\n };\n }\n }\n\n /**\n * List currently running Claude subagent processes.\n *\n * Checks each tracked process via kill(pid, 0) to verify it is still alive.\n * Dead processes are automatically cleaned from the tracking map.\n *\n * @returns Array of spawn results for running processes\n */\n async listRunning(): Promise<SpawnResult[]> {\n const running: SpawnResult[] = [];\n\n for (const [instanceId, tracked] of this.processMap.entries()) {\n try {\n process.kill(tracked.pid, 0);\n running.push({\n instanceId,\n taskId: tracked.taskId,\n providerId: 'claude-code',\n status: 'running',\n startTime: tracked.startTime,\n });\n } catch {\n this.processMap.delete(instanceId);\n }\n }\n\n return running;\n }\n\n /**\n * Terminate a running spawn by instance ID.\n *\n * Sends SIGTERM to the tracked process. If the process is not found\n * or has already exited, this is a no-op.\n *\n * @param instanceId - ID of the spawn instance to terminate\n */\n async terminate(instanceId: string): Promise<void> {\n const tracked = this.processMap.get(instanceId);\n if (!tracked) return;\n\n try {\n process.kill(tracked.pid, 'SIGTERM');\n } catch {\n // Process may have already exited\n }\n this.processMap.delete(instanceId);\n }\n}\n", "/**\n * Claude Code TaskSyncProvider \u2014 bridges Claude's TodoWrite format\n * to the provider-agnostic reconciliation system.\n *\n * All Claude Code / TodoWrite-specific parsing lives here.\n * The core reconciliation engine never sees TodoWrite formats.\n *\n * @task T5800\n */\n\nimport { readFile, rm, stat } from 'node:fs/promises';\nimport { join } from 'node:path';\n\nimport type {\n AdapterTaskSyncProvider,\n ExternalTask,\n ExternalTaskStatus,\n} from '@cleocode/contracts';\n\n// ---------------------------------------------------------------------------\n// TodoWrite native types (Claude-specific, never exposed beyond this file)\n// ---------------------------------------------------------------------------\n\ninterface TodoWriteItem {\n content: string;\n status: 'pending' | 'in_progress' | 'completed';\n activeForm?: string;\n}\n\ninterface TodoWriteState {\n todos: TodoWriteItem[];\n}\n\n// ---------------------------------------------------------------------------\n// Parsing helpers\n// ---------------------------------------------------------------------------\n\n/**\n * Parse a CLEO task ID from TodoWrite content prefix: \"[T001] ...\" -> \"T001\".\n */\nfunction parseTaskId(content: string): string | null {\n const match = content.match(/^\\[T(\\d+)\\]/);\n return match ? `T${match[1]}` : null;\n}\n\n/**\n * Strip ID and status prefixes from content to extract the clean title.\n */\nfunction stripPrefixes(content: string): string {\n return content\n .replace(/^\\[T\\d+\\]\\s*/, '')\n .replace(/^\\[!\\]\\s*/, '')\n .replace(/^\\[BLOCKED\\]\\s*/, '');\n}\n\n/**\n * Map TodoWrite status to normalized ExternalTaskStatus.\n */\nfunction mapStatus(twStatus: TodoWriteItem['status']): ExternalTaskStatus {\n switch (twStatus) {\n case 'completed':\n return 'completed';\n case 'in_progress':\n return 'active';\n case 'pending':\n return 'pending';\n default:\n return 'pending';\n }\n}\n\n/**\n * Resolve the TodoWrite state file path.\n * Claude Code writes its TodoWrite state to a known location.\n */\nfunction getTodoWriteFilePath(projectDir: string): string {\n return join(projectDir, '.cleo', 'sync', 'todowrite-state.json');\n}\n\n// ---------------------------------------------------------------------------\n// Provider implementation\n// ---------------------------------------------------------------------------\n\n/**\n * Claude Code TaskSyncProvider.\n *\n * Reads Claude's TodoWrite JSON state, parses [T001]-prefixed task IDs\n * and status, and returns normalized ExternalTask[].\n *\n * Optional: accepts a custom file path for testing.\n */\nexport class ClaudeCodeTaskSyncProvider implements AdapterTaskSyncProvider {\n private readonly customFilePath?: string;\n\n constructor(options?: { filePath?: string }) {\n this.customFilePath = options?.filePath;\n }\n\n async getExternalTasks(projectDir: string): Promise<ExternalTask[]> {\n const filePath = this.customFilePath ?? getTodoWriteFilePath(projectDir);\n\n // Check file exists\n try {\n await stat(filePath);\n } catch {\n // No TodoWrite state \u2014 return empty (no tasks to sync)\n return [];\n }\n\n // Parse the TodoWrite JSON\n const raw = await readFile(filePath, 'utf-8');\n let state: TodoWriteState;\n try {\n state = JSON.parse(raw) as TodoWriteState;\n } catch {\n return []; // Malformed JSON \u2014 treat as empty\n }\n\n if (!state.todos || !Array.isArray(state.todos)) {\n return [];\n }\n\n const tasks: ExternalTask[] = [];\n let syntheticIndex = 0;\n\n for (const item of state.todos) {\n const cleoTaskId = parseTaskId(item.content);\n const title = cleoTaskId ? stripPrefixes(item.content).trim() : item.content.trim();\n\n if (!title) continue;\n\n tasks.push({\n externalId: cleoTaskId ?? `tw-new-${syntheticIndex++}`,\n cleoTaskId,\n title,\n status: mapStatus(item.status),\n providerMeta: {\n source: 'todowrite',\n activeForm: item.activeForm,\n rawContent: item.content,\n },\n });\n }\n\n return tasks;\n }\n\n async cleanup(projectDir: string): Promise<void> {\n const filePath = this.customFilePath ?? getTodoWriteFilePath(projectDir);\n try {\n await rm(filePath);\n } catch {\n // File may not exist \u2014 that's fine\n }\n }\n}\n", "/**\n * Transport provider for the Claude Code adapter.\n *\n * Implements AdapterTransportProvider to supply Claude Code's\n * native inter-agent transport mechanism.\n *\n * @task T5240\n */\n\nimport type { AdapterTransportProvider } from '@cleocode/contracts';\n\nexport class ClaudeCodeTransportProvider implements AdapterTransportProvider {\n readonly transportName = 'claude-code';\n\n createTransport(): unknown {\n // Returns null \u2014 actual transport creation is handled by the signaldock factory\n // which checks for this adapter's transport capability.\n // Full wiring will be completed in Phase 5.\n return null;\n }\n}\n", "/**\n * Claude Code Adapter\n *\n * Main CLEOProviderAdapter implementation for Anthropic's Claude Code CLI.\n * Provides spawn, hooks, and install capabilities for CLEO integration.\n *\n * @task T5240\n */\n\nimport { exec } from 'node:child_process';\nimport { existsSync } from 'node:fs';\nimport { homedir } from 'node:os';\nimport { join } from 'node:path';\nimport { promisify } from 'node:util';\nimport type {\n AdapterCapabilities,\n AdapterHealthStatus,\n CLEOProviderAdapter,\n} from '@cleocode/contracts';\nimport { ClaudeCodeContextMonitorProvider } from './context-monitor.js';\nimport { ClaudeCodeHookProvider } from './hooks.js';\nimport { ClaudeCodeInstallProvider } from './install.js';\nimport { ClaudeCodePathProvider } from './paths.js';\nimport { ClaudeCodeSpawnProvider } from './spawn.js';\nimport { ClaudeCodeTaskSyncProvider } from './task-sync.js';\nimport { ClaudeCodeTransportProvider } from './transport.js';\n\nconst execAsync = promisify(exec);\n\n/**\n * CLEO provider adapter for Anthropic Claude Code CLI.\n *\n * Bridges CLEO's adapter system with Claude Code's native capabilities:\n * - Hooks: Maps Claude Code events (SessionStart, PostToolUse, etc.) to CAAMP events\n * - Spawn: Launches subagent processes via the `claude` CLI\n * - Install: Registers MCP server, instruction files, and brain observation plugin\n */\nexport class ClaudeCodeAdapter implements CLEOProviderAdapter {\n readonly id = 'claude-code';\n readonly name = 'Claude Code';\n readonly version = '1.0.0';\n\n capabilities: AdapterCapabilities = {\n supportsHooks: true,\n supportedHookEvents: [\n 'onSessionStart',\n 'onSessionEnd',\n 'onToolStart',\n 'onToolComplete',\n 'onError',\n ],\n supportsSpawn: true,\n supportsInstall: true,\n supportsMcp: true,\n supportsInstructionFiles: true,\n instructionFilePattern: 'CLAUDE.md',\n supportsContextMonitor: true,\n supportsStatusline: true,\n supportsProviderPaths: true,\n supportsTransport: true,\n supportsTaskSync: true,\n };\n\n hooks: ClaudeCodeHookProvider;\n spawn: ClaudeCodeSpawnProvider;\n install: ClaudeCodeInstallProvider;\n paths: ClaudeCodePathProvider;\n contextMonitor: ClaudeCodeContextMonitorProvider;\n transport: ClaudeCodeTransportProvider;\n taskSync: ClaudeCodeTaskSyncProvider;\n\n private projectDir: string | null = null;\n private initialized = false;\n\n constructor() {\n this.hooks = new ClaudeCodeHookProvider();\n this.spawn = new ClaudeCodeSpawnProvider();\n this.install = new ClaudeCodeInstallProvider();\n this.paths = new ClaudeCodePathProvider();\n this.contextMonitor = new ClaudeCodeContextMonitorProvider();\n this.transport = new ClaudeCodeTransportProvider();\n this.taskSync = new ClaudeCodeTaskSyncProvider();\n }\n\n /**\n * Initialize the adapter for a given project directory.\n *\n * Validates the environment by checking for the Claude CLI\n * and Claude Code configuration directory.\n *\n * @param projectDir - Root directory of the project\n */\n async initialize(projectDir: string): Promise<void> {\n this.projectDir = projectDir;\n this.initialized = true;\n }\n\n /**\n * Dispose the adapter and clean up resources.\n *\n * Unregisters hooks and releases any tracked state.\n */\n async dispose(): Promise<void> {\n if (this.hooks.isRegistered()) {\n await this.hooks.unregisterNativeHooks();\n }\n this.initialized = false;\n this.projectDir = null;\n }\n\n /**\n * Run a health check to verify Claude Code is accessible.\n *\n * Checks:\n * 1. Adapter has been initialized\n * 2. Claude CLI is available in PATH\n * 3. ~/.claude/ configuration directory exists\n *\n * @returns Health status with details about each check\n */\n async healthCheck(): Promise<AdapterHealthStatus> {\n const details: Record<string, unknown> = {};\n\n if (!this.initialized) {\n return {\n healthy: false,\n provider: this.id,\n details: { error: 'Adapter not initialized' },\n };\n }\n\n // Check Claude CLI availability\n let cliAvailable = false;\n try {\n const { stdout } = await execAsync('which claude');\n cliAvailable = stdout.trim().length > 0;\n details.cliPath = stdout.trim();\n } catch {\n details.cliAvailable = false;\n }\n\n // Check for Claude Code config directory\n const claudeConfigDir = join(homedir(), '.claude');\n const configExists = existsSync(claudeConfigDir);\n details.configDirExists = configExists;\n\n // Check for CLAUDE_CODE_ENTRYPOINT env var\n const entrypointSet = process.env.CLAUDE_CODE_ENTRYPOINT !== undefined;\n details.entrypointEnvSet = entrypointSet;\n\n // Healthy if CLI is available (primary requirement)\n const healthy = cliAvailable;\n details.cliAvailable = cliAvailable;\n\n return {\n healthy,\n provider: this.id,\n details,\n };\n }\n\n /**\n * Check whether the adapter has been initialized.\n */\n isInitialized(): boolean {\n return this.initialized;\n }\n\n /**\n * Get the project directory this adapter was initialized with.\n */\n getProjectDir(): string | null {\n return this.projectDir;\n }\n}\n", "/**\n * Statusline integration for the Claude Code adapter.\n *\n * Implements the statusline portion of AdapterContextMonitorProvider.\n * Checks and configures Claude Code status line for context monitoring.\n *\n * @task T5240\n */\n\nimport { existsSync, readFileSync } from 'node:fs';\nimport { homedir } from 'node:os';\nimport { join } from 'node:path';\n\ntype StatuslineStatus = 'configured' | 'not_configured' | 'custom_no_cleo' | 'no_settings';\n\n/**\n * Get the path to Claude Code's settings.json.\n * Respects CLAUDE_SETTINGS env var, defaults to ~/.claude/settings.json.\n */\nfunction getClaudeSettingsPath(): string {\n return (\n process.env['CLAUDE_SETTINGS'] ??\n join(process.env['CLAUDE_HOME'] ?? join(homedir(), '.claude'), 'settings.json')\n );\n}\n\n/**\n * Check if statusline integration is configured.\n * Returns the current integration status.\n */\nexport function checkStatuslineIntegration(): StatuslineStatus {\n const settingsPath = getClaudeSettingsPath();\n\n if (!existsSync(settingsPath)) return 'no_settings';\n\n try {\n const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));\n const statusLine = settings.statusLine;\n\n if (!statusLine?.type) return 'not_configured';\n if (statusLine.type !== 'command') return 'custom_no_cleo';\n\n const cmd = statusLine.command ?? '';\n\n // Check if it's a CLEO statusline integration\n if (\n cmd.includes('context-monitor.sh') ||\n cmd.includes('cleo-statusline') ||\n cmd.includes('.context-state.json') ||\n cmd.includes('context-states')\n ) {\n return 'configured';\n }\n\n // Check if the script writes to CLEO state file\n const scriptPath = cmd.startsWith('~') ? cmd.replace('~', homedir()) : cmd;\n\n if (existsSync(scriptPath)) {\n try {\n const content = readFileSync(scriptPath, 'utf-8');\n if (content.includes('context-state.json')) return 'configured';\n } catch {\n /* unreadable */\n }\n }\n\n return 'custom_no_cleo';\n } catch {\n return 'no_settings';\n }\n}\n\n/**\n * Get the statusline setup command for Claude Code settings.\n */\nexport function getStatuslineConfig(cleoHome: string): Record<string, unknown> {\n return {\n statusLine: {\n type: 'command',\n command: join(cleoHome, 'lib', 'session', 'context-monitor.sh'),\n },\n };\n}\n\n/**\n * Get human-readable setup instructions.\n */\nexport function getSetupInstructions(cleoHome: string): string {\n const settingsPath = getClaudeSettingsPath();\n\n return [\n 'To enable context monitoring, add to your Claude Code settings:',\n `File: ${settingsPath}`,\n '',\n JSON.stringify(getStatuslineConfig(cleoHome), null, 2),\n '',\n 'This enables real-time context window tracking in the CLI.',\n ].join('\\n');\n}\n", "/**\n * Claude Code provider adapter.\n *\n * CLEO provider adapter for Anthropic Claude Code CLI.\n * Default export is the adapter class for dynamic loading by AdapterManager.\n *\n * @task T5240\n */\n\nimport { ClaudeCodeAdapter } from './adapter.js';\n\nexport { ClaudeCodeAdapter } from './adapter.js';\nexport { ClaudeCodeContextMonitorProvider } from './context-monitor.js';\nexport { ClaudeCodeHookProvider } from './hooks.js';\nexport { ClaudeCodeInstallProvider } from './install.js';\nexport { ClaudeCodePathProvider } from './paths.js';\nexport { ClaudeCodeSpawnProvider } from './spawn.js';\nexport {\n checkStatuslineIntegration,\n getSetupInstructions,\n getStatuslineConfig,\n} from './statusline.js';\nexport { ClaudeCodeTransportProvider } from './transport.js';\n\nexport default ClaudeCodeAdapter;\n\n/**\n * Factory function for creating adapter instances.\n * Used by AdapterManager's dynamic import fallback.\n */\nexport function createAdapter(): ClaudeCodeAdapter {\n return new ClaudeCodeAdapter();\n}\n", "/**\n * Cursor Hook Provider\n *\n * Cursor does not have a native hook/event system for external tools.\n * This provider returns null for all event mappings and marks hooks\n * as unsupported. It exists to satisfy the AdapterHookProvider contract\n * so the adapter can be used uniformly by the AdapterManager.\n *\n * @task T5240\n */\n\nimport type { AdapterHookProvider } from '@cleocode/contracts';\n\n/**\n * Hook provider for Cursor (stub).\n *\n * Cursor lacks a hook-based lifecycle event system. All mapping\n * operations return null. Registration is a no-op.\n */\nexport class CursorHookProvider implements AdapterHookProvider {\n private registered = false;\n\n /**\n * Map a provider event name to a CAAMP hook event name.\n *\n * Always returns null since Cursor does not emit hook events.\n *\n * @param _providerEvent - Ignored; Cursor has no hook events\n * @returns null (no mapping available)\n */\n mapProviderEvent(_providerEvent: string): string | null {\n return null;\n }\n\n /**\n * Register native hooks for a project.\n *\n * No-op for Cursor since it has no hook system.\n *\n * @param _projectDir - Ignored\n */\n async registerNativeHooks(_projectDir: string): Promise<void> {\n this.registered = true;\n }\n\n /**\n * Unregister native hooks.\n *\n * No-op for Cursor since it has no hook system.\n */\n async unregisterNativeHooks(): Promise<void> {\n this.registered = false;\n }\n\n /**\n * Check whether hooks have been registered.\n */\n isRegistered(): boolean {\n return this.registered;\n }\n}\n", "/**\n * Cursor Install Provider\n *\n * Handles CLEO installation into Cursor environments:\n * - Registers CLEO MCP server in .cursor/mcp.json\n * - Ensures .cursorrules has CLEO @-references (legacy format)\n * - Creates .cursor/rules/cleo.mdc with CLEO references (modern format)\n *\n * Cursor supports two instruction file formats:\n * 1. Legacy: .cursorrules (flat file, project root)\n * 2. Modern: .cursor/rules/*.mdc (MDC format, per-rule files)\n *\n * This provider writes to both for maximum compatibility.\n *\n * @task T5240\n */\n\nimport { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';\nimport { join } from 'node:path';\nimport type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';\n\n/** Lines that should appear in instruction files to reference CLEO. */\nconst INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];\n\n/** MCP server registration key used in Cursor config. */\nconst MCP_SERVER_KEY = 'cleo';\n\n/**\n * Install provider for Cursor.\n *\n * Manages CLEO's integration with Cursor by:\n * 1. Registering the CLEO MCP server in .cursor/mcp.json\n * 2. Creating/updating .cursorrules with @-references (legacy)\n * 3. Creating .cursor/rules/cleo.mdc with @-references (modern)\n */\nexport class CursorInstallProvider implements AdapterInstallProvider {\n private installedProjectDir: string | null = null;\n\n /**\n * Install CLEO into a Cursor project.\n *\n * @param options - Installation options including project directory and MCP server path\n * @returns Result describing what was installed\n */\n async install(options: InstallOptions): Promise<InstallResult> {\n const { projectDir, mcpServerPath } = options;\n const installedAt = new Date().toISOString();\n let instructionFileUpdated = false;\n let mcpRegistered = false;\n const details: Record<string, unknown> = {};\n\n // Step 1: Register MCP server in .cursor/mcp.json\n if (mcpServerPath) {\n mcpRegistered = this.registerMcpServer(projectDir, mcpServerPath);\n if (mcpRegistered) {\n details.mcpConfigPath = join(projectDir, '.cursor', 'mcp.json');\n }\n }\n\n // Step 2: Ensure instruction files have @-references\n instructionFileUpdated = this.updateInstructionFiles(projectDir);\n if (instructionFileUpdated) {\n details.instructionFiles = this.getUpdatedFileList(projectDir);\n }\n\n this.installedProjectDir = projectDir;\n\n return {\n success: true,\n installedAt,\n instructionFileUpdated,\n mcpRegistered,\n details,\n };\n }\n\n /**\n * Uninstall CLEO from the current Cursor project.\n *\n * Removes the MCP server registration from .cursor/mcp.json.\n * Does not remove instruction file references (they are harmless if CLEO is not present).\n */\n async uninstall(): Promise<void> {\n if (!this.installedProjectDir) return;\n\n const mcpPath = join(this.installedProjectDir, '.cursor', 'mcp.json');\n if (existsSync(mcpPath)) {\n try {\n const raw = readFileSync(mcpPath, 'utf-8');\n const config = JSON.parse(raw) as Record<string, unknown>;\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n delete mcpServers[MCP_SERVER_KEY];\n writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n }\n } catch {\n // Ignore errors during uninstall\n }\n }\n\n this.installedProjectDir = null;\n }\n\n /**\n * Check whether CLEO is installed in the current environment.\n *\n * Checks for MCP server registered in .cursor/mcp.json.\n */\n async isInstalled(): Promise<boolean> {\n const mcpPath = join(process.cwd(), '.cursor', 'mcp.json');\n if (existsSync(mcpPath)) {\n try {\n const config = JSON.parse(readFileSync(mcpPath, 'utf-8'));\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n return true;\n }\n } catch {\n // Fall through\n }\n }\n\n return false;\n }\n\n /**\n * Ensure instruction files contain @-references to CLEO.\n *\n * Updates .cursorrules (legacy) and creates .cursor/rules/cleo.mdc (modern).\n *\n * @param projectDir - Project root directory\n */\n async ensureInstructionReferences(projectDir: string): Promise<void> {\n this.updateInstructionFiles(projectDir);\n }\n\n /**\n * Register the CLEO MCP server in .cursor/mcp.json.\n *\n * Cursor stores MCP server configuration in .cursor/mcp.json\n * under the mcpServers key.\n *\n * @returns true if registration was performed or updated\n */\n private registerMcpServer(projectDir: string, mcpServerPath: string): boolean {\n const cursorDir = join(projectDir, '.cursor');\n const mcpPath = join(cursorDir, 'mcp.json');\n let config: Record<string, unknown> = {};\n\n mkdirSync(cursorDir, { recursive: true });\n\n if (existsSync(mcpPath)) {\n try {\n config = JSON.parse(readFileSync(mcpPath, 'utf-8'));\n } catch {\n // Start fresh on parse error\n }\n }\n\n if (!config.mcpServers || typeof config.mcpServers !== 'object') {\n config.mcpServers = {};\n }\n\n const mcpServers = config.mcpServers as Record<string, unknown>;\n mcpServers[MCP_SERVER_KEY] = {\n command: 'node',\n args: [mcpServerPath],\n };\n\n writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n return true;\n }\n\n /**\n * Update instruction files with CLEO @-references.\n *\n * Handles both legacy (.cursorrules) and modern (.cursor/rules/cleo.mdc) formats.\n *\n * @returns true if any file was created or modified\n */\n private updateInstructionFiles(projectDir: string): boolean {\n let updated = false;\n\n // Update legacy .cursorrules if it exists\n if (this.updateLegacyRules(projectDir)) {\n updated = true;\n }\n\n // Create/update modern .cursor/rules/cleo.mdc\n if (this.updateModernRules(projectDir)) {\n updated = true;\n }\n\n return updated;\n }\n\n /**\n * Update legacy .cursorrules file with @-references.\n * Only modifies the file if it already exists (does not create it).\n *\n * @returns true if the file was modified\n */\n private updateLegacyRules(projectDir: string): boolean {\n const rulesPath = join(projectDir, '.cursorrules');\n if (!existsSync(rulesPath)) {\n return false;\n }\n\n let content = readFileSync(rulesPath, 'utf-8');\n const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));\n\n if (missingRefs.length === 0) {\n return false;\n }\n\n const separator = content.endsWith('\\n') ? '' : '\\n';\n content = content + separator + missingRefs.join('\\n') + '\\n';\n writeFileSync(rulesPath, content, 'utf-8');\n return true;\n }\n\n /**\n * Create or update .cursor/rules/cleo.mdc with CLEO references.\n *\n * MDC (Markdown Component) format is Cursor's modern rule file format.\n * Each .mdc file in .cursor/rules/ is loaded as a rule set.\n *\n * @returns true if the file was created or modified\n */\n private updateModernRules(projectDir: string): boolean {\n const rulesDir = join(projectDir, '.cursor', 'rules');\n const mdcPath = join(rulesDir, 'cleo.mdc');\n\n const expectedContent = [\n '---',\n 'description: CLEO task management protocol references',\n 'globs: \"**/*\"',\n 'alwaysApply: true',\n '---',\n '',\n ...INSTRUCTION_REFERENCES,\n '',\n ].join('\\n');\n\n if (existsSync(mdcPath)) {\n const existing = readFileSync(mdcPath, 'utf-8');\n if (existing === expectedContent) {\n return false;\n }\n }\n\n mkdirSync(rulesDir, { recursive: true });\n writeFileSync(mdcPath, expectedContent, 'utf-8');\n return true;\n }\n\n /**\n * Get list of instruction files that were updated.\n */\n private getUpdatedFileList(projectDir: string): string[] {\n const files: string[] = [];\n if (existsSync(join(projectDir, '.cursorrules'))) {\n files.push(join(projectDir, '.cursorrules'));\n }\n files.push(join(projectDir, '.cursor', 'rules', 'cleo.mdc'));\n return files;\n }\n}\n", "/**\n * Cursor Adapter\n *\n * Main CLEOProviderAdapter implementation for Cursor AI code editor.\n * Provides install capabilities for CLEO integration. Hooks and spawn\n * are not supported since Cursor lacks CLI-based lifecycle events\n * and subagent spawning.\n *\n * @task T5240\n */\n\nimport { existsSync } from 'node:fs';\nimport { join } from 'node:path';\nimport type {\n AdapterCapabilities,\n AdapterHealthStatus,\n CLEOProviderAdapter,\n} from '@cleocode/contracts';\nimport { CursorHookProvider } from './hooks.js';\nimport { CursorInstallProvider } from './install.js';\n\n/**\n * CLEO provider adapter for Cursor AI code editor.\n *\n * Bridges CLEO's adapter system with Cursor's capabilities:\n * - Install: Registers MCP server in .cursor/mcp.json and manages rule files\n * - Hooks: Stub provider (Cursor has no lifecycle event system)\n * - Spawn: Not supported (Cursor has no CLI for subagent spawning)\n */\nexport class CursorAdapter implements CLEOProviderAdapter {\n readonly id = 'cursor';\n readonly name = 'Cursor';\n readonly version = '1.0.0';\n\n capabilities: AdapterCapabilities = {\n supportsHooks: false,\n supportedHookEvents: [],\n supportsSpawn: false,\n supportsInstall: true,\n supportsMcp: true,\n supportsInstructionFiles: true,\n instructionFilePattern: '.cursor/rules/*.mdc',\n supportsContextMonitor: false,\n supportsStatusline: false,\n supportsProviderPaths: true,\n supportsTransport: false,\n supportsTaskSync: false,\n };\n\n hooks: CursorHookProvider;\n install: CursorInstallProvider;\n\n private projectDir: string | null = null;\n private initialized = false;\n\n constructor() {\n this.hooks = new CursorHookProvider();\n this.install = new CursorInstallProvider();\n }\n\n /**\n * Initialize the adapter for a given project directory.\n *\n * @param projectDir - Root directory of the project\n */\n async initialize(projectDir: string): Promise<void> {\n this.projectDir = projectDir;\n this.initialized = true;\n }\n\n /**\n * Dispose the adapter and clean up resources.\n */\n async dispose(): Promise<void> {\n if (this.hooks.isRegistered()) {\n await this.hooks.unregisterNativeHooks();\n }\n this.initialized = false;\n this.projectDir = null;\n }\n\n /**\n * Run a health check to verify Cursor is accessible.\n *\n * Checks:\n * 1. Adapter has been initialized\n * 2. .cursor/ configuration directory exists in the project\n * 3. CURSOR_EDITOR env var is set\n *\n * @returns Health status with details about each check\n */\n async healthCheck(): Promise<AdapterHealthStatus> {\n const details: Record<string, unknown> = {};\n\n if (!this.initialized) {\n return {\n healthy: false,\n provider: this.id,\n details: { error: 'Adapter not initialized' },\n };\n }\n\n // Check for Cursor config directory in the project\n let configExists = false;\n if (this.projectDir) {\n const cursorConfigDir = join(this.projectDir, '.cursor');\n configExists = existsSync(cursorConfigDir);\n details.configDirExists = configExists;\n }\n\n // Check for CURSOR_EDITOR env var\n const editorEnvSet = process.env.CURSOR_EDITOR !== undefined;\n details.editorEnvSet = editorEnvSet;\n\n // Check for legacy .cursorrules file\n if (this.projectDir) {\n const legacyRulesExist = existsSync(join(this.projectDir, '.cursorrules'));\n details.legacyRulesExist = legacyRulesExist;\n }\n\n // Healthy if we detect Cursor presence (config dir or env var)\n const healthy = configExists || editorEnvSet;\n details.detected = healthy;\n\n return {\n healthy,\n provider: this.id,\n details,\n };\n }\n\n /**\n * Check whether the adapter has been initialized.\n */\n isInitialized(): boolean {\n return this.initialized;\n }\n\n /**\n * Get the project directory this adapter was initialized with.\n */\n getProjectDir(): string | null {\n return this.projectDir;\n }\n}\n", "/**\n * Cursor provider adapter.\n *\n * CLEO provider adapter for Cursor AI code editor.\n * Default export is the adapter class for dynamic loading by AdapterManager.\n *\n * @task T5240\n */\n\nimport { CursorAdapter } from './adapter.js';\n\nexport { CursorAdapter } from './adapter.js';\nexport { CursorHookProvider } from './hooks.js';\nexport { CursorInstallProvider } from './install.js';\n\nexport default CursorAdapter;\n\n/**\n * Factory function for creating adapter instances.\n * Used by AdapterManager's dynamic import fallback.\n */\nexport function createAdapter(): CursorAdapter {\n return new CursorAdapter();\n}\n", "/**\n * OpenCode Hook Provider\n *\n * Maps OpenCode's native hook events to CAAMP hook events.\n * OpenCode supports 6 of 8 CAAMP events through its agent/hook system.\n *\n * OpenCode event mapping:\n * - session.start -> onSessionStart\n * - session.end -> onSessionEnd\n * - tool.start -> onToolStart\n * - tool.complete -> onToolComplete\n * - error -> onError\n * - prompt.submit -> onPromptSubmit\n *\n * @task T5240\n */\n\nimport type { AdapterHookProvider } from '@cleocode/contracts';\n\n/**\n * Mapping from OpenCode native event names to CAAMP event names.\n *\n * OpenCode uses dot-delimited event names (e.g. \"session.start\")\n * while CAAMP uses camelCase (e.g. \"onSessionStart\").\n */\nconst OPENCODE_EVENT_MAP: Record<string, string> = {\n 'session.start': 'onSessionStart',\n 'session.end': 'onSessionEnd',\n 'tool.start': 'onToolStart',\n 'tool.complete': 'onToolComplete',\n error: 'onError',\n 'prompt.submit': 'onPromptSubmit',\n};\n\n/**\n * Hook provider for OpenCode.\n *\n * OpenCode registers hooks via its configuration system at\n * .opencode/config.json. Hook handlers are defined as shell commands\n * or script paths that execute when the corresponding event fires.\n *\n * Since hooks are registered through the config system (managed by\n * the install provider), registerNativeHooks and unregisterNativeHooks\n * track registration state without performing filesystem operations.\n */\nexport class OpenCodeHookProvider implements AdapterHookProvider {\n private registered = false;\n\n /**\n * Map an OpenCode native event name to a CAAMP hook event name.\n *\n * @param providerEvent - OpenCode event name (e.g. \"session.start\", \"tool.complete\")\n * @returns CAAMP event name or null if unmapped\n */\n mapProviderEvent(providerEvent: string): string | null {\n return OPENCODE_EVENT_MAP[providerEvent] ?? null;\n }\n\n /**\n * Register native hooks for a project.\n *\n * For OpenCode, hooks are registered via the config system\n * (.opencode/config.json), which is handled by the install provider.\n * This method marks hooks as registered without performing\n * filesystem operations.\n *\n * @param _projectDir - Project directory (unused; config manages registration)\n */\n async registerNativeHooks(_projectDir: string): Promise<void> {\n this.registered = true;\n }\n\n /**\n * Unregister native hooks.\n *\n * For OpenCode, this is a no-op since hooks are managed through\n * the config system. Unregistration happens via the install\n * provider's uninstall method.\n */\n async unregisterNativeHooks(): Promise<void> {\n this.registered = false;\n }\n\n /**\n * Check whether hooks have been registered via registerNativeHooks.\n */\n isRegistered(): boolean {\n return this.registered;\n }\n\n /**\n * Get the full event mapping for introspection/debugging.\n */\n getEventMap(): Readonly<Record<string, string>> {\n return { ...OPENCODE_EVENT_MAP };\n }\n}\n", "/**\n * OpenCode Install Provider\n *\n * Handles CLEO installation into OpenCode environments:\n * - Registers CLEO MCP server in .opencode/config.json\n * - Ensures AGENTS.md has CLEO @-references\n *\n * @task T5240\n */\n\nimport { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';\nimport { join } from 'node:path';\nimport type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';\n\n/** Lines that should appear in AGENTS.md to reference CLEO. */\nconst INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];\n\n/** MCP server registration key used in OpenCode config. */\nconst MCP_SERVER_KEY = 'cleo';\n\n/**\n * Install provider for OpenCode.\n *\n * Manages CLEO's integration with OpenCode by:\n * 1. Registering the CLEO MCP server in .opencode/config.json\n * 2. Ensuring AGENTS.md contains @-references to CLEO instruction files\n */\nexport class OpenCodeInstallProvider implements AdapterInstallProvider {\n private installedProjectDir: string | null = null;\n\n /**\n * Install CLEO into an OpenCode project.\n *\n * @param options - Installation options including project directory and MCP server path\n * @returns Result describing what was installed\n */\n async install(options: InstallOptions): Promise<InstallResult> {\n const { projectDir, mcpServerPath } = options;\n const installedAt = new Date().toISOString();\n let instructionFileUpdated = false;\n let mcpRegistered = false;\n const details: Record<string, unknown> = {};\n\n // Step 1: Register MCP server in .opencode/config.json\n if (mcpServerPath) {\n mcpRegistered = this.registerMcpServer(projectDir, mcpServerPath);\n if (mcpRegistered) {\n details.mcpConfigPath = join(projectDir, '.opencode', 'config.json');\n }\n }\n\n // Step 2: Ensure AGENTS.md has @-references\n instructionFileUpdated = this.updateInstructionFile(projectDir);\n if (instructionFileUpdated) {\n details.instructionFile = join(projectDir, 'AGENTS.md');\n }\n\n this.installedProjectDir = projectDir;\n\n return {\n success: true,\n installedAt,\n instructionFileUpdated,\n mcpRegistered,\n details,\n };\n }\n\n /**\n * Uninstall CLEO from the current OpenCode project.\n *\n * Removes the MCP server registration from .opencode/config.json.\n * Does not remove AGENTS.md references (they are harmless if CLEO is not present).\n */\n async uninstall(): Promise<void> {\n if (!this.installedProjectDir) return;\n\n const configPath = join(this.installedProjectDir, '.opencode', 'config.json');\n if (existsSync(configPath)) {\n try {\n const raw = readFileSync(configPath, 'utf-8');\n const config = JSON.parse(raw) as Record<string, unknown>;\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n delete mcpServers[MCP_SERVER_KEY];\n writeFileSync(configPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n }\n } catch {\n // Ignore errors during uninstall\n }\n }\n\n this.installedProjectDir = null;\n }\n\n /**\n * Check whether CLEO is installed in the current environment.\n *\n * Checks for MCP server registered in .opencode/config.json.\n * Returns true if the CLEO MCP server entry is found.\n */\n async isInstalled(): Promise<boolean> {\n // Check current directory for .opencode/config.json with cleo server\n const configPath = join(process.cwd(), '.opencode', 'config.json');\n if (existsSync(configPath)) {\n try {\n const config = JSON.parse(readFileSync(configPath, 'utf-8'));\n const mcpServers = config.mcpServers as Record<string, unknown> | undefined;\n if (mcpServers && MCP_SERVER_KEY in mcpServers) {\n return true;\n }\n } catch {\n // Fall through\n }\n }\n\n return false;\n }\n\n /**\n * Ensure AGENTS.md contains @-references to CLEO instruction files.\n *\n * Creates AGENTS.md if it does not exist. Appends any missing references.\n *\n * @param projectDir - Project root directory\n */\n async ensureInstructionReferences(projectDir: string): Promise<void> {\n this.updateInstructionFile(projectDir);\n }\n\n /**\n * Register the CLEO MCP server in .opencode/config.json.\n *\n * OpenCode stores its MCP server configuration in .opencode/config.json\n * under the mcpServers key.\n *\n * @returns true if registration was performed or updated\n */\n private registerMcpServer(projectDir: string, mcpServerPath: string): boolean {\n const openCodeDir = join(projectDir, '.opencode');\n const configPath = join(openCodeDir, 'config.json');\n let config: Record<string, unknown> = {};\n\n mkdirSync(openCodeDir, { recursive: true });\n\n if (existsSync(configPath)) {\n try {\n config = JSON.parse(readFileSync(configPath, 'utf-8'));\n } catch {\n // Start fresh on parse error\n }\n }\n\n if (!config.mcpServers || typeof config.mcpServers !== 'object') {\n config.mcpServers = {};\n }\n\n const mcpServers = config.mcpServers as Record<string, unknown>;\n mcpServers[MCP_SERVER_KEY] = {\n command: 'node',\n args: [mcpServerPath],\n };\n\n writeFileSync(configPath, JSON.stringify(config, null, 2) + '\\n', 'utf-8');\n return true;\n }\n\n /**\n * Update AGENTS.md with CLEO @-references.\n *\n * @returns true if the file was created or modified\n */\n private updateInstructionFile(projectDir: string): boolean {\n const agentsMdPath = join(projectDir, 'AGENTS.md');\n let content = '';\n let existed = false;\n\n if (existsSync(agentsMdPath)) {\n content = readFileSync(agentsMdPath, 'utf-8');\n existed = true;\n }\n\n const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));\n\n if (missingRefs.length === 0) {\n return false;\n }\n\n const refsBlock = missingRefs.join('\\n');\n\n if (existed) {\n // Append missing references\n const separator = content.endsWith('\\n') ? '' : '\\n';\n content = content + separator + refsBlock + '\\n';\n } else {\n // Create new AGENTS.md with references\n content = refsBlock + '\\n';\n }\n\n writeFileSync(agentsMdPath, content, 'utf-8');\n return true;\n }\n}\n", "/**\n * OpenCode Spawn Provider\n *\n * Implements AdapterSpawnProvider for OpenCode CLI.\n * Migrated from src/core/spawn/adapters/opencode-adapter.ts\n *\n * Uses `opencode run --agent ... --format json` to spawn subagent\n * processes. Processes run detached and are tracked by PID for\n * listing and termination.\n *\n * @task T5240\n */\n\nimport { exec, spawn as nodeSpawn } from 'node:child_process';\nimport { mkdir, readFile, writeFile } from 'node:fs/promises';\nimport { join } from 'node:path';\nimport { promisify } from 'node:util';\nimport type { AdapterSpawnProvider, SpawnContext, SpawnResult } from '@cleocode/contracts';\n\nconst execAsync = promisify(exec);\n\n/** Name used for the CLEO subagent definition in OpenCode's agent directory. */\nconst OPENCODE_SUBAGENT_NAME = 'cleo-subagent';\n\n/** Fallback agent name when custom agent definition cannot be created. */\nconst OPENCODE_FALLBACK_AGENT = 'general';\n\n/** Internal tracking entry for a spawned process. */\ninterface TrackedProcess {\n pid: number;\n taskId: string;\n startTime: string;\n}\n\n/**\n * Build the markdown content for an OpenCode agent definition file.\n *\n * OpenCode agents are defined as markdown files with YAML frontmatter\n * in the .opencode/agent/ directory.\n *\n * @param description - Agent description for frontmatter\n * @param instructions - Markdown instructions body\n * @returns Complete agent definition markdown\n */\nexport function buildOpenCodeAgentMarkdown(description: string, instructions: string): string {\n const normalizedDesc = description.replace(/\\s+/g, ' ').trim();\n return [\n '---',\n `description: ${JSON.stringify(normalizedDesc)}`,\n 'mode: subagent',\n 'hidden: true',\n '---',\n '',\n instructions.trim(),\n '',\n ].join('\\n');\n}\n\n/**\n * Ensure the CLEO subagent definition exists in the project's\n * .opencode/agent/ directory.\n *\n * Creates or updates the agent definition file if the content has changed.\n *\n * @param workingDirectory - Project root directory\n * @returns The agent name to use for spawning\n */\nasync function ensureSubagentDefinition(workingDirectory: string): Promise<string> {\n const agentDir = join(workingDirectory, '.opencode', 'agent');\n const agentPath = join(agentDir, `${OPENCODE_SUBAGENT_NAME}.md`);\n const description = 'CLEO task executor with protocol compliance.';\n const instructions = [\n '# CLEO Subagent',\n '',\n 'You are a CLEO subagent executing a delegated task.',\n 'Follow the CLEO protocol and complete the assigned work.',\n '',\n '@~/.cleo/templates/CLEO-INJECTION.md',\n ].join('\\n');\n\n const content = buildOpenCodeAgentMarkdown(description, instructions);\n\n await mkdir(agentDir, { recursive: true });\n\n let existing: string | null = null;\n try {\n existing = await readFile(agentPath, 'utf-8');\n } catch {\n existing = null;\n }\n\n if (existing !== content) {\n await writeFile(agentPath, content, 'utf-8');\n }\n\n return OPENCODE_SUBAGENT_NAME;\n}\n\n/**\n * Spawn provider for OpenCode.\n *\n * Spawns detached OpenCode CLI processes for subagent execution.\n * Each spawn ensures a CLEO subagent definition exists, then runs\n * `opencode run --format json --agent <name> --title <title> <prompt>`\n * as a detached, unref'd child process.\n */\nexport class OpenCodeSpawnProvider implements AdapterSpawnProvider {\n /** Map of instance IDs to tracked process info. */\n private processMap = new Map<string, TrackedProcess>();\n\n /**\n * Check if the OpenCode CLI is available in PATH.\n *\n * @returns true if `opencode` is found via `which`\n */\n async canSpawn(): Promise<boolean> {\n try {\n await execAsync('which opencode');\n return true;\n } catch {\n return false;\n }\n }\n\n /**\n * Spawn a subagent via OpenCode CLI.\n *\n * Ensures the CLEO subagent definition exists in the project's\n * .opencode/agent/ directory, then spawns a detached OpenCode\n * process. The process runs independently of the parent.\n *\n * @param context - Spawn context with taskId, prompt, and options\n * @returns Spawn result with instance ID and status\n */\n async spawn(context: SpawnContext): Promise<SpawnResult> {\n const instanceId = `opencode-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;\n const startTime = new Date().toISOString();\n const workingDirectory = context.workingDirectory ?? process.cwd();\n\n try {\n let agentName: string;\n try {\n agentName = await ensureSubagentDefinition(workingDirectory);\n } catch {\n agentName = OPENCODE_FALLBACK_AGENT;\n }\n\n const child = nodeSpawn(\n 'opencode',\n [\n 'run',\n '--format',\n 'json',\n '--agent',\n agentName,\n '--title',\n `CLEO ${context.taskId}`,\n context.prompt,\n ],\n {\n cwd: workingDirectory,\n detached: true,\n stdio: 'ignore',\n },\n );\n\n child.unref();\n\n if (child.pid) {\n this.processMap.set(instanceId, {\n pid: child.pid,\n taskId: context.taskId,\n startTime,\n });\n }\n\n child.on('exit', () => {\n this.processMap.delete(instanceId);\n });\n\n return {\n instanceId,\n taskId: context.taskId,\n providerId: 'opencode',\n status: 'running',\n startTime,\n };\n } catch {\n return {\n instanceId,\n taskId: context.taskId,\n providerId: 'opencode',\n status: 'failed',\n startTime,\n endTime: new Date().toISOString(),\n };\n }\n }\n\n /**\n * List currently running OpenCode subagent processes.\n *\n * Checks each tracked process via kill(pid, 0) to verify it is still alive.\n * Dead processes are automatically cleaned from the tracking map.\n *\n * @returns Array of spawn results for running processes\n */\n async listRunning(): Promise<SpawnResult[]> {\n const running: SpawnResult[] = [];\n\n for (const [instanceId, tracked] of this.processMap.entries()) {\n try {\n process.kill(tracked.pid, 0);\n running.push({\n instanceId,\n taskId: tracked.taskId,\n providerId: 'opencode',\n status: 'running',\n startTime: tracked.startTime,\n });\n } catch {\n this.processMap.delete(instanceId);\n }\n }\n\n return running;\n }\n\n /**\n * Terminate a running spawn by instance ID.\n *\n * Sends SIGTERM to the tracked process. If the process is not found\n * or has already exited, this is a no-op.\n *\n * @param instanceId - ID of the spawn instance to terminate\n */\n async terminate(instanceId: string): Promise<void> {\n const tracked = this.processMap.get(instanceId);\n if (!tracked) return;\n\n try {\n process.kill(tracked.pid, 'SIGTERM');\n } catch {\n // Process may have already exited\n }\n this.processMap.delete(instanceId);\n }\n}\n", "/**\n * OpenCode Adapter\n *\n * Main CLEOProviderAdapter implementation for OpenCode AI coding assistant.\n * Provides spawn, hooks, and install capabilities for CLEO integration.\n *\n * @task T5240\n */\n\nimport { exec } from 'node:child_process';\nimport { existsSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { promisify } from 'node:util';\nimport type {\n AdapterCapabilities,\n AdapterHealthStatus,\n CLEOProviderAdapter,\n} from '@cleocode/contracts';\nimport { OpenCodeHookProvider } from './hooks.js';\nimport { OpenCodeInstallProvider } from './install.js';\nimport { OpenCodeSpawnProvider } from './spawn.js';\n\nconst execAsync = promisify(exec);\n\n/**\n * CLEO provider adapter for OpenCode AI coding assistant.\n *\n * Bridges CLEO's adapter system with OpenCode's native capabilities:\n * - Hooks: Maps OpenCode events (session.start, tool.complete, etc.) to CAAMP events\n * - Spawn: Launches subagent processes via the `opencode` CLI\n * - Install: Registers MCP server in .opencode/config.json and ensures AGENTS.md references\n */\nexport class OpenCodeAdapter implements CLEOProviderAdapter {\n readonly id = 'opencode';\n readonly name = 'OpenCode';\n readonly version = '1.0.0';\n\n capabilities: AdapterCapabilities = {\n supportsHooks: true,\n supportedHookEvents: [\n 'onSessionStart',\n 'onSessionEnd',\n 'onToolStart',\n 'onToolComplete',\n 'onError',\n 'onPromptSubmit',\n ],\n supportsSpawn: true,\n supportsInstall: true,\n supportsMcp: true,\n supportsInstructionFiles: true,\n instructionFilePattern: 'AGENTS.md',\n supportsContextMonitor: false,\n supportsStatusline: false,\n supportsProviderPaths: true,\n supportsTransport: false,\n supportsTaskSync: false,\n };\n\n hooks: OpenCodeHookProvider;\n spawn: OpenCodeSpawnProvider;\n install: OpenCodeInstallProvider;\n\n private projectDir: string | null = null;\n private initialized = false;\n\n constructor() {\n this.hooks = new OpenCodeHookProvider();\n this.spawn = new OpenCodeSpawnProvider();\n this.install = new OpenCodeInstallProvider();\n }\n\n /**\n * Initialize the adapter for a given project directory.\n *\n * Validates the environment by checking for the OpenCode CLI\n * and OpenCode configuration directory.\n *\n * @param projectDir - Root directory of the project\n */\n async initialize(projectDir: string): Promise<void> {\n this.projectDir = projectDir;\n this.initialized = true;\n }\n\n /**\n * Dispose the adapter and clean up resources.\n *\n * Unregisters hooks and releases any tracked state.\n */\n async dispose(): Promise<void> {\n if (this.hooks.isRegistered()) {\n await this.hooks.unregisterNativeHooks();\n }\n this.initialized = false;\n this.projectDir = null;\n }\n\n /**\n * Run a health check to verify OpenCode is accessible.\n *\n * Checks:\n * 1. Adapter has been initialized\n * 2. OpenCode CLI is available in PATH\n * 3. .opencode/ configuration directory exists in the project\n *\n * @returns Health status with details about each check\n */\n async healthCheck(): Promise<AdapterHealthStatus> {\n const details: Record<string, unknown> = {};\n\n if (!this.initialized) {\n return {\n healthy: false,\n provider: this.id,\n details: { error: 'Adapter not initialized' },\n };\n }\n\n // Check OpenCode CLI availability\n let cliAvailable = false;\n try {\n const { stdout } = await execAsync('which opencode');\n cliAvailable = stdout.trim().length > 0;\n details.cliPath = stdout.trim();\n } catch {\n details.cliAvailable = false;\n }\n\n // Check for OpenCode config directory in the project\n if (this.projectDir) {\n const openCodeConfigDir = join(this.projectDir, '.opencode');\n const configExists = existsSync(openCodeConfigDir);\n details.configDirExists = configExists;\n }\n\n // Check for OPENCODE_VERSION env var\n const versionEnvSet = process.env.OPENCODE_VERSION !== undefined;\n details.versionEnvSet = versionEnvSet;\n\n // Healthy if CLI is available (primary requirement)\n const healthy = cliAvailable;\n details.cliAvailable = cliAvailable;\n\n return {\n healthy,\n provider: this.id,\n details,\n };\n }\n\n /**\n * Check whether the adapter has been initialized.\n */\n isInitialized(): boolean {\n return this.initialized;\n }\n\n /**\n * Get the project directory this adapter was initialized with.\n */\n getProjectDir(): string | null {\n return this.projectDir;\n }\n}\n", "/**\n * OpenCode provider adapter.\n *\n * CLEO provider adapter for OpenCode AI coding assistant.\n * Default export is the adapter class for dynamic loading by AdapterManager.\n *\n * @task T5240\n */\n\nimport { OpenCodeAdapter } from './adapter.js';\n\nexport { OpenCodeAdapter } from './adapter.js';\nexport { OpenCodeHookProvider } from './hooks.js';\nexport { OpenCodeInstallProvider } from './install.js';\nexport { OpenCodeSpawnProvider } from './spawn.js';\n\nexport default OpenCodeAdapter;\n\n/**\n * Factory function for creating adapter instances.\n * Used by AdapterManager's dynamic import fallback.\n */\nexport function createAdapter(): OpenCodeAdapter {\n return new OpenCodeAdapter();\n}\n", "/**\n * @cleocode/adapters\n *\n * Unified provider adapter package for CLEO.\n * Exports all provider adapters and a registry for manifest discovery.\n */\n\n// Re-export adapter classes for direct use\n// Per-provider factory functions (renamed to avoid collisions)\nexport {\n ClaudeCodeAdapter,\n ClaudeCodeContextMonitorProvider,\n ClaudeCodeHookProvider,\n ClaudeCodeInstallProvider,\n ClaudeCodePathProvider,\n ClaudeCodeSpawnProvider,\n ClaudeCodeTransportProvider,\n checkStatuslineIntegration,\n createAdapter as createClaudeCodeAdapter,\n getSetupInstructions,\n getStatuslineConfig,\n} from './providers/claude-code/index.js';\nexport {\n CursorAdapter,\n CursorHookProvider,\n CursorInstallProvider,\n createAdapter as createCursorAdapter,\n} from './providers/cursor/index.js';\nexport {\n createAdapter as createOpenCodeAdapter,\n OpenCodeAdapter,\n OpenCodeHookProvider,\n OpenCodeInstallProvider,\n OpenCodeSpawnProvider,\n} from './providers/opencode/index.js';\nexport type { AdapterManifest } from './registry.js';\nexport { discoverProviders, getProviderManifests } from './registry.js';\n", "/**\n * Adapter registry \u2014 discovers and provides access to provider manifests.\n *\n * Scans the providers/ directory for manifest.json files and returns\n * the discovered adapter manifests for use by AdapterManager.\n *\n * @task T5240\n */\n\nimport { readFileSync } from 'node:fs';\nimport { dirname, join, resolve } from 'node:path';\nimport { fileURLToPath } from 'node:url';\n\n/** Minimal manifest shape for provider discovery. */\nexport interface AdapterManifest {\n id: string;\n name: string;\n version: string;\n description: string;\n provider: string;\n entryPoint: string;\n capabilities: Record<string, unknown>;\n detectionPatterns: Array<{\n type: string;\n pattern: string;\n description: string;\n }>;\n}\n\n/** Known provider IDs bundled with @cleocode/adapters. */\nconst PROVIDER_IDS = ['claude-code', 'opencode', 'cursor'] as const;\n\n/**\n * Get the manifests for all bundled provider adapters.\n *\n * @returns Array of adapter manifests\n */\nexport function getProviderManifests(): AdapterManifest[] {\n const manifests: AdapterManifest[] = [];\n const baseDir = resolve(dirname(fileURLToPath(import.meta.url)), 'providers');\n\n for (const providerId of PROVIDER_IDS) {\n try {\n const manifestPath = join(baseDir, providerId, 'manifest.json');\n const raw = readFileSync(manifestPath, 'utf-8');\n manifests.push(JSON.parse(raw) as AdapterManifest);\n } catch {\n // Skip providers whose manifests cannot be loaded\n }\n }\n\n return manifests;\n}\n\n/**\n * Discover all available provider adapters.\n *\n * Returns a map of provider ID to adapter factory function.\n */\nexport async function discoverProviders(): Promise<Map<string, () => Promise<unknown>>> {\n const providers = new Map<string, () => Promise<unknown>>();\n\n providers.set('claude-code', async () => {\n const { ClaudeCodeAdapter } = await import('./providers/claude-code/index.js');\n return new ClaudeCodeAdapter();\n });\n\n providers.set('opencode', async () => {\n const { OpenCodeAdapter } = await import('./providers/opencode/index.js');\n return new OpenCodeAdapter();\n });\n\n providers.set('cursor', async () => {\n const { CursorAdapter } = await import('./providers/cursor/index.js');\n return new CursorAdapter();\n });\n\n return providers;\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["homedir", "join", "existsSync", "readFileSync", "writeFileSync", "homedir", "join", "init_session", "init_session", "join", "exec", "existsSync", "homedir", "join", "promisify", "execAsync", "existsSync", "readFileSync", "homedir", "join", "init_hooks", "existsSync", "mkdirSync", "readFileSync", "writeFileSync", "join", "INSTRUCTION_REFERENCES", "MCP_SERVER_KEY", "init_install", "existsSync", "join", "init_adapter", "init_hooks", "init_install", "createAdapter", "init_adapter", "init_hooks", "init_install", "init_hooks", "existsSync", "mkdirSync", "readFileSync", "writeFileSync", "join", "INSTRUCTION_REFERENCES", "MCP_SERVER_KEY", "init_install", "exec", "nodeSpawn", "mkdir", "readFile", "writeFile", "join", "promisify", "execAsync", "init_spawn", "exec", "existsSync", "join", "promisify", "execAsync", "init_adapter", "init_hooks", "init_install", "init_spawn", "createAdapter", "init_adapter", "init_hooks", "init_install", "init_spawn", "readFileSync", "dirname", "join", "ClaudeCodeAdapter", "OpenCodeAdapter", "CursorAdapter"]
|
|
7
7
|
}
|