@cleocode/adapters 2026.4.30 → 2026.4.35

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (99) hide show
  1. package/dist/index.js +641 -5
  2. package/dist/index.js.map +4 -4
  3. package/dist/providers/claude-code/adapter.js +184 -0
  4. package/dist/providers/claude-code/adapter.js.map +1 -0
  5. package/dist/providers/claude-code/context-monitor.js +159 -0
  6. package/dist/providers/claude-code/context-monitor.js.map +1 -0
  7. package/dist/providers/claude-code/hooks.js +286 -0
  8. package/dist/providers/claude-code/hooks.js.map +1 -0
  9. package/dist/providers/claude-code/index.js +41 -0
  10. package/dist/providers/claude-code/index.js.map +1 -0
  11. package/dist/providers/claude-code/install.js +199 -0
  12. package/dist/providers/claude-code/install.js.map +1 -0
  13. package/dist/providers/claude-code/paths.js +41 -0
  14. package/dist/providers/claude-code/paths.js.map +1 -0
  15. package/dist/providers/claude-code/spawn.js +171 -0
  16. package/dist/providers/claude-code/spawn.js.map +1 -0
  17. package/dist/providers/claude-code/statusline.js +130 -0
  18. package/dist/providers/claude-code/statusline.js.map +1 -0
  19. package/dist/providers/claude-code/task-sync.js +119 -0
  20. package/dist/providers/claude-code/task-sync.js.map +1 -0
  21. package/dist/providers/claude-code/transport.js +29 -0
  22. package/dist/providers/claude-code/transport.js.map +1 -0
  23. package/dist/providers/codex/adapter.js +146 -0
  24. package/dist/providers/codex/adapter.js.map +1 -0
  25. package/dist/providers/codex/hooks.js +113 -0
  26. package/dist/providers/codex/hooks.js.map +1 -0
  27. package/dist/providers/codex/index.js +39 -0
  28. package/dist/providers/codex/index.js.map +1 -0
  29. package/dist/providers/codex/install.js +124 -0
  30. package/dist/providers/codex/install.js.map +1 -0
  31. package/dist/providers/cursor/adapter.js +151 -0
  32. package/dist/providers/cursor/adapter.js.map +1 -0
  33. package/dist/providers/cursor/hooks.js +208 -0
  34. package/dist/providers/cursor/hooks.js.map +1 -0
  35. package/dist/providers/cursor/index.js +36 -0
  36. package/dist/providers/cursor/index.js.map +1 -0
  37. package/dist/providers/cursor/install.js +180 -0
  38. package/dist/providers/cursor/install.js.map +1 -0
  39. package/dist/providers/cursor/spawn.js +59 -0
  40. package/dist/providers/cursor/spawn.js.map +1 -0
  41. package/dist/providers/gemini-cli/adapter.js +158 -0
  42. package/dist/providers/gemini-cli/adapter.js.map +1 -0
  43. package/dist/providers/gemini-cli/hooks.js +128 -0
  44. package/dist/providers/gemini-cli/hooks.js.map +1 -0
  45. package/dist/providers/gemini-cli/index.js +39 -0
  46. package/dist/providers/gemini-cli/index.js.map +1 -0
  47. package/dist/providers/gemini-cli/install.js +124 -0
  48. package/dist/providers/gemini-cli/install.js.map +1 -0
  49. package/dist/providers/kimi/adapter.js +145 -0
  50. package/dist/providers/kimi/adapter.js.map +1 -0
  51. package/dist/providers/kimi/hooks.js +79 -0
  52. package/dist/providers/kimi/hooks.js.map +1 -0
  53. package/dist/providers/kimi/index.js +39 -0
  54. package/dist/providers/kimi/index.js.map +1 -0
  55. package/dist/providers/kimi/install.js +124 -0
  56. package/dist/providers/kimi/install.js.map +1 -0
  57. package/dist/providers/opencode/adapter.js +166 -0
  58. package/dist/providers/opencode/adapter.js.map +1 -0
  59. package/dist/providers/opencode/hooks.js +206 -0
  60. package/dist/providers/opencode/hooks.js.map +1 -0
  61. package/dist/providers/opencode/index.js +37 -0
  62. package/dist/providers/opencode/index.js.map +1 -0
  63. package/dist/providers/opencode/install.js +115 -0
  64. package/dist/providers/opencode/install.js.map +1 -0
  65. package/dist/providers/opencode/spawn.js +241 -0
  66. package/dist/providers/opencode/spawn.js.map +1 -0
  67. package/dist/providers/pi/adapter.d.ts +102 -0
  68. package/dist/providers/pi/adapter.d.ts.map +1 -0
  69. package/dist/providers/pi/adapter.js +220 -0
  70. package/dist/providers/pi/adapter.js.map +1 -0
  71. package/dist/providers/pi/hooks.d.ts +149 -0
  72. package/dist/providers/pi/hooks.d.ts.map +1 -0
  73. package/dist/providers/pi/hooks.js +223 -0
  74. package/dist/providers/pi/hooks.js.map +1 -0
  75. package/dist/providers/pi/index.d.ts +36 -0
  76. package/dist/providers/pi/index.d.ts.map +1 -0
  77. package/dist/providers/pi/index.js +38 -0
  78. package/dist/providers/pi/index.js.map +1 -0
  79. package/dist/providers/pi/install.d.ts +68 -0
  80. package/dist/providers/pi/install.d.ts.map +1 -0
  81. package/dist/providers/pi/install.js +175 -0
  82. package/dist/providers/pi/install.js.map +1 -0
  83. package/dist/providers/pi/spawn.d.ts +68 -0
  84. package/dist/providers/pi/spawn.d.ts.map +1 -0
  85. package/dist/providers/pi/spawn.js +187 -0
  86. package/dist/providers/pi/spawn.js.map +1 -0
  87. package/dist/providers/shared/transcript-reader.js +124 -0
  88. package/dist/providers/shared/transcript-reader.js.map +1 -0
  89. package/dist/registry.d.ts.map +1 -1
  90. package/dist/registry.js +92 -0
  91. package/dist/registry.js.map +1 -0
  92. package/package.json +3 -3
  93. package/src/providers/pi/adapter.ts +240 -0
  94. package/src/providers/pi/hooks.ts +232 -0
  95. package/src/providers/pi/index.ts +41 -0
  96. package/src/providers/pi/install.ts +189 -0
  97. package/src/providers/pi/manifest.json +40 -0
  98. package/src/providers/pi/spawn.ts +207 -0
  99. package/src/registry.ts +6 -1
@@ -0,0 +1,41 @@
1
+ /**
2
+ * @packageDocumentation
3
+ *
4
+ * CLEO provider adapter for Anthropic Claude Code CLI.
5
+ * Default export is the adapter class for dynamic loading by AdapterManager.
6
+ *
7
+ * @task T5240
8
+ */
9
+ import { ClaudeCodeAdapter } from './adapter.js';
10
+ export { ClaudeCodeAdapter } from './adapter.js';
11
+ export { ClaudeCodeContextMonitorProvider } from './context-monitor.js';
12
+ export { ClaudeCodeHookProvider } from './hooks.js';
13
+ export { ClaudeCodeInstallProvider } from './install.js';
14
+ export { ClaudeCodePathProvider } from './paths.js';
15
+ export { ClaudeCodeSpawnProvider } from './spawn.js';
16
+ export { checkStatuslineIntegration, getSetupInstructions, getStatuslineConfig, } from './statusline.js';
17
+ export { ClaudeCodeTransportProvider } from './transport.js';
18
+ export default ClaudeCodeAdapter;
19
+ /**
20
+ * Factory function for creating adapter instances.
21
+ * Used by AdapterManager's dynamic import fallback.
22
+ *
23
+ * @remarks
24
+ * This is the primary entry point for dynamic adapter loading.
25
+ * AdapterManager calls this function when it resolves the claude-code
26
+ * provider via its import-based discovery mechanism.
27
+ *
28
+ * @returns A new {@link ClaudeCodeAdapter} instance ready for initialization
29
+ *
30
+ * @example
31
+ * ```typescript
32
+ * import { createAdapter } from '@cleocode/adapters/providers/claude-code';
33
+ *
34
+ * const adapter = createAdapter();
35
+ * await adapter.initialize('/path/to/project');
36
+ * ```
37
+ */
38
+ export function createAdapter() {
39
+ return new ClaudeCodeAdapter();
40
+ }
41
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/providers/claude-code/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,gCAAgC,EAAE,MAAM,sBAAsB,CAAC;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAC;AACzD,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACpD,OAAO,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAC;AACrD,OAAO,EACL,0BAA0B,EAC1B,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,2BAA2B,EAAE,MAAM,gBAAgB,CAAC;AAE7D,eAAe,iBAAiB,CAAC;AAEjC;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,iBAAiB,EAAE,CAAC;AACjC,CAAC"}
@@ -0,0 +1,199 @@
1
+ /**
2
+ * Claude Code Install Provider
3
+ *
4
+ * Handles CLEO installation into Claude Code environments:
5
+ * - Ensures CLAUDE.md has CLEO @-references
6
+ * - Manages plugin registration in ~/.claude/settings.json
7
+ *
8
+ * Migrated from src/core/install/claude-plugin.ts
9
+ *
10
+ * @task T5240
11
+ */
12
+ import { copyFileSync, existsSync, mkdirSync, readdirSync, readFileSync, writeFileSync, } from 'node:fs';
13
+ import { homedir } from 'node:os';
14
+ import { dirname, join } from 'node:path';
15
+ import { fileURLToPath } from 'node:url';
16
+ /** Lines that should appear in CLAUDE.md to reference CLEO. */
17
+ const INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];
18
+ /** Resolve the commands directory bundled with this adapter. */
19
+ function getAdapterCommandsDir() {
20
+ // Works in both ESM (import.meta.url) and compiled output
21
+ const thisDir = dirname(fileURLToPath(import.meta.url));
22
+ return join(thisDir, 'commands');
23
+ }
24
+ /**
25
+ * Install provider for Claude Code.
26
+ *
27
+ * Manages CLEO's integration with Claude Code by:
28
+ * 1. Ensuring CLAUDE.md contains @-references to CLEO instruction files
29
+ * 2. Installing adapter-provided commands to .claude/commands/
30
+ * 3. Registering the brain observation plugin in ~/.claude/settings.json
31
+ *
32
+ * @remarks
33
+ * Installation is idempotent -- running install multiple times on the same
34
+ * project produces the same result. The provider disables the legacy
35
+ * `claude-mem\@thedotmack` plugin if present and enables the unified
36
+ * `cleo\@cleocode` plugin instead.
37
+ */
38
+ export class ClaudeCodeInstallProvider {
39
+ /**
40
+ * Install CLEO into a Claude Code project.
41
+ *
42
+ * @param options - Installation options including project directory
43
+ * @returns Result describing what was installed
44
+ */
45
+ async install(options) {
46
+ const { projectDir } = options;
47
+ const installedAt = new Date().toISOString();
48
+ let instructionFileUpdated = false;
49
+ const details = {};
50
+ // Step 1: Ensure CLAUDE.md has @-references
51
+ instructionFileUpdated = this.updateInstructionFile(projectDir);
52
+ if (instructionFileUpdated) {
53
+ details.instructionFile = join(projectDir, 'CLAUDE.md');
54
+ }
55
+ // Step 2: Install adapter-provided commands to .claude/commands/
56
+ const commandsInstalled = this.installCommands(projectDir);
57
+ if (commandsInstalled.length > 0) {
58
+ details.commands = commandsInstalled;
59
+ }
60
+ // Step 3: Register plugin in ~/.claude/settings.json
61
+ const pluginResult = this.registerPlugin();
62
+ if (pluginResult) {
63
+ details.plugin = pluginResult;
64
+ }
65
+ return {
66
+ success: true,
67
+ installedAt,
68
+ instructionFileUpdated,
69
+ details,
70
+ };
71
+ }
72
+ /**
73
+ * Uninstall CLEO from the current Claude Code project.
74
+ *
75
+ * Does not remove CLAUDE.md references (they are harmless if CLEO is not present).
76
+ */
77
+ async uninstall() { }
78
+ /**
79
+ * Check whether CLEO is installed in the current environment.
80
+ *
81
+ * Checks for plugin enabled in ~/.claude/settings.json.
82
+ */
83
+ async isInstalled() {
84
+ // Check ~/.claude/settings.json for plugin registration
85
+ const settingsPath = join(homedir(), '.claude', 'settings.json');
86
+ if (existsSync(settingsPath)) {
87
+ try {
88
+ const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
89
+ const plugins = settings.enabledPlugins;
90
+ if (plugins && plugins['cleo@cleocode'] === true) {
91
+ return true;
92
+ }
93
+ }
94
+ catch {
95
+ // Fall through
96
+ }
97
+ }
98
+ return false;
99
+ }
100
+ /**
101
+ * Ensure CLAUDE.md contains @-references to CLEO instruction files.
102
+ *
103
+ * Creates CLAUDE.md if it does not exist. Appends any missing references.
104
+ *
105
+ * @param projectDir - Project root directory
106
+ */
107
+ async ensureInstructionReferences(projectDir) {
108
+ this.updateInstructionFile(projectDir);
109
+ }
110
+ /**
111
+ * Update CLAUDE.md with CLEO @-references.
112
+ *
113
+ * @returns true if the file was created or modified
114
+ */
115
+ updateInstructionFile(projectDir) {
116
+ const claudeMdPath = join(projectDir, 'CLAUDE.md');
117
+ let content = '';
118
+ let existed = false;
119
+ if (existsSync(claudeMdPath)) {
120
+ content = readFileSync(claudeMdPath, 'utf-8');
121
+ existed = true;
122
+ }
123
+ const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
124
+ if (missingRefs.length === 0) {
125
+ return false;
126
+ }
127
+ const refsBlock = missingRefs.join('\n');
128
+ if (existed) {
129
+ // Append missing references
130
+ const separator = content.endsWith('\n') ? '' : '\n';
131
+ content = content + separator + refsBlock + '\n';
132
+ }
133
+ else {
134
+ // Create new CLAUDE.md with references
135
+ content = refsBlock + '\n';
136
+ }
137
+ writeFileSync(claudeMdPath, content, 'utf-8');
138
+ return true;
139
+ }
140
+ /**
141
+ * Install Claude Code-specific commands to .claude/commands/ in the project.
142
+ *
143
+ * These commands extend CLEO's provider-neutral skills with Claude Code-specific
144
+ * operational patterns (Agent tool spawn templates, model assignment, context guardrails).
145
+ *
146
+ * @param projectDir - Project root directory
147
+ * @returns Array of installed command filenames
148
+ */
149
+ installCommands(projectDir) {
150
+ const adapterCommandsDir = getAdapterCommandsDir();
151
+ if (!existsSync(adapterCommandsDir)) {
152
+ return [];
153
+ }
154
+ const targetDir = join(projectDir, '.claude', 'commands');
155
+ mkdirSync(targetDir, { recursive: true });
156
+ const installed = [];
157
+ const files = readdirSync(adapterCommandsDir).filter((f) => f.endsWith('.md'));
158
+ for (const file of files) {
159
+ const src = join(adapterCommandsDir, file);
160
+ const dest = join(targetDir, file);
161
+ copyFileSync(src, dest);
162
+ installed.push(file);
163
+ }
164
+ return installed;
165
+ }
166
+ /**
167
+ * Register the CLEO brain plugin in ~/.claude/settings.json.
168
+ *
169
+ * @returns Description of what was registered, or null if no change needed
170
+ */
171
+ registerPlugin() {
172
+ const home = homedir();
173
+ const settingsPath = join(home, '.claude', 'settings.json');
174
+ let settings = {};
175
+ if (existsSync(settingsPath)) {
176
+ try {
177
+ settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
178
+ }
179
+ catch {
180
+ // Start fresh
181
+ }
182
+ }
183
+ const enabledPlugins = settings.enabledPlugins ?? {};
184
+ const pluginKey = 'cleo@cleocode';
185
+ if (enabledPlugins[pluginKey] === true) {
186
+ return null;
187
+ }
188
+ // Disable old claude-mem if present
189
+ if (enabledPlugins['claude-mem@thedotmack'] === true) {
190
+ enabledPlugins['claude-mem@thedotmack'] = false;
191
+ }
192
+ enabledPlugins[pluginKey] = true;
193
+ settings.enabledPlugins = enabledPlugins;
194
+ mkdirSync(join(home, '.claude'), { recursive: true });
195
+ writeFileSync(settingsPath, JSON.stringify(settings, null, 2) + '\n', 'utf-8');
196
+ return `Enabled ${pluginKey} in ~/.claude/settings.json`;
197
+ }
198
+ }
199
+ //# sourceMappingURL=install.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/claude-code/install.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,41 @@
1
+ /**
2
+ * Claude Code path provider.
3
+ *
4
+ * Implements AdapterPathProvider with Claude Code-specific directory locations.
5
+ *
6
+ * @task T5240
7
+ */
8
+ import { homedir } from 'node:os';
9
+ import { join } from 'node:path';
10
+ /**
11
+ * Path provider for Anthropic Claude Code CLI.
12
+ *
13
+ * Resolves Claude Code's standard directory layout:
14
+ * - Config dir: ~/.claude (or CLAUDE_HOME)
15
+ * - Settings: ~/.claude/settings.json (or CLAUDE_SETTINGS)
16
+ * - Agents: ~/.claude/agents
17
+ * - Memory DB: ~/.claude-mem/claude-mem.db (or CLAUDE_MEM_DB)
18
+ *
19
+ * @remarks
20
+ * All paths respect environment variable overrides for CI and non-standard
21
+ * installations. When env vars are unset, the canonical default paths are used.
22
+ */
23
+ export class ClaudeCodePathProvider {
24
+ /** Get the provider's root configuration directory. */
25
+ getProviderDir() {
26
+ return process.env['CLAUDE_HOME'] ?? join(homedir(), '.claude');
27
+ }
28
+ /** Get the path to the provider's settings file, or null if unavailable. */
29
+ getSettingsPath() {
30
+ return process.env['CLAUDE_SETTINGS'] ?? join(this.getProviderDir(), 'settings.json');
31
+ }
32
+ /** Get the directory where agents are installed, or null if unsupported. */
33
+ getAgentInstallDir() {
34
+ return join(this.getProviderDir(), 'agents');
35
+ }
36
+ /** Get the path to the provider's memory database, or null if unsupported. */
37
+ getMemoryDbPath() {
38
+ return process.env['CLAUDE_MEM_DB'] ?? join(homedir(), '.claude-mem', 'claude-mem.db');
39
+ }
40
+ }
41
+ //# sourceMappingURL=paths.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"paths.js","sourceRoot":"","sources":["../../../src/providers/claude-code/paths.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAGjC;;;;;;;;;;;;GAYG;AACH,MAAM,OAAO,sBAAsB;IACjC,uDAAuD;IACvD,cAAc;QACZ,OAAO,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,CAAC,CAAC;IAClE,CAAC;IAED,4EAA4E;IAC5E,eAAe;QACb,OAAO,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,eAAe,CAAC,CAAC;IACxF,CAAC;IAED,4EAA4E;IAC5E,kBAAkB;QAChB,OAAO,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,QAAQ,CAAC,CAAC;IAC/C,CAAC;IAED,8EAA8E;IAC9E,eAAe;QACb,OAAO,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,aAAa,EAAE,eAAe,CAAC,CAAC;IACzF,CAAC;CACF"}
@@ -0,0 +1,171 @@
1
+ /**
2
+ * Claude Code Spawn Provider
3
+ *
4
+ * Implements AdapterSpawnProvider for Claude Code CLI.
5
+ * Migrated from src/core/spawn/adapters/claude-code-adapter.ts
6
+ *
7
+ * Uses the native `claude` CLI to spawn subagent processes with prompts
8
+ * written to temporary files. Processes run detached and are tracked
9
+ * by PID for listing and termination.
10
+ *
11
+ * @task T5240
12
+ */
13
+ import { exec, spawn as nodeSpawn } from 'node:child_process';
14
+ import { unlink, writeFile } from 'node:fs/promises';
15
+ import { promisify } from 'node:util';
16
+ import { getErrorMessage } from '@cleocode/contracts';
17
+ const execAsync = promisify(exec);
18
+ /**
19
+ * Spawn provider for Claude Code.
20
+ *
21
+ * Spawns detached Claude CLI processes for subagent execution.
22
+ * Each spawn writes its prompt to a temporary file, then runs
23
+ * `claude --allow-insecure --no-upgrade-check <tmpFile>` as a
24
+ * detached, unref'd child process.
25
+ *
26
+ * @remarks
27
+ * The provider uses `--allow-insecure --no-upgrade-check` flags to
28
+ * ensure the Claude CLI starts without interactive prompts. Prompts are
29
+ * written to temporary files under `/tmp/` and cleaned up after the
30
+ * child process exits. Processes are tracked by instance ID in an
31
+ * in-memory map and verified via `kill(pid, 0)` liveness checks.
32
+ */
33
+ export class ClaudeCodeSpawnProvider {
34
+ /** Map of instance IDs to tracked process info. */
35
+ processMap = new Map();
36
+ /**
37
+ * Check if the Claude CLI is available in PATH.
38
+ *
39
+ * @returns true if `claude` is found via `which`
40
+ */
41
+ async canSpawn() {
42
+ try {
43
+ await execAsync('which claude');
44
+ return true;
45
+ }
46
+ catch {
47
+ return false;
48
+ }
49
+ }
50
+ /**
51
+ * Spawn a subagent via Claude CLI.
52
+ *
53
+ * Writes the prompt to a temporary file and spawns a detached Claude
54
+ * process. The process runs independently of the parent.
55
+ *
56
+ * @param context - Spawn context with taskId, prompt, and options
57
+ * @returns Spawn result with instance ID and status
58
+ */
59
+ async spawn(context) {
60
+ const instanceId = `claude-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;
61
+ const startTime = new Date().toISOString();
62
+ let tmpFile;
63
+ try {
64
+ tmpFile = `/tmp/claude-spawn-${instanceId}.txt`;
65
+ await writeFile(tmpFile, context.prompt, 'utf-8');
66
+ const args = ['--allow-insecure', '--no-upgrade-check', tmpFile];
67
+ const spawnOpts = {
68
+ detached: true,
69
+ stdio: 'ignore',
70
+ };
71
+ if (context.workingDirectory) {
72
+ spawnOpts.cwd = context.workingDirectory;
73
+ }
74
+ const child = nodeSpawn('claude', args, spawnOpts);
75
+ child.unref();
76
+ if (child.pid) {
77
+ this.processMap.set(instanceId, {
78
+ pid: child.pid,
79
+ taskId: context.taskId,
80
+ startTime,
81
+ });
82
+ }
83
+ const capturedTmpFile = tmpFile;
84
+ child.on('exit', async () => {
85
+ this.processMap.delete(instanceId);
86
+ try {
87
+ await unlink(capturedTmpFile);
88
+ }
89
+ catch {
90
+ // Ignore cleanup errors
91
+ }
92
+ });
93
+ return {
94
+ instanceId,
95
+ taskId: context.taskId,
96
+ providerId: 'claude-code',
97
+ status: 'running',
98
+ startTime,
99
+ };
100
+ }
101
+ catch (error) {
102
+ // Log spawn failure for debugging
103
+ console.error(`[ClaudeCodeSpawnProvider] Failed to spawn: ${getErrorMessage(error)}`);
104
+ if (tmpFile) {
105
+ try {
106
+ await unlink(tmpFile);
107
+ }
108
+ catch {
109
+ // Ignore cleanup errors
110
+ }
111
+ }
112
+ return {
113
+ instanceId,
114
+ taskId: context.taskId,
115
+ providerId: 'claude-code',
116
+ status: 'failed',
117
+ startTime,
118
+ endTime: new Date().toISOString(),
119
+ error: getErrorMessage(error),
120
+ };
121
+ }
122
+ }
123
+ /**
124
+ * List currently running Claude subagent processes.
125
+ *
126
+ * Checks each tracked process via kill(pid, 0) to verify it is still alive.
127
+ * Dead processes are automatically cleaned from the tracking map.
128
+ *
129
+ * @returns Array of spawn results for running processes
130
+ */
131
+ async listRunning() {
132
+ const running = [];
133
+ for (const [instanceId, tracked] of this.processMap.entries()) {
134
+ try {
135
+ process.kill(tracked.pid, 0);
136
+ running.push({
137
+ instanceId,
138
+ taskId: tracked.taskId,
139
+ providerId: 'claude-code',
140
+ status: 'running',
141
+ startTime: tracked.startTime,
142
+ });
143
+ }
144
+ catch {
145
+ this.processMap.delete(instanceId);
146
+ }
147
+ }
148
+ return running;
149
+ }
150
+ /**
151
+ * Terminate a running spawn by instance ID.
152
+ *
153
+ * Sends SIGTERM to the tracked process. If the process is not found
154
+ * or has already exited, this is a no-op.
155
+ *
156
+ * @param instanceId - ID of the spawn instance to terminate
157
+ */
158
+ async terminate(instanceId) {
159
+ const tracked = this.processMap.get(instanceId);
160
+ if (!tracked)
161
+ return;
162
+ try {
163
+ process.kill(tracked.pid, 'SIGTERM');
164
+ }
165
+ catch {
166
+ // Process may have already exited
167
+ }
168
+ this.processMap.delete(instanceId);
169
+ }
170
+ }
171
+ //# sourceMappingURL=spawn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spawn.js","sourceRoot":"","sources":["../../../src/providers/claude-code/spawn.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,130 @@
1
+ /**
2
+ * Statusline integration for the Claude Code adapter.
3
+ *
4
+ * Implements the statusline portion of AdapterContextMonitorProvider.
5
+ * Checks and configures Claude Code status line for context monitoring.
6
+ *
7
+ * @task T5240
8
+ */
9
+ import { existsSync, readFileSync } from 'node:fs';
10
+ import { homedir } from 'node:os';
11
+ import { join } from 'node:path';
12
+ /**
13
+ * Get the path to Claude Code's settings.json.
14
+ * Respects CLAUDE_SETTINGS env var, defaults to ~/.claude/settings.json.
15
+ */
16
+ function getClaudeSettingsPath() {
17
+ return (process.env['CLAUDE_SETTINGS'] ??
18
+ join(process.env['CLAUDE_HOME'] ?? join(homedir(), '.claude'), 'settings.json'));
19
+ }
20
+ /**
21
+ * Check if statusline integration is configured.
22
+ * Returns the current integration status.
23
+ *
24
+ * @remarks
25
+ * Reads Claude Code's settings.json and inspects the `statusLine` field
26
+ * to determine whether CLEO context monitoring is active.
27
+ *
28
+ * @returns One of: 'configured', 'not_configured', 'custom_no_cleo', 'no_settings'
29
+ *
30
+ * @example
31
+ * ```typescript
32
+ * import { checkStatuslineIntegration } from './statusline.js';
33
+ *
34
+ * const status = checkStatuslineIntegration();
35
+ * if (status === 'not_configured') {
36
+ * console.log('Run cleo install to set up context monitoring');
37
+ * }
38
+ * ```
39
+ */
40
+ export function checkStatuslineIntegration() {
41
+ const settingsPath = getClaudeSettingsPath();
42
+ if (!existsSync(settingsPath))
43
+ return 'no_settings';
44
+ try {
45
+ const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
46
+ const statusLine = settings.statusLine;
47
+ if (!statusLine?.type)
48
+ return 'not_configured';
49
+ if (statusLine.type !== 'command')
50
+ return 'custom_no_cleo';
51
+ const cmd = statusLine.command ?? '';
52
+ // Check if it's a CLEO statusline integration
53
+ if (cmd.includes('context-monitor.sh') ||
54
+ cmd.includes('cleo-statusline') ||
55
+ cmd.includes('.context-state.json') ||
56
+ cmd.includes('context-states')) {
57
+ return 'configured';
58
+ }
59
+ // Check if the script writes to CLEO state file
60
+ const scriptPath = cmd.startsWith('~') ? cmd.replace('~', homedir()) : cmd;
61
+ if (existsSync(scriptPath)) {
62
+ try {
63
+ const content = readFileSync(scriptPath, 'utf-8');
64
+ if (content.includes('context-state.json'))
65
+ return 'configured';
66
+ }
67
+ catch {
68
+ /* unreadable */
69
+ }
70
+ }
71
+ return 'custom_no_cleo';
72
+ }
73
+ catch {
74
+ return 'no_settings';
75
+ }
76
+ }
77
+ /**
78
+ * Get the statusline setup command for Claude Code settings.
79
+ *
80
+ * @remarks
81
+ * Returns a JSON-serializable object that can be merged into
82
+ * Claude Code's settings.json to enable context monitoring.
83
+ *
84
+ * @param cleoHome - Absolute path to the CLEO home directory
85
+ * @returns Settings object containing the statusLine configuration
86
+ *
87
+ * @example
88
+ * ```typescript
89
+ * import { getStatuslineConfig } from './statusline.js';
90
+ *
91
+ * const config = getStatuslineConfig('/home/user/.cleo');
92
+ * ```
93
+ */
94
+ export function getStatuslineConfig(cleoHome) {
95
+ return {
96
+ statusLine: {
97
+ type: 'command',
98
+ command: join(cleoHome, 'lib', 'session', 'context-monitor.sh'),
99
+ },
100
+ };
101
+ }
102
+ /**
103
+ * Get human-readable setup instructions.
104
+ *
105
+ * @remarks
106
+ * Returns a multi-line string with file path, JSON config, and explanation
107
+ * suitable for display to the user.
108
+ *
109
+ * @param cleoHome - Absolute path to the CLEO home directory
110
+ * @returns Formatted setup instructions string
111
+ *
112
+ * @example
113
+ * ```typescript
114
+ * import { getSetupInstructions } from './statusline.js';
115
+ *
116
+ * console.log(getSetupInstructions('/home/user/.cleo'));
117
+ * ```
118
+ */
119
+ export function getSetupInstructions(cleoHome) {
120
+ const settingsPath = getClaudeSettingsPath();
121
+ return [
122
+ 'To enable context monitoring, add to your Claude Code settings:',
123
+ `File: ${settingsPath}`,
124
+ '',
125
+ JSON.stringify(getStatuslineConfig(cleoHome), null, 2),
126
+ '',
127
+ 'This enables real-time context window tracking in the CLI.',
128
+ ].join('\n');
129
+ }
130
+ //# sourceMappingURL=statusline.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"statusline.js","sourceRoot":"","sources":["../../../src/providers/claude-code/statusline.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAIjC;;;GAGG;AACH,SAAS,qBAAqB;IAC5B,OAAO,CACL,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;QAC9B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,CAAC,EAAE,eAAe,CAAC,CAChF,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,UAAU,0BAA0B;IACxC,MAAM,YAAY,GAAG,qBAAqB,EAAE,CAAC;IAE7C,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC;QAAE,OAAO,aAAa,CAAC;IAEpD,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,CAAC;QACjE,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAC;QAEvC,IAAI,CAAC,UAAU,EAAE,IAAI;YAAE,OAAO,gBAAgB,CAAC;QAC/C,IAAI,UAAU,CAAC,IAAI,KAAK,SAAS;YAAE,OAAO,gBAAgB,CAAC;QAE3D,MAAM,GAAG,GAAG,UAAU,CAAC,OAAO,IAAI,EAAE,CAAC;QAErC,8CAA8C;QAC9C,IACE,GAAG,CAAC,QAAQ,CAAC,oBAAoB,CAAC;YAClC,GAAG,CAAC,QAAQ,CAAC,iBAAiB,CAAC;YAC/B,GAAG,CAAC,QAAQ,CAAC,qBAAqB,CAAC;YACnC,GAAG,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAC9B,CAAC;YACD,OAAO,YAAY,CAAC;QACtB,CAAC;QAED,gDAAgD;QAChD,MAAM,UAAU,GAAG,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;QAE3E,IAAI,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;YAC3B,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,YAAY,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;gBAClD,IAAI,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAC;oBAAE,OAAO,YAAY,CAAC;YAClE,CAAC;YAAC,MAAM,CAAC;gBACP,gBAAgB;YAClB,CAAC;QACH,CAAC;QAED,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,aAAa,CAAC;IACvB,CAAC;AACH,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,UAAU,mBAAmB,CAAC,QAAgB;IAClD,OAAO;QACL,UAAU,EAAE;YACV,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,oBAAoB,CAAC;SAChE;KACF,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,UAAU,oBAAoB,CAAC,QAAgB;IACnD,MAAM,YAAY,GAAG,qBAAqB,EAAE,CAAC;IAE7C,OAAO;QACL,iEAAiE;QACjE,SAAS,YAAY,EAAE;QACvB,EAAE;QACF,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;QACtD,EAAE;QACF,4DAA4D;KAC7D,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACf,CAAC"}