@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,286 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Claude Code Hook Provider
|
|
3
|
-
*
|
|
4
|
-
* Maps Claude Code's native hook events to CAAMP canonical hook events.
|
|
5
|
-
* Claude Code supports 14 of 16 canonical events (all except PreModel, PostModel).
|
|
6
|
-
*
|
|
7
|
-
* Event translation uses CAAMP normalizer APIs:
|
|
8
|
-
* - `toCanonical(nativeName, 'claude-code')` for runtime event name resolution
|
|
9
|
-
* - `getSupportedEvents('claude-code')` to enumerate supported canonical events
|
|
10
|
-
* - `getProviderHookProfile('claude-code')` for the full provider profile
|
|
11
|
-
*
|
|
12
|
-
* A static map derived from CAAMP 1.9.1 hook-mappings.json is maintained as
|
|
13
|
-
* a fallback for environments where CAAMP's runtime resolution is unavailable.
|
|
14
|
-
*
|
|
15
|
-
* @task T164
|
|
16
|
-
* @epic T134
|
|
17
|
-
*/
|
|
18
|
-
import { readdir, readFile } from 'node:fs/promises';
|
|
19
|
-
import { join } from 'node:path';
|
|
20
|
-
/** CAAMP provider identifier for Claude Code. */
|
|
21
|
-
const PROVIDER_ID = 'claude-code';
|
|
22
|
-
/**
|
|
23
|
-
* Fallback map from Claude Code native event names to CAAMP canonical names.
|
|
24
|
-
*
|
|
25
|
-
* Derived from `getProviderHookProfile('claude-code').mappings` in CAAMP 1.9.1.
|
|
26
|
-
* Covers all 14 supported events. PreModel and PostModel are not supported
|
|
27
|
-
* by Claude Code and are absent from this map.
|
|
28
|
-
*
|
|
29
|
-
* Used as fallback when CAAMP runtime is unavailable, and as the synchronous
|
|
30
|
-
* implementation of `mapProviderEvent()`.
|
|
31
|
-
*/
|
|
32
|
-
const CLAUDE_CODE_EVENT_MAP = {
|
|
33
|
-
// CAAMP: toNative('SessionStart', 'claude-code') = 'SessionStart'
|
|
34
|
-
SessionStart: 'SessionStart',
|
|
35
|
-
// CAAMP: toNative('SessionEnd', 'claude-code') = 'SessionEnd'
|
|
36
|
-
SessionEnd: 'SessionEnd',
|
|
37
|
-
// CAAMP: toNative('PromptSubmit', 'claude-code') = 'UserPromptSubmit'
|
|
38
|
-
UserPromptSubmit: 'PromptSubmit',
|
|
39
|
-
// CAAMP: toNative('ResponseComplete', 'claude-code') = 'Stop'
|
|
40
|
-
Stop: 'ResponseComplete',
|
|
41
|
-
// CAAMP: toNative('PreToolUse', 'claude-code') = 'PreToolUse'
|
|
42
|
-
PreToolUse: 'PreToolUse',
|
|
43
|
-
// CAAMP: toNative('PostToolUse', 'claude-code') = 'PostToolUse'
|
|
44
|
-
PostToolUse: 'PostToolUse',
|
|
45
|
-
// CAAMP: toNative('PostToolUseFailure','claude-code') = 'PostToolUseFailure'
|
|
46
|
-
PostToolUseFailure: 'PostToolUseFailure',
|
|
47
|
-
// CAAMP: toNative('PermissionRequest', 'claude-code') = 'PermissionRequest'
|
|
48
|
-
PermissionRequest: 'PermissionRequest',
|
|
49
|
-
// CAAMP: toNative('SubagentStart', 'claude-code') = 'SubagentStart'
|
|
50
|
-
SubagentStart: 'SubagentStart',
|
|
51
|
-
// CAAMP: toNative('SubagentStop', 'claude-code') = 'SubagentStop'
|
|
52
|
-
SubagentStop: 'SubagentStop',
|
|
53
|
-
// CAAMP: toNative('PreCompact', 'claude-code') = 'PreCompact'
|
|
54
|
-
PreCompact: 'PreCompact',
|
|
55
|
-
// CAAMP: toNative('PostCompact', 'claude-code') = 'PostCompact'
|
|
56
|
-
PostCompact: 'PostCompact',
|
|
57
|
-
// CAAMP: toNative('Notification', 'claude-code') = 'Notification'
|
|
58
|
-
Notification: 'Notification',
|
|
59
|
-
// CAAMP: toNative('ConfigChange', 'claude-code') = 'ConfigChange'
|
|
60
|
-
ConfigChange: 'ConfigChange',
|
|
61
|
-
};
|
|
62
|
-
/**
|
|
63
|
-
* Hook provider for Claude Code.
|
|
64
|
-
*
|
|
65
|
-
* Claude Code registers hooks via its global config at `~/.claude/settings.json`.
|
|
66
|
-
* Supported handler types: command, http, prompt, agent.
|
|
67
|
-
*
|
|
68
|
-
* Event mapping is based on `getProviderHookProfile('claude-code')` from
|
|
69
|
-
* CAAMP 1.9.1. Async accessors (`getSupportedCanonicalEvents`,
|
|
70
|
-
* `getProviderProfile`) call CAAMP directly when available.
|
|
71
|
-
*
|
|
72
|
-
* Since hooks are registered through the config system (managed by the install
|
|
73
|
-
* provider), `registerNativeHooks` and `unregisterNativeHooks` track registration
|
|
74
|
-
* state without performing filesystem operations.
|
|
75
|
-
*
|
|
76
|
-
* @remarks
|
|
77
|
-
* Claude Code is the only provider that supports all 14 of its declared
|
|
78
|
-
* canonical events at runtime. The static event map is maintained as a
|
|
79
|
-
* synchronous fallback; async methods like {@link getSupportedCanonicalEvents}
|
|
80
|
-
* and {@link getProviderProfile} call CAAMP directly when available.
|
|
81
|
-
*
|
|
82
|
-
* @task T164
|
|
83
|
-
* @epic T134
|
|
84
|
-
*/
|
|
85
|
-
export class ClaudeCodeHookProvider {
|
|
86
|
-
/** Whether hooks have been registered for the current session. */
|
|
87
|
-
registered = false;
|
|
88
|
-
/**
|
|
89
|
-
* Map a Claude Code native event name to a CAAMP canonical hook event name.
|
|
90
|
-
*
|
|
91
|
-
* Looks up the native event name in the map derived from
|
|
92
|
-
* `getProviderHookProfile('claude-code').mappings` (CAAMP 1.9.1).
|
|
93
|
-
* Returns null for unrecognised events (e.g. PreModel, PostModel which
|
|
94
|
-
* Claude Code does not support).
|
|
95
|
-
*
|
|
96
|
-
* @param providerEvent - Claude Code native event (e.g. "UserPromptSubmit", "Stop")
|
|
97
|
-
* @returns CAAMP canonical event name, or null if unmapped
|
|
98
|
-
* @task T164
|
|
99
|
-
*/
|
|
100
|
-
mapProviderEvent(providerEvent) {
|
|
101
|
-
return CLAUDE_CODE_EVENT_MAP[providerEvent] ?? null;
|
|
102
|
-
}
|
|
103
|
-
/**
|
|
104
|
-
* Register native hooks for a project.
|
|
105
|
-
*
|
|
106
|
-
* For Claude Code, hooks are registered via the config system
|
|
107
|
-
* (`~/.claude/settings.json`), managed by the install provider.
|
|
108
|
-
* This method marks hooks as registered without performing filesystem operations.
|
|
109
|
-
*
|
|
110
|
-
* Iterating supported events is handled at install time using
|
|
111
|
-
* `getSupportedCanonicalEvents()` to enumerate all 14 supported hooks.
|
|
112
|
-
*
|
|
113
|
-
* @param _projectDir - Project directory (unused; Claude Code uses global config)
|
|
114
|
-
* @task T164
|
|
115
|
-
*/
|
|
116
|
-
async registerNativeHooks(_projectDir) {
|
|
117
|
-
this.registered = true;
|
|
118
|
-
}
|
|
119
|
-
/**
|
|
120
|
-
* Unregister native hooks.
|
|
121
|
-
*
|
|
122
|
-
* For Claude Code, this is a no-op since hooks are managed through the config
|
|
123
|
-
* system. Unregistration happens via the install provider's uninstall method.
|
|
124
|
-
*
|
|
125
|
-
* @task T164
|
|
126
|
-
*/
|
|
127
|
-
async unregisterNativeHooks() {
|
|
128
|
-
this.registered = false;
|
|
129
|
-
}
|
|
130
|
-
/**
|
|
131
|
-
* Check whether hooks have been registered via `registerNativeHooks`.
|
|
132
|
-
*/
|
|
133
|
-
isRegistered() {
|
|
134
|
-
return this.registered;
|
|
135
|
-
}
|
|
136
|
-
/**
|
|
137
|
-
* Get the native→canonical event mapping for introspection and debugging.
|
|
138
|
-
*
|
|
139
|
-
* Returns the map derived from `getProviderHookProfile('claude-code').mappings`
|
|
140
|
-
* (CAAMP 1.9.1). Use `getSupportedCanonicalEvents()` to enumerate canonical
|
|
141
|
-
* names via live CAAMP APIs.
|
|
142
|
-
*
|
|
143
|
-
* @returns Immutable record of native event name → canonical event name
|
|
144
|
-
*/
|
|
145
|
-
getEventMap() {
|
|
146
|
-
return { ...CLAUDE_CODE_EVENT_MAP };
|
|
147
|
-
}
|
|
148
|
-
/**
|
|
149
|
-
* Enumerate supported canonical events via CAAMP's `getSupportedEvents()`.
|
|
150
|
-
*
|
|
151
|
-
* Calls `getSupportedEvents('claude-code')` from the CAAMP normalizer to
|
|
152
|
-
* get the authoritative list. Claude Code supports 14 of 16 canonical events
|
|
153
|
-
* (PreModel and PostModel are not supported). Falls back to the values of
|
|
154
|
-
* the static event map when CAAMP is unavailable at runtime.
|
|
155
|
-
*
|
|
156
|
-
* @returns Array of CAAMP canonical event names supported by Claude Code
|
|
157
|
-
* @task T164
|
|
158
|
-
*/
|
|
159
|
-
async getSupportedCanonicalEvents() {
|
|
160
|
-
try {
|
|
161
|
-
const { getSupportedEvents } = await import('@cleocode/caamp');
|
|
162
|
-
return getSupportedEvents(PROVIDER_ID);
|
|
163
|
-
}
|
|
164
|
-
catch {
|
|
165
|
-
return [...new Set(Object.values(CLAUDE_CODE_EVENT_MAP))];
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
/**
|
|
169
|
-
* Retrieve the full provider hook profile from CAAMP.
|
|
170
|
-
*
|
|
171
|
-
* Calls `getProviderHookProfile('claude-code')` from the CAAMP normalizer to
|
|
172
|
-
* get the complete profile: hook system type (`config`), config path
|
|
173
|
-
* (`~/.claude/settings.json`), handler types, and all event mappings.
|
|
174
|
-
* Returns null when CAAMP is unavailable at runtime.
|
|
175
|
-
*
|
|
176
|
-
* @returns Provider hook profile or null if CAAMP is unavailable
|
|
177
|
-
* @task T164
|
|
178
|
-
*/
|
|
179
|
-
async getProviderProfile() {
|
|
180
|
-
try {
|
|
181
|
-
const { getProviderHookProfile } = await import('@cleocode/caamp');
|
|
182
|
-
return getProviderHookProfile(PROVIDER_ID) ?? null;
|
|
183
|
-
}
|
|
184
|
-
catch {
|
|
185
|
-
return null;
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
/**
|
|
189
|
-
* Translate a CAAMP canonical event to its Claude Code native name via CAAMP.
|
|
190
|
-
*
|
|
191
|
-
* Calls `toNative(canonical, 'claude-code')` from the CAAMP normalizer.
|
|
192
|
-
* Returns null for unsupported events (PreModel, PostModel) or when
|
|
193
|
-
* CAAMP is unavailable.
|
|
194
|
-
*
|
|
195
|
-
* @param canonical - CAAMP canonical event name (e.g. "PromptSubmit")
|
|
196
|
-
* @returns Claude Code native event name or null
|
|
197
|
-
* @task T164
|
|
198
|
-
*/
|
|
199
|
-
async toNativeEvent(canonical) {
|
|
200
|
-
try {
|
|
201
|
-
const { toNative } = await import('@cleocode/caamp');
|
|
202
|
-
return toNative(canonical, PROVIDER_ID);
|
|
203
|
-
}
|
|
204
|
-
catch {
|
|
205
|
-
// Invert the static map as fallback
|
|
206
|
-
const entry = Object.entries(CLAUDE_CODE_EVENT_MAP).find(([, v]) => v === canonical);
|
|
207
|
-
return entry?.[0] ?? null;
|
|
208
|
-
}
|
|
209
|
-
}
|
|
210
|
-
/**
|
|
211
|
-
* Extract a plain-text transcript from Claude Code session JSONL files.
|
|
212
|
-
*
|
|
213
|
-
* Reads the most recent .jsonl file under `~/.claude/projects/` and
|
|
214
|
-
* extracts user/assistant turn text into a flat string for brain
|
|
215
|
-
* observation extraction.
|
|
216
|
-
*
|
|
217
|
-
* Returns null when no session data is found or on any read error.
|
|
218
|
-
*
|
|
219
|
-
* @param _sessionId - CLEO session ID (unused; reads the most recent file)
|
|
220
|
-
* @param _projectDir - Project directory (unused; Claude Code uses global paths)
|
|
221
|
-
* @task T144 @epic T134
|
|
222
|
-
*/
|
|
223
|
-
async getTranscript(_sessionId, _projectDir) {
|
|
224
|
-
try {
|
|
225
|
-
const homeDir = process.env.HOME ?? process.env.USERPROFILE ?? '/root';
|
|
226
|
-
const projectsDir = join(homeDir, '.claude', 'projects');
|
|
227
|
-
// Find all JSONL files across project subdirectories
|
|
228
|
-
let allFiles = [];
|
|
229
|
-
try {
|
|
230
|
-
const projectDirs = await readdir(projectsDir, { withFileTypes: true });
|
|
231
|
-
for (const entry of projectDirs) {
|
|
232
|
-
if (!entry.isDirectory())
|
|
233
|
-
continue;
|
|
234
|
-
const subDir = join(projectsDir, entry.name);
|
|
235
|
-
try {
|
|
236
|
-
const files = await readdir(subDir);
|
|
237
|
-
for (const file of files) {
|
|
238
|
-
if (!file.endsWith('.jsonl'))
|
|
239
|
-
continue;
|
|
240
|
-
const filePath = join(subDir, file);
|
|
241
|
-
// Use file path modification heuristic (filename usually includes timestamp)
|
|
242
|
-
allFiles.push({ path: filePath, mtime: 0 });
|
|
243
|
-
}
|
|
244
|
-
}
|
|
245
|
-
catch {
|
|
246
|
-
// Skip unreadable subdirectories
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
}
|
|
250
|
-
catch {
|
|
251
|
-
return null;
|
|
252
|
-
}
|
|
253
|
-
if (allFiles.length === 0)
|
|
254
|
-
return null;
|
|
255
|
-
// Sort by path descending (timestamps in filenames sort naturally)
|
|
256
|
-
allFiles = allFiles.sort((a, b) => b.path.localeCompare(a.path));
|
|
257
|
-
const mostRecent = allFiles[0];
|
|
258
|
-
if (!mostRecent)
|
|
259
|
-
return null;
|
|
260
|
-
const raw = await readFile(mostRecent.path, 'utf-8');
|
|
261
|
-
const lines = raw.split('\n').filter((l) => l.trim());
|
|
262
|
-
const turns = [];
|
|
263
|
-
for (const line of lines) {
|
|
264
|
-
try {
|
|
265
|
-
const entry = JSON.parse(line);
|
|
266
|
-
const role = entry.role;
|
|
267
|
-
const content = entry.content;
|
|
268
|
-
if (role === 'assistant' && typeof content === 'string') {
|
|
269
|
-
turns.push(`assistant: ${content}`);
|
|
270
|
-
}
|
|
271
|
-
else if (role === 'user' && typeof content === 'string') {
|
|
272
|
-
turns.push(`user: ${content}`);
|
|
273
|
-
}
|
|
274
|
-
}
|
|
275
|
-
catch {
|
|
276
|
-
// Skip malformed lines
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
return turns.length > 0 ? turns.join('\n') : null;
|
|
280
|
-
}
|
|
281
|
-
catch {
|
|
282
|
-
return null;
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
}
|
|
286
|
-
//# sourceMappingURL=hooks.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/claude-code/hooks.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @packageDocumentation
|
|
3
|
-
*
|
|
4
|
-
* CLEO provider adapter for Anthropic Claude Code CLI.
|
|
5
|
-
* Default export is the adapter class for dynamic loading by AdapterManager.
|
|
6
|
-
*
|
|
7
|
-
* @task T5240
|
|
8
|
-
*/
|
|
9
|
-
import { ClaudeCodeAdapter } from './adapter.js';
|
|
10
|
-
export { ClaudeCodeAdapter } from './adapter.js';
|
|
11
|
-
export { ClaudeCodeContextMonitorProvider } from './context-monitor.js';
|
|
12
|
-
export { ClaudeCodeHookProvider } from './hooks.js';
|
|
13
|
-
export { ClaudeCodeInstallProvider } from './install.js';
|
|
14
|
-
export { ClaudeCodePathProvider } from './paths.js';
|
|
15
|
-
export { ClaudeCodeSpawnProvider } from './spawn.js';
|
|
16
|
-
export { checkStatuslineIntegration, getSetupInstructions, getStatuslineConfig, } from './statusline.js';
|
|
17
|
-
export { ClaudeCodeTransportProvider } from './transport.js';
|
|
18
|
-
export default ClaudeCodeAdapter;
|
|
19
|
-
/**
|
|
20
|
-
* Factory function for creating adapter instances.
|
|
21
|
-
* Used by AdapterManager's dynamic import fallback.
|
|
22
|
-
*
|
|
23
|
-
* @remarks
|
|
24
|
-
* This is the primary entry point for dynamic adapter loading.
|
|
25
|
-
* AdapterManager calls this function when it resolves the claude-code
|
|
26
|
-
* provider via its import-based discovery mechanism.
|
|
27
|
-
*
|
|
28
|
-
* @returns A new {@link ClaudeCodeAdapter} instance ready for initialization
|
|
29
|
-
*
|
|
30
|
-
* @example
|
|
31
|
-
* ```typescript
|
|
32
|
-
* import { createAdapter } from '@cleocode/adapters/providers/claude-code';
|
|
33
|
-
*
|
|
34
|
-
* const adapter = createAdapter();
|
|
35
|
-
* await adapter.initialize('/path/to/project');
|
|
36
|
-
* ```
|
|
37
|
-
*/
|
|
38
|
-
export declare function createAdapter(): ClaudeCodeAdapter;
|
|
39
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,gCAAgC,EAAE,MAAM,sBAAsB,CAAC;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAC;AACzD,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACpD,OAAO,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAC;AACrD,OAAO,EACL,0BAA0B,EAC1B,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,2BAA2B,EAAE,MAAM,gBAAgB,CAAC;AAE7D,eAAe,iBAAiB,CAAC;AAEjC;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,aAAa,IAAI,iBAAiB,CAEjD"}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @packageDocumentation
|
|
3
|
-
*
|
|
4
|
-
* CLEO provider adapter for Anthropic Claude Code CLI.
|
|
5
|
-
* Default export is the adapter class for dynamic loading by AdapterManager.
|
|
6
|
-
*
|
|
7
|
-
* @task T5240
|
|
8
|
-
*/
|
|
9
|
-
import { ClaudeCodeAdapter } from './adapter.js';
|
|
10
|
-
export { ClaudeCodeAdapter } from './adapter.js';
|
|
11
|
-
export { ClaudeCodeContextMonitorProvider } from './context-monitor.js';
|
|
12
|
-
export { ClaudeCodeHookProvider } from './hooks.js';
|
|
13
|
-
export { ClaudeCodeInstallProvider } from './install.js';
|
|
14
|
-
export { ClaudeCodePathProvider } from './paths.js';
|
|
15
|
-
export { ClaudeCodeSpawnProvider } from './spawn.js';
|
|
16
|
-
export { checkStatuslineIntegration, getSetupInstructions, getStatuslineConfig, } from './statusline.js';
|
|
17
|
-
export { ClaudeCodeTransportProvider } from './transport.js';
|
|
18
|
-
export default ClaudeCodeAdapter;
|
|
19
|
-
/**
|
|
20
|
-
* Factory function for creating adapter instances.
|
|
21
|
-
* Used by AdapterManager's dynamic import fallback.
|
|
22
|
-
*
|
|
23
|
-
* @remarks
|
|
24
|
-
* This is the primary entry point for dynamic adapter loading.
|
|
25
|
-
* AdapterManager calls this function when it resolves the claude-code
|
|
26
|
-
* provider via its import-based discovery mechanism.
|
|
27
|
-
*
|
|
28
|
-
* @returns A new {@link ClaudeCodeAdapter} instance ready for initialization
|
|
29
|
-
*
|
|
30
|
-
* @example
|
|
31
|
-
* ```typescript
|
|
32
|
-
* import { createAdapter } from '@cleocode/adapters/providers/claude-code';
|
|
33
|
-
*
|
|
34
|
-
* const adapter = createAdapter();
|
|
35
|
-
* await adapter.initialize('/path/to/project');
|
|
36
|
-
* ```
|
|
37
|
-
*/
|
|
38
|
-
export function createAdapter() {
|
|
39
|
-
return new ClaudeCodeAdapter();
|
|
40
|
-
}
|
|
41
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/providers/claude-code/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,gCAAgC,EAAE,MAAM,sBAAsB,CAAC;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAC;AACzD,OAAO,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACpD,OAAO,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAC;AACrD,OAAO,EACL,0BAA0B,EAC1B,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,2BAA2B,EAAE,MAAM,gBAAgB,CAAC;AAE7D,eAAe,iBAAiB,CAAC;AAEjC;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,iBAAiB,EAAE,CAAC;AACjC,CAAC"}
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Claude Code Install Provider
|
|
3
|
-
*
|
|
4
|
-
* Handles CLEO installation into Claude Code environments:
|
|
5
|
-
* - Ensures CLAUDE.md has CLEO @-references
|
|
6
|
-
* - Manages plugin registration in ~/.claude/settings.json
|
|
7
|
-
*
|
|
8
|
-
* Migrated from src/core/install/claude-plugin.ts
|
|
9
|
-
*
|
|
10
|
-
* @task T5240
|
|
11
|
-
*/
|
|
12
|
-
import type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';
|
|
13
|
-
/**
|
|
14
|
-
* Install provider for Claude Code.
|
|
15
|
-
*
|
|
16
|
-
* Manages CLEO's integration with Claude Code by:
|
|
17
|
-
* 1. Ensuring CLAUDE.md contains @-references to CLEO instruction files
|
|
18
|
-
* 2. Registering the brain observation plugin in ~/.claude/settings.json
|
|
19
|
-
*
|
|
20
|
-
* @remarks
|
|
21
|
-
* Installation is idempotent -- running install multiple times on the same
|
|
22
|
-
* project produces the same result. The provider disables the legacy
|
|
23
|
-
* `claude-mem\@thedotmack` plugin if present and enables the unified
|
|
24
|
-
* `cleo\@cleocode` plugin instead.
|
|
25
|
-
*/
|
|
26
|
-
export declare class ClaudeCodeInstallProvider implements AdapterInstallProvider {
|
|
27
|
-
/**
|
|
28
|
-
* Install CLEO into a Claude Code project.
|
|
29
|
-
*
|
|
30
|
-
* @param options - Installation options including project directory
|
|
31
|
-
* @returns Result describing what was installed
|
|
32
|
-
*/
|
|
33
|
-
install(options: InstallOptions): Promise<InstallResult>;
|
|
34
|
-
/**
|
|
35
|
-
* Uninstall CLEO from the current Claude Code project.
|
|
36
|
-
*
|
|
37
|
-
* Does not remove CLAUDE.md references (they are harmless if CLEO is not present).
|
|
38
|
-
*/
|
|
39
|
-
uninstall(): Promise<void>;
|
|
40
|
-
/**
|
|
41
|
-
* Check whether CLEO is installed in the current environment.
|
|
42
|
-
*
|
|
43
|
-
* Checks for plugin enabled in ~/.claude/settings.json.
|
|
44
|
-
*/
|
|
45
|
-
isInstalled(): Promise<boolean>;
|
|
46
|
-
/**
|
|
47
|
-
* Ensure CLAUDE.md contains @-references to CLEO instruction files.
|
|
48
|
-
*
|
|
49
|
-
* Creates CLAUDE.md if it does not exist. Appends any missing references.
|
|
50
|
-
*
|
|
51
|
-
* @param projectDir - Project root directory
|
|
52
|
-
*/
|
|
53
|
-
ensureInstructionReferences(projectDir: string): Promise<void>;
|
|
54
|
-
/**
|
|
55
|
-
* Update CLAUDE.md with CLEO @-references.
|
|
56
|
-
*
|
|
57
|
-
* @returns true if the file was created or modified
|
|
58
|
-
*/
|
|
59
|
-
private updateInstructionFile;
|
|
60
|
-
/**
|
|
61
|
-
* Register the CLEO brain plugin in ~/.claude/settings.json.
|
|
62
|
-
*
|
|
63
|
-
* @returns Description of what was registered, or null if no change needed
|
|
64
|
-
*/
|
|
65
|
-
private registerPlugin;
|
|
66
|
-
}
|
|
67
|
-
//# sourceMappingURL=install.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/install.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAKH,OAAO,KAAK,EAAE,sBAAsB,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAKjG;;;;;;;;;;;;GAYG;AACH,qBAAa,yBAA0B,YAAW,sBAAsB;IACtE;;;;;OAKG;IACG,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC;IA2B9D;;;;OAIG;IACG,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAEhC;;;;OAIG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAkBrC;;;;;;OAMG;IACG,2BAA2B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;IA+B7B;;;;OAIG;IACH,OAAO,CAAC,cAAc;CAiCvB"}
|
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Claude Code Install Provider
|
|
3
|
-
*
|
|
4
|
-
* Handles CLEO installation into Claude Code environments:
|
|
5
|
-
* - Ensures CLAUDE.md has CLEO @-references
|
|
6
|
-
* - Manages plugin registration in ~/.claude/settings.json
|
|
7
|
-
*
|
|
8
|
-
* Migrated from src/core/install/claude-plugin.ts
|
|
9
|
-
*
|
|
10
|
-
* @task T5240
|
|
11
|
-
*/
|
|
12
|
-
import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
|
|
13
|
-
import { homedir } from 'node:os';
|
|
14
|
-
import { join } from 'node:path';
|
|
15
|
-
/** Lines that should appear in CLAUDE.md to reference CLEO. */
|
|
16
|
-
const INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];
|
|
17
|
-
/**
|
|
18
|
-
* Install provider for Claude Code.
|
|
19
|
-
*
|
|
20
|
-
* Manages CLEO's integration with Claude Code by:
|
|
21
|
-
* 1. Ensuring CLAUDE.md contains @-references to CLEO instruction files
|
|
22
|
-
* 2. Registering the brain observation plugin in ~/.claude/settings.json
|
|
23
|
-
*
|
|
24
|
-
* @remarks
|
|
25
|
-
* Installation is idempotent -- running install multiple times on the same
|
|
26
|
-
* project produces the same result. The provider disables the legacy
|
|
27
|
-
* `claude-mem\@thedotmack` plugin if present and enables the unified
|
|
28
|
-
* `cleo\@cleocode` plugin instead.
|
|
29
|
-
*/
|
|
30
|
-
export class ClaudeCodeInstallProvider {
|
|
31
|
-
/**
|
|
32
|
-
* Install CLEO into a Claude Code project.
|
|
33
|
-
*
|
|
34
|
-
* @param options - Installation options including project directory
|
|
35
|
-
* @returns Result describing what was installed
|
|
36
|
-
*/
|
|
37
|
-
async install(options) {
|
|
38
|
-
const { projectDir } = options;
|
|
39
|
-
const installedAt = new Date().toISOString();
|
|
40
|
-
let instructionFileUpdated = false;
|
|
41
|
-
const details = {};
|
|
42
|
-
// Step 1: Ensure CLAUDE.md has @-references
|
|
43
|
-
instructionFileUpdated = this.updateInstructionFile(projectDir);
|
|
44
|
-
if (instructionFileUpdated) {
|
|
45
|
-
details.instructionFile = join(projectDir, 'CLAUDE.md');
|
|
46
|
-
}
|
|
47
|
-
// Step 2: Register plugin in ~/.claude/settings.json
|
|
48
|
-
const pluginResult = this.registerPlugin();
|
|
49
|
-
if (pluginResult) {
|
|
50
|
-
details.plugin = pluginResult;
|
|
51
|
-
}
|
|
52
|
-
return {
|
|
53
|
-
success: true,
|
|
54
|
-
installedAt,
|
|
55
|
-
instructionFileUpdated,
|
|
56
|
-
mcpRegistered: false,
|
|
57
|
-
details,
|
|
58
|
-
};
|
|
59
|
-
}
|
|
60
|
-
/**
|
|
61
|
-
* Uninstall CLEO from the current Claude Code project.
|
|
62
|
-
*
|
|
63
|
-
* Does not remove CLAUDE.md references (they are harmless if CLEO is not present).
|
|
64
|
-
*/
|
|
65
|
-
async uninstall() { }
|
|
66
|
-
/**
|
|
67
|
-
* Check whether CLEO is installed in the current environment.
|
|
68
|
-
*
|
|
69
|
-
* Checks for plugin enabled in ~/.claude/settings.json.
|
|
70
|
-
*/
|
|
71
|
-
async isInstalled() {
|
|
72
|
-
// Check ~/.claude/settings.json for plugin registration
|
|
73
|
-
const settingsPath = join(homedir(), '.claude', 'settings.json');
|
|
74
|
-
if (existsSync(settingsPath)) {
|
|
75
|
-
try {
|
|
76
|
-
const settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
|
|
77
|
-
const plugins = settings.enabledPlugins;
|
|
78
|
-
if (plugins && plugins['cleo@cleocode'] === true) {
|
|
79
|
-
return true;
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
catch {
|
|
83
|
-
// Fall through
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
return false;
|
|
87
|
-
}
|
|
88
|
-
/**
|
|
89
|
-
* Ensure CLAUDE.md contains @-references to CLEO instruction files.
|
|
90
|
-
*
|
|
91
|
-
* Creates CLAUDE.md if it does not exist. Appends any missing references.
|
|
92
|
-
*
|
|
93
|
-
* @param projectDir - Project root directory
|
|
94
|
-
*/
|
|
95
|
-
async ensureInstructionReferences(projectDir) {
|
|
96
|
-
this.updateInstructionFile(projectDir);
|
|
97
|
-
}
|
|
98
|
-
/**
|
|
99
|
-
* Update CLAUDE.md with CLEO @-references.
|
|
100
|
-
*
|
|
101
|
-
* @returns true if the file was created or modified
|
|
102
|
-
*/
|
|
103
|
-
updateInstructionFile(projectDir) {
|
|
104
|
-
const claudeMdPath = join(projectDir, 'CLAUDE.md');
|
|
105
|
-
let content = '';
|
|
106
|
-
let existed = false;
|
|
107
|
-
if (existsSync(claudeMdPath)) {
|
|
108
|
-
content = readFileSync(claudeMdPath, 'utf-8');
|
|
109
|
-
existed = true;
|
|
110
|
-
}
|
|
111
|
-
const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
|
|
112
|
-
if (missingRefs.length === 0) {
|
|
113
|
-
return false;
|
|
114
|
-
}
|
|
115
|
-
const refsBlock = missingRefs.join('\n');
|
|
116
|
-
if (existed) {
|
|
117
|
-
// Append missing references
|
|
118
|
-
const separator = content.endsWith('\n') ? '' : '\n';
|
|
119
|
-
content = content + separator + refsBlock + '\n';
|
|
120
|
-
}
|
|
121
|
-
else {
|
|
122
|
-
// Create new CLAUDE.md with references
|
|
123
|
-
content = refsBlock + '\n';
|
|
124
|
-
}
|
|
125
|
-
writeFileSync(claudeMdPath, content, 'utf-8');
|
|
126
|
-
return true;
|
|
127
|
-
}
|
|
128
|
-
/**
|
|
129
|
-
* Register the CLEO brain plugin in ~/.claude/settings.json.
|
|
130
|
-
*
|
|
131
|
-
* @returns Description of what was registered, or null if no change needed
|
|
132
|
-
*/
|
|
133
|
-
registerPlugin() {
|
|
134
|
-
const home = homedir();
|
|
135
|
-
const settingsPath = join(home, '.claude', 'settings.json');
|
|
136
|
-
let settings = {};
|
|
137
|
-
if (existsSync(settingsPath)) {
|
|
138
|
-
try {
|
|
139
|
-
settings = JSON.parse(readFileSync(settingsPath, 'utf-8'));
|
|
140
|
-
}
|
|
141
|
-
catch {
|
|
142
|
-
// Start fresh
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
const enabledPlugins = settings.enabledPlugins ?? {};
|
|
146
|
-
const pluginKey = 'cleo@cleocode';
|
|
147
|
-
if (enabledPlugins[pluginKey] === true) {
|
|
148
|
-
return null;
|
|
149
|
-
}
|
|
150
|
-
// Disable old claude-mem if present
|
|
151
|
-
if (enabledPlugins['claude-mem@thedotmack'] === true) {
|
|
152
|
-
enabledPlugins['claude-mem@thedotmack'] = false;
|
|
153
|
-
}
|
|
154
|
-
enabledPlugins[pluginKey] = true;
|
|
155
|
-
settings.enabledPlugins = enabledPlugins;
|
|
156
|
-
mkdirSync(join(home, '.claude'), { recursive: true });
|
|
157
|
-
writeFileSync(settingsPath, JSON.stringify(settings, null, 2) + '\n', 'utf-8');
|
|
158
|
-
return `Enabled ${pluginKey} in ~/.claude/settings.json`;
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
//# sourceMappingURL=install.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/claude-code/install.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Claude Code path provider.
|
|
3
|
-
*
|
|
4
|
-
* Implements AdapterPathProvider with Claude Code-specific directory locations.
|
|
5
|
-
*
|
|
6
|
-
* @task T5240
|
|
7
|
-
*/
|
|
8
|
-
import type { AdapterPathProvider } from '@cleocode/contracts';
|
|
9
|
-
/**
|
|
10
|
-
* Path provider for Anthropic Claude Code CLI.
|
|
11
|
-
*
|
|
12
|
-
* Resolves Claude Code's standard directory layout:
|
|
13
|
-
* - Config dir: ~/.claude (or CLAUDE_HOME)
|
|
14
|
-
* - Settings: ~/.claude/settings.json (or CLAUDE_SETTINGS)
|
|
15
|
-
* - Agents: ~/.claude/agents
|
|
16
|
-
* - Memory DB: ~/.claude-mem/claude-mem.db (or CLAUDE_MEM_DB)
|
|
17
|
-
*
|
|
18
|
-
* @remarks
|
|
19
|
-
* All paths respect environment variable overrides for CI and non-standard
|
|
20
|
-
* installations. When env vars are unset, the canonical default paths are used.
|
|
21
|
-
*/
|
|
22
|
-
export declare class ClaudeCodePathProvider implements AdapterPathProvider {
|
|
23
|
-
/** Get the provider's root configuration directory. */
|
|
24
|
-
getProviderDir(): string;
|
|
25
|
-
/** Get the path to the provider's settings file, or null if unavailable. */
|
|
26
|
-
getSettingsPath(): string | null;
|
|
27
|
-
/** Get the directory where agents are installed, or null if unsupported. */
|
|
28
|
-
getAgentInstallDir(): string | null;
|
|
29
|
-
/** Get the path to the provider's memory database, or null if unsupported. */
|
|
30
|
-
getMemoryDbPath(): string | null;
|
|
31
|
-
}
|
|
32
|
-
//# sourceMappingURL=paths.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"paths.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/paths.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAIH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAE/D;;;;;;;;;;;;GAYG;AACH,qBAAa,sBAAuB,YAAW,mBAAmB;IAChE,uDAAuD;IACvD,cAAc,IAAI,MAAM;IAIxB,4EAA4E;IAC5E,eAAe,IAAI,MAAM,GAAG,IAAI;IAIhC,4EAA4E;IAC5E,kBAAkB,IAAI,MAAM,GAAG,IAAI;IAInC,8EAA8E;IAC9E,eAAe,IAAI,MAAM,GAAG,IAAI;CAGjC"}
|