@cleocode/adapters 2026.3.37 → 2026.3.39
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/LICENSE +21 -0
- package/README.md +503 -0
- package/dist/index.js +621 -496
- package/dist/index.js.map +4 -4
- package/package.json +12 -7
- package/src/__tests__/claude-code-adapter.test.d.ts +10 -0
- package/src/__tests__/claude-code-adapter.test.d.ts.map +1 -0
- package/src/__tests__/claude-code-adapter.test.js +192 -0
- package/src/__tests__/claude-code-adapter.test.js.map +1 -0
- package/src/__tests__/claude-code-adapter.test.ts +235 -0
- package/src/__tests__/cursor-adapter.test.d.ts +10 -0
- package/src/__tests__/cursor-adapter.test.d.ts.map +1 -0
- package/src/__tests__/cursor-adapter.test.js +196 -0
- package/src/__tests__/cursor-adapter.test.js.map +1 -0
- package/src/__tests__/cursor-adapter.test.ts +246 -0
- package/src/__tests__/opencode-adapter.test.d.ts +10 -0
- package/src/__tests__/opencode-adapter.test.d.ts.map +1 -0
- package/src/__tests__/opencode-adapter.test.js +204 -0
- package/src/__tests__/opencode-adapter.test.js.map +1 -0
- package/src/__tests__/opencode-adapter.test.ts +250 -0
- package/src/index.d.ts +28 -20
- package/src/index.d.ts.map +1 -1
- package/src/index.js +4 -19
- package/src/index.js.map +1 -1
- package/src/index.ts +25 -25
- package/src/providers/claude-code/__tests__/adapter.test.d.ts +1 -1
- package/src/providers/claude-code/__tests__/adapter.test.d.ts.map +0 -0
- package/src/providers/claude-code/__tests__/adapter.test.js +2 -2
- package/src/providers/claude-code/__tests__/adapter.test.js.map +1 -1
- package/src/providers/claude-code/__tests__/adapter.test.ts +2 -2
- package/src/providers/claude-code/adapter.d.ts +54 -50
- package/src/providers/claude-code/adapter.d.ts.map +0 -0
- package/src/providers/claude-code/adapter.js +1 -1
- package/src/providers/claude-code/adapter.js.map +1 -1
- package/src/providers/claude-code/adapter.ts +1 -1
- package/src/providers/claude-code/context-monitor.d.ts +6 -6
- package/src/providers/claude-code/context-monitor.d.ts.map +0 -0
- package/src/providers/claude-code/context-monitor.js +0 -0
- package/src/providers/claude-code/context-monitor.js.map +0 -0
- package/src/providers/claude-code/context-monitor.ts +0 -0
- package/src/providers/claude-code/hooks.d.ts +36 -36
- package/src/providers/claude-code/hooks.d.ts.map +0 -0
- package/src/providers/claude-code/hooks.js +0 -0
- package/src/providers/claude-code/hooks.js.map +0 -0
- package/src/providers/claude-code/hooks.ts +0 -0
- package/src/providers/claude-code/index.d.ts +6 -2
- package/src/providers/claude-code/index.d.ts.map +1 -1
- package/src/providers/claude-code/index.js +1 -1
- package/src/providers/claude-code/index.js.map +1 -1
- package/src/providers/claude-code/index.ts +2 -2
- package/src/providers/claude-code/install.d.ts +52 -52
- package/src/providers/claude-code/install.d.ts.map +1 -1
- package/src/providers/claude-code/install.js +1 -4
- package/src/providers/claude-code/install.js.map +1 -1
- package/src/providers/claude-code/install.ts +1 -4
- package/src/providers/claude-code/manifest.json +0 -0
- package/src/providers/claude-code/paths.d.ts +5 -5
- package/src/providers/claude-code/paths.d.ts.map +0 -0
- package/src/providers/claude-code/paths.js +0 -0
- package/src/providers/claude-code/paths.js.map +0 -0
- package/src/providers/claude-code/paths.ts +0 -0
- package/src/providers/claude-code/spawn.d.ts +37 -37
- package/src/providers/claude-code/spawn.d.ts.map +1 -1
- package/src/providers/claude-code/spawn.js +4 -0
- package/src/providers/claude-code/spawn.js.map +1 -1
- package/src/providers/claude-code/spawn.ts +5 -0
- package/src/providers/claude-code/statusline.d.ts +1 -2
- package/src/providers/claude-code/statusline.d.ts.map +0 -0
- package/src/providers/claude-code/statusline.js +2 -1
- package/src/providers/claude-code/statusline.js.map +1 -1
- package/src/providers/claude-code/statusline.ts +3 -3
- package/src/providers/claude-code/task-sync.d.ts +7 -7
- package/src/providers/claude-code/task-sync.d.ts.map +1 -1
- package/src/providers/claude-code/task-sync.js +1 -3
- package/src/providers/claude-code/task-sync.js.map +1 -1
- package/src/providers/claude-code/task-sync.ts +1 -3
- package/src/providers/claude-code/transport.d.ts +3 -3
- package/src/providers/claude-code/transport.d.ts.map +0 -0
- package/src/providers/claude-code/transport.js +0 -0
- package/src/providers/claude-code/transport.js.map +0 -0
- package/src/providers/claude-code/transport.ts +0 -0
- package/src/providers/cursor/__tests__/adapter.test.d.ts +1 -1
- package/src/providers/cursor/__tests__/adapter.test.d.ts.map +0 -0
- package/src/providers/cursor/__tests__/adapter.test.js +2 -2
- package/src/providers/cursor/__tests__/adapter.test.js.map +1 -1
- package/src/providers/cursor/__tests__/adapter.test.ts +2 -2
- package/src/providers/cursor/adapter.d.ts +44 -40
- package/src/providers/cursor/adapter.d.ts.map +0 -0
- package/src/providers/cursor/adapter.js +0 -0
- package/src/providers/cursor/adapter.js.map +0 -0
- package/src/providers/cursor/adapter.ts +0 -0
- package/src/providers/cursor/hooks.d.ts +29 -29
- package/src/providers/cursor/hooks.d.ts.map +0 -0
- package/src/providers/cursor/hooks.js +0 -0
- package/src/providers/cursor/hooks.js.map +0 -0
- package/src/providers/cursor/hooks.ts +0 -0
- package/src/providers/cursor/index.d.ts +1 -1
- package/src/providers/cursor/index.d.ts.map +0 -0
- package/src/providers/cursor/index.js +0 -0
- package/src/providers/cursor/index.js.map +0 -0
- package/src/providers/cursor/index.ts +0 -0
- package/src/providers/cursor/install.d.ts +67 -67
- package/src/providers/cursor/install.d.ts.map +1 -1
- package/src/providers/cursor/install.js +1 -4
- package/src/providers/cursor/install.js.map +1 -1
- package/src/providers/cursor/install.ts +1 -4
- package/src/providers/cursor/manifest.json +0 -0
- package/src/providers/cursor/spawn.d.ts +31 -31
- package/src/providers/cursor/spawn.d.ts.map +0 -0
- package/src/providers/cursor/spawn.js +0 -0
- package/src/providers/cursor/spawn.js.map +1 -1
- package/src/providers/cursor/spawn.ts +2 -2
- package/src/providers/opencode/__tests__/adapter.test.d.ts +1 -1
- package/src/providers/opencode/__tests__/adapter.test.d.ts.map +0 -0
- package/src/providers/opencode/__tests__/adapter.test.js +2 -2
- package/src/providers/opencode/__tests__/adapter.test.js.map +1 -1
- package/src/providers/opencode/__tests__/adapter.test.ts +2 -2
- package/src/providers/opencode/adapter.d.ts +50 -46
- package/src/providers/opencode/adapter.d.ts.map +0 -0
- package/src/providers/opencode/adapter.js +0 -0
- package/src/providers/opencode/adapter.js.map +0 -0
- package/src/providers/opencode/adapter.ts +0 -0
- package/src/providers/opencode/hooks.d.ts +36 -36
- package/src/providers/opencode/hooks.d.ts.map +0 -0
- package/src/providers/opencode/hooks.js +1 -1
- package/src/providers/opencode/hooks.js.map +1 -1
- package/src/providers/opencode/hooks.ts +1 -1
- package/src/providers/opencode/index.d.ts +2 -2
- package/src/providers/opencode/index.d.ts.map +1 -1
- package/src/providers/opencode/index.js +1 -1
- package/src/providers/opencode/index.js.map +1 -1
- package/src/providers/opencode/index.ts +1 -1
- package/src/providers/opencode/install.d.ts +46 -46
- package/src/providers/opencode/install.d.ts.map +1 -1
- package/src/providers/opencode/install.js +1 -4
- package/src/providers/opencode/install.js.map +1 -1
- package/src/providers/opencode/install.ts +1 -4
- package/src/providers/opencode/manifest.json +0 -0
- package/src/providers/opencode/spawn.d.ts +42 -39
- package/src/providers/opencode/spawn.d.ts.map +1 -1
- package/src/providers/opencode/spawn.js +0 -0
- package/src/providers/opencode/spawn.js.map +1 -1
- package/src/providers/opencode/spawn.ts +2 -7
- package/src/registry.d.ts +12 -12
- package/src/registry.d.ts.map +1 -1
- package/src/registry.js +0 -0
- package/src/registry.js.map +1 -1
- package/src/registry.ts +1 -3
- package/dist/index.d.ts +0 -27
- package/dist/index.d.ts.map +0 -1
- package/dist/providers/claude-code/adapter.d.ts +0 -75
- package/dist/providers/claude-code/adapter.d.ts.map +0 -1
- package/dist/providers/claude-code/adapter.js +0 -154
- package/dist/providers/claude-code/adapter.js.map +0 -1
- package/dist/providers/claude-code/context-monitor.d.ts +0 -24
- package/dist/providers/claude-code/context-monitor.d.ts.map +0 -1
- package/dist/providers/claude-code/context-monitor.js +0 -148
- package/dist/providers/claude-code/context-monitor.js.map +0 -1
- package/dist/providers/claude-code/hooks.d.ts +0 -59
- package/dist/providers/claude-code/hooks.d.ts.map +0 -1
- package/dist/providers/claude-code/hooks.js +0 -77
- package/dist/providers/claude-code/hooks.js.map +0 -1
- package/dist/providers/claude-code/index.d.ts +0 -24
- package/dist/providers/claude-code/index.d.ts.map +0 -1
- package/dist/providers/claude-code/index.js +0 -26
- package/dist/providers/claude-code/index.js.map +0 -1
- package/dist/providers/claude-code/install.d.ts +0 -75
- package/dist/providers/claude-code/install.d.ts.map +0 -1
- package/dist/providers/claude-code/install.js +0 -237
- package/dist/providers/claude-code/install.js.map +0 -1
- package/dist/providers/claude-code/paths.d.ts +0 -24
- package/dist/providers/claude-code/paths.d.ts.map +0 -1
- package/dist/providers/claude-code/paths.js +0 -33
- package/dist/providers/claude-code/paths.js.map +0 -1
- package/dist/providers/claude-code/spawn.d.ts +0 -60
- package/dist/providers/claude-code/spawn.d.ts.map +0 -1
- package/dist/providers/claude-code/spawn.js +0 -160
- package/dist/providers/claude-code/spawn.js.map +0 -1
- package/dist/providers/claude-code/statusline.d.ts +0 -24
- package/dist/providers/claude-code/statusline.d.ts.map +0 -1
- package/dist/providers/claude-code/statusline.js +0 -85
- package/dist/providers/claude-code/statusline.js.map +0 -1
- package/dist/providers/claude-code/task-sync.d.ts +0 -27
- package/dist/providers/claude-code/task-sync.d.ts.map +0 -1
- package/dist/providers/claude-code/task-sync.js +0 -124
- package/dist/providers/claude-code/task-sync.js.map +0 -1
- package/dist/providers/claude-code/transport.d.ts +0 -14
- package/dist/providers/claude-code/transport.d.ts.map +0 -1
- package/dist/providers/claude-code/transport.js +0 -18
- package/dist/providers/claude-code/transport.js.map +0 -1
- package/dist/providers/cursor/adapter.d.ts +0 -62
- package/dist/providers/cursor/adapter.d.ts.map +0 -1
- package/dist/providers/cursor/adapter.js +0 -124
- package/dist/providers/cursor/adapter.js.map +0 -1
- package/dist/providers/cursor/hooks.d.ts +0 -48
- package/dist/providers/cursor/hooks.d.ts.map +0 -1
- package/dist/providers/cursor/hooks.js +0 -55
- package/dist/providers/cursor/hooks.js.map +0 -1
- package/dist/providers/cursor/index.d.ts +0 -19
- package/dist/providers/cursor/index.d.ts.map +0 -1
- package/dist/providers/cursor/index.js +0 -21
- package/dist/providers/cursor/index.js.map +0 -1
- package/dist/providers/cursor/install.d.ts +0 -94
- package/dist/providers/cursor/install.d.ts.map +0 -1
- package/dist/providers/cursor/install.js +0 -241
- package/dist/providers/cursor/install.js.map +0 -1
- package/dist/providers/cursor/spawn.d.ts +0 -50
- package/dist/providers/cursor/spawn.d.ts.map +0 -1
- package/dist/providers/cursor/spawn.js +0 -59
- package/dist/providers/cursor/spawn.js.map +0 -1
- package/dist/providers/opencode/adapter.d.ts +0 -67
- package/dist/providers/opencode/adapter.d.ts.map +0 -1
- package/dist/providers/opencode/adapter.js +0 -144
- package/dist/providers/opencode/adapter.js.map +0 -1
- package/dist/providers/opencode/hooks.d.ts +0 -66
- package/dist/providers/opencode/hooks.d.ts.map +0 -1
- package/dist/providers/opencode/hooks.js +0 -89
- package/dist/providers/opencode/hooks.js.map +0 -1
- package/dist/providers/opencode/index.d.ts +0 -20
- package/dist/providers/opencode/index.d.ts.map +0 -1
- package/dist/providers/opencode/index.js +0 -22
- package/dist/providers/opencode/index.js.map +0 -1
- package/dist/providers/opencode/install.d.ts +0 -65
- package/dist/providers/opencode/install.d.ts.map +0 -1
- package/dist/providers/opencode/install.js +0 -183
- package/dist/providers/opencode/install.js.map +0 -1
- package/dist/providers/opencode/spawn.d.ts +0 -72
- package/dist/providers/opencode/spawn.d.ts.map +0 -1
- package/dist/providers/opencode/spawn.js +0 -219
- package/dist/providers/opencode/spawn.js.map +0 -1
- package/dist/registry.d.ts +0 -36
- package/dist/registry.d.ts.map +0 -1
- package/dist/registry.js +0 -55
- package/dist/registry.js.map +0 -1
|
@@ -1,241 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Cursor Install Provider
|
|
3
|
-
*
|
|
4
|
-
* Handles CLEO installation into Cursor environments:
|
|
5
|
-
* - Registers CLEO MCP server in .cursor/mcp.json
|
|
6
|
-
* - Ensures .cursorrules has CLEO @-references (legacy format)
|
|
7
|
-
* - Creates .cursor/rules/cleo.mdc with CLEO references (modern format)
|
|
8
|
-
*
|
|
9
|
-
* Cursor supports two instruction file formats:
|
|
10
|
-
* 1. Legacy: .cursorrules (flat file, project root)
|
|
11
|
-
* 2. Modern: .cursor/rules/*.mdc (MDC format, per-rule files)
|
|
12
|
-
*
|
|
13
|
-
* This provider writes to both for maximum compatibility.
|
|
14
|
-
*
|
|
15
|
-
* @task T5240
|
|
16
|
-
*/
|
|
17
|
-
import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
|
|
18
|
-
import { join } from 'node:path';
|
|
19
|
-
/** Lines that should appear in instruction files to reference CLEO. */
|
|
20
|
-
const INSTRUCTION_REFERENCES = [
|
|
21
|
-
'@~/.cleo/templates/CLEO-INJECTION.md',
|
|
22
|
-
'@.cleo/memory-bridge.md',
|
|
23
|
-
];
|
|
24
|
-
/** MCP server registration key used in Cursor config. */
|
|
25
|
-
const MCP_SERVER_KEY = 'cleo';
|
|
26
|
-
/**
|
|
27
|
-
* Install provider for Cursor.
|
|
28
|
-
*
|
|
29
|
-
* Manages CLEO's integration with Cursor by:
|
|
30
|
-
* 1. Registering the CLEO MCP server in .cursor/mcp.json
|
|
31
|
-
* 2. Creating/updating .cursorrules with @-references (legacy)
|
|
32
|
-
* 3. Creating .cursor/rules/cleo.mdc with @-references (modern)
|
|
33
|
-
*/
|
|
34
|
-
export class CursorInstallProvider {
|
|
35
|
-
installedProjectDir = null;
|
|
36
|
-
/**
|
|
37
|
-
* Install CLEO into a Cursor project.
|
|
38
|
-
*
|
|
39
|
-
* @param options - Installation options including project directory and MCP server path
|
|
40
|
-
* @returns Result describing what was installed
|
|
41
|
-
*/
|
|
42
|
-
async install(options) {
|
|
43
|
-
const { projectDir, mcpServerPath } = options;
|
|
44
|
-
const installedAt = new Date().toISOString();
|
|
45
|
-
let instructionFileUpdated = false;
|
|
46
|
-
let mcpRegistered = false;
|
|
47
|
-
const details = {};
|
|
48
|
-
// Step 1: Register MCP server in .cursor/mcp.json
|
|
49
|
-
if (mcpServerPath) {
|
|
50
|
-
mcpRegistered = this.registerMcpServer(projectDir, mcpServerPath);
|
|
51
|
-
if (mcpRegistered) {
|
|
52
|
-
details.mcpConfigPath = join(projectDir, '.cursor', 'mcp.json');
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
// Step 2: Ensure instruction files have @-references
|
|
56
|
-
instructionFileUpdated = this.updateInstructionFiles(projectDir);
|
|
57
|
-
if (instructionFileUpdated) {
|
|
58
|
-
details.instructionFiles = this.getUpdatedFileList(projectDir);
|
|
59
|
-
}
|
|
60
|
-
this.installedProjectDir = projectDir;
|
|
61
|
-
return {
|
|
62
|
-
success: true,
|
|
63
|
-
installedAt,
|
|
64
|
-
instructionFileUpdated,
|
|
65
|
-
mcpRegistered,
|
|
66
|
-
details,
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
/**
|
|
70
|
-
* Uninstall CLEO from the current Cursor project.
|
|
71
|
-
*
|
|
72
|
-
* Removes the MCP server registration from .cursor/mcp.json.
|
|
73
|
-
* Does not remove instruction file references (they are harmless if CLEO is not present).
|
|
74
|
-
*/
|
|
75
|
-
async uninstall() {
|
|
76
|
-
if (!this.installedProjectDir)
|
|
77
|
-
return;
|
|
78
|
-
const mcpPath = join(this.installedProjectDir, '.cursor', 'mcp.json');
|
|
79
|
-
if (existsSync(mcpPath)) {
|
|
80
|
-
try {
|
|
81
|
-
const raw = readFileSync(mcpPath, 'utf-8');
|
|
82
|
-
const config = JSON.parse(raw);
|
|
83
|
-
const mcpServers = config.mcpServers;
|
|
84
|
-
if (mcpServers && MCP_SERVER_KEY in mcpServers) {
|
|
85
|
-
delete mcpServers[MCP_SERVER_KEY];
|
|
86
|
-
writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\n', 'utf-8');
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
catch {
|
|
90
|
-
// Ignore errors during uninstall
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
this.installedProjectDir = null;
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Check whether CLEO is installed in the current environment.
|
|
97
|
-
*
|
|
98
|
-
* Checks for MCP server registered in .cursor/mcp.json.
|
|
99
|
-
*/
|
|
100
|
-
async isInstalled() {
|
|
101
|
-
const mcpPath = join(process.cwd(), '.cursor', 'mcp.json');
|
|
102
|
-
if (existsSync(mcpPath)) {
|
|
103
|
-
try {
|
|
104
|
-
const config = JSON.parse(readFileSync(mcpPath, 'utf-8'));
|
|
105
|
-
const mcpServers = config.mcpServers;
|
|
106
|
-
if (mcpServers && MCP_SERVER_KEY in mcpServers) {
|
|
107
|
-
return true;
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
catch {
|
|
111
|
-
// Fall through
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
return false;
|
|
115
|
-
}
|
|
116
|
-
/**
|
|
117
|
-
* Ensure instruction files contain @-references to CLEO.
|
|
118
|
-
*
|
|
119
|
-
* Updates .cursorrules (legacy) and creates .cursor/rules/cleo.mdc (modern).
|
|
120
|
-
*
|
|
121
|
-
* @param projectDir - Project root directory
|
|
122
|
-
*/
|
|
123
|
-
async ensureInstructionReferences(projectDir) {
|
|
124
|
-
this.updateInstructionFiles(projectDir);
|
|
125
|
-
}
|
|
126
|
-
/**
|
|
127
|
-
* Register the CLEO MCP server in .cursor/mcp.json.
|
|
128
|
-
*
|
|
129
|
-
* Cursor stores MCP server configuration in .cursor/mcp.json
|
|
130
|
-
* under the mcpServers key.
|
|
131
|
-
*
|
|
132
|
-
* @returns true if registration was performed or updated
|
|
133
|
-
*/
|
|
134
|
-
registerMcpServer(projectDir, mcpServerPath) {
|
|
135
|
-
const cursorDir = join(projectDir, '.cursor');
|
|
136
|
-
const mcpPath = join(cursorDir, 'mcp.json');
|
|
137
|
-
let config = {};
|
|
138
|
-
mkdirSync(cursorDir, { recursive: true });
|
|
139
|
-
if (existsSync(mcpPath)) {
|
|
140
|
-
try {
|
|
141
|
-
config = JSON.parse(readFileSync(mcpPath, 'utf-8'));
|
|
142
|
-
}
|
|
143
|
-
catch {
|
|
144
|
-
// Start fresh on parse error
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
if (!config.mcpServers || typeof config.mcpServers !== 'object') {
|
|
148
|
-
config.mcpServers = {};
|
|
149
|
-
}
|
|
150
|
-
const mcpServers = config.mcpServers;
|
|
151
|
-
mcpServers[MCP_SERVER_KEY] = {
|
|
152
|
-
command: 'node',
|
|
153
|
-
args: [mcpServerPath],
|
|
154
|
-
};
|
|
155
|
-
writeFileSync(mcpPath, JSON.stringify(config, null, 2) + '\n', 'utf-8');
|
|
156
|
-
return true;
|
|
157
|
-
}
|
|
158
|
-
/**
|
|
159
|
-
* Update instruction files with CLEO @-references.
|
|
160
|
-
*
|
|
161
|
-
* Handles both legacy (.cursorrules) and modern (.cursor/rules/cleo.mdc) formats.
|
|
162
|
-
*
|
|
163
|
-
* @returns true if any file was created or modified
|
|
164
|
-
*/
|
|
165
|
-
updateInstructionFiles(projectDir) {
|
|
166
|
-
let updated = false;
|
|
167
|
-
// Update legacy .cursorrules if it exists
|
|
168
|
-
if (this.updateLegacyRules(projectDir)) {
|
|
169
|
-
updated = true;
|
|
170
|
-
}
|
|
171
|
-
// Create/update modern .cursor/rules/cleo.mdc
|
|
172
|
-
if (this.updateModernRules(projectDir)) {
|
|
173
|
-
updated = true;
|
|
174
|
-
}
|
|
175
|
-
return updated;
|
|
176
|
-
}
|
|
177
|
-
/**
|
|
178
|
-
* Update legacy .cursorrules file with @-references.
|
|
179
|
-
* Only modifies the file if it already exists (does not create it).
|
|
180
|
-
*
|
|
181
|
-
* @returns true if the file was modified
|
|
182
|
-
*/
|
|
183
|
-
updateLegacyRules(projectDir) {
|
|
184
|
-
const rulesPath = join(projectDir, '.cursorrules');
|
|
185
|
-
if (!existsSync(rulesPath)) {
|
|
186
|
-
return false;
|
|
187
|
-
}
|
|
188
|
-
let content = readFileSync(rulesPath, 'utf-8');
|
|
189
|
-
const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
|
|
190
|
-
if (missingRefs.length === 0) {
|
|
191
|
-
return false;
|
|
192
|
-
}
|
|
193
|
-
const separator = content.endsWith('\n') ? '' : '\n';
|
|
194
|
-
content = content + separator + missingRefs.join('\n') + '\n';
|
|
195
|
-
writeFileSync(rulesPath, content, 'utf-8');
|
|
196
|
-
return true;
|
|
197
|
-
}
|
|
198
|
-
/**
|
|
199
|
-
* Create or update .cursor/rules/cleo.mdc with CLEO references.
|
|
200
|
-
*
|
|
201
|
-
* MDC (Markdown Component) format is Cursor's modern rule file format.
|
|
202
|
-
* Each .mdc file in .cursor/rules/ is loaded as a rule set.
|
|
203
|
-
*
|
|
204
|
-
* @returns true if the file was created or modified
|
|
205
|
-
*/
|
|
206
|
-
updateModernRules(projectDir) {
|
|
207
|
-
const rulesDir = join(projectDir, '.cursor', 'rules');
|
|
208
|
-
const mdcPath = join(rulesDir, 'cleo.mdc');
|
|
209
|
-
const expectedContent = [
|
|
210
|
-
'---',
|
|
211
|
-
'description: CLEO task management protocol references',
|
|
212
|
-
'globs: "**/*"',
|
|
213
|
-
'alwaysApply: true',
|
|
214
|
-
'---',
|
|
215
|
-
'',
|
|
216
|
-
...INSTRUCTION_REFERENCES,
|
|
217
|
-
'',
|
|
218
|
-
].join('\n');
|
|
219
|
-
if (existsSync(mdcPath)) {
|
|
220
|
-
const existing = readFileSync(mdcPath, 'utf-8');
|
|
221
|
-
if (existing === expectedContent) {
|
|
222
|
-
return false;
|
|
223
|
-
}
|
|
224
|
-
}
|
|
225
|
-
mkdirSync(rulesDir, { recursive: true });
|
|
226
|
-
writeFileSync(mdcPath, expectedContent, 'utf-8');
|
|
227
|
-
return true;
|
|
228
|
-
}
|
|
229
|
-
/**
|
|
230
|
-
* Get list of instruction files that were updated.
|
|
231
|
-
*/
|
|
232
|
-
getUpdatedFileList(projectDir) {
|
|
233
|
-
const files = [];
|
|
234
|
-
if (existsSync(join(projectDir, '.cursorrules'))) {
|
|
235
|
-
files.push(join(projectDir, '.cursorrules'));
|
|
236
|
-
}
|
|
237
|
-
files.push(join(projectDir, '.cursor', 'rules', 'cleo.mdc'));
|
|
238
|
-
return files;
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
|
-
//# sourceMappingURL=install.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/cursor/install.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Cursor Spawn Provider
|
|
3
|
-
*
|
|
4
|
-
* Cursor is a GUI-based AI code editor and does not support
|
|
5
|
-
* CLI-based subagent spawning. This provider implements
|
|
6
|
-
* the AdapterSpawnProvider interface with appropriate rejections.
|
|
7
|
-
*
|
|
8
|
-
* @task T5240
|
|
9
|
-
*/
|
|
10
|
-
import type { AdapterSpawnProvider, SpawnContext, SpawnResult } from '@cleocode/contracts';
|
|
11
|
-
/**
|
|
12
|
-
* Spawn provider for Cursor.
|
|
13
|
-
*
|
|
14
|
-
* Cursor does not support subagent spawning via CLI. The adapter
|
|
15
|
-
* declares supportsSpawn: false in its capabilities. All methods
|
|
16
|
-
* either reject or return empty results.
|
|
17
|
-
*/
|
|
18
|
-
export declare class CursorSpawnProvider implements AdapterSpawnProvider {
|
|
19
|
-
/**
|
|
20
|
-
* Check if Cursor supports spawning subagents.
|
|
21
|
-
*
|
|
22
|
-
* @returns false (Cursor does not support CLI spawning)
|
|
23
|
-
*/
|
|
24
|
-
canSpawn(): Promise<boolean>;
|
|
25
|
-
/**
|
|
26
|
-
* Attempt to spawn a subagent via Cursor.
|
|
27
|
-
*
|
|
28
|
-
* Always throws because Cursor does not support subagent spawning.
|
|
29
|
-
* Callers should check canSpawn() before calling this method.
|
|
30
|
-
*
|
|
31
|
-
* @param _context - Unused; spawning is not supported
|
|
32
|
-
* @throws Error explaining that Cursor does not support subagent spawning
|
|
33
|
-
*/
|
|
34
|
-
spawn(_context: SpawnContext): Promise<SpawnResult>;
|
|
35
|
-
/**
|
|
36
|
-
* List running Cursor subagent processes.
|
|
37
|
-
*
|
|
38
|
-
* @returns Empty array (no processes can be spawned)
|
|
39
|
-
*/
|
|
40
|
-
listRunning(): Promise<SpawnResult[]>;
|
|
41
|
-
/**
|
|
42
|
-
* Terminate a Cursor subagent process.
|
|
43
|
-
*
|
|
44
|
-
* No-op because Cursor cannot spawn processes.
|
|
45
|
-
*
|
|
46
|
-
* @param _instanceId - Unused; no processes to terminate
|
|
47
|
-
*/
|
|
48
|
-
terminate(_instanceId: string): Promise<void>;
|
|
49
|
-
}
|
|
50
|
-
//# sourceMappingURL=spawn.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spawn.d.ts","sourceRoot":"","sources":["../../../src/providers/cursor/spawn.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,oBAAoB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAE3F;;;;;;GAMG;AACH,qBAAa,mBAAoB,YAAW,oBAAoB;IAC9D;;;;OAIG;IACG,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC;IAIlC;;;;;;;;OAQG;IACG,KAAK,CAAC,QAAQ,EAAE,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC;IAQzD;;;;OAIG;IACG,WAAW,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAI3C;;;;;;OAMG;IACG,SAAS,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAGpD"}
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Cursor Spawn Provider
|
|
3
|
-
*
|
|
4
|
-
* Cursor is a GUI-based AI code editor and does not support
|
|
5
|
-
* CLI-based subagent spawning. This provider implements
|
|
6
|
-
* the AdapterSpawnProvider interface with appropriate rejections.
|
|
7
|
-
*
|
|
8
|
-
* @task T5240
|
|
9
|
-
*/
|
|
10
|
-
/**
|
|
11
|
-
* Spawn provider for Cursor.
|
|
12
|
-
*
|
|
13
|
-
* Cursor does not support subagent spawning via CLI. The adapter
|
|
14
|
-
* declares supportsSpawn: false in its capabilities. All methods
|
|
15
|
-
* either reject or return empty results.
|
|
16
|
-
*/
|
|
17
|
-
export class CursorSpawnProvider {
|
|
18
|
-
/**
|
|
19
|
-
* Check if Cursor supports spawning subagents.
|
|
20
|
-
*
|
|
21
|
-
* @returns false (Cursor does not support CLI spawning)
|
|
22
|
-
*/
|
|
23
|
-
async canSpawn() {
|
|
24
|
-
return false;
|
|
25
|
-
}
|
|
26
|
-
/**
|
|
27
|
-
* Attempt to spawn a subagent via Cursor.
|
|
28
|
-
*
|
|
29
|
-
* Always throws because Cursor does not support subagent spawning.
|
|
30
|
-
* Callers should check canSpawn() before calling this method.
|
|
31
|
-
*
|
|
32
|
-
* @param _context - Unused; spawning is not supported
|
|
33
|
-
* @throws Error explaining that Cursor does not support subagent spawning
|
|
34
|
-
*/
|
|
35
|
-
async spawn(_context) {
|
|
36
|
-
throw new Error('Cursor does not support subagent spawning. ' +
|
|
37
|
-
'Cursor is a GUI-based editor without CLI subagent capabilities. ' +
|
|
38
|
-
'Use a provider that supports spawning (e.g., Claude Code or OpenCode).');
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* List running Cursor subagent processes.
|
|
42
|
-
*
|
|
43
|
-
* @returns Empty array (no processes can be spawned)
|
|
44
|
-
*/
|
|
45
|
-
async listRunning() {
|
|
46
|
-
return [];
|
|
47
|
-
}
|
|
48
|
-
/**
|
|
49
|
-
* Terminate a Cursor subagent process.
|
|
50
|
-
*
|
|
51
|
-
* No-op because Cursor cannot spawn processes.
|
|
52
|
-
*
|
|
53
|
-
* @param _instanceId - Unused; no processes to terminate
|
|
54
|
-
*/
|
|
55
|
-
async terminate(_instanceId) {
|
|
56
|
-
// No-op: Cursor does not spawn processes.
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
//# sourceMappingURL=spawn.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spawn.js","sourceRoot":"","sources":["../../../src/providers/cursor/spawn.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAIH;;;;;;GAMG;AACH,MAAM,OAAO,mBAAmB;IAC9B;;;;OAIG;IACH,KAAK,CAAC,QAAQ;QACZ,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,KAAK,CAAC,QAAsB;QAChC,MAAM,IAAI,KAAK,CACb,6CAA6C;YAC7C,kEAAkE;YAClE,wEAAwE,CACzE,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,WAAW;QACf,OAAO,EAAE,CAAC;IACZ,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,SAAS,CAAC,WAAmB;QACjC,0CAA0C;IAC5C,CAAC;CACF"}
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* OpenCode Adapter
|
|
3
|
-
*
|
|
4
|
-
* Main CLEOProviderAdapter implementation for OpenCode AI coding assistant.
|
|
5
|
-
* Provides spawn, hooks, and install capabilities for CLEO integration.
|
|
6
|
-
*
|
|
7
|
-
* @task T5240
|
|
8
|
-
*/
|
|
9
|
-
import type { AdapterCapabilities, AdapterHealthStatus, CLEOProviderAdapter } from '@cleocode/contracts';
|
|
10
|
-
import { OpenCodeHookProvider } from './hooks.js';
|
|
11
|
-
import { OpenCodeInstallProvider } from './install.js';
|
|
12
|
-
import { OpenCodeSpawnProvider } from './spawn.js';
|
|
13
|
-
/**
|
|
14
|
-
* CLEO provider adapter for OpenCode AI coding assistant.
|
|
15
|
-
*
|
|
16
|
-
* Bridges CLEO's adapter system with OpenCode's native capabilities:
|
|
17
|
-
* - Hooks: Maps OpenCode events (session.start, tool.complete, etc.) to CAAMP events
|
|
18
|
-
* - Spawn: Launches subagent processes via the `opencode` CLI
|
|
19
|
-
* - Install: Registers MCP server in .opencode/config.json and ensures AGENTS.md references
|
|
20
|
-
*/
|
|
21
|
-
export declare class OpenCodeAdapter implements CLEOProviderAdapter {
|
|
22
|
-
readonly id = "opencode";
|
|
23
|
-
readonly name = "OpenCode";
|
|
24
|
-
readonly version = "1.0.0";
|
|
25
|
-
capabilities: AdapterCapabilities;
|
|
26
|
-
hooks: OpenCodeHookProvider;
|
|
27
|
-
spawn: OpenCodeSpawnProvider;
|
|
28
|
-
install: OpenCodeInstallProvider;
|
|
29
|
-
private projectDir;
|
|
30
|
-
private initialized;
|
|
31
|
-
constructor();
|
|
32
|
-
/**
|
|
33
|
-
* Initialize the adapter for a given project directory.
|
|
34
|
-
*
|
|
35
|
-
* Validates the environment by checking for the OpenCode CLI
|
|
36
|
-
* and OpenCode configuration directory.
|
|
37
|
-
*
|
|
38
|
-
* @param projectDir - Root directory of the project
|
|
39
|
-
*/
|
|
40
|
-
initialize(projectDir: string): Promise<void>;
|
|
41
|
-
/**
|
|
42
|
-
* Dispose the adapter and clean up resources.
|
|
43
|
-
*
|
|
44
|
-
* Unregisters hooks and releases any tracked state.
|
|
45
|
-
*/
|
|
46
|
-
dispose(): Promise<void>;
|
|
47
|
-
/**
|
|
48
|
-
* Run a health check to verify OpenCode is accessible.
|
|
49
|
-
*
|
|
50
|
-
* Checks:
|
|
51
|
-
* 1. Adapter has been initialized
|
|
52
|
-
* 2. OpenCode CLI is available in PATH
|
|
53
|
-
* 3. .opencode/ configuration directory exists in the project
|
|
54
|
-
*
|
|
55
|
-
* @returns Health status with details about each check
|
|
56
|
-
*/
|
|
57
|
-
healthCheck(): Promise<AdapterHealthStatus>;
|
|
58
|
-
/**
|
|
59
|
-
* Check whether the adapter has been initialized.
|
|
60
|
-
*/
|
|
61
|
-
isInitialized(): boolean;
|
|
62
|
-
/**
|
|
63
|
-
* Get the project directory this adapter was initialized with.
|
|
64
|
-
*/
|
|
65
|
-
getProjectDir(): string | null;
|
|
66
|
-
}
|
|
67
|
-
//# sourceMappingURL=adapter.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,OAAO,KAAK,EACV,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAInD;;;;;;;GAOG;AACH,qBAAa,eAAgB,YAAW,mBAAmB;IACzD,QAAQ,CAAC,EAAE,cAAc;IACzB,QAAQ,CAAC,IAAI,cAAc;IAC3B,QAAQ,CAAC,OAAO,WAAW;IAE3B,YAAY,EAAE,mBAAmB,CAoB/B;IAEF,KAAK,EAAE,oBAAoB,CAAC;IAC5B,KAAK,EAAE,qBAAqB,CAAC;IAC7B,OAAO,EAAE,uBAAuB,CAAC;IAEjC,OAAO,CAAC,UAAU,CAAuB;IACzC,OAAO,CAAC,WAAW,CAAS;;IAQ5B;;;;;;;OAOG;IACG,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnD;;;;OAIG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ9B;;;;;;;;;OASG;IACG,WAAW,IAAI,OAAO,CAAC,mBAAmB,CAAC;IA2CjD;;OAEG;IACH,aAAa,IAAI,OAAO;IAIxB;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,IAAI;CAG/B"}
|
|
@@ -1,144 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* OpenCode Adapter
|
|
3
|
-
*
|
|
4
|
-
* Main CLEOProviderAdapter implementation for OpenCode AI coding assistant.
|
|
5
|
-
* Provides spawn, hooks, and install capabilities for CLEO integration.
|
|
6
|
-
*
|
|
7
|
-
* @task T5240
|
|
8
|
-
*/
|
|
9
|
-
import { exec } from 'node:child_process';
|
|
10
|
-
import { existsSync } from 'node:fs';
|
|
11
|
-
import { join } from 'node:path';
|
|
12
|
-
import { promisify } from 'node:util';
|
|
13
|
-
import { OpenCodeHookProvider } from './hooks.js';
|
|
14
|
-
import { OpenCodeInstallProvider } from './install.js';
|
|
15
|
-
import { OpenCodeSpawnProvider } from './spawn.js';
|
|
16
|
-
const execAsync = promisify(exec);
|
|
17
|
-
/**
|
|
18
|
-
* CLEO provider adapter for OpenCode AI coding assistant.
|
|
19
|
-
*
|
|
20
|
-
* Bridges CLEO's adapter system with OpenCode's native capabilities:
|
|
21
|
-
* - Hooks: Maps OpenCode events (session.start, tool.complete, etc.) to CAAMP events
|
|
22
|
-
* - Spawn: Launches subagent processes via the `opencode` CLI
|
|
23
|
-
* - Install: Registers MCP server in .opencode/config.json and ensures AGENTS.md references
|
|
24
|
-
*/
|
|
25
|
-
export class OpenCodeAdapter {
|
|
26
|
-
id = 'opencode';
|
|
27
|
-
name = 'OpenCode';
|
|
28
|
-
version = '1.0.0';
|
|
29
|
-
capabilities = {
|
|
30
|
-
supportsHooks: true,
|
|
31
|
-
supportedHookEvents: [
|
|
32
|
-
'onSessionStart',
|
|
33
|
-
'onSessionEnd',
|
|
34
|
-
'onToolStart',
|
|
35
|
-
'onToolComplete',
|
|
36
|
-
'onError',
|
|
37
|
-
'onPromptSubmit',
|
|
38
|
-
],
|
|
39
|
-
supportsSpawn: true,
|
|
40
|
-
supportsInstall: true,
|
|
41
|
-
supportsMcp: true,
|
|
42
|
-
supportsInstructionFiles: true,
|
|
43
|
-
instructionFilePattern: 'AGENTS.md',
|
|
44
|
-
supportsContextMonitor: false,
|
|
45
|
-
supportsStatusline: false,
|
|
46
|
-
supportsProviderPaths: true,
|
|
47
|
-
supportsTransport: false,
|
|
48
|
-
supportsTaskSync: false,
|
|
49
|
-
};
|
|
50
|
-
hooks;
|
|
51
|
-
spawn;
|
|
52
|
-
install;
|
|
53
|
-
projectDir = null;
|
|
54
|
-
initialized = false;
|
|
55
|
-
constructor() {
|
|
56
|
-
this.hooks = new OpenCodeHookProvider();
|
|
57
|
-
this.spawn = new OpenCodeSpawnProvider();
|
|
58
|
-
this.install = new OpenCodeInstallProvider();
|
|
59
|
-
}
|
|
60
|
-
/**
|
|
61
|
-
* Initialize the adapter for a given project directory.
|
|
62
|
-
*
|
|
63
|
-
* Validates the environment by checking for the OpenCode CLI
|
|
64
|
-
* and OpenCode configuration directory.
|
|
65
|
-
*
|
|
66
|
-
* @param projectDir - Root directory of the project
|
|
67
|
-
*/
|
|
68
|
-
async initialize(projectDir) {
|
|
69
|
-
this.projectDir = projectDir;
|
|
70
|
-
this.initialized = true;
|
|
71
|
-
}
|
|
72
|
-
/**
|
|
73
|
-
* Dispose the adapter and clean up resources.
|
|
74
|
-
*
|
|
75
|
-
* Unregisters hooks and releases any tracked state.
|
|
76
|
-
*/
|
|
77
|
-
async dispose() {
|
|
78
|
-
if (this.hooks.isRegistered()) {
|
|
79
|
-
await this.hooks.unregisterNativeHooks();
|
|
80
|
-
}
|
|
81
|
-
this.initialized = false;
|
|
82
|
-
this.projectDir = null;
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Run a health check to verify OpenCode is accessible.
|
|
86
|
-
*
|
|
87
|
-
* Checks:
|
|
88
|
-
* 1. Adapter has been initialized
|
|
89
|
-
* 2. OpenCode CLI is available in PATH
|
|
90
|
-
* 3. .opencode/ configuration directory exists in the project
|
|
91
|
-
*
|
|
92
|
-
* @returns Health status with details about each check
|
|
93
|
-
*/
|
|
94
|
-
async healthCheck() {
|
|
95
|
-
const details = {};
|
|
96
|
-
if (!this.initialized) {
|
|
97
|
-
return {
|
|
98
|
-
healthy: false,
|
|
99
|
-
provider: this.id,
|
|
100
|
-
details: { error: 'Adapter not initialized' },
|
|
101
|
-
};
|
|
102
|
-
}
|
|
103
|
-
// Check OpenCode CLI availability
|
|
104
|
-
let cliAvailable = false;
|
|
105
|
-
try {
|
|
106
|
-
const { stdout } = await execAsync('which opencode');
|
|
107
|
-
cliAvailable = stdout.trim().length > 0;
|
|
108
|
-
details.cliPath = stdout.trim();
|
|
109
|
-
}
|
|
110
|
-
catch {
|
|
111
|
-
details.cliAvailable = false;
|
|
112
|
-
}
|
|
113
|
-
// Check for OpenCode config directory in the project
|
|
114
|
-
if (this.projectDir) {
|
|
115
|
-
const openCodeConfigDir = join(this.projectDir, '.opencode');
|
|
116
|
-
const configExists = existsSync(openCodeConfigDir);
|
|
117
|
-
details.configDirExists = configExists;
|
|
118
|
-
}
|
|
119
|
-
// Check for OPENCODE_VERSION env var
|
|
120
|
-
const versionEnvSet = process.env.OPENCODE_VERSION !== undefined;
|
|
121
|
-
details.versionEnvSet = versionEnvSet;
|
|
122
|
-
// Healthy if CLI is available (primary requirement)
|
|
123
|
-
const healthy = cliAvailable;
|
|
124
|
-
details.cliAvailable = cliAvailable;
|
|
125
|
-
return {
|
|
126
|
-
healthy,
|
|
127
|
-
provider: this.id,
|
|
128
|
-
details,
|
|
129
|
-
};
|
|
130
|
-
}
|
|
131
|
-
/**
|
|
132
|
-
* Check whether the adapter has been initialized.
|
|
133
|
-
*/
|
|
134
|
-
isInitialized() {
|
|
135
|
-
return this.initialized;
|
|
136
|
-
}
|
|
137
|
-
/**
|
|
138
|
-
* Get the project directory this adapter was initialized with.
|
|
139
|
-
*/
|
|
140
|
-
getProjectDir() {
|
|
141
|
-
return this.projectDir;
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
//# sourceMappingURL=adapter.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/opencode/adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* OpenCode Hook Provider
|
|
3
|
-
*
|
|
4
|
-
* Maps OpenCode's native hook events to CAAMP hook events.
|
|
5
|
-
* OpenCode supports 6 of 8 CAAMP events through its agent/hook system.
|
|
6
|
-
*
|
|
7
|
-
* OpenCode event mapping:
|
|
8
|
-
* - session.start -> onSessionStart
|
|
9
|
-
* - session.end -> onSessionEnd
|
|
10
|
-
* - tool.start -> onToolStart
|
|
11
|
-
* - tool.complete -> onToolComplete
|
|
12
|
-
* - error -> onError
|
|
13
|
-
* - prompt.submit -> onPromptSubmit
|
|
14
|
-
*
|
|
15
|
-
* @task T5240
|
|
16
|
-
*/
|
|
17
|
-
import type { AdapterHookProvider } from '@cleocode/contracts';
|
|
18
|
-
/**
|
|
19
|
-
* Hook provider for OpenCode.
|
|
20
|
-
*
|
|
21
|
-
* OpenCode registers hooks via its configuration system at
|
|
22
|
-
* .opencode/config.json. Hook handlers are defined as shell commands
|
|
23
|
-
* or script paths that execute when the corresponding event fires.
|
|
24
|
-
*
|
|
25
|
-
* Since hooks are registered through the config system (managed by
|
|
26
|
-
* the install provider), registerNativeHooks and unregisterNativeHooks
|
|
27
|
-
* track registration state without performing filesystem operations.
|
|
28
|
-
*/
|
|
29
|
-
export declare class OpenCodeHookProvider implements AdapterHookProvider {
|
|
30
|
-
private registered;
|
|
31
|
-
/**
|
|
32
|
-
* Map an OpenCode native event name to a CAAMP hook event name.
|
|
33
|
-
*
|
|
34
|
-
* @param providerEvent - OpenCode event name (e.g. "session.start", "tool.complete")
|
|
35
|
-
* @returns CAAMP event name or null if unmapped
|
|
36
|
-
*/
|
|
37
|
-
mapProviderEvent(providerEvent: string): string | null;
|
|
38
|
-
/**
|
|
39
|
-
* Register native hooks for a project.
|
|
40
|
-
*
|
|
41
|
-
* For OpenCode, hooks are registered via the config system
|
|
42
|
-
* (.opencode/config.json), which is handled by the install provider.
|
|
43
|
-
* This method marks hooks as registered without performing
|
|
44
|
-
* filesystem operations.
|
|
45
|
-
*
|
|
46
|
-
* @param _projectDir - Project directory (unused; config manages registration)
|
|
47
|
-
*/
|
|
48
|
-
registerNativeHooks(_projectDir: string): Promise<void>;
|
|
49
|
-
/**
|
|
50
|
-
* Unregister native hooks.
|
|
51
|
-
*
|
|
52
|
-
* For OpenCode, this is a no-op since hooks are managed through
|
|
53
|
-
* the config system. Unregistration happens via the install
|
|
54
|
-
* provider's uninstall method.
|
|
55
|
-
*/
|
|
56
|
-
unregisterNativeHooks(): Promise<void>;
|
|
57
|
-
/**
|
|
58
|
-
* Check whether hooks have been registered via registerNativeHooks.
|
|
59
|
-
*/
|
|
60
|
-
isRegistered(): boolean;
|
|
61
|
-
/**
|
|
62
|
-
* Get the full event mapping for introspection/debugging.
|
|
63
|
-
*/
|
|
64
|
-
getEventMap(): Readonly<Record<string, string>>;
|
|
65
|
-
}
|
|
66
|
-
//# sourceMappingURL=hooks.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAiB/D;;;;;;;;;;GAUG;AACH,qBAAa,oBAAqB,YAAW,mBAAmB;IAC9D,OAAO,CAAC,UAAU,CAAS;IAE3B;;;;;OAKG;IACH,gBAAgB,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAItD;;;;;;;;;OASG;IACG,mBAAmB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7D;;;;;;OAMG;IACG,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5C;;OAEG;IACH,YAAY,IAAI,OAAO;IAIvB;;OAEG;IACH,WAAW,IAAI,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAGhD"}
|