@cleocode/adapters 2.0.0

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 (217) hide show
  1. package/dist/index.d.ts +27 -0
  2. package/dist/index.d.ts.map +1 -0
  3. package/dist/index.js +1927 -0
  4. package/dist/index.js.map +7 -0
  5. package/dist/providers/claude-code/adapter.d.ts +75 -0
  6. package/dist/providers/claude-code/adapter.d.ts.map +1 -0
  7. package/dist/providers/claude-code/adapter.js +154 -0
  8. package/dist/providers/claude-code/adapter.js.map +1 -0
  9. package/dist/providers/claude-code/context-monitor.d.ts +24 -0
  10. package/dist/providers/claude-code/context-monitor.d.ts.map +1 -0
  11. package/dist/providers/claude-code/context-monitor.js +148 -0
  12. package/dist/providers/claude-code/context-monitor.js.map +1 -0
  13. package/dist/providers/claude-code/hooks.d.ts +59 -0
  14. package/dist/providers/claude-code/hooks.d.ts.map +1 -0
  15. package/dist/providers/claude-code/hooks.js +77 -0
  16. package/dist/providers/claude-code/hooks.js.map +1 -0
  17. package/dist/providers/claude-code/index.d.ts +24 -0
  18. package/dist/providers/claude-code/index.d.ts.map +1 -0
  19. package/dist/providers/claude-code/index.js +26 -0
  20. package/dist/providers/claude-code/index.js.map +1 -0
  21. package/dist/providers/claude-code/install.d.ts +75 -0
  22. package/dist/providers/claude-code/install.d.ts.map +1 -0
  23. package/dist/providers/claude-code/install.js +237 -0
  24. package/dist/providers/claude-code/install.js.map +1 -0
  25. package/dist/providers/claude-code/paths.d.ts +24 -0
  26. package/dist/providers/claude-code/paths.d.ts.map +1 -0
  27. package/dist/providers/claude-code/paths.js +33 -0
  28. package/dist/providers/claude-code/paths.js.map +1 -0
  29. package/dist/providers/claude-code/spawn.d.ts +60 -0
  30. package/dist/providers/claude-code/spawn.d.ts.map +1 -0
  31. package/dist/providers/claude-code/spawn.js +160 -0
  32. package/dist/providers/claude-code/spawn.js.map +1 -0
  33. package/dist/providers/claude-code/statusline.d.ts +24 -0
  34. package/dist/providers/claude-code/statusline.d.ts.map +1 -0
  35. package/dist/providers/claude-code/statusline.js +85 -0
  36. package/dist/providers/claude-code/statusline.js.map +1 -0
  37. package/dist/providers/claude-code/task-sync.d.ts +27 -0
  38. package/dist/providers/claude-code/task-sync.d.ts.map +1 -0
  39. package/dist/providers/claude-code/task-sync.js +124 -0
  40. package/dist/providers/claude-code/task-sync.js.map +1 -0
  41. package/dist/providers/claude-code/transport.d.ts +14 -0
  42. package/dist/providers/claude-code/transport.d.ts.map +1 -0
  43. package/dist/providers/claude-code/transport.js +18 -0
  44. package/dist/providers/claude-code/transport.js.map +1 -0
  45. package/dist/providers/cursor/adapter.d.ts +62 -0
  46. package/dist/providers/cursor/adapter.d.ts.map +1 -0
  47. package/dist/providers/cursor/adapter.js +124 -0
  48. package/dist/providers/cursor/adapter.js.map +1 -0
  49. package/dist/providers/cursor/hooks.d.ts +48 -0
  50. package/dist/providers/cursor/hooks.d.ts.map +1 -0
  51. package/dist/providers/cursor/hooks.js +55 -0
  52. package/dist/providers/cursor/hooks.js.map +1 -0
  53. package/dist/providers/cursor/index.d.ts +19 -0
  54. package/dist/providers/cursor/index.d.ts.map +1 -0
  55. package/dist/providers/cursor/index.js +21 -0
  56. package/dist/providers/cursor/index.js.map +1 -0
  57. package/dist/providers/cursor/install.d.ts +94 -0
  58. package/dist/providers/cursor/install.d.ts.map +1 -0
  59. package/dist/providers/cursor/install.js +241 -0
  60. package/dist/providers/cursor/install.js.map +1 -0
  61. package/dist/providers/cursor/spawn.d.ts +50 -0
  62. package/dist/providers/cursor/spawn.d.ts.map +1 -0
  63. package/dist/providers/cursor/spawn.js +59 -0
  64. package/dist/providers/cursor/spawn.js.map +1 -0
  65. package/dist/providers/opencode/adapter.d.ts +67 -0
  66. package/dist/providers/opencode/adapter.d.ts.map +1 -0
  67. package/dist/providers/opencode/adapter.js +144 -0
  68. package/dist/providers/opencode/adapter.js.map +1 -0
  69. package/dist/providers/opencode/hooks.d.ts +66 -0
  70. package/dist/providers/opencode/hooks.d.ts.map +1 -0
  71. package/dist/providers/opencode/hooks.js +89 -0
  72. package/dist/providers/opencode/hooks.js.map +1 -0
  73. package/dist/providers/opencode/index.d.ts +20 -0
  74. package/dist/providers/opencode/index.d.ts.map +1 -0
  75. package/dist/providers/opencode/index.js +22 -0
  76. package/dist/providers/opencode/index.js.map +1 -0
  77. package/dist/providers/opencode/install.d.ts +65 -0
  78. package/dist/providers/opencode/install.d.ts.map +1 -0
  79. package/dist/providers/opencode/install.js +183 -0
  80. package/dist/providers/opencode/install.js.map +1 -0
  81. package/dist/providers/opencode/spawn.d.ts +72 -0
  82. package/dist/providers/opencode/spawn.d.ts.map +1 -0
  83. package/dist/providers/opencode/spawn.js +219 -0
  84. package/dist/providers/opencode/spawn.js.map +1 -0
  85. package/dist/registry.d.ts +36 -0
  86. package/dist/registry.d.ts.map +1 -0
  87. package/dist/registry.js +55 -0
  88. package/dist/registry.js.map +1 -0
  89. package/package.json +32 -0
  90. package/src/index.d.ts +27 -0
  91. package/src/index.d.ts.map +1 -0
  92. package/src/index.js +28 -0
  93. package/src/index.js.map +1 -0
  94. package/src/index.ts +37 -0
  95. package/src/providers/claude-code/__tests__/adapter.test.d.ts +7 -0
  96. package/src/providers/claude-code/__tests__/adapter.test.d.ts.map +1 -0
  97. package/src/providers/claude-code/__tests__/adapter.test.js +249 -0
  98. package/src/providers/claude-code/__tests__/adapter.test.js.map +1 -0
  99. package/src/providers/claude-code/__tests__/adapter.test.ts +291 -0
  100. package/src/providers/claude-code/adapter.d.ts +75 -0
  101. package/src/providers/claude-code/adapter.d.ts.map +1 -0
  102. package/src/providers/claude-code/adapter.js +154 -0
  103. package/src/providers/claude-code/adapter.js.map +1 -0
  104. package/src/providers/claude-code/adapter.ts +175 -0
  105. package/src/providers/claude-code/context-monitor.d.ts +24 -0
  106. package/src/providers/claude-code/context-monitor.d.ts.map +1 -0
  107. package/src/providers/claude-code/context-monitor.js +148 -0
  108. package/src/providers/claude-code/context-monitor.js.map +1 -0
  109. package/src/providers/claude-code/context-monitor.ts +175 -0
  110. package/src/providers/claude-code/hooks.d.ts +59 -0
  111. package/src/providers/claude-code/hooks.d.ts.map +1 -0
  112. package/src/providers/claude-code/hooks.js +77 -0
  113. package/src/providers/claude-code/hooks.js.map +1 -0
  114. package/src/providers/claude-code/hooks.ts +85 -0
  115. package/src/providers/claude-code/index.d.ts +24 -0
  116. package/src/providers/claude-code/index.d.ts.map +1 -0
  117. package/src/providers/claude-code/index.js +26 -0
  118. package/src/providers/claude-code/index.js.map +1 -0
  119. package/src/providers/claude-code/index.ts +33 -0
  120. package/src/providers/claude-code/install.d.ts +75 -0
  121. package/src/providers/claude-code/install.d.ts.map +1 -0
  122. package/src/providers/claude-code/install.js +237 -0
  123. package/src/providers/claude-code/install.js.map +1 -0
  124. package/src/providers/claude-code/install.ts +267 -0
  125. package/src/providers/claude-code/manifest.json +26 -0
  126. package/src/providers/claude-code/paths.d.ts +24 -0
  127. package/src/providers/claude-code/paths.d.ts.map +1 -0
  128. package/src/providers/claude-code/paths.js +33 -0
  129. package/src/providers/claude-code/paths.js.map +1 -0
  130. package/src/providers/claude-code/paths.ts +38 -0
  131. package/src/providers/claude-code/spawn.d.ts +60 -0
  132. package/src/providers/claude-code/spawn.d.ts.map +1 -0
  133. package/src/providers/claude-code/spawn.js +160 -0
  134. package/src/providers/claude-code/spawn.js.map +1 -0
  135. package/src/providers/claude-code/spawn.ts +178 -0
  136. package/src/providers/claude-code/statusline.d.ts +24 -0
  137. package/src/providers/claude-code/statusline.d.ts.map +1 -0
  138. package/src/providers/claude-code/statusline.js +85 -0
  139. package/src/providers/claude-code/statusline.js.map +1 -0
  140. package/src/providers/claude-code/statusline.ts +99 -0
  141. package/src/providers/claude-code/task-sync.d.ts +27 -0
  142. package/src/providers/claude-code/task-sync.d.ts.map +1 -0
  143. package/src/providers/claude-code/task-sync.js +124 -0
  144. package/src/providers/claude-code/task-sync.js.map +1 -0
  145. package/src/providers/claude-code/task-sync.ts +158 -0
  146. package/src/providers/claude-code/transport.d.ts +14 -0
  147. package/src/providers/claude-code/transport.d.ts.map +1 -0
  148. package/src/providers/claude-code/transport.js +18 -0
  149. package/src/providers/claude-code/transport.js.map +1 -0
  150. package/src/providers/claude-code/transport.ts +21 -0
  151. package/src/providers/cursor/__tests__/adapter.test.d.ts +7 -0
  152. package/src/providers/cursor/__tests__/adapter.test.d.ts.map +1 -0
  153. package/src/providers/cursor/__tests__/adapter.test.js +246 -0
  154. package/src/providers/cursor/__tests__/adapter.test.js.map +1 -0
  155. package/src/providers/cursor/__tests__/adapter.test.ts +291 -0
  156. package/src/providers/cursor/adapter.d.ts +62 -0
  157. package/src/providers/cursor/adapter.d.ts.map +1 -0
  158. package/src/providers/cursor/adapter.js +124 -0
  159. package/src/providers/cursor/adapter.js.map +1 -0
  160. package/src/providers/cursor/adapter.ts +145 -0
  161. package/src/providers/cursor/hooks.d.ts +48 -0
  162. package/src/providers/cursor/hooks.d.ts.map +1 -0
  163. package/src/providers/cursor/hooks.js +55 -0
  164. package/src/providers/cursor/hooks.js.map +1 -0
  165. package/src/providers/cursor/hooks.ts +61 -0
  166. package/src/providers/cursor/index.d.ts +19 -0
  167. package/src/providers/cursor/index.d.ts.map +1 -0
  168. package/src/providers/cursor/index.js +21 -0
  169. package/src/providers/cursor/index.js.map +1 -0
  170. package/src/providers/cursor/index.ts +24 -0
  171. package/src/providers/cursor/install.d.ts +94 -0
  172. package/src/providers/cursor/install.d.ts.map +1 -0
  173. package/src/providers/cursor/install.js +241 -0
  174. package/src/providers/cursor/install.js.map +1 -0
  175. package/src/providers/cursor/install.ts +271 -0
  176. package/src/providers/cursor/manifest.json +26 -0
  177. package/src/providers/cursor/spawn.d.ts +50 -0
  178. package/src/providers/cursor/spawn.d.ts.map +1 -0
  179. package/src/providers/cursor/spawn.js +59 -0
  180. package/src/providers/cursor/spawn.js.map +1 -0
  181. package/src/providers/cursor/spawn.ts +66 -0
  182. package/src/providers/opencode/__tests__/adapter.test.d.ts +7 -0
  183. package/src/providers/opencode/__tests__/adapter.test.d.ts.map +1 -0
  184. package/src/providers/opencode/__tests__/adapter.test.js +263 -0
  185. package/src/providers/opencode/__tests__/adapter.test.js.map +1 -0
  186. package/src/providers/opencode/__tests__/adapter.test.ts +309 -0
  187. package/src/providers/opencode/adapter.d.ts +67 -0
  188. package/src/providers/opencode/adapter.d.ts.map +1 -0
  189. package/src/providers/opencode/adapter.js +144 -0
  190. package/src/providers/opencode/adapter.js.map +1 -0
  191. package/src/providers/opencode/adapter.ts +165 -0
  192. package/src/providers/opencode/hooks.d.ts +66 -0
  193. package/src/providers/opencode/hooks.d.ts.map +1 -0
  194. package/src/providers/opencode/hooks.js +89 -0
  195. package/src/providers/opencode/hooks.js.map +1 -0
  196. package/src/providers/opencode/hooks.ts +97 -0
  197. package/src/providers/opencode/index.d.ts +20 -0
  198. package/src/providers/opencode/index.d.ts.map +1 -0
  199. package/src/providers/opencode/index.js +22 -0
  200. package/src/providers/opencode/index.js.map +1 -0
  201. package/src/providers/opencode/index.ts +25 -0
  202. package/src/providers/opencode/install.d.ts +65 -0
  203. package/src/providers/opencode/install.d.ts.map +1 -0
  204. package/src/providers/opencode/install.js +183 -0
  205. package/src/providers/opencode/install.js.map +1 -0
  206. package/src/providers/opencode/install.ts +206 -0
  207. package/src/providers/opencode/manifest.json +26 -0
  208. package/src/providers/opencode/spawn.d.ts +72 -0
  209. package/src/providers/opencode/spawn.d.ts.map +1 -0
  210. package/src/providers/opencode/spawn.js +219 -0
  211. package/src/providers/opencode/spawn.js.map +1 -0
  212. package/src/providers/opencode/spawn.ts +253 -0
  213. package/src/registry.d.ts +36 -0
  214. package/src/registry.d.ts.map +1 -0
  215. package/src/registry.js +55 -0
  216. package/src/registry.js.map +1 -0
  217. package/src/registry.ts +81 -0
@@ -0,0 +1,60 @@
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
+ export declare class ClaudeCodeSpawnProvider implements AdapterSpawnProvider {
23
+ /** Map of instance IDs to tracked process info. */
24
+ private processMap;
25
+ /**
26
+ * Check if the Claude CLI is available in PATH.
27
+ *
28
+ * @returns true if `claude` is found via `which`
29
+ */
30
+ canSpawn(): Promise<boolean>;
31
+ /**
32
+ * Spawn a subagent via Claude CLI.
33
+ *
34
+ * Writes the prompt to a temporary file and spawns a detached Claude
35
+ * process. The process runs independently of the parent.
36
+ *
37
+ * @param context - Spawn context with taskId, prompt, and options
38
+ * @returns Spawn result with instance ID and status
39
+ */
40
+ spawn(context: SpawnContext): Promise<SpawnResult>;
41
+ /**
42
+ * List currently running Claude subagent processes.
43
+ *
44
+ * Checks each tracked process via kill(pid, 0) to verify it is still alive.
45
+ * Dead processes are automatically cleaned from the tracking map.
46
+ *
47
+ * @returns Array of spawn results for running processes
48
+ */
49
+ listRunning(): Promise<SpawnResult[]>;
50
+ /**
51
+ * Terminate a running spawn by instance ID.
52
+ *
53
+ * Sends SIGTERM to the tracked process. If the process is not found
54
+ * or has already exited, this is a no-op.
55
+ *
56
+ * @param instanceId - ID of the spawn instance to terminate
57
+ */
58
+ terminate(instanceId: string): Promise<void>;
59
+ }
60
+ //# sourceMappingURL=spawn.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spawn.d.ts","sourceRoot":"","sources":["spawn.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAKH,OAAO,KAAK,EAAE,oBAAoB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAW3F;;;;;;;GAOG;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;IAmExD;;;;;;;OAOG;IACG,WAAW,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAqB3C;;;;;;;OAOG;IACG,SAAS,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAWnD"}
@@ -0,0 +1,160 @@
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
+ const execAsync = promisify(exec);
17
+ /**
18
+ * Spawn provider for Claude Code.
19
+ *
20
+ * Spawns detached Claude CLI processes for subagent execution.
21
+ * Each spawn writes its prompt to a temporary file, then runs
22
+ * `claude --allow-insecure --no-upgrade-check <tmpFile>` as a
23
+ * detached, unref'd child process.
24
+ */
25
+ export class ClaudeCodeSpawnProvider {
26
+ /** Map of instance IDs to tracked process info. */
27
+ processMap = new Map();
28
+ /**
29
+ * Check if the Claude CLI is available in PATH.
30
+ *
31
+ * @returns true if `claude` is found via `which`
32
+ */
33
+ async canSpawn() {
34
+ try {
35
+ await execAsync('which claude');
36
+ return true;
37
+ }
38
+ catch {
39
+ return false;
40
+ }
41
+ }
42
+ /**
43
+ * Spawn a subagent via Claude CLI.
44
+ *
45
+ * Writes the prompt to a temporary file and spawns a detached Claude
46
+ * process. The process runs independently of the parent.
47
+ *
48
+ * @param context - Spawn context with taskId, prompt, and options
49
+ * @returns Spawn result with instance ID and status
50
+ */
51
+ async spawn(context) {
52
+ const instanceId = `claude-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;
53
+ const startTime = new Date().toISOString();
54
+ let tmpFile;
55
+ try {
56
+ tmpFile = `/tmp/claude-spawn-${instanceId}.txt`;
57
+ await writeFile(tmpFile, context.prompt, 'utf-8');
58
+ const args = ['--allow-insecure', '--no-upgrade-check', tmpFile];
59
+ const spawnOpts = {
60
+ detached: true,
61
+ stdio: 'ignore',
62
+ };
63
+ if (context.workingDirectory) {
64
+ spawnOpts.cwd = context.workingDirectory;
65
+ }
66
+ const child = nodeSpawn('claude', args, spawnOpts);
67
+ child.unref();
68
+ if (child.pid) {
69
+ this.processMap.set(instanceId, {
70
+ pid: child.pid,
71
+ taskId: context.taskId,
72
+ startTime,
73
+ });
74
+ }
75
+ const capturedTmpFile = tmpFile;
76
+ child.on('exit', async () => {
77
+ this.processMap.delete(instanceId);
78
+ try {
79
+ await unlink(capturedTmpFile);
80
+ }
81
+ catch {
82
+ // Ignore cleanup errors
83
+ }
84
+ });
85
+ return {
86
+ instanceId,
87
+ taskId: context.taskId,
88
+ providerId: 'claude-code',
89
+ status: 'running',
90
+ startTime,
91
+ };
92
+ }
93
+ catch (error) {
94
+ if (tmpFile) {
95
+ try {
96
+ await unlink(tmpFile);
97
+ }
98
+ catch {
99
+ // Ignore cleanup errors
100
+ }
101
+ }
102
+ return {
103
+ instanceId,
104
+ taskId: context.taskId,
105
+ providerId: 'claude-code',
106
+ status: 'failed',
107
+ startTime,
108
+ endTime: new Date().toISOString(),
109
+ };
110
+ }
111
+ }
112
+ /**
113
+ * List currently running Claude subagent processes.
114
+ *
115
+ * Checks each tracked process via kill(pid, 0) to verify it is still alive.
116
+ * Dead processes are automatically cleaned from the tracking map.
117
+ *
118
+ * @returns Array of spawn results for running processes
119
+ */
120
+ async listRunning() {
121
+ const running = [];
122
+ for (const [instanceId, tracked] of this.processMap.entries()) {
123
+ try {
124
+ process.kill(tracked.pid, 0);
125
+ running.push({
126
+ instanceId,
127
+ taskId: tracked.taskId,
128
+ providerId: 'claude-code',
129
+ status: 'running',
130
+ startTime: tracked.startTime,
131
+ });
132
+ }
133
+ catch {
134
+ this.processMap.delete(instanceId);
135
+ }
136
+ }
137
+ return running;
138
+ }
139
+ /**
140
+ * Terminate a running spawn by instance ID.
141
+ *
142
+ * Sends SIGTERM to the tracked process. If the process is not found
143
+ * or has already exited, this is a no-op.
144
+ *
145
+ * @param instanceId - ID of the spawn instance to terminate
146
+ */
147
+ async terminate(instanceId) {
148
+ const tracked = this.processMap.get(instanceId);
149
+ if (!tracked)
150
+ return;
151
+ try {
152
+ process.kill(tracked.pid, 'SIGTERM');
153
+ }
154
+ catch {
155
+ // Process may have already exited
156
+ }
157
+ this.processMap.delete(instanceId);
158
+ }
159
+ }
160
+ //# sourceMappingURL=spawn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spawn.js","sourceRoot":"","sources":["spawn.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,178 @@
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
+
14
+ import { exec, spawn as nodeSpawn } from 'node:child_process';
15
+ import { unlink, writeFile } from 'node:fs/promises';
16
+ import { promisify } from 'node:util';
17
+ import type { AdapterSpawnProvider, SpawnContext, SpawnResult } from '@cleocode/contracts';
18
+
19
+ const execAsync = promisify(exec);
20
+
21
+ /** Internal tracking entry for a spawned process. */
22
+ interface TrackedProcess {
23
+ pid: number;
24
+ taskId: string;
25
+ startTime: string;
26
+ }
27
+
28
+ /**
29
+ * Spawn provider for Claude Code.
30
+ *
31
+ * Spawns detached Claude CLI processes for subagent execution.
32
+ * Each spawn writes its prompt to a temporary file, then runs
33
+ * `claude --allow-insecure --no-upgrade-check <tmpFile>` as a
34
+ * detached, unref'd child process.
35
+ */
36
+ export class ClaudeCodeSpawnProvider implements AdapterSpawnProvider {
37
+ /** Map of instance IDs to tracked process info. */
38
+ private processMap = new Map<string, TrackedProcess>();
39
+
40
+ /**
41
+ * Check if the Claude CLI is available in PATH.
42
+ *
43
+ * @returns true if `claude` is found via `which`
44
+ */
45
+ async canSpawn(): Promise<boolean> {
46
+ try {
47
+ await execAsync('which claude');
48
+ return true;
49
+ } catch {
50
+ return false;
51
+ }
52
+ }
53
+
54
+ /**
55
+ * Spawn a subagent via Claude CLI.
56
+ *
57
+ * Writes the prompt to a temporary file and spawns a detached Claude
58
+ * process. The process runs independently of the parent.
59
+ *
60
+ * @param context - Spawn context with taskId, prompt, and options
61
+ * @returns Spawn result with instance ID and status
62
+ */
63
+ async spawn(context: SpawnContext): Promise<SpawnResult> {
64
+ const instanceId = `claude-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;
65
+ const startTime = new Date().toISOString();
66
+ let tmpFile: string | undefined;
67
+
68
+ try {
69
+ tmpFile = `/tmp/claude-spawn-${instanceId}.txt`;
70
+ await writeFile(tmpFile, context.prompt, 'utf-8');
71
+
72
+ const args = ['--allow-insecure', '--no-upgrade-check', tmpFile];
73
+ const spawnOpts: Parameters<typeof nodeSpawn>[2] = {
74
+ detached: true,
75
+ stdio: 'ignore',
76
+ };
77
+
78
+ if (context.workingDirectory) {
79
+ spawnOpts.cwd = context.workingDirectory;
80
+ }
81
+
82
+ const child = nodeSpawn('claude', args, spawnOpts);
83
+ child.unref();
84
+
85
+ if (child.pid) {
86
+ this.processMap.set(instanceId, {
87
+ pid: child.pid,
88
+ taskId: context.taskId,
89
+ startTime,
90
+ });
91
+ }
92
+
93
+ const capturedTmpFile = tmpFile;
94
+ child.on('exit', async () => {
95
+ this.processMap.delete(instanceId);
96
+ try {
97
+ await unlink(capturedTmpFile);
98
+ } catch {
99
+ // Ignore cleanup errors
100
+ }
101
+ });
102
+
103
+ return {
104
+ instanceId,
105
+ taskId: context.taskId,
106
+ providerId: 'claude-code',
107
+ status: 'running',
108
+ startTime,
109
+ };
110
+ } catch (error) {
111
+ if (tmpFile) {
112
+ try {
113
+ await unlink(tmpFile);
114
+ } catch {
115
+ // Ignore cleanup errors
116
+ }
117
+ }
118
+
119
+ return {
120
+ instanceId,
121
+ taskId: context.taskId,
122
+ providerId: 'claude-code',
123
+ status: 'failed',
124
+ startTime,
125
+ endTime: new Date().toISOString(),
126
+ };
127
+ }
128
+ }
129
+
130
+ /**
131
+ * List currently running Claude subagent processes.
132
+ *
133
+ * Checks each tracked process via kill(pid, 0) to verify it is still alive.
134
+ * Dead processes are automatically cleaned from the tracking map.
135
+ *
136
+ * @returns Array of spawn results for running processes
137
+ */
138
+ async listRunning(): Promise<SpawnResult[]> {
139
+ const running: SpawnResult[] = [];
140
+
141
+ for (const [instanceId, tracked] of this.processMap.entries()) {
142
+ try {
143
+ process.kill(tracked.pid, 0);
144
+ running.push({
145
+ instanceId,
146
+ taskId: tracked.taskId,
147
+ providerId: 'claude-code',
148
+ status: 'running',
149
+ startTime: tracked.startTime,
150
+ });
151
+ } catch {
152
+ this.processMap.delete(instanceId);
153
+ }
154
+ }
155
+
156
+ return running;
157
+ }
158
+
159
+ /**
160
+ * Terminate a running spawn by instance ID.
161
+ *
162
+ * Sends SIGTERM to the tracked process. If the process is not found
163
+ * or has already exited, this is a no-op.
164
+ *
165
+ * @param instanceId - ID of the spawn instance to terminate
166
+ */
167
+ async terminate(instanceId: string): Promise<void> {
168
+ const tracked = this.processMap.get(instanceId);
169
+ if (!tracked) return;
170
+
171
+ try {
172
+ process.kill(tracked.pid, 'SIGTERM');
173
+ } catch {
174
+ // Process may have already exited
175
+ }
176
+ this.processMap.delete(instanceId);
177
+ }
178
+ }
@@ -0,0 +1,24 @@
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
+ export declare function checkStatuslineIntegration(): StatuslineStatus;
15
+ /**
16
+ * Get the statusline setup command for Claude Code settings.
17
+ */
18
+ export declare function getStatuslineConfig(cleoHome: string): Record<string, unknown>;
19
+ /**
20
+ * Get human-readable setup instructions.
21
+ */
22
+ export declare function getSetupInstructions(cleoHome: string): string;
23
+ export {};
24
+ //# sourceMappingURL=statusline.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"statusline.d.ts","sourceRoot":"","sources":["statusline.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,KAAK,gBAAgB,GAAG,YAAY,GAAG,gBAAgB,GAAG,gBAAgB,GAAG,aAAa,CAAC;AAa3F;;;GAGG;AACH,wBAAgB,0BAA0B,IAAI,gBAAgB,CAwC7D;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAO7E;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAW7D"}
@@ -0,0 +1,85 @@
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'] ?? join(process.env['CLAUDE_HOME'] ?? join(homedir(), '.claude'), 'settings.json');
18
+ }
19
+ /**
20
+ * Check if statusline integration is configured.
21
+ * Returns the current integration status.
22
+ */
23
+ export function checkStatuslineIntegration() {
24
+ const settingsPath = getClaudeSettingsPath();
25
+ if (!existsSync(settingsPath))
26
+ return 'no_settings';
27
+ try {
28
+ const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
29
+ const statusLine = settings.statusLine;
30
+ if (!statusLine?.type)
31
+ return 'not_configured';
32
+ if (statusLine.type !== 'command')
33
+ return 'custom_no_cleo';
34
+ const cmd = statusLine.command ?? '';
35
+ // Check if it's a CLEO statusline integration
36
+ if (cmd.includes('context-monitor.sh') ||
37
+ cmd.includes('cleo-statusline') ||
38
+ cmd.includes('.context-state.json') ||
39
+ cmd.includes('context-states')) {
40
+ return 'configured';
41
+ }
42
+ // Check if the script writes to CLEO state file
43
+ const scriptPath = cmd.startsWith('~') ? cmd.replace('~', homedir()) : cmd;
44
+ if (existsSync(scriptPath)) {
45
+ try {
46
+ const content = readFileSync(scriptPath, 'utf-8');
47
+ if (content.includes('context-state.json'))
48
+ return 'configured';
49
+ }
50
+ catch {
51
+ /* unreadable */
52
+ }
53
+ }
54
+ return 'custom_no_cleo';
55
+ }
56
+ catch {
57
+ return 'no_settings';
58
+ }
59
+ }
60
+ /**
61
+ * Get the statusline setup command for Claude Code settings.
62
+ */
63
+ export function getStatuslineConfig(cleoHome) {
64
+ return {
65
+ statusLine: {
66
+ type: 'command',
67
+ command: join(cleoHome, 'lib', 'session', 'context-monitor.sh'),
68
+ },
69
+ };
70
+ }
71
+ /**
72
+ * Get human-readable setup instructions.
73
+ */
74
+ export function getSetupInstructions(cleoHome) {
75
+ const settingsPath = getClaudeSettingsPath();
76
+ return [
77
+ 'To enable context monitoring, add to your Claude Code settings:',
78
+ `File: ${settingsPath}`,
79
+ '',
80
+ JSON.stringify(getStatuslineConfig(cleoHome), null, 2),
81
+ '',
82
+ 'This enables real-time context window tracking in the CLI.',
83
+ ].join('\n');
84
+ }
85
+ //# sourceMappingURL=statusline.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"statusline.js","sourceRoot":"","sources":["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,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,IAAI,IAAI,CAC3C,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,CAAC,EACxD,eAAe,CAChB,CAAC;AACJ,CAAC;AAED;;;GAGG;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;;GAEG;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;;GAEG;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"}
@@ -0,0 +1,99 @@
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
+
10
+ import { existsSync, readFileSync } from 'node:fs';
11
+ import { homedir } from 'node:os';
12
+ import { join } from 'node:path';
13
+
14
+ type StatuslineStatus = 'configured' | 'not_configured' | 'custom_no_cleo' | 'no_settings';
15
+
16
+ /**
17
+ * Get the path to Claude Code's settings.json.
18
+ * Respects CLAUDE_SETTINGS env var, defaults to ~/.claude/settings.json.
19
+ */
20
+ function getClaudeSettingsPath(): string {
21
+ return process.env['CLAUDE_SETTINGS'] ?? join(
22
+ process.env['CLAUDE_HOME'] ?? join(homedir(), '.claude'),
23
+ 'settings.json',
24
+ );
25
+ }
26
+
27
+ /**
28
+ * Check if statusline integration is configured.
29
+ * Returns the current integration status.
30
+ */
31
+ export function checkStatuslineIntegration(): StatuslineStatus {
32
+ const settingsPath = getClaudeSettingsPath();
33
+
34
+ if (!existsSync(settingsPath)) return 'no_settings';
35
+
36
+ try {
37
+ const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
38
+ const statusLine = settings.statusLine;
39
+
40
+ if (!statusLine?.type) return 'not_configured';
41
+ if (statusLine.type !== 'command') return 'custom_no_cleo';
42
+
43
+ const cmd = statusLine.command ?? '';
44
+
45
+ // Check if it's a CLEO statusline integration
46
+ if (
47
+ cmd.includes('context-monitor.sh') ||
48
+ cmd.includes('cleo-statusline') ||
49
+ cmd.includes('.context-state.json') ||
50
+ cmd.includes('context-states')
51
+ ) {
52
+ return 'configured';
53
+ }
54
+
55
+ // Check if the script writes to CLEO state file
56
+ const scriptPath = cmd.startsWith('~') ? cmd.replace('~', homedir()) : cmd;
57
+
58
+ if (existsSync(scriptPath)) {
59
+ try {
60
+ const content = readFileSync(scriptPath, 'utf-8');
61
+ if (content.includes('context-state.json')) return 'configured';
62
+ } catch {
63
+ /* unreadable */
64
+ }
65
+ }
66
+
67
+ return 'custom_no_cleo';
68
+ } catch {
69
+ return 'no_settings';
70
+ }
71
+ }
72
+
73
+ /**
74
+ * Get the statusline setup command for Claude Code settings.
75
+ */
76
+ export function getStatuslineConfig(cleoHome: string): Record<string, unknown> {
77
+ return {
78
+ statusLine: {
79
+ type: 'command',
80
+ command: join(cleoHome, 'lib', 'session', 'context-monitor.sh'),
81
+ },
82
+ };
83
+ }
84
+
85
+ /**
86
+ * Get human-readable setup instructions.
87
+ */
88
+ export function getSetupInstructions(cleoHome: string): string {
89
+ const settingsPath = getClaudeSettingsPath();
90
+
91
+ return [
92
+ 'To enable context monitoring, add to your Claude Code settings:',
93
+ `File: ${settingsPath}`,
94
+ '',
95
+ JSON.stringify(getStatuslineConfig(cleoHome), null, 2),
96
+ '',
97
+ 'This enables real-time context window tracking in the CLI.',
98
+ ].join('\n');
99
+ }
@@ -0,0 +1,27 @@
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
+ * @task T5800
9
+ */
10
+ import type { AdapterTaskSyncProvider, ExternalTask } from '@cleocode/contracts';
11
+ /**
12
+ * Claude Code TaskSyncProvider.
13
+ *
14
+ * Reads Claude's TodoWrite JSON state, parses [T001]-prefixed task IDs
15
+ * and status, and returns normalized ExternalTask[].
16
+ *
17
+ * Optional: accepts a custom file path for testing.
18
+ */
19
+ export declare class ClaudeCodeTaskSyncProvider implements AdapterTaskSyncProvider {
20
+ private readonly customFilePath?;
21
+ constructor(options?: {
22
+ filePath?: string;
23
+ });
24
+ getExternalTasks(projectDir: string): Promise<ExternalTask[]>;
25
+ cleanup(projectDir: string): Promise<void>;
26
+ }
27
+ //# sourceMappingURL=task-sync.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"task-sync.d.ts","sourceRoot":"","sources":["task-sync.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAKH,OAAO,KAAK,EACV,uBAAuB,EACvB,YAAY,EAEb,MAAM,qBAAqB,CAAC;AAkE7B;;;;;;;GAOG;AACH,qBAAa,0BAA2B,YAAW,uBAAuB;IACxE,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAS;gBAE7B,OAAO,CAAC,EAAE;QAAE,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE;IAIrC,gBAAgB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAmD7D,OAAO,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAQjD"}