@cleocode/adapters 2026.4.31 → 2026.4.36

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (99) hide show
  1. package/dist/index.js +641 -5
  2. package/dist/index.js.map +4 -4
  3. package/dist/providers/claude-code/adapter.js +184 -0
  4. package/dist/providers/claude-code/adapter.js.map +1 -0
  5. package/dist/providers/claude-code/context-monitor.js +159 -0
  6. package/dist/providers/claude-code/context-monitor.js.map +1 -0
  7. package/dist/providers/claude-code/hooks.js +286 -0
  8. package/dist/providers/claude-code/hooks.js.map +1 -0
  9. package/dist/providers/claude-code/index.js +41 -0
  10. package/dist/providers/claude-code/index.js.map +1 -0
  11. package/dist/providers/claude-code/install.js +199 -0
  12. package/dist/providers/claude-code/install.js.map +1 -0
  13. package/dist/providers/claude-code/paths.js +41 -0
  14. package/dist/providers/claude-code/paths.js.map +1 -0
  15. package/dist/providers/claude-code/spawn.js +171 -0
  16. package/dist/providers/claude-code/spawn.js.map +1 -0
  17. package/dist/providers/claude-code/statusline.js +130 -0
  18. package/dist/providers/claude-code/statusline.js.map +1 -0
  19. package/dist/providers/claude-code/task-sync.js +119 -0
  20. package/dist/providers/claude-code/task-sync.js.map +1 -0
  21. package/dist/providers/claude-code/transport.js +29 -0
  22. package/dist/providers/claude-code/transport.js.map +1 -0
  23. package/dist/providers/codex/adapter.js +146 -0
  24. package/dist/providers/codex/adapter.js.map +1 -0
  25. package/dist/providers/codex/hooks.js +113 -0
  26. package/dist/providers/codex/hooks.js.map +1 -0
  27. package/dist/providers/codex/index.js +39 -0
  28. package/dist/providers/codex/index.js.map +1 -0
  29. package/dist/providers/codex/install.js +124 -0
  30. package/dist/providers/codex/install.js.map +1 -0
  31. package/dist/providers/cursor/adapter.js +151 -0
  32. package/dist/providers/cursor/adapter.js.map +1 -0
  33. package/dist/providers/cursor/hooks.js +208 -0
  34. package/dist/providers/cursor/hooks.js.map +1 -0
  35. package/dist/providers/cursor/index.js +36 -0
  36. package/dist/providers/cursor/index.js.map +1 -0
  37. package/dist/providers/cursor/install.js +180 -0
  38. package/dist/providers/cursor/install.js.map +1 -0
  39. package/dist/providers/cursor/spawn.js +59 -0
  40. package/dist/providers/cursor/spawn.js.map +1 -0
  41. package/dist/providers/gemini-cli/adapter.js +158 -0
  42. package/dist/providers/gemini-cli/adapter.js.map +1 -0
  43. package/dist/providers/gemini-cli/hooks.js +128 -0
  44. package/dist/providers/gemini-cli/hooks.js.map +1 -0
  45. package/dist/providers/gemini-cli/index.js +39 -0
  46. package/dist/providers/gemini-cli/index.js.map +1 -0
  47. package/dist/providers/gemini-cli/install.js +124 -0
  48. package/dist/providers/gemini-cli/install.js.map +1 -0
  49. package/dist/providers/kimi/adapter.js +145 -0
  50. package/dist/providers/kimi/adapter.js.map +1 -0
  51. package/dist/providers/kimi/hooks.js +79 -0
  52. package/dist/providers/kimi/hooks.js.map +1 -0
  53. package/dist/providers/kimi/index.js +39 -0
  54. package/dist/providers/kimi/index.js.map +1 -0
  55. package/dist/providers/kimi/install.js +124 -0
  56. package/dist/providers/kimi/install.js.map +1 -0
  57. package/dist/providers/opencode/adapter.js +166 -0
  58. package/dist/providers/opencode/adapter.js.map +1 -0
  59. package/dist/providers/opencode/hooks.js +206 -0
  60. package/dist/providers/opencode/hooks.js.map +1 -0
  61. package/dist/providers/opencode/index.js +37 -0
  62. package/dist/providers/opencode/index.js.map +1 -0
  63. package/dist/providers/opencode/install.js +115 -0
  64. package/dist/providers/opencode/install.js.map +1 -0
  65. package/dist/providers/opencode/spawn.js +241 -0
  66. package/dist/providers/opencode/spawn.js.map +1 -0
  67. package/dist/providers/pi/adapter.d.ts +102 -0
  68. package/dist/providers/pi/adapter.d.ts.map +1 -0
  69. package/dist/providers/pi/adapter.js +220 -0
  70. package/dist/providers/pi/adapter.js.map +1 -0
  71. package/dist/providers/pi/hooks.d.ts +149 -0
  72. package/dist/providers/pi/hooks.d.ts.map +1 -0
  73. package/dist/providers/pi/hooks.js +223 -0
  74. package/dist/providers/pi/hooks.js.map +1 -0
  75. package/dist/providers/pi/index.d.ts +36 -0
  76. package/dist/providers/pi/index.d.ts.map +1 -0
  77. package/dist/providers/pi/index.js +38 -0
  78. package/dist/providers/pi/index.js.map +1 -0
  79. package/dist/providers/pi/install.d.ts +68 -0
  80. package/dist/providers/pi/install.d.ts.map +1 -0
  81. package/dist/providers/pi/install.js +175 -0
  82. package/dist/providers/pi/install.js.map +1 -0
  83. package/dist/providers/pi/spawn.d.ts +68 -0
  84. package/dist/providers/pi/spawn.d.ts.map +1 -0
  85. package/dist/providers/pi/spawn.js +187 -0
  86. package/dist/providers/pi/spawn.js.map +1 -0
  87. package/dist/providers/shared/transcript-reader.js +124 -0
  88. package/dist/providers/shared/transcript-reader.js.map +1 -0
  89. package/dist/registry.d.ts.map +1 -1
  90. package/dist/registry.js +92 -0
  91. package/dist/registry.js.map +1 -0
  92. package/package.json +3 -3
  93. package/src/providers/pi/adapter.ts +240 -0
  94. package/src/providers/pi/hooks.ts +232 -0
  95. package/src/providers/pi/index.ts +41 -0
  96. package/src/providers/pi/install.ts +189 -0
  97. package/src/providers/pi/manifest.json +40 -0
  98. package/src/providers/pi/spawn.ts +207 -0
  99. package/src/registry.ts +6 -1
@@ -0,0 +1 @@
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"}
@@ -0,0 +1,115 @@
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
+ details,
46
+ };
47
+ }
48
+ /**
49
+ * Uninstall CLEO from the current OpenCode project.
50
+ *
51
+ * Does not remove AGENTS.md references (they are harmless if CLEO is not present).
52
+ */
53
+ async uninstall() { }
54
+ /**
55
+ * Check whether CLEO is installed in the current environment.
56
+ *
57
+ * Checks for CLEO references in AGENTS.md.
58
+ */
59
+ async isInstalled() {
60
+ const agentsMdPath = join(process.cwd(), 'AGENTS.md');
61
+ if (existsSync(agentsMdPath)) {
62
+ try {
63
+ const content = readFileSync(agentsMdPath, 'utf-8');
64
+ if (INSTRUCTION_REFERENCES.some((ref) => content.includes(ref))) {
65
+ return true;
66
+ }
67
+ }
68
+ catch {
69
+ // Fall through
70
+ }
71
+ }
72
+ return false;
73
+ }
74
+ /**
75
+ * Ensure AGENTS.md contains @-references to CLEO instruction files.
76
+ *
77
+ * Creates AGENTS.md if it does not exist. Appends any missing references.
78
+ *
79
+ * @param projectDir - Project root directory
80
+ */
81
+ async ensureInstructionReferences(projectDir) {
82
+ this.updateInstructionFile(projectDir);
83
+ }
84
+ /**
85
+ * Update AGENTS.md with CLEO @-references.
86
+ *
87
+ * @returns true if the file was created or modified
88
+ */
89
+ updateInstructionFile(projectDir) {
90
+ const agentsMdPath = join(projectDir, 'AGENTS.md');
91
+ let content = '';
92
+ let existed = false;
93
+ if (existsSync(agentsMdPath)) {
94
+ content = readFileSync(agentsMdPath, 'utf-8');
95
+ existed = true;
96
+ }
97
+ const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
98
+ if (missingRefs.length === 0) {
99
+ return false;
100
+ }
101
+ const refsBlock = missingRefs.join('\n');
102
+ if (existed) {
103
+ // Append missing references
104
+ const separator = content.endsWith('\n') ? '' : '\n';
105
+ content = content + separator + refsBlock + '\n';
106
+ }
107
+ else {
108
+ // Create new AGENTS.md with references
109
+ content = refsBlock + '\n';
110
+ }
111
+ writeFileSync(agentsMdPath, content, 'utf-8');
112
+ return true;
113
+ }
114
+ }
115
+ //# sourceMappingURL=install.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/opencode/install.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,241 @@
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 { exec, spawn as nodeSpawn } from 'node:child_process';
14
+ import { mkdir, readFile, writeFile } from 'node:fs/promises';
15
+ import { join } from 'node:path';
16
+ import { promisify } from 'node:util';
17
+ const execAsync = promisify(exec);
18
+ /** Name used for the CLEO subagent definition in OpenCode's agent directory. */
19
+ const OPENCODE_SUBAGENT_NAME = 'cleo-subagent';
20
+ /** Fallback agent name when custom agent definition cannot be created. */
21
+ const OPENCODE_FALLBACK_AGENT = 'general';
22
+ /**
23
+ * Build the markdown content for an OpenCode agent definition file.
24
+ *
25
+ * OpenCode agents are defined as markdown files with YAML frontmatter
26
+ * in the .opencode/agent/ directory.
27
+ *
28
+ * @remarks
29
+ * The generated markdown uses YAML frontmatter with `mode: subagent`
30
+ * and `hidden: true` so the agent does not appear in OpenCode's
31
+ * interactive agent selection menu.
32
+ *
33
+ * @param description - Agent description for frontmatter
34
+ * @param instructions - Markdown instructions body
35
+ * @returns Complete agent definition markdown with YAML frontmatter
36
+ *
37
+ * @example
38
+ * ```typescript
39
+ * import { buildOpenCodeAgentMarkdown } from '@cleocode/adapters/providers/opencode/spawn';
40
+ *
41
+ * const md = buildOpenCodeAgentMarkdown(
42
+ * 'CLEO task executor',
43
+ * '# Subagent\n\nExecute the delegated task.',
44
+ * );
45
+ * ```
46
+ */
47
+ export function buildOpenCodeAgentMarkdown(description, instructions) {
48
+ const normalizedDesc = description.replace(/\s+/g, ' ').trim();
49
+ return [
50
+ '---',
51
+ `description: ${JSON.stringify(normalizedDesc)}`,
52
+ 'mode: subagent',
53
+ 'hidden: true',
54
+ '---',
55
+ '',
56
+ instructions.trim(),
57
+ '',
58
+ ].join('\n');
59
+ }
60
+ /**
61
+ * Ensure the CLEO subagent definition exists in the project's
62
+ * .opencode/agent/ directory.
63
+ *
64
+ * Creates or updates the agent definition file if the content has changed.
65
+ *
66
+ * @param workingDirectory - Project root directory
67
+ * @returns The agent name to use for spawning
68
+ */
69
+ async function ensureSubagentDefinition(workingDirectory) {
70
+ const agentDir = join(workingDirectory, '.opencode', 'agent');
71
+ const agentPath = join(agentDir, `${OPENCODE_SUBAGENT_NAME}.md`);
72
+ const description = 'CLEO task executor with protocol compliance.';
73
+ const instructions = [
74
+ '# CLEO Subagent',
75
+ '',
76
+ 'You are a CLEO subagent executing a delegated task.',
77
+ 'Follow the CLEO protocol and complete the assigned work.',
78
+ '',
79
+ '@~/.cleo/templates/CLEO-INJECTION.md',
80
+ ].join('\n');
81
+ const content = buildOpenCodeAgentMarkdown(description, instructions);
82
+ await mkdir(agentDir, { recursive: true });
83
+ let existing = null;
84
+ try {
85
+ existing = await readFile(agentPath, 'utf-8');
86
+ }
87
+ catch {
88
+ existing = null;
89
+ }
90
+ if (existing !== content) {
91
+ await writeFile(agentPath, content, 'utf-8');
92
+ }
93
+ return OPENCODE_SUBAGENT_NAME;
94
+ }
95
+ /**
96
+ * Spawn provider for OpenCode.
97
+ *
98
+ * Spawns detached OpenCode CLI processes for subagent execution.
99
+ * Each spawn ensures a CLEO subagent definition exists, then runs
100
+ * `opencode run --format json --agent <name> --title <title> <prompt>`
101
+ * as a detached, unref'd child process.
102
+ *
103
+ * @remarks
104
+ * Before spawning, the provider ensures a `cleo-subagent` agent definition
105
+ * exists in `.opencode/agent/`. If the definition cannot be created, it
106
+ * falls back to the built-in `general` agent. Processes are tracked by
107
+ * instance ID in an in-memory map and verified via `kill(pid, 0)` liveness
108
+ * checks.
109
+ */
110
+ export class OpenCodeSpawnProvider {
111
+ /** Map of instance IDs to tracked process info. */
112
+ processMap = new Map();
113
+ /**
114
+ * Check if the OpenCode CLI is available in PATH.
115
+ *
116
+ * @returns true if `opencode` is found via `which`
117
+ */
118
+ async canSpawn() {
119
+ try {
120
+ await execAsync('which opencode');
121
+ return true;
122
+ }
123
+ catch {
124
+ return false;
125
+ }
126
+ }
127
+ /**
128
+ * Spawn a subagent via OpenCode CLI.
129
+ *
130
+ * Ensures the CLEO subagent definition exists in the project's
131
+ * .opencode/agent/ directory, then spawns a detached OpenCode
132
+ * process. The process runs independently of the parent.
133
+ *
134
+ * @param context - Spawn context with taskId, prompt, and options
135
+ * @returns Spawn result with instance ID and status
136
+ */
137
+ async spawn(context) {
138
+ const instanceId = `opencode-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;
139
+ const startTime = new Date().toISOString();
140
+ const workingDirectory = context.workingDirectory ?? process.cwd();
141
+ try {
142
+ let agentName;
143
+ try {
144
+ agentName = await ensureSubagentDefinition(workingDirectory);
145
+ }
146
+ catch {
147
+ agentName = OPENCODE_FALLBACK_AGENT;
148
+ }
149
+ const child = nodeSpawn('opencode', [
150
+ 'run',
151
+ '--format',
152
+ 'json',
153
+ '--agent',
154
+ agentName,
155
+ '--title',
156
+ `CLEO ${context.taskId}`,
157
+ context.prompt,
158
+ ], {
159
+ cwd: workingDirectory,
160
+ detached: true,
161
+ stdio: 'ignore',
162
+ });
163
+ child.unref();
164
+ if (child.pid) {
165
+ this.processMap.set(instanceId, {
166
+ pid: child.pid,
167
+ taskId: context.taskId,
168
+ startTime,
169
+ });
170
+ }
171
+ child.on('exit', () => {
172
+ this.processMap.delete(instanceId);
173
+ });
174
+ return {
175
+ instanceId,
176
+ taskId: context.taskId,
177
+ providerId: 'opencode',
178
+ status: 'running',
179
+ startTime,
180
+ };
181
+ }
182
+ catch {
183
+ return {
184
+ instanceId,
185
+ taskId: context.taskId,
186
+ providerId: 'opencode',
187
+ status: 'failed',
188
+ startTime,
189
+ endTime: new Date().toISOString(),
190
+ };
191
+ }
192
+ }
193
+ /**
194
+ * List currently running OpenCode subagent processes.
195
+ *
196
+ * Checks each tracked process via kill(pid, 0) to verify it is still alive.
197
+ * Dead processes are automatically cleaned from the tracking map.
198
+ *
199
+ * @returns Array of spawn results for running processes
200
+ */
201
+ async listRunning() {
202
+ const running = [];
203
+ for (const [instanceId, tracked] of this.processMap.entries()) {
204
+ try {
205
+ process.kill(tracked.pid, 0);
206
+ running.push({
207
+ instanceId,
208
+ taskId: tracked.taskId,
209
+ providerId: 'opencode',
210
+ status: 'running',
211
+ startTime: tracked.startTime,
212
+ });
213
+ }
214
+ catch {
215
+ this.processMap.delete(instanceId);
216
+ }
217
+ }
218
+ return running;
219
+ }
220
+ /**
221
+ * Terminate a running spawn by instance ID.
222
+ *
223
+ * Sends SIGTERM to the tracked process. If the process is not found
224
+ * or has already exited, this is a no-op.
225
+ *
226
+ * @param instanceId - ID of the spawn instance to terminate
227
+ */
228
+ async terminate(instanceId) {
229
+ const tracked = this.processMap.get(instanceId);
230
+ if (!tracked)
231
+ return;
232
+ try {
233
+ process.kill(tracked.pid, 'SIGTERM');
234
+ }
235
+ catch {
236
+ // Process may have already exited
237
+ }
238
+ this.processMap.delete(instanceId);
239
+ }
240
+ }
241
+ //# sourceMappingURL=spawn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spawn.js","sourceRoot":"","sources":["../../../src/providers/opencode/spawn.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,102 @@
1
+ /**
2
+ * Pi Adapter
3
+ *
4
+ * Main CLEOProviderAdapter implementation for the Pi coding agent
5
+ * (https://github.com/badlogic/pi-mono). Pi is CAAMP's first-class primary
6
+ * harness and owns skills, instructions, extensions, and subagent spawning
7
+ * through native filesystem conventions.
8
+ *
9
+ * Pi supports 11 of 16 CAAMP canonical events through its TypeScript extension
10
+ * system (session_start, session_shutdown, input, turn_end, tool_call,
11
+ * tool_result, before_agent_start, agent_end, before_provider_request, context).
12
+ *
13
+ * Detection: PI_CLI_PATH env var, PI_CODING_AGENT_DIR env var, PI_HOME env var,
14
+ * or presence of ~/.pi/agent/ directory.
15
+ *
16
+ * @task T553
17
+ */
18
+ import type { AdapterCapabilities, AdapterHealthStatus, CLEOProviderAdapter } from '@cleocode/contracts';
19
+ import { PiHookProvider } from './hooks.js';
20
+ import { PiInstallProvider } from './install.js';
21
+ import { PiSpawnProvider } from './spawn.js';
22
+ /**
23
+ * CLEO provider adapter for Pi coding agent.
24
+ *
25
+ * Bridges CLEO's adapter system with Pi's native capabilities:
26
+ * - Hooks: Maps Pi events (session_start, tool_call, etc.) to CAAMP events
27
+ * - Spawn: Launches subagent processes via the `pi` CLI
28
+ * - Install: Manages AGENTS.md instruction files and global Pi state root
29
+ *
30
+ * @remarks
31
+ * Pi is CAAMP's first-class primary harness (ADR-035). It supports 11 of 16
32
+ * canonical hook events through its TypeScript extension system. Extensions
33
+ * live at `~/.pi/agent/extensions/` (global) or `<projectDir>/.pi/extensions/`
34
+ * (project scope).
35
+ *
36
+ * The session_shutdown event handler in `cleo-cant-bridge.ts` clears module
37
+ * cache. The adapter's hook mapping ensures that Pi's session lifecycle events
38
+ * are visible in the CAAMP event stream for downstream listeners (e.g. memory
39
+ * refresh triggers, backup triggers).
40
+ *
41
+ * Detection hierarchy (first match wins):
42
+ * 1. `PI_CLI_PATH` env var set
43
+ * 2. `PI_CODING_AGENT_DIR` env var set
44
+ * 3. `PI_HOME` env var set
45
+ * 4. `~/.pi/agent/` directory exists
46
+ * 5. `pi` CLI available in PATH
47
+ */
48
+ export declare class PiAdapter implements CLEOProviderAdapter {
49
+ /** Unique provider identifier. */
50
+ readonly id = "pi";
51
+ /** Human-readable provider name. */
52
+ readonly name = "Pi";
53
+ /** Adapter version string. */
54
+ readonly version = "1.0.0";
55
+ /** Declared capabilities for this provider. */
56
+ capabilities: AdapterCapabilities;
57
+ /** Hook provider for CAAMP event mapping and registration. */
58
+ hooks: PiHookProvider;
59
+ /** Spawn provider for launching subagent processes via `pi` CLI. */
60
+ spawn: PiSpawnProvider;
61
+ /** Install provider for managing AGENTS.md instruction files. */
62
+ install: PiInstallProvider;
63
+ /** Project directory this adapter was initialized with, or null. */
64
+ private projectDir;
65
+ /** Whether {@link initialize} has been called. */
66
+ private initialized;
67
+ constructor();
68
+ /**
69
+ * Initialize the adapter for a given project directory.
70
+ *
71
+ * Validates the environment by checking for the Pi CLI and Pi state root.
72
+ *
73
+ * @param projectDir - Root directory of the project
74
+ */
75
+ initialize(projectDir: string): Promise<void>;
76
+ /**
77
+ * Dispose the adapter and clean up resources.
78
+ *
79
+ * Unregisters hooks and releases any tracked state.
80
+ */
81
+ dispose(): Promise<void>;
82
+ /**
83
+ * Run a health check to verify Pi is accessible.
84
+ *
85
+ * Checks:
86
+ * 1. Adapter has been initialized
87
+ * 2. Pi CLI is available (via PI_CLI_PATH or `which pi`)
88
+ * 3. Pi global state root (~/.pi/agent/ or PI_CODING_AGENT_DIR) exists
89
+ *
90
+ * @returns Health status with details about each check
91
+ */
92
+ healthCheck(): Promise<AdapterHealthStatus>;
93
+ /**
94
+ * Check whether the adapter has been initialized.
95
+ */
96
+ isInitialized(): boolean;
97
+ /**
98
+ * Get the project directory this adapter was initialized with.
99
+ */
100
+ getProjectDir(): string | null;
101
+ }
102
+ //# sourceMappingURL=adapter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../../src/providers/pi/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AAOH,OAAO,KAAK,EACV,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAC5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAwB7C;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,qBAAa,SAAU,YAAW,mBAAmB;IACnD,kCAAkC;IAClC,QAAQ,CAAC,EAAE,QAAQ;IACnB,oCAAoC;IACpC,QAAQ,CAAC,IAAI,QAAQ;IACrB,8BAA8B;IAC9B,QAAQ,CAAC,OAAO,WAAW;IAE3B,+CAA+C;IAC/C,YAAY,EAAE,mBAAmB,CA0B/B;IAEF,8DAA8D;IAC9D,KAAK,EAAE,cAAc,CAAC;IACtB,oEAAoE;IACpE,KAAK,EAAE,eAAe,CAAC;IACvB,iEAAiE;IACjE,OAAO,EAAE,iBAAiB,CAAC;IAE3B,oEAAoE;IACpE,OAAO,CAAC,UAAU,CAAuB;IACzC,kDAAkD;IAClD,OAAO,CAAC,WAAW,CAAS;;IAQ5B;;;;;;OAMG;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;IAwDjD;;OAEG;IACH,aAAa,IAAI,OAAO;IAIxB;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,IAAI;CAG/B"}