@cleocode/adapters 2026.4.11 → 2026.4.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +3 -3
- package/src/__tests__/claude-code-adapter.test.ts +1 -3
- package/src/__tests__/cursor-adapter.test.ts +1 -3
- package/src/__tests__/opencode-adapter.test.ts +1 -3
- package/src/providers/claude-code/__tests__/adapter.test.ts +0 -12
- package/src/providers/claude-code/adapter.ts +0 -1
- package/src/providers/claude-code/install.ts +0 -1
- package/src/providers/codex/adapter.ts +0 -1
- package/src/providers/codex/install.ts +0 -1
- package/src/providers/cursor/__tests__/adapter.test.ts +0 -12
- package/src/providers/cursor/adapter.ts +0 -1
- package/src/providers/cursor/install.ts +0 -1
- package/src/providers/gemini-cli/adapter.ts +0 -1
- package/src/providers/gemini-cli/install.ts +0 -1
- package/src/providers/kimi/adapter.ts +0 -1
- package/src/providers/kimi/install.ts +0 -1
- package/src/providers/opencode/__tests__/adapter.test.ts +0 -12
- package/src/providers/opencode/adapter.ts +0 -1
- package/src/providers/opencode/install.ts +0 -1
- package/dist/index.d.ts +0 -23
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -3258
- package/dist/index.js.map +0 -7
- package/dist/providers/claude-code/adapter.d.ts +0 -95
- package/dist/providers/claude-code/adapter.d.ts.map +0 -1
- package/dist/providers/claude-code/adapter.js +0 -185
- package/dist/providers/claude-code/adapter.js.map +0 -1
- package/dist/providers/claude-code/context-monitor.d.ts +0 -35
- package/dist/providers/claude-code/context-monitor.d.ts.map +0 -1
- package/dist/providers/claude-code/context-monitor.js +0 -159
- package/dist/providers/claude-code/context-monitor.js.map +0 -1
- package/dist/providers/claude-code/hooks.d.ts +0 -146
- package/dist/providers/claude-code/hooks.d.ts.map +0 -1
- package/dist/providers/claude-code/hooks.js +0 -286
- package/dist/providers/claude-code/hooks.js.map +0 -1
- package/dist/providers/claude-code/index.d.ts +0 -39
- package/dist/providers/claude-code/index.d.ts.map +0 -1
- package/dist/providers/claude-code/index.js +0 -41
- package/dist/providers/claude-code/index.js.map +0 -1
- package/dist/providers/claude-code/install.d.ts +0 -67
- package/dist/providers/claude-code/install.d.ts.map +0 -1
- package/dist/providers/claude-code/install.js +0 -161
- package/dist/providers/claude-code/install.js.map +0 -1
- package/dist/providers/claude-code/paths.d.ts +0 -32
- package/dist/providers/claude-code/paths.d.ts.map +0 -1
- package/dist/providers/claude-code/paths.js +0 -41
- package/dist/providers/claude-code/paths.js.map +0 -1
- package/dist/providers/claude-code/spawn.d.ts +0 -67
- package/dist/providers/claude-code/spawn.d.ts.map +0 -1
- package/dist/providers/claude-code/spawn.js +0 -171
- package/dist/providers/claude-code/spawn.js.map +0 -1
- package/dist/providers/claude-code/statusline.d.ts +0 -68
- package/dist/providers/claude-code/statusline.d.ts.map +0 -1
- package/dist/providers/claude-code/statusline.js +0 -130
- package/dist/providers/claude-code/statusline.js.map +0 -1
- package/dist/providers/claude-code/task-sync.d.ts +0 -32
- package/dist/providers/claude-code/task-sync.d.ts.map +0 -1
- package/dist/providers/claude-code/task-sync.js +0 -119
- package/dist/providers/claude-code/task-sync.js.map +0 -1
- package/dist/providers/claude-code/transport.d.ts +0 -25
- package/dist/providers/claude-code/transport.d.ts.map +0 -1
- package/dist/providers/claude-code/transport.js +0 -29
- package/dist/providers/claude-code/transport.js.map +0 -1
- package/dist/providers/codex/adapter.d.ts +0 -83
- package/dist/providers/codex/adapter.d.ts.map +0 -1
- package/dist/providers/codex/adapter.js +0 -147
- package/dist/providers/codex/adapter.js.map +0 -1
- package/dist/providers/codex/hooks.d.ts +0 -91
- package/dist/providers/codex/hooks.d.ts.map +0 -1
- package/dist/providers/codex/hooks.js +0 -113
- package/dist/providers/codex/hooks.js.map +0 -1
- package/dist/providers/codex/index.d.ts +0 -37
- package/dist/providers/codex/index.d.ts.map +0 -1
- package/dist/providers/codex/index.js +0 -39
- package/dist/providers/codex/index.js.map +0 -1
- package/dist/providers/codex/install.d.ts +0 -65
- package/dist/providers/codex/install.d.ts.map +0 -1
- package/dist/providers/codex/install.js +0 -125
- package/dist/providers/codex/install.js.map +0 -1
- package/dist/providers/cursor/adapter.d.ts +0 -76
- package/dist/providers/cursor/adapter.d.ts.map +0 -1
- package/dist/providers/cursor/adapter.js +0 -152
- package/dist/providers/cursor/adapter.js.map +0 -1
- package/dist/providers/cursor/hooks.d.ts +0 -140
- package/dist/providers/cursor/hooks.d.ts.map +0 -1
- package/dist/providers/cursor/hooks.js +0 -208
- package/dist/providers/cursor/hooks.js.map +0 -1
- package/dist/providers/cursor/index.d.ts +0 -34
- package/dist/providers/cursor/index.d.ts.map +0 -1
- package/dist/providers/cursor/index.js +0 -36
- package/dist/providers/cursor/index.js.map +0 -1
- package/dist/providers/cursor/install.d.ts +0 -87
- package/dist/providers/cursor/install.d.ts.map +0 -1
- package/dist/providers/cursor/install.js +0 -181
- package/dist/providers/cursor/install.js.map +0 -1
- package/dist/providers/cursor/spawn.d.ts +0 -50
- package/dist/providers/cursor/spawn.d.ts.map +0 -1
- package/dist/providers/cursor/spawn.js +0 -59
- package/dist/providers/cursor/spawn.js.map +0 -1
- package/dist/providers/gemini-cli/adapter.d.ts +0 -84
- package/dist/providers/gemini-cli/adapter.d.ts.map +0 -1
- package/dist/providers/gemini-cli/adapter.js +0 -159
- package/dist/providers/gemini-cli/adapter.js.map +0 -1
- package/dist/providers/gemini-cli/hooks.d.ts +0 -99
- package/dist/providers/gemini-cli/hooks.d.ts.map +0 -1
- package/dist/providers/gemini-cli/hooks.js +0 -128
- package/dist/providers/gemini-cli/hooks.js.map +0 -1
- package/dist/providers/gemini-cli/index.d.ts +0 -37
- package/dist/providers/gemini-cli/index.d.ts.map +0 -1
- package/dist/providers/gemini-cli/index.js +0 -39
- package/dist/providers/gemini-cli/index.js.map +0 -1
- package/dist/providers/gemini-cli/install.d.ts +0 -65
- package/dist/providers/gemini-cli/install.d.ts.map +0 -1
- package/dist/providers/gemini-cli/install.js +0 -125
- package/dist/providers/gemini-cli/install.js.map +0 -1
- package/dist/providers/kimi/adapter.d.ts +0 -85
- package/dist/providers/kimi/adapter.d.ts.map +0 -1
- package/dist/providers/kimi/adapter.js +0 -146
- package/dist/providers/kimi/adapter.js.map +0 -1
- package/dist/providers/kimi/hooks.d.ts +0 -70
- package/dist/providers/kimi/hooks.d.ts.map +0 -1
- package/dist/providers/kimi/hooks.js +0 -79
- package/dist/providers/kimi/hooks.js.map +0 -1
- package/dist/providers/kimi/index.d.ts +0 -37
- package/dist/providers/kimi/index.d.ts.map +0 -1
- package/dist/providers/kimi/index.js +0 -39
- package/dist/providers/kimi/index.js.map +0 -1
- package/dist/providers/kimi/install.d.ts +0 -65
- package/dist/providers/kimi/install.d.ts.map +0 -1
- package/dist/providers/kimi/install.js +0 -125
- package/dist/providers/kimi/install.js.map +0 -1
- package/dist/providers/opencode/adapter.d.ts +0 -83
- package/dist/providers/opencode/adapter.d.ts.map +0 -1
- package/dist/providers/opencode/adapter.js +0 -167
- package/dist/providers/opencode/adapter.js.map +0 -1
- package/dist/providers/opencode/hooks.d.ts +0 -136
- package/dist/providers/opencode/hooks.d.ts.map +0 -1
- package/dist/providers/opencode/hooks.js +0 -206
- package/dist/providers/opencode/hooks.js.map +0 -1
- package/dist/providers/opencode/index.d.ts +0 -35
- package/dist/providers/opencode/index.d.ts.map +0 -1
- package/dist/providers/opencode/index.js +0 -37
- package/dist/providers/opencode/index.js.map +0 -1
- package/dist/providers/opencode/install.d.ts +0 -56
- package/dist/providers/opencode/install.d.ts.map +0 -1
- package/dist/providers/opencode/install.js +0 -116
- package/dist/providers/opencode/install.js.map +0 -1
- package/dist/providers/opencode/spawn.d.ts +0 -94
- package/dist/providers/opencode/spawn.d.ts.map +0 -1
- package/dist/providers/opencode/spawn.js +0 -241
- package/dist/providers/opencode/spawn.js.map +0 -1
- package/dist/providers/shared/transcript-reader.d.ts +0 -58
- package/dist/providers/shared/transcript-reader.d.ts.map +0 -1
- package/dist/providers/shared/transcript-reader.js +0 -124
- package/dist/providers/shared/transcript-reader.js.map +0 -1
- package/dist/registry.d.ts +0 -88
- package/dist/registry.d.ts.map +0 -1
- package/dist/registry.js +0 -88
- package/dist/registry.js.map +0 -1
|
@@ -1,206 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* OpenCode Hook Provider
|
|
3
|
-
*
|
|
4
|
-
* Maps OpenCode's native hook events to CAAMP canonical hook events.
|
|
5
|
-
* OpenCode supports 10 of 16 canonical events through its plugin system.
|
|
6
|
-
*
|
|
7
|
-
* Event translation uses CAAMP normalizer APIs:
|
|
8
|
-
* - `toCanonical(nativeName, 'opencode')` for runtime event name resolution
|
|
9
|
-
* - `getSupportedEvents('opencode')` to enumerate supported canonical events
|
|
10
|
-
* - `getProviderHookProfile('opencode')` for the full provider profile
|
|
11
|
-
*
|
|
12
|
-
* OpenCode uses a JavaScript plugin system with event-prefixed names
|
|
13
|
-
* (e.g. `event:session.created`) for some hooks and bare names for others.
|
|
14
|
-
* The map is derived from `getProviderHookProfile('opencode').mappings` in
|
|
15
|
-
* CAAMP 1.9.1. PostToolUseFailure, SubagentStart, SubagentStop, Notification,
|
|
16
|
-
* and ConfigChange are not supported by OpenCode.
|
|
17
|
-
*
|
|
18
|
-
* @task T164
|
|
19
|
-
* @epic T134
|
|
20
|
-
*/
|
|
21
|
-
/** CAAMP provider identifier for OpenCode. */
|
|
22
|
-
const PROVIDER_ID = 'opencode';
|
|
23
|
-
/**
|
|
24
|
-
* Fallback map from OpenCode native event names to CAAMP canonical names.
|
|
25
|
-
*
|
|
26
|
-
* Derived from `getProviderHookProfile('opencode').mappings` in CAAMP 1.9.1.
|
|
27
|
-
* Covers all 10 supported events. PostToolUseFailure, SubagentStart,
|
|
28
|
-
* SubagentStop, Notification, and ConfigChange are not supported by OpenCode
|
|
29
|
-
* and are absent from this map.
|
|
30
|
-
*
|
|
31
|
-
* OpenCode uses dot-delimited and event-prefixed names (e.g. "event:session.created")
|
|
32
|
-
* while CAAMP canonical names are PascalCase (e.g. "SessionStart").
|
|
33
|
-
*/
|
|
34
|
-
const OPENCODE_EVENT_MAP = {
|
|
35
|
-
// CAAMP: toNative('SessionStart', 'opencode') = 'event:session.created'
|
|
36
|
-
'event:session.created': 'SessionStart',
|
|
37
|
-
// CAAMP: toNative('SessionEnd', 'opencode') = 'event:session.deleted'
|
|
38
|
-
'event:session.deleted': 'SessionEnd',
|
|
39
|
-
// CAAMP: toNative('PromptSubmit', 'opencode') = 'chat.message'
|
|
40
|
-
'chat.message': 'PromptSubmit',
|
|
41
|
-
// CAAMP: toNative('ResponseComplete', 'opencode') = 'event:session.idle'
|
|
42
|
-
'event:session.idle': 'ResponseComplete',
|
|
43
|
-
// CAAMP: toNative('PreToolUse', 'opencode') = 'tool.execute.before'
|
|
44
|
-
'tool.execute.before': 'PreToolUse',
|
|
45
|
-
// CAAMP: toNative('PostToolUse', 'opencode') = 'tool.execute.after'
|
|
46
|
-
'tool.execute.after': 'PostToolUse',
|
|
47
|
-
// CAAMP: toNative('PermissionRequest', 'opencode') = 'permission.ask'
|
|
48
|
-
'permission.ask': 'PermissionRequest',
|
|
49
|
-
// CAAMP: toNative('PreModel', 'opencode') = 'chat.params'
|
|
50
|
-
'chat.params': 'PreModel',
|
|
51
|
-
// CAAMP: toNative('PreCompact', 'opencode') = 'experimental.session.compacting'
|
|
52
|
-
'experimental.session.compacting': 'PreCompact',
|
|
53
|
-
// CAAMP: toNative('PostCompact', 'opencode') = 'event:session.compacted'
|
|
54
|
-
'event:session.compacted': 'PostCompact',
|
|
55
|
-
};
|
|
56
|
-
/**
|
|
57
|
-
* Hook provider for OpenCode.
|
|
58
|
-
*
|
|
59
|
-
* OpenCode registers hooks via its JavaScript plugin system at
|
|
60
|
-
* `.opencode/plugins/`. Supported handler type: plugin (JavaScript).
|
|
61
|
-
*
|
|
62
|
-
* Event mapping is based on `getProviderHookProfile('opencode')` from
|
|
63
|
-
* CAAMP 1.9.1. Async accessors (`getSupportedCanonicalEvents`,
|
|
64
|
-
* `getProviderProfile`) call CAAMP directly when available.
|
|
65
|
-
*
|
|
66
|
-
* Since hooks are registered through the plugin system (managed by the install
|
|
67
|
-
* provider), `registerNativeHooks` and `unregisterNativeHooks` track registration
|
|
68
|
-
* state without performing filesystem operations.
|
|
69
|
-
*
|
|
70
|
-
* @remarks
|
|
71
|
-
* OpenCode uses dot-delimited and `event:`-prefixed event names
|
|
72
|
-
* (e.g. `event:session.created`, `tool.execute.before`) which differ
|
|
73
|
-
* significantly from the PascalCase CAAMP canonical names. The static
|
|
74
|
-
* event map covers all 10 supported events. Async CAAMP accessors
|
|
75
|
-
* (`getSupportedCanonicalEvents`, `getProviderProfile`, `toNativeEvent`)
|
|
76
|
-
* call the normalizer directly when available and fall back to the static map.
|
|
77
|
-
*
|
|
78
|
-
* @task T164
|
|
79
|
-
* @epic T134
|
|
80
|
-
*/
|
|
81
|
-
export class OpenCodeHookProvider {
|
|
82
|
-
/** Whether hooks have been registered for the current session. */
|
|
83
|
-
registered = false;
|
|
84
|
-
/**
|
|
85
|
-
* Map an OpenCode native event name to a CAAMP canonical hook event name.
|
|
86
|
-
*
|
|
87
|
-
* Looks up the native event name in the map derived from
|
|
88
|
-
* `getProviderHookProfile('opencode').mappings` (CAAMP 1.9.1).
|
|
89
|
-
* Returns null for unsupported events (PostToolUseFailure, SubagentStart,
|
|
90
|
-
* SubagentStop, Notification, ConfigChange).
|
|
91
|
-
*
|
|
92
|
-
* @param providerEvent - OpenCode native event (e.g. "event:session.created", "tool.execute.before")
|
|
93
|
-
* @returns CAAMP canonical event name, or null if unmapped
|
|
94
|
-
* @task T164
|
|
95
|
-
*/
|
|
96
|
-
mapProviderEvent(providerEvent) {
|
|
97
|
-
return OPENCODE_EVENT_MAP[providerEvent] ?? null;
|
|
98
|
-
}
|
|
99
|
-
/**
|
|
100
|
-
* Register native hooks for a project.
|
|
101
|
-
*
|
|
102
|
-
* For OpenCode, hooks are registered via the plugin system
|
|
103
|
-
* (`.opencode/plugins/`), managed by the install provider.
|
|
104
|
-
* This method marks hooks as registered without performing filesystem operations.
|
|
105
|
-
*
|
|
106
|
-
* Iterating supported events is handled at install time using
|
|
107
|
-
* `getSupportedCanonicalEvents()` to enumerate all 10 supported hooks.
|
|
108
|
-
*
|
|
109
|
-
* @param _projectDir - Project directory (unused; config manages registration)
|
|
110
|
-
* @task T164
|
|
111
|
-
*/
|
|
112
|
-
async registerNativeHooks(_projectDir) {
|
|
113
|
-
this.registered = true;
|
|
114
|
-
}
|
|
115
|
-
/**
|
|
116
|
-
* Unregister native hooks.
|
|
117
|
-
*
|
|
118
|
-
* For OpenCode, this is a no-op since hooks are managed through the plugin
|
|
119
|
-
* system. Unregistration happens via the install provider's uninstall method.
|
|
120
|
-
*
|
|
121
|
-
* @task T164
|
|
122
|
-
*/
|
|
123
|
-
async unregisterNativeHooks() {
|
|
124
|
-
this.registered = false;
|
|
125
|
-
}
|
|
126
|
-
/**
|
|
127
|
-
* Check whether hooks have been registered via `registerNativeHooks`.
|
|
128
|
-
*/
|
|
129
|
-
isRegistered() {
|
|
130
|
-
return this.registered;
|
|
131
|
-
}
|
|
132
|
-
/**
|
|
133
|
-
* Get the native→canonical event mapping for introspection and debugging.
|
|
134
|
-
*
|
|
135
|
-
* Returns the map derived from `getProviderHookProfile('opencode').mappings`
|
|
136
|
-
* (CAAMP 1.9.1). Use `getSupportedCanonicalEvents()` to enumerate canonical
|
|
137
|
-
* names via live CAAMP APIs.
|
|
138
|
-
*
|
|
139
|
-
* @returns Immutable record of native event name → canonical event name
|
|
140
|
-
*/
|
|
141
|
-
getEventMap() {
|
|
142
|
-
return { ...OPENCODE_EVENT_MAP };
|
|
143
|
-
}
|
|
144
|
-
/**
|
|
145
|
-
* Enumerate supported canonical events via CAAMP's `getSupportedEvents()`.
|
|
146
|
-
*
|
|
147
|
-
* Calls `getSupportedEvents('opencode')` from the CAAMP normalizer to get the
|
|
148
|
-
* authoritative list. OpenCode supports 10 of 16 canonical events via its
|
|
149
|
-
* plugin system. Falls back to the values of the static event map when
|
|
150
|
-
* CAAMP is unavailable at runtime.
|
|
151
|
-
*
|
|
152
|
-
* @returns Array of CAAMP canonical event names supported by OpenCode
|
|
153
|
-
* @task T164
|
|
154
|
-
*/
|
|
155
|
-
async getSupportedCanonicalEvents() {
|
|
156
|
-
try {
|
|
157
|
-
const { getSupportedEvents } = await import('@cleocode/caamp');
|
|
158
|
-
return getSupportedEvents(PROVIDER_ID);
|
|
159
|
-
}
|
|
160
|
-
catch {
|
|
161
|
-
return [...new Set(Object.values(OPENCODE_EVENT_MAP))];
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
/**
|
|
165
|
-
* Retrieve the full provider hook profile from CAAMP.
|
|
166
|
-
*
|
|
167
|
-
* Calls `getProviderHookProfile('opencode')` from the CAAMP normalizer to
|
|
168
|
-
* get the complete profile: hook system type (`plugin`), config path
|
|
169
|
-
* (`.opencode/plugins/`), handler types, and all event mappings.
|
|
170
|
-
* Returns null when CAAMP is unavailable at runtime.
|
|
171
|
-
*
|
|
172
|
-
* @returns Provider hook profile or null if CAAMP is unavailable
|
|
173
|
-
* @task T164
|
|
174
|
-
*/
|
|
175
|
-
async getProviderProfile() {
|
|
176
|
-
try {
|
|
177
|
-
const { getProviderHookProfile } = await import('@cleocode/caamp');
|
|
178
|
-
return getProviderHookProfile(PROVIDER_ID) ?? null;
|
|
179
|
-
}
|
|
180
|
-
catch {
|
|
181
|
-
return null;
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
/**
|
|
185
|
-
* Translate a CAAMP canonical event to its OpenCode native name via CAAMP.
|
|
186
|
-
*
|
|
187
|
-
* Calls `toNative(canonical, 'opencode')` from the CAAMP normalizer.
|
|
188
|
-
* Returns null for unsupported events or when CAAMP is unavailable.
|
|
189
|
-
*
|
|
190
|
-
* @param canonical - CAAMP canonical event name (e.g. "PreToolUse")
|
|
191
|
-
* @returns OpenCode native event name or null
|
|
192
|
-
* @task T164
|
|
193
|
-
*/
|
|
194
|
-
async toNativeEvent(canonical) {
|
|
195
|
-
try {
|
|
196
|
-
const { toNative } = await import('@cleocode/caamp');
|
|
197
|
-
return toNative(canonical, PROVIDER_ID);
|
|
198
|
-
}
|
|
199
|
-
catch {
|
|
200
|
-
// Invert the static map as fallback
|
|
201
|
-
const entry = Object.entries(OPENCODE_EVENT_MAP).find(([, v]) => v === canonical);
|
|
202
|
-
return entry?.[0] ?? null;
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
//# sourceMappingURL=hooks.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/opencode/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAIH,8CAA8C;AAC9C,MAAM,WAAW,GAAG,UAAmB,CAAC;AAExC;;;;;;;;;;GAUG;AACH,MAAM,kBAAkB,GAA2B;IACjD,8EAA8E;IAC9E,uBAAuB,EAAE,cAAc;IACvC,8EAA8E;IAC9E,uBAAuB,EAAE,YAAY;IACrC,qEAAqE;IACrE,cAAc,EAAE,cAAc;IAC9B,2EAA2E;IAC3E,oBAAoB,EAAE,kBAAkB;IACxC,4EAA4E;IAC5E,qBAAqB,EAAE,YAAY;IACnC,2EAA2E;IAC3E,oBAAoB,EAAE,aAAa;IACnC,uEAAuE;IACvE,gBAAgB,EAAE,mBAAmB;IACrC,oEAAoE;IACpE,aAAa,EAAE,UAAU;IACzB,wFAAwF;IACxF,iCAAiC,EAAE,YAAY;IAC/C,gFAAgF;IAChF,yBAAyB,EAAE,aAAa;CACzC,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,MAAM,OAAO,oBAAoB;IAC/B,kEAAkE;IAC1D,UAAU,GAAG,KAAK,CAAC;IAE3B;;;;;;;;;;;OAWG;IACH,gBAAgB,CAAC,aAAqB;QACpC,OAAO,kBAAkB,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC;IACnD,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,KAAK,CAAC,mBAAmB,CAAC,WAAmB;QAC3C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,qBAAqB;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;;;;;;OAQG;IACH,WAAW;QACT,OAAO,EAAE,GAAG,kBAAkB,EAAE,CAAC;IACnC,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,2BAA2B;QAC/B,IAAI,CAAC;YACH,MAAM,EAAE,kBAAkB,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YAC/D,OAAO,kBAAkB,CAAC,WAAW,CAAa,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;QACzD,CAAC;IACH,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,kBAAkB;QACtB,IAAI,CAAC;YACH,MAAM,EAAE,sBAAsB,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACnE,OAAO,sBAAsB,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,aAAa,CAAC,SAAiB;QACnC,IAAI,CAAC;YACH,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACrD,OAAO,QAAQ,CAAC,SAA2C,EAAE,WAAW,CAAC,CAAC;QAC5E,CAAC;QAAC,MAAM,CAAC;YACP,oCAAoC;YACpC,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC;YAClF,OAAO,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAC5B,CAAC;IACH,CAAC;CACF"}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @packageDocumentation
|
|
3
|
-
*
|
|
4
|
-
* CLEO provider adapter for OpenCode AI coding assistant.
|
|
5
|
-
* Default export is the adapter class for dynamic loading by AdapterManager.
|
|
6
|
-
*
|
|
7
|
-
* @task T5240
|
|
8
|
-
*/
|
|
9
|
-
import { OpenCodeAdapter } from './adapter.js';
|
|
10
|
-
export { OpenCodeAdapter } from './adapter.js';
|
|
11
|
-
export { OpenCodeHookProvider } from './hooks.js';
|
|
12
|
-
export { OpenCodeInstallProvider } from './install.js';
|
|
13
|
-
export { OpenCodeSpawnProvider } from './spawn.js';
|
|
14
|
-
export default OpenCodeAdapter;
|
|
15
|
-
/**
|
|
16
|
-
* Factory function for creating adapter instances.
|
|
17
|
-
* Used by AdapterManager's dynamic import fallback.
|
|
18
|
-
*
|
|
19
|
-
* @remarks
|
|
20
|
-
* This is the primary entry point for dynamic adapter loading.
|
|
21
|
-
* AdapterManager calls this function when it resolves the opencode
|
|
22
|
-
* provider via its import-based discovery mechanism.
|
|
23
|
-
*
|
|
24
|
-
* @returns A new {@link OpenCodeAdapter} instance ready for initialization
|
|
25
|
-
*
|
|
26
|
-
* @example
|
|
27
|
-
* ```typescript
|
|
28
|
-
* import { createAdapter } from '@cleocode/adapters/providers/opencode';
|
|
29
|
-
*
|
|
30
|
-
* const adapter = createAdapter();
|
|
31
|
-
* await adapter.initialize('/path/to/project');
|
|
32
|
-
* ```
|
|
33
|
-
*/
|
|
34
|
-
export declare function createAdapter(): OpenCodeAdapter;
|
|
35
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE/C,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAEnD,eAAe,eAAe,CAAC;AAE/B;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,aAAa,IAAI,eAAe,CAE/C"}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @packageDocumentation
|
|
3
|
-
*
|
|
4
|
-
* CLEO provider adapter for OpenCode AI coding assistant.
|
|
5
|
-
* Default export is the adapter class for dynamic loading by AdapterManager.
|
|
6
|
-
*
|
|
7
|
-
* @task T5240
|
|
8
|
-
*/
|
|
9
|
-
import { OpenCodeAdapter } from './adapter.js';
|
|
10
|
-
export { OpenCodeAdapter } from './adapter.js';
|
|
11
|
-
export { OpenCodeHookProvider } from './hooks.js';
|
|
12
|
-
export { OpenCodeInstallProvider } from './install.js';
|
|
13
|
-
export { OpenCodeSpawnProvider } from './spawn.js';
|
|
14
|
-
export default OpenCodeAdapter;
|
|
15
|
-
/**
|
|
16
|
-
* Factory function for creating adapter instances.
|
|
17
|
-
* Used by AdapterManager's dynamic import fallback.
|
|
18
|
-
*
|
|
19
|
-
* @remarks
|
|
20
|
-
* This is the primary entry point for dynamic adapter loading.
|
|
21
|
-
* AdapterManager calls this function when it resolves the opencode
|
|
22
|
-
* provider via its import-based discovery mechanism.
|
|
23
|
-
*
|
|
24
|
-
* @returns A new {@link OpenCodeAdapter} instance ready for initialization
|
|
25
|
-
*
|
|
26
|
-
* @example
|
|
27
|
-
* ```typescript
|
|
28
|
-
* import { createAdapter } from '@cleocode/adapters/providers/opencode';
|
|
29
|
-
*
|
|
30
|
-
* const adapter = createAdapter();
|
|
31
|
-
* await adapter.initialize('/path/to/project');
|
|
32
|
-
* ```
|
|
33
|
-
*/
|
|
34
|
-
export function createAdapter() {
|
|
35
|
-
return new OpenCodeAdapter();
|
|
36
|
-
}
|
|
37
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/providers/opencode/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE/C,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAEnD,eAAe,eAAe,CAAC;AAE/B;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,eAAe,EAAE,CAAC;AAC/B,CAAC"}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* OpenCode Install Provider
|
|
3
|
-
*
|
|
4
|
-
* Handles CLEO installation into OpenCode environments:
|
|
5
|
-
* - Ensures AGENTS.md has CLEO @-references
|
|
6
|
-
*
|
|
7
|
-
* @task T5240
|
|
8
|
-
*/
|
|
9
|
-
import type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';
|
|
10
|
-
/**
|
|
11
|
-
* Install provider for OpenCode.
|
|
12
|
-
*
|
|
13
|
-
* Manages CLEO's integration with OpenCode by:
|
|
14
|
-
* 1. Ensuring AGENTS.md contains @-references to CLEO instruction files
|
|
15
|
-
*
|
|
16
|
-
* @remarks
|
|
17
|
-
* Installation is idempotent -- running install multiple times on the same
|
|
18
|
-
* project produces the same result. Only AGENTS.md is managed; OpenCode's
|
|
19
|
-
* plugin system is handled separately by the hook provider.
|
|
20
|
-
*/
|
|
21
|
-
export declare class OpenCodeInstallProvider implements AdapterInstallProvider {
|
|
22
|
-
/**
|
|
23
|
-
* Install CLEO into an OpenCode project.
|
|
24
|
-
*
|
|
25
|
-
* @param options - Installation options including project directory
|
|
26
|
-
* @returns Result describing what was installed
|
|
27
|
-
*/
|
|
28
|
-
install(options: InstallOptions): Promise<InstallResult>;
|
|
29
|
-
/**
|
|
30
|
-
* Uninstall CLEO from the current OpenCode project.
|
|
31
|
-
*
|
|
32
|
-
* Does not remove AGENTS.md references (they are harmless if CLEO is not present).
|
|
33
|
-
*/
|
|
34
|
-
uninstall(): Promise<void>;
|
|
35
|
-
/**
|
|
36
|
-
* Check whether CLEO is installed in the current environment.
|
|
37
|
-
*
|
|
38
|
-
* Checks for CLEO references in AGENTS.md.
|
|
39
|
-
*/
|
|
40
|
-
isInstalled(): Promise<boolean>;
|
|
41
|
-
/**
|
|
42
|
-
* Ensure AGENTS.md contains @-references to CLEO instruction files.
|
|
43
|
-
*
|
|
44
|
-
* Creates AGENTS.md if it does not exist. Appends any missing references.
|
|
45
|
-
*
|
|
46
|
-
* @param projectDir - Project root directory
|
|
47
|
-
*/
|
|
48
|
-
ensureInstructionReferences(projectDir: string): Promise<void>;
|
|
49
|
-
/**
|
|
50
|
-
* Update AGENTS.md with CLEO @-references.
|
|
51
|
-
*
|
|
52
|
-
* @returns true if the file was created or modified
|
|
53
|
-
*/
|
|
54
|
-
private updateInstructionFile;
|
|
55
|
-
}
|
|
56
|
-
//# sourceMappingURL=install.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/install.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,KAAK,EAAE,sBAAsB,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAKjG;;;;;;;;;;GAUG;AACH,qBAAa,uBAAwB,YAAW,sBAAsB;IACpE;;;;;OAKG;IACG,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC;IAqB9D;;;;OAIG;IACG,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAEhC;;;;OAIG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAgBrC;;;;;;OAMG;IACG,2BAA2B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;CA8B9B"}
|
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* OpenCode Install Provider
|
|
3
|
-
*
|
|
4
|
-
* Handles CLEO installation into OpenCode environments:
|
|
5
|
-
* - Ensures AGENTS.md has CLEO @-references
|
|
6
|
-
*
|
|
7
|
-
* @task T5240
|
|
8
|
-
*/
|
|
9
|
-
import { existsSync, readFileSync, writeFileSync } from 'node:fs';
|
|
10
|
-
import { join } from 'node:path';
|
|
11
|
-
/** Lines that should appear in AGENTS.md to reference CLEO. */
|
|
12
|
-
const INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];
|
|
13
|
-
/**
|
|
14
|
-
* Install provider for OpenCode.
|
|
15
|
-
*
|
|
16
|
-
* Manages CLEO's integration with OpenCode by:
|
|
17
|
-
* 1. Ensuring AGENTS.md contains @-references to CLEO instruction files
|
|
18
|
-
*
|
|
19
|
-
* @remarks
|
|
20
|
-
* Installation is idempotent -- running install multiple times on the same
|
|
21
|
-
* project produces the same result. Only AGENTS.md is managed; OpenCode's
|
|
22
|
-
* plugin system is handled separately by the hook provider.
|
|
23
|
-
*/
|
|
24
|
-
export class OpenCodeInstallProvider {
|
|
25
|
-
/**
|
|
26
|
-
* Install CLEO into an OpenCode project.
|
|
27
|
-
*
|
|
28
|
-
* @param options - Installation options including project directory
|
|
29
|
-
* @returns Result describing what was installed
|
|
30
|
-
*/
|
|
31
|
-
async install(options) {
|
|
32
|
-
const { projectDir } = options;
|
|
33
|
-
const installedAt = new Date().toISOString();
|
|
34
|
-
let instructionFileUpdated = false;
|
|
35
|
-
const details = {};
|
|
36
|
-
// Step 1: Ensure AGENTS.md has @-references
|
|
37
|
-
instructionFileUpdated = this.updateInstructionFile(projectDir);
|
|
38
|
-
if (instructionFileUpdated) {
|
|
39
|
-
details.instructionFile = join(projectDir, 'AGENTS.md');
|
|
40
|
-
}
|
|
41
|
-
return {
|
|
42
|
-
success: true,
|
|
43
|
-
installedAt,
|
|
44
|
-
instructionFileUpdated,
|
|
45
|
-
mcpRegistered: false,
|
|
46
|
-
details,
|
|
47
|
-
};
|
|
48
|
-
}
|
|
49
|
-
/**
|
|
50
|
-
* Uninstall CLEO from the current OpenCode project.
|
|
51
|
-
*
|
|
52
|
-
* Does not remove AGENTS.md references (they are harmless if CLEO is not present).
|
|
53
|
-
*/
|
|
54
|
-
async uninstall() { }
|
|
55
|
-
/**
|
|
56
|
-
* Check whether CLEO is installed in the current environment.
|
|
57
|
-
*
|
|
58
|
-
* Checks for CLEO references in AGENTS.md.
|
|
59
|
-
*/
|
|
60
|
-
async isInstalled() {
|
|
61
|
-
const agentsMdPath = join(process.cwd(), 'AGENTS.md');
|
|
62
|
-
if (existsSync(agentsMdPath)) {
|
|
63
|
-
try {
|
|
64
|
-
const content = readFileSync(agentsMdPath, 'utf-8');
|
|
65
|
-
if (INSTRUCTION_REFERENCES.some((ref) => content.includes(ref))) {
|
|
66
|
-
return true;
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
catch {
|
|
70
|
-
// Fall through
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
return false;
|
|
74
|
-
}
|
|
75
|
-
/**
|
|
76
|
-
* Ensure AGENTS.md contains @-references to CLEO instruction files.
|
|
77
|
-
*
|
|
78
|
-
* Creates AGENTS.md if it does not exist. Appends any missing references.
|
|
79
|
-
*
|
|
80
|
-
* @param projectDir - Project root directory
|
|
81
|
-
*/
|
|
82
|
-
async ensureInstructionReferences(projectDir) {
|
|
83
|
-
this.updateInstructionFile(projectDir);
|
|
84
|
-
}
|
|
85
|
-
/**
|
|
86
|
-
* Update AGENTS.md with CLEO @-references.
|
|
87
|
-
*
|
|
88
|
-
* @returns true if the file was created or modified
|
|
89
|
-
*/
|
|
90
|
-
updateInstructionFile(projectDir) {
|
|
91
|
-
const agentsMdPath = join(projectDir, 'AGENTS.md');
|
|
92
|
-
let content = '';
|
|
93
|
-
let existed = false;
|
|
94
|
-
if (existsSync(agentsMdPath)) {
|
|
95
|
-
content = readFileSync(agentsMdPath, 'utf-8');
|
|
96
|
-
existed = true;
|
|
97
|
-
}
|
|
98
|
-
const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
|
|
99
|
-
if (missingRefs.length === 0) {
|
|
100
|
-
return false;
|
|
101
|
-
}
|
|
102
|
-
const refsBlock = missingRefs.join('\n');
|
|
103
|
-
if (existed) {
|
|
104
|
-
// Append missing references
|
|
105
|
-
const separator = content.endsWith('\n') ? '' : '\n';
|
|
106
|
-
content = content + separator + refsBlock + '\n';
|
|
107
|
-
}
|
|
108
|
-
else {
|
|
109
|
-
// Create new AGENTS.md with references
|
|
110
|
-
content = refsBlock + '\n';
|
|
111
|
-
}
|
|
112
|
-
writeFileSync(agentsMdPath, content, 'utf-8');
|
|
113
|
-
return true;
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
//# sourceMappingURL=install.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/opencode/install.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* OpenCode Spawn Provider
|
|
3
|
-
*
|
|
4
|
-
* Implements AdapterSpawnProvider for OpenCode CLI.
|
|
5
|
-
* Migrated from src/core/spawn/adapters/opencode-adapter.ts
|
|
6
|
-
*
|
|
7
|
-
* Uses `opencode run --agent ... --format json` to spawn subagent
|
|
8
|
-
* processes. Processes run detached and are tracked by PID for
|
|
9
|
-
* listing and termination.
|
|
10
|
-
*
|
|
11
|
-
* @task T5240
|
|
12
|
-
*/
|
|
13
|
-
import type { AdapterSpawnProvider, SpawnContext, SpawnResult } from '@cleocode/contracts';
|
|
14
|
-
/**
|
|
15
|
-
* Build the markdown content for an OpenCode agent definition file.
|
|
16
|
-
*
|
|
17
|
-
* OpenCode agents are defined as markdown files with YAML frontmatter
|
|
18
|
-
* in the .opencode/agent/ directory.
|
|
19
|
-
*
|
|
20
|
-
* @remarks
|
|
21
|
-
* The generated markdown uses YAML frontmatter with `mode: subagent`
|
|
22
|
-
* and `hidden: true` so the agent does not appear in OpenCode's
|
|
23
|
-
* interactive agent selection menu.
|
|
24
|
-
*
|
|
25
|
-
* @param description - Agent description for frontmatter
|
|
26
|
-
* @param instructions - Markdown instructions body
|
|
27
|
-
* @returns Complete agent definition markdown with YAML frontmatter
|
|
28
|
-
*
|
|
29
|
-
* @example
|
|
30
|
-
* ```typescript
|
|
31
|
-
* import { buildOpenCodeAgentMarkdown } from '@cleocode/adapters/providers/opencode/spawn';
|
|
32
|
-
*
|
|
33
|
-
* const md = buildOpenCodeAgentMarkdown(
|
|
34
|
-
* 'CLEO task executor',
|
|
35
|
-
* '# Subagent\n\nExecute the delegated task.',
|
|
36
|
-
* );
|
|
37
|
-
* ```
|
|
38
|
-
*/
|
|
39
|
-
export declare function buildOpenCodeAgentMarkdown(description: string, instructions: string): string;
|
|
40
|
-
/**
|
|
41
|
-
* Spawn provider for OpenCode.
|
|
42
|
-
*
|
|
43
|
-
* Spawns detached OpenCode CLI processes for subagent execution.
|
|
44
|
-
* Each spawn ensures a CLEO subagent definition exists, then runs
|
|
45
|
-
* `opencode run --format json --agent <name> --title <title> <prompt>`
|
|
46
|
-
* as a detached, unref'd child process.
|
|
47
|
-
*
|
|
48
|
-
* @remarks
|
|
49
|
-
* Before spawning, the provider ensures a `cleo-subagent` agent definition
|
|
50
|
-
* exists in `.opencode/agent/`. If the definition cannot be created, it
|
|
51
|
-
* falls back to the built-in `general` agent. Processes are tracked by
|
|
52
|
-
* instance ID in an in-memory map and verified via `kill(pid, 0)` liveness
|
|
53
|
-
* checks.
|
|
54
|
-
*/
|
|
55
|
-
export declare class OpenCodeSpawnProvider implements AdapterSpawnProvider {
|
|
56
|
-
/** Map of instance IDs to tracked process info. */
|
|
57
|
-
private processMap;
|
|
58
|
-
/**
|
|
59
|
-
* Check if the OpenCode CLI is available in PATH.
|
|
60
|
-
*
|
|
61
|
-
* @returns true if `opencode` is found via `which`
|
|
62
|
-
*/
|
|
63
|
-
canSpawn(): Promise<boolean>;
|
|
64
|
-
/**
|
|
65
|
-
* Spawn a subagent via OpenCode CLI.
|
|
66
|
-
*
|
|
67
|
-
* Ensures the CLEO subagent definition exists in the project's
|
|
68
|
-
* .opencode/agent/ directory, then spawns a detached OpenCode
|
|
69
|
-
* process. The process runs independently of the parent.
|
|
70
|
-
*
|
|
71
|
-
* @param context - Spawn context with taskId, prompt, and options
|
|
72
|
-
* @returns Spawn result with instance ID and status
|
|
73
|
-
*/
|
|
74
|
-
spawn(context: SpawnContext): Promise<SpawnResult>;
|
|
75
|
-
/**
|
|
76
|
-
* List currently running OpenCode subagent processes.
|
|
77
|
-
*
|
|
78
|
-
* Checks each tracked process via kill(pid, 0) to verify it is still alive.
|
|
79
|
-
* Dead processes are automatically cleaned from the tracking map.
|
|
80
|
-
*
|
|
81
|
-
* @returns Array of spawn results for running processes
|
|
82
|
-
*/
|
|
83
|
-
listRunning(): Promise<SpawnResult[]>;
|
|
84
|
-
/**
|
|
85
|
-
* Terminate a running spawn by instance ID.
|
|
86
|
-
*
|
|
87
|
-
* Sends SIGTERM to the tracked process. If the process is not found
|
|
88
|
-
* or has already exited, this is a no-op.
|
|
89
|
-
*
|
|
90
|
-
* @param instanceId - ID of the spawn instance to terminate
|
|
91
|
-
*/
|
|
92
|
-
terminate(instanceId: string): Promise<void>;
|
|
93
|
-
}
|
|
94
|
-
//# sourceMappingURL=spawn.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spawn.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/spawn.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAMH,OAAO,KAAK,EAAE,oBAAoB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAiB3F;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,wBAAgB,0BAA0B,CAAC,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,MAAM,CAY5F;AA0CD;;;;;;;;;;;;;;GAcG;AACH,qBAAa,qBAAsB,YAAW,oBAAoB;IAChE,mDAAmD;IACnD,OAAO,CAAC,UAAU,CAAqC;IAEvD;;;;OAIG;IACG,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC;IASlC;;;;;;;;;OASG;IACG,KAAK,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC;IAiExD;;;;;;;OAOG;IACG,WAAW,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAqB3C;;;;;;;OAOG;IACG,SAAS,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAWnD"}
|