@cleocode/adapters 2026.5.4 → 2026.5.5

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 (123) hide show
  1. package/package.json +4 -4
  2. package/dist/cant-context.js +0 -711
  3. package/dist/cant-context.js.map +0 -1
  4. package/dist/providers/claude-code/adapter.js +0 -222
  5. package/dist/providers/claude-code/adapter.js.map +0 -1
  6. package/dist/providers/claude-code/context-monitor.js +0 -159
  7. package/dist/providers/claude-code/context-monitor.js.map +0 -1
  8. package/dist/providers/claude-code/hooks.js +0 -428
  9. package/dist/providers/claude-code/hooks.js.map +0 -1
  10. package/dist/providers/claude-code/index.js +0 -41
  11. package/dist/providers/claude-code/index.js.map +0 -1
  12. package/dist/providers/claude-code/install.js +0 -310
  13. package/dist/providers/claude-code/install.js.map +0 -1
  14. package/dist/providers/claude-code/paths.js +0 -41
  15. package/dist/providers/claude-code/paths.js.map +0 -1
  16. package/dist/providers/claude-code/spawn.js +0 -198
  17. package/dist/providers/claude-code/spawn.js.map +0 -1
  18. package/dist/providers/claude-code/statusline.js +0 -130
  19. package/dist/providers/claude-code/statusline.js.map +0 -1
  20. package/dist/providers/claude-code/task-sync.js +0 -119
  21. package/dist/providers/claude-code/task-sync.js.map +0 -1
  22. package/dist/providers/claude-code/transport.js +0 -29
  23. package/dist/providers/claude-code/transport.js.map +0 -1
  24. package/dist/providers/claude-sdk/adapter.js +0 -88
  25. package/dist/providers/claude-sdk/adapter.js.map +0 -1
  26. package/dist/providers/claude-sdk/index.js +0 -34
  27. package/dist/providers/claude-sdk/index.js.map +0 -1
  28. package/dist/providers/claude-sdk/install.js +0 -61
  29. package/dist/providers/claude-sdk/install.js.map +0 -1
  30. package/dist/providers/claude-sdk/mcp-registry.js +0 -66
  31. package/dist/providers/claude-sdk/mcp-registry.js.map +0 -1
  32. package/dist/providers/claude-sdk/session-store.js +0 -84
  33. package/dist/providers/claude-sdk/session-store.js.map +0 -1
  34. package/dist/providers/claude-sdk/spawn.js +0 -251
  35. package/dist/providers/claude-sdk/spawn.js.map +0 -1
  36. package/dist/providers/claude-sdk/tool-bridge.js +0 -50
  37. package/dist/providers/claude-sdk/tool-bridge.js.map +0 -1
  38. package/dist/providers/codex/adapter.js +0 -146
  39. package/dist/providers/codex/adapter.js.map +0 -1
  40. package/dist/providers/codex/hooks.js +0 -113
  41. package/dist/providers/codex/hooks.js.map +0 -1
  42. package/dist/providers/codex/index.js +0 -40
  43. package/dist/providers/codex/index.js.map +0 -1
  44. package/dist/providers/codex/install.js +0 -132
  45. package/dist/providers/codex/install.js.map +0 -1
  46. package/dist/providers/codex/spawn.js +0 -203
  47. package/dist/providers/codex/spawn.js.map +0 -1
  48. package/dist/providers/cursor/adapter.js +0 -151
  49. package/dist/providers/cursor/adapter.js.map +0 -1
  50. package/dist/providers/cursor/hooks.js +0 -208
  51. package/dist/providers/cursor/hooks.js.map +0 -1
  52. package/dist/providers/cursor/index.js +0 -36
  53. package/dist/providers/cursor/index.js.map +0 -1
  54. package/dist/providers/cursor/install.js +0 -281
  55. package/dist/providers/cursor/install.js.map +0 -1
  56. package/dist/providers/cursor/spawn.js +0 -59
  57. package/dist/providers/cursor/spawn.js.map +0 -1
  58. package/dist/providers/gemini-cli/adapter.js +0 -158
  59. package/dist/providers/gemini-cli/adapter.js.map +0 -1
  60. package/dist/providers/gemini-cli/hooks.js +0 -128
  61. package/dist/providers/gemini-cli/hooks.js.map +0 -1
  62. package/dist/providers/gemini-cli/index.js +0 -40
  63. package/dist/providers/gemini-cli/index.js.map +0 -1
  64. package/dist/providers/gemini-cli/install.js +0 -124
  65. package/dist/providers/gemini-cli/install.js.map +0 -1
  66. package/dist/providers/gemini-cli/spawn.js +0 -195
  67. package/dist/providers/gemini-cli/spawn.js.map +0 -1
  68. package/dist/providers/kimi/adapter.js +0 -145
  69. package/dist/providers/kimi/adapter.js.map +0 -1
  70. package/dist/providers/kimi/hooks.js +0 -79
  71. package/dist/providers/kimi/hooks.js.map +0 -1
  72. package/dist/providers/kimi/index.js +0 -40
  73. package/dist/providers/kimi/index.js.map +0 -1
  74. package/dist/providers/kimi/install.js +0 -124
  75. package/dist/providers/kimi/install.js.map +0 -1
  76. package/dist/providers/kimi/spawn.js +0 -225
  77. package/dist/providers/kimi/spawn.js.map +0 -1
  78. package/dist/providers/openai-sdk/adapter.js +0 -121
  79. package/dist/providers/openai-sdk/adapter.js.map +0 -1
  80. package/dist/providers/openai-sdk/guardrails.js +0 -174
  81. package/dist/providers/openai-sdk/guardrails.js.map +0 -1
  82. package/dist/providers/openai-sdk/handoff.js +0 -128
  83. package/dist/providers/openai-sdk/handoff.js.map +0 -1
  84. package/dist/providers/openai-sdk/index.js +0 -40
  85. package/dist/providers/openai-sdk/index.js.map +0 -1
  86. package/dist/providers/openai-sdk/install.js +0 -120
  87. package/dist/providers/openai-sdk/install.js.map +0 -1
  88. package/dist/providers/openai-sdk/spawn.js +0 -361
  89. package/dist/providers/openai-sdk/spawn.js.map +0 -1
  90. package/dist/providers/openai-sdk/tracing.js +0 -159
  91. package/dist/providers/openai-sdk/tracing.js.map +0 -1
  92. package/dist/providers/opencode/adapter.js +0 -166
  93. package/dist/providers/opencode/adapter.js.map +0 -1
  94. package/dist/providers/opencode/hooks.js +0 -206
  95. package/dist/providers/opencode/hooks.js.map +0 -1
  96. package/dist/providers/opencode/index.js +0 -37
  97. package/dist/providers/opencode/index.js.map +0 -1
  98. package/dist/providers/opencode/install.js +0 -242
  99. package/dist/providers/opencode/install.js.map +0 -1
  100. package/dist/providers/opencode/spawn.js +0 -257
  101. package/dist/providers/opencode/spawn.js.map +0 -1
  102. package/dist/providers/pi/adapter.js +0 -220
  103. package/dist/providers/pi/adapter.js.map +0 -1
  104. package/dist/providers/pi/hooks.js +0 -223
  105. package/dist/providers/pi/hooks.js.map +0 -1
  106. package/dist/providers/pi/index.js +0 -38
  107. package/dist/providers/pi/index.js.map +0 -1
  108. package/dist/providers/pi/install.js +0 -183
  109. package/dist/providers/pi/install.js.map +0 -1
  110. package/dist/providers/pi/spawn.js +0 -187
  111. package/dist/providers/pi/spawn.js.map +0 -1
  112. package/dist/providers/shared/conduit-trace-writer.js +0 -65
  113. package/dist/providers/shared/conduit-trace-writer.js.map +0 -1
  114. package/dist/providers/shared/hook-template-installer.js +0 -209
  115. package/dist/providers/shared/hook-template-installer.js.map +0 -1
  116. package/dist/providers/shared/paths.js +0 -77
  117. package/dist/providers/shared/paths.js.map +0 -1
  118. package/dist/providers/shared/sdk-result-mapper.js +0 -55
  119. package/dist/providers/shared/sdk-result-mapper.js.map +0 -1
  120. package/dist/providers/shared/transcript-reader.js +0 -124
  121. package/dist/providers/shared/transcript-reader.js.map +0 -1
  122. package/dist/registry.js +0 -92
  123. package/dist/registry.js.map +0 -1
@@ -1,132 +0,0 @@
1
- /**
2
- * Codex CLI Install Provider
3
- *
4
- * Handles CLEO installation into Codex CLI environments:
5
- * - Ensures AGENTS.md has CLEO @-references
6
- *
7
- * @task T162
8
- * @epic T134
9
- */
10
- import { existsSync, readFileSync, writeFileSync } from 'node:fs';
11
- import { join } from 'node:path';
12
- import { getCleoTemplatesTildePath } from '../shared/paths.js';
13
- /**
14
- * Lines that should appear in AGENTS.md to reference CLEO.
15
- * The CLEO-INJECTION.md path is resolved dynamically to support non-default
16
- * XDG / OS installation locations (T916).
17
- */
18
- const INSTRUCTION_REFERENCES = [
19
- `@${getCleoTemplatesTildePath()}/CLEO-INJECTION.md`,
20
- '@.cleo/memory-bridge.md',
21
- ];
22
- /**
23
- * Install provider for Codex CLI.
24
- *
25
- * Manages CLEO's integration with Codex CLI by:
26
- * 1. Ensuring AGENTS.md contains @-references to CLEO instruction files
27
- *
28
- * @remarks
29
- * Installation is idempotent -- running install multiple times on the same
30
- * project produces the same result. Only AGENTS.md is managed; Codex CLI
31
- * does not have an MCP or plugin registration mechanism.
32
- *
33
- * @task T162
34
- * @epic T134
35
- */
36
- export class CodexInstallProvider {
37
- /**
38
- * Install CLEO into a Codex CLI environment.
39
- *
40
- * @param options - Installation options including project directory
41
- * @returns Result describing what was installed
42
- * @task T162
43
- */
44
- async install(options) {
45
- const { projectDir } = options;
46
- const installedAt = new Date().toISOString();
47
- let instructionFileUpdated = false;
48
- const details = {};
49
- // Step 1: Ensure AGENTS.md has @-references
50
- instructionFileUpdated = this.updateInstructionFile(projectDir);
51
- if (instructionFileUpdated) {
52
- details.instructionFile = join(projectDir, 'AGENTS.md');
53
- }
54
- return {
55
- success: true,
56
- installedAt,
57
- instructionFileUpdated,
58
- details,
59
- };
60
- }
61
- /**
62
- * Uninstall CLEO from the Codex CLI environment.
63
- *
64
- * Does not remove AGENTS.md references (they are harmless if CLEO is not present).
65
- * @task T162
66
- */
67
- async uninstall() {
68
- // No-op: no MCP registration to remove
69
- }
70
- /**
71
- * Check whether CLEO is installed in the Codex CLI environment.
72
- *
73
- * Checks for CLEO references in AGENTS.md.
74
- * @task T162
75
- */
76
- async isInstalled() {
77
- const agentsMdPath = join(process.cwd(), 'AGENTS.md');
78
- if (existsSync(agentsMdPath)) {
79
- try {
80
- const content = readFileSync(agentsMdPath, 'utf-8');
81
- if (INSTRUCTION_REFERENCES.some((ref) => content.includes(ref))) {
82
- return true;
83
- }
84
- }
85
- catch {
86
- // Fall through
87
- }
88
- }
89
- return false;
90
- }
91
- /**
92
- * Ensure AGENTS.md contains @-references to CLEO instruction files.
93
- *
94
- * Creates AGENTS.md if it does not exist. Appends any missing references.
95
- *
96
- * @param projectDir - Project root directory
97
- * @task T162
98
- */
99
- async ensureInstructionReferences(projectDir) {
100
- this.updateInstructionFile(projectDir);
101
- }
102
- /**
103
- * Update AGENTS.md with CLEO @-references.
104
- *
105
- * @param projectDir - Project root directory
106
- * @returns true if the file was created or modified
107
- */
108
- updateInstructionFile(projectDir) {
109
- const agentsMdPath = join(projectDir, 'AGENTS.md');
110
- let content = '';
111
- let existed = false;
112
- if (existsSync(agentsMdPath)) {
113
- content = readFileSync(agentsMdPath, 'utf-8');
114
- existed = true;
115
- }
116
- const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
117
- if (missingRefs.length === 0) {
118
- return false;
119
- }
120
- const refsBlock = missingRefs.join('\n');
121
- if (existed) {
122
- const separator = content.endsWith('\n') ? '' : '\n';
123
- content = content + separator + refsBlock + '\n';
124
- }
125
- else {
126
- content = refsBlock + '\n';
127
- }
128
- writeFileSync(agentsMdPath, content, 'utf-8');
129
- return true;
130
- }
131
- }
132
- //# sourceMappingURL=install.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/codex/install.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAClE,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,OAAO,EAAE,yBAAyB,EAAE,MAAM,oBAAoB,CAAC;AAE/D;;;;GAIG;AACH,MAAM,sBAAsB,GAAG;IAC7B,IAAI,yBAAyB,EAAE,oBAAoB;IACnD,yBAAyB;CAC1B,CAAC;AAEF;;;;;;;;;;;;;GAaG;AACH,MAAM,OAAO,oBAAoB;IAC/B;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CAAC,OAAuB;QACnC,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;QAC/B,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QAC7C,IAAI,sBAAsB,GAAG,KAAK,CAAC;QACnC,MAAM,OAAO,GAA4B,EAAE,CAAC;QAE5C,4CAA4C;QAC5C,sBAAsB,GAAG,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC;QAChE,IAAI,sBAAsB,EAAE,CAAC;YAC3B,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;QAC1D,CAAC;QAED,OAAO;YACL,OAAO,EAAE,IAAI;YACb,WAAW;YACX,sBAAsB;YACtB,OAAO;SACR,CAAC;IACJ,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,SAAS;QACb,uCAAuC;IACzC,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,WAAW;QACf,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,WAAW,CAAC,CAAC;QACtD,IAAI,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;YAC7B,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;gBACpD,IAAI,sBAAsB,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBAChE,OAAO,IAAI,CAAC;gBACd,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,eAAe;YACjB,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,2BAA2B,CAAC,UAAkB;QAClD,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC;IACzC,CAAC;IAED;;;;;OAKG;IACK,qBAAqB,CAAC,UAAkB;QAC9C,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;QACnD,IAAI,OAAO,GAAG,EAAE,CAAC;QACjB,IAAI,OAAO,GAAG,KAAK,CAAC;QAEpB,IAAI,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;YAC7B,OAAO,GAAG,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;YAC9C,OAAO,GAAG,IAAI,CAAC;QACjB,CAAC;QAED,MAAM,WAAW,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;QAEnF,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC7B,OAAO,KAAK,CAAC;QACf,CAAC;QAED,MAAM,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEzC,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,SAAS,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;YACrD,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,SAAS,GAAG,IAAI,CAAC;QACnD,CAAC;aAAM,CAAC;YACN,OAAO,GAAG,SAAS,GAAG,IAAI,CAAC;QAC7B,CAAC;QAED,aAAa,CAAC,YAAY,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAC9C,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -1,203 +0,0 @@
1
- /**
2
- * Codex CLI Spawn Provider
3
- *
4
- * Implements `AdapterSpawnProvider` for the OpenAI Codex CLI (`codex` binary).
5
- *
6
- * The `codex` binary is the OpenAI Codex CLI agent, available at:
7
- * https://github.com/openai/codex
8
- *
9
- * Invocation: `codex --full-auto <prompt-file>`
10
- *
11
- * The provider uses `--full-auto` (non-interactive, auto-approve all actions)
12
- * which is the headless equivalent of the Claude Code `--dangerously-skip-permissions`
13
- * flag. Processes run detached and are tracked by PID for listing and termination.
14
- *
15
- * If the `codex` binary is not found, `canSpawn()` returns `false` with a
16
- * graceful error — no crash.
17
- *
18
- * @remarks
19
- * As of 2026, the Codex CLI is the successor to the original OpenAI Codex
20
- * playground. It reads prompts from stdin or file arguments and emits output
21
- * to stdout. The `--full-auto` flag suppresses interactive approval prompts.
22
- * Install: `npm install -g @openai/codex` or see the GitHub repo above.
23
- *
24
- * @task T648
25
- */
26
- import { exec, spawn as nodeSpawn } from 'node:child_process';
27
- import { unlink, writeFile } from 'node:fs/promises';
28
- import { promisify } from 'node:util';
29
- import { getErrorMessage } from '@cleocode/contracts';
30
- const execAsync = promisify(exec);
31
- /**
32
- * Spawn provider for the OpenAI Codex CLI.
33
- *
34
- * Spawns detached Codex CLI processes for subagent execution. Each spawn
35
- * writes its prompt to a temporary file, then runs
36
- * `codex --full-auto <tmpFile>` as a detached, unref'd child process.
37
- *
38
- * @remarks
39
- * `canSpawn()` returns `false` (with no crash) when the `codex` binary is
40
- * not found in PATH. Install instructions are emitted via `console.warn`
41
- * once to help operators discover the binary is missing.
42
- *
43
- * Processes are tracked by instance ID in an in-memory map and verified
44
- * via `kill(pid, 0)` liveness checks.
45
- *
46
- * @task T648
47
- */
48
- export class CodexSpawnProvider {
49
- /** Map of instance IDs to tracked process info. */
50
- processMap = new Map();
51
- /**
52
- * Check if the Codex CLI is available in PATH.
53
- *
54
- * @returns `true` if `codex` is found via `which`
55
- */
56
- async canSpawn() {
57
- try {
58
- await execAsync('which codex');
59
- return true;
60
- }
61
- catch {
62
- console.warn('[CodexSpawnProvider] codex CLI not found. ' +
63
- 'Install: npm install -g @openai/codex ' +
64
- 'Docs: https://github.com/openai/codex');
65
- return false;
66
- }
67
- }
68
- /**
69
- * Spawn a subagent via the Codex CLI.
70
- *
71
- * Writes the prompt to a temporary file and spawns a detached Codex
72
- * process. The process runs independently of the parent.
73
- *
74
- * @param context - Spawn context with taskId, prompt, and options
75
- * @returns Spawn result with instance ID and status
76
- */
77
- async spawn(context) {
78
- const instanceId = `codex-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;
79
- const startTime = new Date().toISOString();
80
- let tmpFile;
81
- try {
82
- // Enrich prompt with CANT bundle, memory bridge, and mental model.
83
- // Best-effort: if CANT context is unavailable, the raw prompt is used.
84
- let enrichedPrompt = context.prompt;
85
- try {
86
- const { buildCantEnrichedPrompt } = await import('../../cant-context.js');
87
- enrichedPrompt = await buildCantEnrichedPrompt({
88
- projectDir: context.workingDirectory ?? process.cwd(),
89
- basePrompt: context.prompt,
90
- agentName: context.options?.agentName ?? undefined,
91
- });
92
- }
93
- catch {
94
- // CANT enrichment unavailable — use raw prompt
95
- }
96
- tmpFile = `/tmp/codex-spawn-${instanceId}.txt`;
97
- await writeFile(tmpFile, enrichedPrompt, 'utf-8');
98
- // --full-auto: non-interactive batch mode (auto-approve all actions)
99
- const args = ['--full-auto', tmpFile];
100
- const spawnOpts = {
101
- detached: true,
102
- stdio: 'ignore',
103
- };
104
- if (context.workingDirectory) {
105
- spawnOpts.cwd = context.workingDirectory;
106
- }
107
- const child = nodeSpawn('codex', args, spawnOpts);
108
- child.unref();
109
- if (child.pid) {
110
- this.processMap.set(instanceId, {
111
- pid: child.pid,
112
- taskId: context.taskId,
113
- startTime,
114
- });
115
- }
116
- const capturedTmpFile = tmpFile;
117
- child.on('exit', async () => {
118
- this.processMap.delete(instanceId);
119
- try {
120
- await unlink(capturedTmpFile);
121
- }
122
- catch {
123
- // Ignore cleanup errors
124
- }
125
- });
126
- return {
127
- instanceId,
128
- taskId: context.taskId,
129
- providerId: 'codex',
130
- status: 'running',
131
- startTime,
132
- };
133
- }
134
- catch (error) {
135
- console.error(`[CodexSpawnProvider] Failed to spawn: ${getErrorMessage(error)}`);
136
- if (tmpFile) {
137
- try {
138
- await unlink(tmpFile);
139
- }
140
- catch {
141
- // Ignore cleanup errors
142
- }
143
- }
144
- return {
145
- instanceId,
146
- taskId: context.taskId,
147
- providerId: 'codex',
148
- status: 'failed',
149
- startTime,
150
- endTime: new Date().toISOString(),
151
- error: getErrorMessage(error),
152
- };
153
- }
154
- }
155
- /**
156
- * List currently running Codex subagent processes.
157
- *
158
- * Checks each tracked process via kill(pid, 0) to verify it is still alive.
159
- * Dead processes are automatically cleaned from the tracking map.
160
- *
161
- * @returns Array of spawn results for running processes
162
- */
163
- async listRunning() {
164
- const running = [];
165
- for (const [instanceId, tracked] of this.processMap.entries()) {
166
- try {
167
- process.kill(tracked.pid, 0);
168
- running.push({
169
- instanceId,
170
- taskId: tracked.taskId,
171
- providerId: 'codex',
172
- status: 'running',
173
- startTime: tracked.startTime,
174
- });
175
- }
176
- catch {
177
- this.processMap.delete(instanceId);
178
- }
179
- }
180
- return running;
181
- }
182
- /**
183
- * Terminate a running spawn by instance ID.
184
- *
185
- * Sends SIGTERM to the tracked process. If the process is not found
186
- * or has already exited, this is a no-op.
187
- *
188
- * @param instanceId - ID of the spawn instance to terminate
189
- */
190
- async terminate(instanceId) {
191
- const tracked = this.processMap.get(instanceId);
192
- if (!tracked)
193
- return;
194
- try {
195
- process.kill(tracked.pid, 'SIGTERM');
196
- }
197
- catch {
198
- // Process may have already exited
199
- }
200
- this.processMap.delete(instanceId);
201
- }
202
- }
203
- //# sourceMappingURL=spawn.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"spawn.js","sourceRoot":"","sources":["../../../src/providers/codex/spawn.ts"],"names":[],"mappings":"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"}
@@ -1,151 +0,0 @@
1
- /**
2
- * Cursor Adapter
3
- *
4
- * Main CLEOProviderAdapter implementation for Cursor AI code editor.
5
- * Provides install capabilities for CLEO integration. Hooks and spawn
6
- * are not supported since Cursor lacks CLI-based lifecycle events
7
- * and subagent spawning.
8
- *
9
- * @task T5240
10
- */
11
- import { existsSync } from 'node:fs';
12
- import { join } from 'node:path';
13
- import { CursorHookProvider } from './hooks.js';
14
- import { CursorInstallProvider } from './install.js';
15
- /**
16
- * CLEO provider adapter for Cursor AI code editor.
17
- *
18
- * Bridges CLEO's adapter system with Cursor's capabilities:
19
- * - Install: Manages .cursorrules and .cursor/rules/cleo.mdc rule files
20
- * - Hooks: Stub provider (Cursor has no lifecycle event system)
21
- * - Spawn: Not supported (Cursor has no CLI for subagent spawning)
22
- *
23
- * @remarks
24
- * Cursor is a GUI-based editor, so many CLI-oriented capabilities
25
- * (spawn, transport, task sync, context monitor) are unsupported.
26
- * Integration is primarily through instruction rule files placed in
27
- * `.cursor/rules/` (modern MDC format) and `.cursorrules` (legacy).
28
- */
29
- export class CursorAdapter {
30
- /** Unique provider identifier. */
31
- id = 'cursor';
32
- /** Human-readable provider name. */
33
- name = 'Cursor';
34
- /** Adapter version string. */
35
- version = '1.0.0';
36
- /** Declared capabilities for this provider. */
37
- capabilities = {
38
- supportsHooks: true,
39
- // 10/16 canonical events — derived from getProviderHookProfile('cursor') in CAAMP 1.9.1.
40
- // PermissionRequest, PreModel, PostModel, PostCompact, Notification, ConfigChange are
41
- // not supported by Cursor's hook system.
42
- supportedHookEvents: [
43
- 'SessionStart',
44
- 'SessionEnd',
45
- 'PromptSubmit',
46
- 'ResponseComplete',
47
- 'PreToolUse',
48
- 'PostToolUse',
49
- 'PostToolUseFailure',
50
- 'SubagentStart',
51
- 'SubagentStop',
52
- 'PreCompact',
53
- ],
54
- supportsSpawn: false,
55
- supportsInstall: true,
56
- supportsInstructionFiles: true,
57
- instructionFilePattern: '.cursor/rules/*.mdc',
58
- supportsContextMonitor: false,
59
- supportsStatusline: false,
60
- supportsProviderPaths: true,
61
- supportsTransport: false,
62
- supportsTaskSync: false,
63
- };
64
- /** Hook provider for CAAMP event mapping. */
65
- hooks;
66
- /** Install provider for managing rule files. */
67
- install;
68
- /** Project directory this adapter was initialized with, or null. */
69
- projectDir = null;
70
- /** Whether {@link initialize} has been called. */
71
- initialized = false;
72
- constructor() {
73
- this.hooks = new CursorHookProvider();
74
- this.install = new CursorInstallProvider();
75
- }
76
- /**
77
- * Initialize the adapter for a given project directory.
78
- *
79
- * @param projectDir - Root directory of the project
80
- */
81
- async initialize(projectDir) {
82
- this.projectDir = projectDir;
83
- this.initialized = true;
84
- }
85
- /**
86
- * Dispose the adapter and clean up resources.
87
- */
88
- async dispose() {
89
- if (this.hooks.isRegistered()) {
90
- await this.hooks.unregisterNativeHooks();
91
- }
92
- this.initialized = false;
93
- this.projectDir = null;
94
- }
95
- /**
96
- * Run a health check to verify Cursor is accessible.
97
- *
98
- * Checks:
99
- * 1. Adapter has been initialized
100
- * 2. .cursor/ configuration directory exists in the project
101
- * 3. CURSOR_EDITOR env var is set
102
- *
103
- * @returns Health status with details about each check
104
- */
105
- async healthCheck() {
106
- const details = {};
107
- if (!this.initialized) {
108
- return {
109
- healthy: false,
110
- provider: this.id,
111
- details: { error: 'Adapter not initialized' },
112
- };
113
- }
114
- // Check for Cursor config directory in the project
115
- let configExists = false;
116
- if (this.projectDir) {
117
- const cursorConfigDir = join(this.projectDir, '.cursor');
118
- configExists = existsSync(cursorConfigDir);
119
- details.configDirExists = configExists;
120
- }
121
- // Check for CURSOR_EDITOR env var
122
- const editorEnvSet = process.env.CURSOR_EDITOR !== undefined;
123
- details.editorEnvSet = editorEnvSet;
124
- // Check for legacy .cursorrules file
125
- if (this.projectDir) {
126
- const legacyRulesExist = existsSync(join(this.projectDir, '.cursorrules'));
127
- details.legacyRulesExist = legacyRulesExist;
128
- }
129
- // Healthy if we detect Cursor presence (config dir or env var)
130
- const healthy = configExists || editorEnvSet;
131
- details.detected = healthy;
132
- return {
133
- healthy,
134
- provider: this.id,
135
- details,
136
- };
137
- }
138
- /**
139
- * Check whether the adapter has been initialized.
140
- */
141
- isInitialized() {
142
- return this.initialized;
143
- }
144
- /**
145
- * Get the project directory this adapter was initialized with.
146
- */
147
- getProjectDir() {
148
- return this.projectDir;
149
- }
150
- }
151
- //# sourceMappingURL=adapter.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/cursor/adapter.ts"],"names":[],"mappings":"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"}