@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.
- package/package.json +4 -4
- package/dist/cant-context.js +0 -711
- package/dist/cant-context.js.map +0 -1
- package/dist/providers/claude-code/adapter.js +0 -222
- package/dist/providers/claude-code/adapter.js.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.js +0 -428
- package/dist/providers/claude-code/hooks.js.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.js +0 -310
- package/dist/providers/claude-code/install.js.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.js +0 -198
- package/dist/providers/claude-code/spawn.js.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.js +0 -119
- package/dist/providers/claude-code/task-sync.js.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/claude-sdk/adapter.js +0 -88
- package/dist/providers/claude-sdk/adapter.js.map +0 -1
- package/dist/providers/claude-sdk/index.js +0 -34
- package/dist/providers/claude-sdk/index.js.map +0 -1
- package/dist/providers/claude-sdk/install.js +0 -61
- package/dist/providers/claude-sdk/install.js.map +0 -1
- package/dist/providers/claude-sdk/mcp-registry.js +0 -66
- package/dist/providers/claude-sdk/mcp-registry.js.map +0 -1
- package/dist/providers/claude-sdk/session-store.js +0 -84
- package/dist/providers/claude-sdk/session-store.js.map +0 -1
- package/dist/providers/claude-sdk/spawn.js +0 -251
- package/dist/providers/claude-sdk/spawn.js.map +0 -1
- package/dist/providers/claude-sdk/tool-bridge.js +0 -50
- package/dist/providers/claude-sdk/tool-bridge.js.map +0 -1
- package/dist/providers/codex/adapter.js +0 -146
- package/dist/providers/codex/adapter.js.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.js +0 -40
- package/dist/providers/codex/index.js.map +0 -1
- package/dist/providers/codex/install.js +0 -132
- package/dist/providers/codex/install.js.map +0 -1
- package/dist/providers/codex/spawn.js +0 -203
- package/dist/providers/codex/spawn.js.map +0 -1
- package/dist/providers/cursor/adapter.js +0 -151
- package/dist/providers/cursor/adapter.js.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.js +0 -36
- package/dist/providers/cursor/index.js.map +0 -1
- package/dist/providers/cursor/install.js +0 -281
- package/dist/providers/cursor/install.js.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.js +0 -158
- package/dist/providers/gemini-cli/adapter.js.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.js +0 -40
- package/dist/providers/gemini-cli/index.js.map +0 -1
- package/dist/providers/gemini-cli/install.js +0 -124
- package/dist/providers/gemini-cli/install.js.map +0 -1
- package/dist/providers/gemini-cli/spawn.js +0 -195
- package/dist/providers/gemini-cli/spawn.js.map +0 -1
- package/dist/providers/kimi/adapter.js +0 -145
- package/dist/providers/kimi/adapter.js.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.js +0 -40
- package/dist/providers/kimi/index.js.map +0 -1
- package/dist/providers/kimi/install.js +0 -124
- package/dist/providers/kimi/install.js.map +0 -1
- package/dist/providers/kimi/spawn.js +0 -225
- package/dist/providers/kimi/spawn.js.map +0 -1
- package/dist/providers/openai-sdk/adapter.js +0 -121
- package/dist/providers/openai-sdk/adapter.js.map +0 -1
- package/dist/providers/openai-sdk/guardrails.js +0 -174
- package/dist/providers/openai-sdk/guardrails.js.map +0 -1
- package/dist/providers/openai-sdk/handoff.js +0 -128
- package/dist/providers/openai-sdk/handoff.js.map +0 -1
- package/dist/providers/openai-sdk/index.js +0 -40
- package/dist/providers/openai-sdk/index.js.map +0 -1
- package/dist/providers/openai-sdk/install.js +0 -120
- package/dist/providers/openai-sdk/install.js.map +0 -1
- package/dist/providers/openai-sdk/spawn.js +0 -361
- package/dist/providers/openai-sdk/spawn.js.map +0 -1
- package/dist/providers/openai-sdk/tracing.js +0 -159
- package/dist/providers/openai-sdk/tracing.js.map +0 -1
- package/dist/providers/opencode/adapter.js +0 -166
- package/dist/providers/opencode/adapter.js.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.js +0 -37
- package/dist/providers/opencode/index.js.map +0 -1
- package/dist/providers/opencode/install.js +0 -242
- package/dist/providers/opencode/install.js.map +0 -1
- package/dist/providers/opencode/spawn.js +0 -257
- package/dist/providers/opencode/spawn.js.map +0 -1
- package/dist/providers/pi/adapter.js +0 -220
- package/dist/providers/pi/adapter.js.map +0 -1
- package/dist/providers/pi/hooks.js +0 -223
- package/dist/providers/pi/hooks.js.map +0 -1
- package/dist/providers/pi/index.js +0 -38
- package/dist/providers/pi/index.js.map +0 -1
- package/dist/providers/pi/install.js +0 -183
- package/dist/providers/pi/install.js.map +0 -1
- package/dist/providers/pi/spawn.js +0 -187
- package/dist/providers/pi/spawn.js.map +0 -1
- package/dist/providers/shared/conduit-trace-writer.js +0 -65
- package/dist/providers/shared/conduit-trace-writer.js.map +0 -1
- package/dist/providers/shared/hook-template-installer.js +0 -209
- package/dist/providers/shared/hook-template-installer.js.map +0 -1
- package/dist/providers/shared/paths.js +0 -77
- package/dist/providers/shared/paths.js.map +0 -1
- package/dist/providers/shared/sdk-result-mapper.js +0 -55
- package/dist/providers/shared/sdk-result-mapper.js.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.js +0 -92
- 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":"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"}
|
|
@@ -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":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AAEH,OAAO,EAAE,IAAI,EAAE,KAAK,IAAI,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAEtC,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtD,MAAM,SAAS,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;AASlC;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,OAAO,kBAAkB;IAC7B,mDAAmD;IAC3C,UAAU,GAAG,IAAI,GAAG,EAA0B,CAAC;IAEvD;;;;OAIG;IACH,KAAK,CAAC,QAAQ;QACZ,IAAI,CAAC;YACH,MAAM,SAAS,CAAC,aAAa,CAAC,CAAC;YAC/B,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,IAAI,CACV,4CAA4C;gBAC1C,yCAAyC;gBACzC,uCAAuC,CAC1C,CAAC;YACF,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,KAAK,CAAC,OAAqB;QAC/B,MAAM,UAAU,GAAG,SAAS,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;QACvF,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QAC3C,IAAI,OAA2B,CAAC;QAEhC,IAAI,CAAC;YACH,mEAAmE;YACnE,uEAAuE;YACvE,IAAI,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC;YACpC,IAAI,CAAC;gBACH,MAAM,EAAE,uBAAuB,EAAE,GAAG,MAAM,MAAM,CAAC,uBAAuB,CAAC,CAAC;gBAC1E,cAAc,GAAG,MAAM,uBAAuB,CAAC;oBAC7C,UAAU,EAAE,OAAO,CAAC,gBAAgB,IAAI,OAAO,CAAC,GAAG,EAAE;oBACrD,UAAU,EAAE,OAAO,CAAC,MAAM;oBAC1B,SAAS,EAAG,OAAO,CAAC,OAAO,EAAE,SAAoB,IAAI,SAAS;iBAC/D,CAAC,CAAC;YACL,CAAC;YAAC,MAAM,CAAC;gBACP,+CAA+C;YACjD,CAAC;YAED,OAAO,GAAG,oBAAoB,UAAU,MAAM,CAAC;YAC/C,MAAM,SAAS,CAAC,OAAO,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC;YAElD,qEAAqE;YACrE,MAAM,IAAI,GAAG,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;YACtC,MAAM,SAAS,GAAoC;gBACjD,QAAQ,EAAE,IAAI;gBACd,KAAK,EAAE,QAAQ;aAChB,CAAC;YAEF,IAAI,OAAO,CAAC,gBAAgB,EAAE,CAAC;gBAC7B,SAAS,CAAC,GAAG,GAAG,OAAO,CAAC,gBAAgB,CAAC;YAC3C,CAAC;YAED,MAAM,KAAK,GAAG,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC;YAClD,KAAK,CAAC,KAAK,EAAE,CAAC;YAEd,IAAI,KAAK,CAAC,GAAG,EAAE,CAAC;gBACd,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,EAAE;oBAC9B,GAAG,EAAE,KAAK,CAAC,GAAG;oBACd,MAAM,EAAE,OAAO,CAAC,MAAM;oBACtB,SAAS;iBACV,CAAC,CAAC;YACL,CAAC;YAED,MAAM,eAAe,GAAG,OAAO,CAAC;YAChC,KAAK,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,IAAI,EAAE;gBAC1B,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;gBACnC,IAAI,CAAC;oBACH,MAAM,MAAM,CAAC,eAAe,CAAC,CAAC;gBAChC,CAAC;gBAAC,MAAM,CAAC;oBACP,wBAAwB;gBAC1B,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,OAAO;gBACL,UAAU;gBACV,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,UAAU,EAAE,OAAO;gBACnB,MAAM,EAAE,SAAS;gBACjB,SAAS;aACV,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,yCAAyC,eAAe,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YAEjF,IAAI,OAAO,EAAE,CAAC;gBACZ,IAAI,CAAC;oBACH,MAAM,MAAM,CAAC,OAAO,CAAC,CAAC;gBACxB,CAAC;gBAAC,MAAM,CAAC;oBACP,wBAAwB;gBAC1B,CAAC;YACH,CAAC;YAED,OAAO;gBACL,UAAU;gBACV,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,UAAU,EAAE,OAAO;gBACnB,MAAM,EAAE,QAAQ;gBAChB,SAAS;gBACT,OAAO,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;gBACjC,KAAK,EAAE,eAAe,CAAC,KAAK,CAAC;aAC9B,CAAC;QACJ,CAAC;IACH,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,WAAW;QACf,MAAM,OAAO,GAAkB,EAAE,CAAC;QAElC,KAAK,MAAM,CAAC,UAAU,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC;YAC9D,IAAI,CAAC;gBACH,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;gBAC7B,OAAO,CAAC,IAAI,CAAC;oBACX,UAAU;oBACV,MAAM,EAAE,OAAO,CAAC,MAAM;oBACtB,UAAU,EAAE,OAAO;oBACnB,MAAM,EAAE,SAAS;oBACjB,SAAS,EAAE,OAAO,CAAC,SAAS;iBAC7B,CAAC,CAAC;YACL,CAAC;YAAC,MAAM,CAAC;gBACP,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YACrC,CAAC;QACH,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,SAAS,CAAC,UAAkB;QAChC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO;YAAE,OAAO;QAErB,IAAI,CAAC;YACH,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QACvC,CAAC;QAAC,MAAM,CAAC;YACP,kCAAkC;QACpC,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IACrC,CAAC;CACF"}
|
|
@@ -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":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAMjC,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAErD;;;;;;;;;;;;;GAaG;AACH,MAAM,OAAO,aAAa;IACxB,kCAAkC;IACzB,EAAE,GAAG,QAAQ,CAAC;IACvB,oCAAoC;IAC3B,IAAI,GAAG,QAAQ,CAAC;IACzB,8BAA8B;IACrB,OAAO,GAAG,OAAO,CAAC;IAE3B,+CAA+C;IAC/C,YAAY,GAAwB;QAClC,aAAa,EAAE,IAAI;QACnB,yFAAyF;QACzF,sFAAsF;QACtF,yCAAyC;QACzC,mBAAmB,EAAE;YACnB,cAAc;YACd,YAAY;YACZ,cAAc;YACd,kBAAkB;YAClB,YAAY;YACZ,aAAa;YACb,oBAAoB;YACpB,eAAe;YACf,cAAc;YACd,YAAY;SACb;QACD,aAAa,EAAE,KAAK;QACpB,eAAe,EAAE,IAAI;QACrB,wBAAwB,EAAE,IAAI;QAC9B,sBAAsB,EAAE,qBAAqB;QAC7C,sBAAsB,EAAE,KAAK;QAC7B,kBAAkB,EAAE,KAAK;QACzB,qBAAqB,EAAE,IAAI;QAC3B,iBAAiB,EAAE,KAAK;QACxB,gBAAgB,EAAE,KAAK;KACxB,CAAC;IAEF,6CAA6C;IAC7C,KAAK,CAAqB;IAC1B,gDAAgD;IAChD,OAAO,CAAwB;IAE/B,oEAAoE;IAC5D,UAAU,GAAkB,IAAI,CAAC;IACzC,kDAAkD;IAC1C,WAAW,GAAG,KAAK,CAAC;IAE5B;QACE,IAAI,CAAC,KAAK,GAAG,IAAI,kBAAkB,EAAE,CAAC;QACtC,IAAI,CAAC,OAAO,GAAG,IAAI,qBAAqB,EAAE,CAAC;IAC7C,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,UAAU,CAAC,UAAkB;QACjC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAO;QACX,IAAI,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,EAAE,CAAC;YAC9B,MAAM,IAAI,CAAC,KAAK,CAAC,qBAAqB,EAAE,CAAC;QAC3C,CAAC;QACD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,WAAW;QACf,MAAM,OAAO,GAA4B,EAAE,CAAC;QAE5C,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,QAAQ,EAAE,IAAI,CAAC,EAAE;gBACjB,OAAO,EAAE,EAAE,KAAK,EAAE,yBAAyB,EAAE;aAC9C,CAAC;QACJ,CAAC;QAED,mDAAmD;QACnD,IAAI,YAAY,GAAG,KAAK,CAAC;QACzB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;YACzD,YAAY,GAAG,UAAU,CAAC,eAAe,CAAC,CAAC;YAC3C,OAAO,CAAC,eAAe,GAAG,YAAY,CAAC;QACzC,CAAC;QAED,kCAAkC;QAClC,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,CAAC,aAAa,KAAK,SAAS,CAAC;QAC7D,OAAO,CAAC,YAAY,GAAG,YAAY,CAAC;QAEpC,qCAAqC;QACrC,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,MAAM,gBAAgB,GAAG,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC,CAAC;YAC3E,OAAO,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QAC9C,CAAC;QAED,+DAA+D;QAC/D,MAAM,OAAO,GAAG,YAAY,IAAI,YAAY,CAAC;QAC7C,OAAO,CAAC,QAAQ,GAAG,OAAO,CAAC;QAE3B,OAAO;YACL,OAAO;YACP,QAAQ,EAAE,IAAI,CAAC,EAAE;YACjB,OAAO;SACR,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,aAAa;QACX,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,aAAa;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;CACF"}
|