@cleocode/adapters 2026.4.42 → 2026.4.44

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 (88) hide show
  1. package/dist/cant-context.d.ts +35 -0
  2. package/dist/cant-context.d.ts.map +1 -1
  3. package/dist/index.js +153 -37
  4. package/dist/index.js.map +3 -3
  5. package/dist/providers/claude-code/install.d.ts.map +1 -1
  6. package/package.json +7 -5
  7. package/src/cant-context.ts +210 -20
  8. package/src/providers/claude-code/install.ts +1 -5
  9. package/dist/cant-context.js +0 -284
  10. package/dist/cant-context.js.map +0 -1
  11. package/dist/providers/claude-code/adapter.js +0 -187
  12. package/dist/providers/claude-code/adapter.js.map +0 -1
  13. package/dist/providers/claude-code/context-monitor.js +0 -159
  14. package/dist/providers/claude-code/context-monitor.js.map +0 -1
  15. package/dist/providers/claude-code/hooks.js +0 -389
  16. package/dist/providers/claude-code/hooks.js.map +0 -1
  17. package/dist/providers/claude-code/index.js +0 -41
  18. package/dist/providers/claude-code/index.js.map +0 -1
  19. package/dist/providers/claude-code/install.js +0 -199
  20. package/dist/providers/claude-code/install.js.map +0 -1
  21. package/dist/providers/claude-code/paths.js +0 -41
  22. package/dist/providers/claude-code/paths.js.map +0 -1
  23. package/dist/providers/claude-code/spawn.js +0 -185
  24. package/dist/providers/claude-code/spawn.js.map +0 -1
  25. package/dist/providers/claude-code/statusline.js +0 -130
  26. package/dist/providers/claude-code/statusline.js.map +0 -1
  27. package/dist/providers/claude-code/task-sync.js +0 -119
  28. package/dist/providers/claude-code/task-sync.js.map +0 -1
  29. package/dist/providers/claude-code/transport.js +0 -29
  30. package/dist/providers/claude-code/transport.js.map +0 -1
  31. package/dist/providers/codex/adapter.js +0 -146
  32. package/dist/providers/codex/adapter.js.map +0 -1
  33. package/dist/providers/codex/hooks.js +0 -113
  34. package/dist/providers/codex/hooks.js.map +0 -1
  35. package/dist/providers/codex/index.js +0 -39
  36. package/dist/providers/codex/index.js.map +0 -1
  37. package/dist/providers/codex/install.js +0 -124
  38. package/dist/providers/codex/install.js.map +0 -1
  39. package/dist/providers/cursor/adapter.js +0 -151
  40. package/dist/providers/cursor/adapter.js.map +0 -1
  41. package/dist/providers/cursor/hooks.js +0 -208
  42. package/dist/providers/cursor/hooks.js.map +0 -1
  43. package/dist/providers/cursor/index.js +0 -36
  44. package/dist/providers/cursor/index.js.map +0 -1
  45. package/dist/providers/cursor/install.js +0 -180
  46. package/dist/providers/cursor/install.js.map +0 -1
  47. package/dist/providers/cursor/spawn.js +0 -59
  48. package/dist/providers/cursor/spawn.js.map +0 -1
  49. package/dist/providers/gemini-cli/adapter.js +0 -158
  50. package/dist/providers/gemini-cli/adapter.js.map +0 -1
  51. package/dist/providers/gemini-cli/hooks.js +0 -128
  52. package/dist/providers/gemini-cli/hooks.js.map +0 -1
  53. package/dist/providers/gemini-cli/index.js +0 -39
  54. package/dist/providers/gemini-cli/index.js.map +0 -1
  55. package/dist/providers/gemini-cli/install.js +0 -124
  56. package/dist/providers/gemini-cli/install.js.map +0 -1
  57. package/dist/providers/kimi/adapter.js +0 -145
  58. package/dist/providers/kimi/adapter.js.map +0 -1
  59. package/dist/providers/kimi/hooks.js +0 -79
  60. package/dist/providers/kimi/hooks.js.map +0 -1
  61. package/dist/providers/kimi/index.js +0 -39
  62. package/dist/providers/kimi/index.js.map +0 -1
  63. package/dist/providers/kimi/install.js +0 -124
  64. package/dist/providers/kimi/install.js.map +0 -1
  65. package/dist/providers/opencode/adapter.js +0 -166
  66. package/dist/providers/opencode/adapter.js.map +0 -1
  67. package/dist/providers/opencode/hooks.js +0 -206
  68. package/dist/providers/opencode/hooks.js.map +0 -1
  69. package/dist/providers/opencode/index.js +0 -37
  70. package/dist/providers/opencode/index.js.map +0 -1
  71. package/dist/providers/opencode/install.js +0 -115
  72. package/dist/providers/opencode/install.js.map +0 -1
  73. package/dist/providers/opencode/spawn.js +0 -256
  74. package/dist/providers/opencode/spawn.js.map +0 -1
  75. package/dist/providers/pi/adapter.js +0 -220
  76. package/dist/providers/pi/adapter.js.map +0 -1
  77. package/dist/providers/pi/hooks.js +0 -223
  78. package/dist/providers/pi/hooks.js.map +0 -1
  79. package/dist/providers/pi/index.js +0 -38
  80. package/dist/providers/pi/index.js.map +0 -1
  81. package/dist/providers/pi/install.js +0 -175
  82. package/dist/providers/pi/install.js.map +0 -1
  83. package/dist/providers/pi/spawn.js +0 -187
  84. package/dist/providers/pi/spawn.js.map +0 -1
  85. package/dist/providers/shared/transcript-reader.js +0 -124
  86. package/dist/providers/shared/transcript-reader.js.map +0 -1
  87. package/dist/registry.js +0 -92
  88. package/dist/registry.js.map +0 -1
@@ -1,41 +0,0 @@
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
@@ -1 +0,0 @@
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"}
@@ -1,185 +0,0 @@
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
- // Enrich prompt with CANT bundle, memory bridge, and mental model (T555).
65
- // Best-effort: if CANT context is unavailable, the raw prompt is used.
66
- let enrichedPrompt = context.prompt;
67
- try {
68
- const { buildCantEnrichedPrompt } = await import('../../cant-context.js');
69
- enrichedPrompt = await buildCantEnrichedPrompt({
70
- projectDir: context.workingDirectory ?? process.cwd(),
71
- basePrompt: context.prompt,
72
- agentName: context.options?.agentName ?? undefined,
73
- });
74
- }
75
- catch {
76
- // CANT enrichment unavailable — use raw prompt
77
- }
78
- tmpFile = `/tmp/claude-spawn-${instanceId}.txt`;
79
- await writeFile(tmpFile, enrichedPrompt, 'utf-8');
80
- const args = ['--allow-insecure', '--no-upgrade-check', tmpFile];
81
- const spawnOpts = {
82
- detached: true,
83
- stdio: 'ignore',
84
- };
85
- if (context.workingDirectory) {
86
- spawnOpts.cwd = context.workingDirectory;
87
- }
88
- const child = nodeSpawn('claude', args, spawnOpts);
89
- child.unref();
90
- if (child.pid) {
91
- this.processMap.set(instanceId, {
92
- pid: child.pid,
93
- taskId: context.taskId,
94
- startTime,
95
- });
96
- }
97
- const capturedTmpFile = tmpFile;
98
- child.on('exit', async () => {
99
- this.processMap.delete(instanceId);
100
- try {
101
- await unlink(capturedTmpFile);
102
- }
103
- catch {
104
- // Ignore cleanup errors
105
- }
106
- });
107
- return {
108
- instanceId,
109
- taskId: context.taskId,
110
- providerId: 'claude-code',
111
- status: 'running',
112
- startTime,
113
- };
114
- }
115
- catch (error) {
116
- // Log spawn failure for debugging
117
- console.error(`[ClaudeCodeSpawnProvider] Failed to spawn: ${getErrorMessage(error)}`);
118
- if (tmpFile) {
119
- try {
120
- await unlink(tmpFile);
121
- }
122
- catch {
123
- // Ignore cleanup errors
124
- }
125
- }
126
- return {
127
- instanceId,
128
- taskId: context.taskId,
129
- providerId: 'claude-code',
130
- status: 'failed',
131
- startTime,
132
- endTime: new Date().toISOString(),
133
- error: getErrorMessage(error),
134
- };
135
- }
136
- }
137
- /**
138
- * List currently running Claude subagent processes.
139
- *
140
- * Checks each tracked process via kill(pid, 0) to verify it is still alive.
141
- * Dead processes are automatically cleaned from the tracking map.
142
- *
143
- * @returns Array of spawn results for running processes
144
- */
145
- async listRunning() {
146
- const running = [];
147
- for (const [instanceId, tracked] of this.processMap.entries()) {
148
- try {
149
- process.kill(tracked.pid, 0);
150
- running.push({
151
- instanceId,
152
- taskId: tracked.taskId,
153
- providerId: 'claude-code',
154
- status: 'running',
155
- startTime: tracked.startTime,
156
- });
157
- }
158
- catch {
159
- this.processMap.delete(instanceId);
160
- }
161
- }
162
- return running;
163
- }
164
- /**
165
- * Terminate a running spawn by instance ID.
166
- *
167
- * Sends SIGTERM to the tracked process. If the process is not found
168
- * or has already exited, this is a no-op.
169
- *
170
- * @param instanceId - ID of the spawn instance to terminate
171
- */
172
- async terminate(instanceId) {
173
- const tracked = this.processMap.get(instanceId);
174
- if (!tracked)
175
- return;
176
- try {
177
- process.kill(tracked.pid, 'SIGTERM');
178
- }
179
- catch {
180
- // Process may have already exited
181
- }
182
- this.processMap.delete(instanceId);
183
- }
184
- }
185
- //# sourceMappingURL=spawn.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"spawn.js","sourceRoot":"","sources":["../../../src/providers/claude-code/spawn.ts"],"names":[],"mappings":"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"}
@@ -1,130 +0,0 @@
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
@@ -1 +0,0 @@
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"}
@@ -1,119 +0,0 @@
1
- /**
2
- * Claude Code TaskSyncProvider — bridges Claude's TodoWrite format
3
- * to the provider-agnostic reconciliation system.
4
- *
5
- * All Claude Code / TodoWrite-specific parsing lives here.
6
- * The core reconciliation engine never sees TodoWrite formats.
7
- */
8
- import { readFile, stat } from 'node:fs/promises';
9
- import { join } from 'node:path';
10
- // ---------------------------------------------------------------------------
11
- // Parsing helpers
12
- // ---------------------------------------------------------------------------
13
- /**
14
- * Parse a CLEO task ID from TodoWrite content prefix: "[T001] ..." -> "T001".
15
- */
16
- function parseTaskId(content) {
17
- const match = content.match(/^\[T(\d+)\]/);
18
- return match ? `T${match[1]}` : null;
19
- }
20
- /**
21
- * Strip ID and status prefixes from content to extract the clean title.
22
- */
23
- function stripPrefixes(content) {
24
- return content
25
- .replace(/^\[T\d+\]\s*/, '')
26
- .replace(/^\[!\]\s*/, '')
27
- .replace(/^\[BLOCKED\]\s*/, '');
28
- }
29
- /**
30
- * Map TodoWrite status to normalized ExternalTaskStatus.
31
- */
32
- function mapStatus(twStatus) {
33
- switch (twStatus) {
34
- case 'completed':
35
- return 'completed';
36
- case 'in_progress':
37
- return 'active';
38
- case 'pending':
39
- return 'pending';
40
- default:
41
- return 'pending';
42
- }
43
- }
44
- /**
45
- * Resolve the TodoWrite state file path.
46
- * Claude Code writes its TodoWrite state to a known location.
47
- */
48
- function getTodoWriteFilePath(projectDir) {
49
- return join(projectDir, '.cleo', 'sync', 'todowrite-state.json');
50
- }
51
- // ---------------------------------------------------------------------------
52
- // Provider implementation
53
- // ---------------------------------------------------------------------------
54
- /**
55
- * Claude Code TaskSyncProvider.
56
- *
57
- * Reads Claude's TodoWrite JSON state, parses [T001]-prefixed task IDs
58
- * and status, and returns normalized ExternalTask[].
59
- *
60
- * Optional: accepts a custom file path for testing.
61
- *
62
- * @remarks
63
- * TodoWrite items with `[T001]`-style prefixes are mapped to their CLEO
64
- * task IDs. Items without a prefix receive a synthetic `tw-new-N` ID
65
- * for reconciliation. The provider reads from
66
- * `.cleo/sync/todowrite-state.json` by default.
67
- */
68
- export class ClaudeCodeTaskSyncProvider {
69
- /** Optional override path for the TodoWrite state file (used in tests). */
70
- customFilePath;
71
- constructor(options) {
72
- this.customFilePath = options?.filePath;
73
- }
74
- /** Retrieve external tasks from Claude's TodoWrite state file. */
75
- async getExternalTasks(projectDir) {
76
- const filePath = this.customFilePath ?? getTodoWriteFilePath(projectDir);
77
- // Check file exists
78
- try {
79
- await stat(filePath);
80
- }
81
- catch {
82
- // No TodoWrite state — return empty (no tasks to sync)
83
- return [];
84
- }
85
- // Parse the TodoWrite JSON
86
- const raw = await readFile(filePath, 'utf-8');
87
- let state;
88
- try {
89
- state = JSON.parse(raw);
90
- }
91
- catch {
92
- return []; // Malformed JSON — treat as empty
93
- }
94
- if (!state.todos || !Array.isArray(state.todos)) {
95
- return [];
96
- }
97
- const tasks = [];
98
- let syntheticIndex = 0;
99
- for (const item of state.todos) {
100
- const cleoTaskId = parseTaskId(item.content);
101
- const title = cleoTaskId ? stripPrefixes(item.content).trim() : item.content.trim();
102
- if (!title)
103
- continue;
104
- tasks.push({
105
- externalId: cleoTaskId ?? `tw-new-${syntheticIndex++}`,
106
- title,
107
- status: mapStatus(item.status),
108
- providerMeta: {
109
- source: 'todowrite',
110
- cleoTaskId,
111
- activeForm: item.activeForm,
112
- rawContent: item.content,
113
- },
114
- });
115
- }
116
- return tasks;
117
- }
118
- }
119
- //# sourceMappingURL=task-sync.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"task-sync.js","sourceRoot":"","sources":["../../../src/providers/claude-code/task-sync.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAkBjC,8EAA8E;AAC9E,kBAAkB;AAClB,8EAA8E;AAE9E;;GAEG;AACH,SAAS,WAAW,CAAC,OAAe;IAClC,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;IAC3C,OAAO,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;AACvC,CAAC;AAED;;GAEG;AACH,SAAS,aAAa,CAAC,OAAe;IACpC,OAAO,OAAO;SACX,OAAO,CAAC,cAAc,EAAE,EAAE,CAAC;SAC3B,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC;SACxB,OAAO,CAAC,iBAAiB,EAAE,EAAE,CAAC,CAAC;AACpC,CAAC;AAED;;GAEG;AACH,SAAS,SAAS,CAAC,QAAiC;IAClD,QAAQ,QAAQ,EAAE,CAAC;QACjB,KAAK,WAAW;YACd,OAAO,WAAW,CAAC;QACrB,KAAK,aAAa;YAChB,OAAO,QAAQ,CAAC;QAClB,KAAK,SAAS;YACZ,OAAO,SAAS,CAAC;QACnB;YACE,OAAO,SAAS,CAAC;IACrB,CAAC;AACH,CAAC;AAED;;;GAGG;AACH,SAAS,oBAAoB,CAAC,UAAkB;IAC9C,OAAO,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,sBAAsB,CAAC,CAAC;AACnE,CAAC;AAED,8EAA8E;AAC9E,0BAA0B;AAC1B,8EAA8E;AAE9E;;;;;;;;;;;;;GAaG;AACH,MAAM,OAAO,0BAA0B;IACrC,2EAA2E;IAC1D,cAAc,CAAU;IAEzC,YAAY,OAA+B;QACzC,IAAI,CAAC,cAAc,GAAG,OAAO,EAAE,QAAQ,CAAC;IAC1C,CAAC;IAED,kEAAkE;IAClE,KAAK,CAAC,gBAAgB,CAAC,UAAkB;QACvC,MAAM,QAAQ,GAAG,IAAI,CAAC,cAAc,IAAI,oBAAoB,CAAC,UAAU,CAAC,CAAC;QAEzE,oBAAoB;QACpB,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,QAAQ,CAAC,CAAC;QACvB,CAAC;QAAC,MAAM,CAAC;YACP,uDAAuD;YACvD,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,2BAA2B;QAC3B,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QAC9C,IAAI,KAAqB,CAAC;QAC1B,IAAI,CAAC;YACH,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAmB,CAAC;QAC5C,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,CAAC,CAAC,kCAAkC;QAC/C,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;YAChD,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,KAAK,GAAmB,EAAE,CAAC;QACjC,IAAI,cAAc,GAAG,CAAC,CAAC;QAEvB,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;YAC/B,MAAM,UAAU,GAAG,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC7C,MAAM,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;YAEpF,IAAI,CAAC,KAAK;gBAAE,SAAS;YAErB,KAAK,CAAC,IAAI,CAAC;gBACT,UAAU,EAAE,UAAU,IAAI,UAAU,cAAc,EAAE,EAAE;gBACtD,KAAK;gBACL,MAAM,EAAE,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC;gBAC9B,YAAY,EAAE;oBACZ,MAAM,EAAE,WAAW;oBACnB,UAAU;oBACV,UAAU,EAAE,IAAI,CAAC,UAAU;oBAC3B,UAAU,EAAE,IAAI,CAAC,OAAO;iBACzB;aACF,CAAC,CAAC;QACL,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;CACF"}
@@ -1,29 +0,0 @@
1
- /**
2
- * Transport provider for the Claude Code adapter.
3
- *
4
- * Implements AdapterTransportProvider to supply Claude Code's
5
- * native inter-agent transport mechanism.
6
- *
7
- * @task T5240
8
- */
9
- /**
10
- * Transport provider for Claude Code inter-agent communication.
11
- *
12
- * @remarks
13
- * Currently returns null from {@link createTransport} because actual transport
14
- * creation is handled by the signaldock factory which checks for this adapter's
15
- * transport capability flag. Full wiring will be completed in Phase 5 of the
16
- * adapter system rollout.
17
- */
18
- export class ClaudeCodeTransportProvider {
19
- /** Provider-specific transport name used for capability negotiation. */
20
- transportName = 'claude-code';
21
- /** Create a transport instance for inter-agent messaging. */
22
- createTransport() {
23
- // Returns null — actual transport creation is handled by the signaldock factory
24
- // which checks for this adapter's transport capability.
25
- // Full wiring will be completed in Phase 5.
26
- return null;
27
- }
28
- }
29
- //# sourceMappingURL=transport.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transport.js","sourceRoot":"","sources":["../../../src/providers/claude-code/transport.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH;;;;;;;;GAQG;AACH,MAAM,OAAO,2BAA2B;IACtC,wEAAwE;IAC/D,aAAa,GAAG,aAAa,CAAC;IAEvC,6DAA6D;IAC7D,eAAe;QACb,gFAAgF;QAChF,wDAAwD;QACxD,4CAA4C;QAC5C,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -1,146 +0,0 @@
1
- /**
2
- * Codex CLI Adapter
3
- *
4
- * Main CLEOProviderAdapter implementation for OpenAI Codex CLI.
5
- * Provides hooks and install capabilities for CLEO integration.
6
- *
7
- * @task T162
8
- * @epic T134
9
- */
10
- import { exec } from 'node:child_process';
11
- import { existsSync } from 'node:fs';
12
- import { homedir } from 'node:os';
13
- import { join } from 'node:path';
14
- import { promisify } from 'node:util';
15
- import { CodexHookProvider } from './hooks.js';
16
- import { CodexInstallProvider } from './install.js';
17
- const execAsync = promisify(exec);
18
- /**
19
- * CLEO provider adapter for OpenAI Codex CLI.
20
- *
21
- * Bridges CLEO's adapter system with Codex CLI's native capabilities:
22
- * - Hooks: Maps Codex events (SessionStart, PromptSubmit, ResponseComplete) to CAAMP events
23
- * - Install: Ensures AGENTS.md references for CLEO instruction files
24
- *
25
- * @remarks
26
- * Codex CLI supports only 3 canonical events (SessionStart, PromptSubmit,
27
- * ResponseComplete) and has no spawn or transport capabilities. Integration
28
- * is primarily through instruction files (AGENTS.md).
29
- *
30
- * @task T162
31
- * @epic T134
32
- */
33
- export class CodexAdapter {
34
- /** Unique provider identifier. */
35
- id = 'codex';
36
- /** Human-readable provider name. */
37
- name = 'Codex';
38
- /** Adapter version string. */
39
- version = '1.0.0';
40
- /** Declared capabilities for this provider. */
41
- capabilities = {
42
- supportsHooks: true,
43
- supportedHookEvents: ['SessionStart', 'UserPromptSubmit', 'Stop'],
44
- supportsSpawn: false,
45
- supportsInstall: true,
46
- supportsInstructionFiles: false,
47
- supportsContextMonitor: false,
48
- supportsStatusline: false,
49
- supportsProviderPaths: false,
50
- supportsTransport: false,
51
- supportsTaskSync: false,
52
- };
53
- /** Hook provider for CAAMP event mapping. */
54
- hooks;
55
- /** Install provider for managing instruction files. */
56
- install;
57
- /** Project directory this adapter was initialized with, or null. */
58
- projectDir = null;
59
- /** Whether {@link initialize} has been called. */
60
- initialized = false;
61
- constructor() {
62
- this.hooks = new CodexHookProvider();
63
- this.install = new CodexInstallProvider();
64
- }
65
- /**
66
- * Initialize the adapter for a given project directory.
67
- *
68
- * @param projectDir - Root directory of the project
69
- * @task T162
70
- */
71
- async initialize(projectDir) {
72
- this.projectDir = projectDir;
73
- this.initialized = true;
74
- }
75
- /**
76
- * Dispose the adapter and clean up resources.
77
- *
78
- * Unregisters hooks and releases any tracked state.
79
- * @task T162
80
- */
81
- async dispose() {
82
- if (this.hooks.isRegistered()) {
83
- await this.hooks.unregisterNativeHooks();
84
- }
85
- this.initialized = false;
86
- this.projectDir = null;
87
- }
88
- /**
89
- * Run a health check to verify Codex CLI is accessible.
90
- *
91
- * Checks:
92
- * 1. Adapter has been initialized
93
- * 2. Codex CLI binary is available in PATH
94
- * 3. ~/.codex/ configuration directory exists
95
- *
96
- * @returns Health status with details about each check
97
- * @task T162
98
- */
99
- async healthCheck() {
100
- const details = {};
101
- if (!this.initialized) {
102
- return {
103
- healthy: false,
104
- provider: this.id,
105
- details: { error: 'Adapter not initialized' },
106
- };
107
- }
108
- // Check Codex CLI availability
109
- let cliAvailable = false;
110
- try {
111
- const { stdout } = await execAsync('which codex');
112
- cliAvailable = stdout.trim().length > 0;
113
- details.cliPath = stdout.trim();
114
- }
115
- catch {
116
- details.cliAvailable = false;
117
- }
118
- // Check for Codex CLI config directory
119
- const codexConfigDir = join(homedir(), '.codex');
120
- const configExists = existsSync(codexConfigDir);
121
- details.configDirExists = configExists;
122
- // Healthy if CLI is available (primary requirement)
123
- const healthy = cliAvailable;
124
- details.cliAvailable = cliAvailable;
125
- return {
126
- healthy,
127
- provider: this.id,
128
- details,
129
- };
130
- }
131
- /**
132
- * Check whether the adapter has been initialized.
133
- * @task T162
134
- */
135
- isInitialized() {
136
- return this.initialized;
137
- }
138
- /**
139
- * Get the project directory this adapter was initialized with.
140
- * @task T162
141
- */
142
- getProjectDir() {
143
- return this.projectDir;
144
- }
145
- }
146
- //# sourceMappingURL=adapter.js.map