@cleocode/adapters 2026.4.11 → 2026.4.13
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/package.json +3 -3
- package/src/__tests__/claude-code-adapter.test.ts +1 -3
- package/src/__tests__/cursor-adapter.test.ts +1 -3
- package/src/__tests__/opencode-adapter.test.ts +1 -3
- package/src/providers/claude-code/__tests__/adapter.test.ts +0 -12
- package/src/providers/claude-code/adapter.ts +0 -1
- package/src/providers/claude-code/install.ts +0 -1
- package/src/providers/codex/adapter.ts +0 -1
- package/src/providers/codex/install.ts +0 -1
- package/src/providers/cursor/__tests__/adapter.test.ts +0 -12
- package/src/providers/cursor/adapter.ts +0 -1
- package/src/providers/cursor/install.ts +0 -1
- package/src/providers/gemini-cli/adapter.ts +0 -1
- package/src/providers/gemini-cli/install.ts +0 -1
- package/src/providers/kimi/adapter.ts +0 -1
- package/src/providers/kimi/install.ts +0 -1
- package/src/providers/opencode/__tests__/adapter.test.ts +0 -12
- package/src/providers/opencode/adapter.ts +0 -1
- package/src/providers/opencode/install.ts +0 -1
- package/dist/index.d.ts +0 -23
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -3258
- package/dist/index.js.map +0 -7
- package/dist/providers/claude-code/adapter.d.ts +0 -95
- package/dist/providers/claude-code/adapter.d.ts.map +0 -1
- package/dist/providers/claude-code/adapter.js +0 -185
- package/dist/providers/claude-code/adapter.js.map +0 -1
- package/dist/providers/claude-code/context-monitor.d.ts +0 -35
- package/dist/providers/claude-code/context-monitor.d.ts.map +0 -1
- package/dist/providers/claude-code/context-monitor.js +0 -159
- package/dist/providers/claude-code/context-monitor.js.map +0 -1
- package/dist/providers/claude-code/hooks.d.ts +0 -146
- package/dist/providers/claude-code/hooks.d.ts.map +0 -1
- package/dist/providers/claude-code/hooks.js +0 -286
- package/dist/providers/claude-code/hooks.js.map +0 -1
- package/dist/providers/claude-code/index.d.ts +0 -39
- package/dist/providers/claude-code/index.d.ts.map +0 -1
- package/dist/providers/claude-code/index.js +0 -41
- package/dist/providers/claude-code/index.js.map +0 -1
- package/dist/providers/claude-code/install.d.ts +0 -67
- package/dist/providers/claude-code/install.d.ts.map +0 -1
- package/dist/providers/claude-code/install.js +0 -161
- package/dist/providers/claude-code/install.js.map +0 -1
- package/dist/providers/claude-code/paths.d.ts +0 -32
- package/dist/providers/claude-code/paths.d.ts.map +0 -1
- package/dist/providers/claude-code/paths.js +0 -41
- package/dist/providers/claude-code/paths.js.map +0 -1
- package/dist/providers/claude-code/spawn.d.ts +0 -67
- package/dist/providers/claude-code/spawn.d.ts.map +0 -1
- package/dist/providers/claude-code/spawn.js +0 -171
- package/dist/providers/claude-code/spawn.js.map +0 -1
- package/dist/providers/claude-code/statusline.d.ts +0 -68
- package/dist/providers/claude-code/statusline.d.ts.map +0 -1
- package/dist/providers/claude-code/statusline.js +0 -130
- package/dist/providers/claude-code/statusline.js.map +0 -1
- package/dist/providers/claude-code/task-sync.d.ts +0 -32
- package/dist/providers/claude-code/task-sync.d.ts.map +0 -1
- package/dist/providers/claude-code/task-sync.js +0 -119
- package/dist/providers/claude-code/task-sync.js.map +0 -1
- package/dist/providers/claude-code/transport.d.ts +0 -25
- package/dist/providers/claude-code/transport.d.ts.map +0 -1
- package/dist/providers/claude-code/transport.js +0 -29
- package/dist/providers/claude-code/transport.js.map +0 -1
- package/dist/providers/codex/adapter.d.ts +0 -83
- package/dist/providers/codex/adapter.d.ts.map +0 -1
- package/dist/providers/codex/adapter.js +0 -147
- package/dist/providers/codex/adapter.js.map +0 -1
- package/dist/providers/codex/hooks.d.ts +0 -91
- package/dist/providers/codex/hooks.d.ts.map +0 -1
- package/dist/providers/codex/hooks.js +0 -113
- package/dist/providers/codex/hooks.js.map +0 -1
- package/dist/providers/codex/index.d.ts +0 -37
- package/dist/providers/codex/index.d.ts.map +0 -1
- package/dist/providers/codex/index.js +0 -39
- package/dist/providers/codex/index.js.map +0 -1
- package/dist/providers/codex/install.d.ts +0 -65
- package/dist/providers/codex/install.d.ts.map +0 -1
- package/dist/providers/codex/install.js +0 -125
- package/dist/providers/codex/install.js.map +0 -1
- package/dist/providers/cursor/adapter.d.ts +0 -76
- package/dist/providers/cursor/adapter.d.ts.map +0 -1
- package/dist/providers/cursor/adapter.js +0 -152
- package/dist/providers/cursor/adapter.js.map +0 -1
- package/dist/providers/cursor/hooks.d.ts +0 -140
- package/dist/providers/cursor/hooks.d.ts.map +0 -1
- package/dist/providers/cursor/hooks.js +0 -208
- package/dist/providers/cursor/hooks.js.map +0 -1
- package/dist/providers/cursor/index.d.ts +0 -34
- package/dist/providers/cursor/index.d.ts.map +0 -1
- package/dist/providers/cursor/index.js +0 -36
- package/dist/providers/cursor/index.js.map +0 -1
- package/dist/providers/cursor/install.d.ts +0 -87
- package/dist/providers/cursor/install.d.ts.map +0 -1
- package/dist/providers/cursor/install.js +0 -181
- 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/gemini-cli/adapter.d.ts +0 -84
- package/dist/providers/gemini-cli/adapter.d.ts.map +0 -1
- package/dist/providers/gemini-cli/adapter.js +0 -159
- package/dist/providers/gemini-cli/adapter.js.map +0 -1
- package/dist/providers/gemini-cli/hooks.d.ts +0 -99
- package/dist/providers/gemini-cli/hooks.d.ts.map +0 -1
- package/dist/providers/gemini-cli/hooks.js +0 -128
- package/dist/providers/gemini-cli/hooks.js.map +0 -1
- package/dist/providers/gemini-cli/index.d.ts +0 -37
- package/dist/providers/gemini-cli/index.d.ts.map +0 -1
- package/dist/providers/gemini-cli/index.js +0 -39
- package/dist/providers/gemini-cli/index.js.map +0 -1
- package/dist/providers/gemini-cli/install.d.ts +0 -65
- package/dist/providers/gemini-cli/install.d.ts.map +0 -1
- package/dist/providers/gemini-cli/install.js +0 -125
- package/dist/providers/gemini-cli/install.js.map +0 -1
- package/dist/providers/kimi/adapter.d.ts +0 -85
- package/dist/providers/kimi/adapter.d.ts.map +0 -1
- package/dist/providers/kimi/adapter.js +0 -146
- package/dist/providers/kimi/adapter.js.map +0 -1
- package/dist/providers/kimi/hooks.d.ts +0 -70
- package/dist/providers/kimi/hooks.d.ts.map +0 -1
- package/dist/providers/kimi/hooks.js +0 -79
- package/dist/providers/kimi/hooks.js.map +0 -1
- package/dist/providers/kimi/index.d.ts +0 -37
- package/dist/providers/kimi/index.d.ts.map +0 -1
- package/dist/providers/kimi/index.js +0 -39
- package/dist/providers/kimi/index.js.map +0 -1
- package/dist/providers/kimi/install.d.ts +0 -65
- package/dist/providers/kimi/install.d.ts.map +0 -1
- package/dist/providers/kimi/install.js +0 -125
- package/dist/providers/kimi/install.js.map +0 -1
- package/dist/providers/opencode/adapter.d.ts +0 -83
- package/dist/providers/opencode/adapter.d.ts.map +0 -1
- package/dist/providers/opencode/adapter.js +0 -167
- package/dist/providers/opencode/adapter.js.map +0 -1
- package/dist/providers/opencode/hooks.d.ts +0 -136
- package/dist/providers/opencode/hooks.d.ts.map +0 -1
- package/dist/providers/opencode/hooks.js +0 -206
- package/dist/providers/opencode/hooks.js.map +0 -1
- package/dist/providers/opencode/index.d.ts +0 -35
- package/dist/providers/opencode/index.d.ts.map +0 -1
- package/dist/providers/opencode/index.js +0 -37
- package/dist/providers/opencode/index.js.map +0 -1
- package/dist/providers/opencode/install.d.ts +0 -56
- package/dist/providers/opencode/install.d.ts.map +0 -1
- package/dist/providers/opencode/install.js +0 -116
- package/dist/providers/opencode/install.js.map +0 -1
- package/dist/providers/opencode/spawn.d.ts +0 -94
- package/dist/providers/opencode/spawn.d.ts.map +0 -1
- package/dist/providers/opencode/spawn.js +0 -241
- package/dist/providers/opencode/spawn.js.map +0 -1
- package/dist/providers/shared/transcript-reader.d.ts +0 -58
- package/dist/providers/shared/transcript-reader.d.ts.map +0 -1
- package/dist/providers/shared/transcript-reader.js +0 -124
- package/dist/providers/shared/transcript-reader.js.map +0 -1
- package/dist/registry.d.ts +0 -88
- package/dist/registry.d.ts.map +0 -1
- package/dist/registry.js +0 -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,67 +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 type { AdapterSpawnProvider, SpawnContext, SpawnResult } from '@cleocode/contracts';
|
|
14
|
-
/**
|
|
15
|
-
* Spawn provider for Claude Code.
|
|
16
|
-
*
|
|
17
|
-
* Spawns detached Claude CLI processes for subagent execution.
|
|
18
|
-
* Each spawn writes its prompt to a temporary file, then runs
|
|
19
|
-
* `claude --allow-insecure --no-upgrade-check <tmpFile>` as a
|
|
20
|
-
* detached, unref'd child process.
|
|
21
|
-
*
|
|
22
|
-
* @remarks
|
|
23
|
-
* The provider uses `--allow-insecure --no-upgrade-check` flags to
|
|
24
|
-
* ensure the Claude CLI starts without interactive prompts. Prompts are
|
|
25
|
-
* written to temporary files under `/tmp/` and cleaned up after the
|
|
26
|
-
* child process exits. Processes are tracked by instance ID in an
|
|
27
|
-
* in-memory map and verified via `kill(pid, 0)` liveness checks.
|
|
28
|
-
*/
|
|
29
|
-
export declare class ClaudeCodeSpawnProvider implements AdapterSpawnProvider {
|
|
30
|
-
/** Map of instance IDs to tracked process info. */
|
|
31
|
-
private processMap;
|
|
32
|
-
/**
|
|
33
|
-
* Check if the Claude CLI is available in PATH.
|
|
34
|
-
*
|
|
35
|
-
* @returns true if `claude` is found via `which`
|
|
36
|
-
*/
|
|
37
|
-
canSpawn(): Promise<boolean>;
|
|
38
|
-
/**
|
|
39
|
-
* Spawn a subagent via Claude CLI.
|
|
40
|
-
*
|
|
41
|
-
* Writes the prompt to a temporary file and spawns a detached Claude
|
|
42
|
-
* process. The process runs independently of the parent.
|
|
43
|
-
*
|
|
44
|
-
* @param context - Spawn context with taskId, prompt, and options
|
|
45
|
-
* @returns Spawn result with instance ID and status
|
|
46
|
-
*/
|
|
47
|
-
spawn(context: SpawnContext): Promise<SpawnResult>;
|
|
48
|
-
/**
|
|
49
|
-
* List currently running Claude subagent processes.
|
|
50
|
-
*
|
|
51
|
-
* Checks each tracked process via kill(pid, 0) to verify it is still alive.
|
|
52
|
-
* Dead processes are automatically cleaned from the tracking map.
|
|
53
|
-
*
|
|
54
|
-
* @returns Array of spawn results for running processes
|
|
55
|
-
*/
|
|
56
|
-
listRunning(): Promise<SpawnResult[]>;
|
|
57
|
-
/**
|
|
58
|
-
* Terminate a running spawn by instance ID.
|
|
59
|
-
*
|
|
60
|
-
* Sends SIGTERM to the tracked process. If the process is not found
|
|
61
|
-
* or has already exited, this is a no-op.
|
|
62
|
-
*
|
|
63
|
-
* @param instanceId - ID of the spawn instance to terminate
|
|
64
|
-
*/
|
|
65
|
-
terminate(instanceId: string): Promise<void>;
|
|
66
|
-
}
|
|
67
|
-
//# sourceMappingURL=spawn.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spawn.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/spawn.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAKH,OAAO,KAAK,EAAE,oBAAoB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAY3F;;;;;;;;;;;;;;GAcG;AACH,qBAAa,uBAAwB,YAAW,oBAAoB;IAClE,mDAAmD;IACnD,OAAO,CAAC,UAAU,CAAqC;IAEvD;;;;OAIG;IACG,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC;IASlC;;;;;;;;OAQG;IACG,KAAK,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC;IAuExD;;;;;;;OAOG;IACG,WAAW,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAqB3C;;;;;;;OAOG;IACG,SAAS,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAWnD"}
|
|
@@ -1,171 +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
|
-
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spawn.js","sourceRoot":"","sources":["../../../src/providers/claude-code/spawn.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,68 +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
|
-
type StatuslineStatus = 'configured' | 'not_configured' | 'custom_no_cleo' | 'no_settings';
|
|
10
|
-
/**
|
|
11
|
-
* Check if statusline integration is configured.
|
|
12
|
-
* Returns the current integration status.
|
|
13
|
-
*
|
|
14
|
-
* @remarks
|
|
15
|
-
* Reads Claude Code's settings.json and inspects the `statusLine` field
|
|
16
|
-
* to determine whether CLEO context monitoring is active.
|
|
17
|
-
*
|
|
18
|
-
* @returns One of: 'configured', 'not_configured', 'custom_no_cleo', 'no_settings'
|
|
19
|
-
*
|
|
20
|
-
* @example
|
|
21
|
-
* ```typescript
|
|
22
|
-
* import { checkStatuslineIntegration } from './statusline.js';
|
|
23
|
-
*
|
|
24
|
-
* const status = checkStatuslineIntegration();
|
|
25
|
-
* if (status === 'not_configured') {
|
|
26
|
-
* console.log('Run cleo install to set up context monitoring');
|
|
27
|
-
* }
|
|
28
|
-
* ```
|
|
29
|
-
*/
|
|
30
|
-
export declare function checkStatuslineIntegration(): StatuslineStatus;
|
|
31
|
-
/**
|
|
32
|
-
* Get the statusline setup command for Claude Code settings.
|
|
33
|
-
*
|
|
34
|
-
* @remarks
|
|
35
|
-
* Returns a JSON-serializable object that can be merged into
|
|
36
|
-
* Claude Code's settings.json to enable context monitoring.
|
|
37
|
-
*
|
|
38
|
-
* @param cleoHome - Absolute path to the CLEO home directory
|
|
39
|
-
* @returns Settings object containing the statusLine configuration
|
|
40
|
-
*
|
|
41
|
-
* @example
|
|
42
|
-
* ```typescript
|
|
43
|
-
* import { getStatuslineConfig } from './statusline.js';
|
|
44
|
-
*
|
|
45
|
-
* const config = getStatuslineConfig('/home/user/.cleo');
|
|
46
|
-
* ```
|
|
47
|
-
*/
|
|
48
|
-
export declare function getStatuslineConfig(cleoHome: string): Record<string, unknown>;
|
|
49
|
-
/**
|
|
50
|
-
* Get human-readable setup instructions.
|
|
51
|
-
*
|
|
52
|
-
* @remarks
|
|
53
|
-
* Returns a multi-line string with file path, JSON config, and explanation
|
|
54
|
-
* suitable for display to the user.
|
|
55
|
-
*
|
|
56
|
-
* @param cleoHome - Absolute path to the CLEO home directory
|
|
57
|
-
* @returns Formatted setup instructions string
|
|
58
|
-
*
|
|
59
|
-
* @example
|
|
60
|
-
* ```typescript
|
|
61
|
-
* import { getSetupInstructions } from './statusline.js';
|
|
62
|
-
*
|
|
63
|
-
* console.log(getSetupInstructions('/home/user/.cleo'));
|
|
64
|
-
* ```
|
|
65
|
-
*/
|
|
66
|
-
export declare function getSetupInstructions(cleoHome: string): string;
|
|
67
|
-
export {};
|
|
68
|
-
//# sourceMappingURL=statusline.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"statusline.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/statusline.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,KAAK,gBAAgB,GAAG,YAAY,GAAG,gBAAgB,GAAG,gBAAgB,GAAG,aAAa,CAAC;AAa3F;;;;;;;;;;;;;;;;;;;GAmBG;AACH,wBAAgB,0BAA0B,IAAI,gBAAgB,CAwC7D;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAO7E;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAW7D"}
|
|
@@ -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,32 +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 type { ExternalTask, ExternalTaskProvider } from '@cleocode/contracts';
|
|
9
|
-
/**
|
|
10
|
-
* Claude Code TaskSyncProvider.
|
|
11
|
-
*
|
|
12
|
-
* Reads Claude's TodoWrite JSON state, parses [T001]-prefixed task IDs
|
|
13
|
-
* and status, and returns normalized ExternalTask[].
|
|
14
|
-
*
|
|
15
|
-
* Optional: accepts a custom file path for testing.
|
|
16
|
-
*
|
|
17
|
-
* @remarks
|
|
18
|
-
* TodoWrite items with `[T001]`-style prefixes are mapped to their CLEO
|
|
19
|
-
* task IDs. Items without a prefix receive a synthetic `tw-new-N` ID
|
|
20
|
-
* for reconciliation. The provider reads from
|
|
21
|
-
* `.cleo/sync/todowrite-state.json` by default.
|
|
22
|
-
*/
|
|
23
|
-
export declare class ClaudeCodeTaskSyncProvider implements ExternalTaskProvider {
|
|
24
|
-
/** Optional override path for the TodoWrite state file (used in tests). */
|
|
25
|
-
private readonly customFilePath?;
|
|
26
|
-
constructor(options?: {
|
|
27
|
-
filePath?: string;
|
|
28
|
-
});
|
|
29
|
-
/** Retrieve external tasks from Claude's TodoWrite state file. */
|
|
30
|
-
getExternalTasks(projectDir: string): Promise<ExternalTask[]>;
|
|
31
|
-
}
|
|
32
|
-
//# sourceMappingURL=task-sync.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"task-sync.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/task-sync.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAKH,OAAO,KAAK,EAAE,YAAY,EAAE,oBAAoB,EAAsB,MAAM,qBAAqB,CAAC;AAkElG;;;;;;;;;;;;;GAaG;AACH,qBAAa,0BAA2B,YAAW,oBAAoB;IACrE,2EAA2E;IAC3E,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAS;gBAE7B,OAAO,CAAC,EAAE;QAAE,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE;IAI3C,kEAAkE;IAC5D,gBAAgB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;CAgDpE"}
|
|
@@ -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":"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"}
|