@cleocode/adapters 2026.5.4 → 2026.5.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (123) hide show
  1. package/package.json +4 -4
  2. package/dist/cant-context.js +0 -711
  3. package/dist/cant-context.js.map +0 -1
  4. package/dist/providers/claude-code/adapter.js +0 -222
  5. package/dist/providers/claude-code/adapter.js.map +0 -1
  6. package/dist/providers/claude-code/context-monitor.js +0 -159
  7. package/dist/providers/claude-code/context-monitor.js.map +0 -1
  8. package/dist/providers/claude-code/hooks.js +0 -428
  9. package/dist/providers/claude-code/hooks.js.map +0 -1
  10. package/dist/providers/claude-code/index.js +0 -41
  11. package/dist/providers/claude-code/index.js.map +0 -1
  12. package/dist/providers/claude-code/install.js +0 -310
  13. package/dist/providers/claude-code/install.js.map +0 -1
  14. package/dist/providers/claude-code/paths.js +0 -41
  15. package/dist/providers/claude-code/paths.js.map +0 -1
  16. package/dist/providers/claude-code/spawn.js +0 -198
  17. package/dist/providers/claude-code/spawn.js.map +0 -1
  18. package/dist/providers/claude-code/statusline.js +0 -130
  19. package/dist/providers/claude-code/statusline.js.map +0 -1
  20. package/dist/providers/claude-code/task-sync.js +0 -119
  21. package/dist/providers/claude-code/task-sync.js.map +0 -1
  22. package/dist/providers/claude-code/transport.js +0 -29
  23. package/dist/providers/claude-code/transport.js.map +0 -1
  24. package/dist/providers/claude-sdk/adapter.js +0 -88
  25. package/dist/providers/claude-sdk/adapter.js.map +0 -1
  26. package/dist/providers/claude-sdk/index.js +0 -34
  27. package/dist/providers/claude-sdk/index.js.map +0 -1
  28. package/dist/providers/claude-sdk/install.js +0 -61
  29. package/dist/providers/claude-sdk/install.js.map +0 -1
  30. package/dist/providers/claude-sdk/mcp-registry.js +0 -66
  31. package/dist/providers/claude-sdk/mcp-registry.js.map +0 -1
  32. package/dist/providers/claude-sdk/session-store.js +0 -84
  33. package/dist/providers/claude-sdk/session-store.js.map +0 -1
  34. package/dist/providers/claude-sdk/spawn.js +0 -251
  35. package/dist/providers/claude-sdk/spawn.js.map +0 -1
  36. package/dist/providers/claude-sdk/tool-bridge.js +0 -50
  37. package/dist/providers/claude-sdk/tool-bridge.js.map +0 -1
  38. package/dist/providers/codex/adapter.js +0 -146
  39. package/dist/providers/codex/adapter.js.map +0 -1
  40. package/dist/providers/codex/hooks.js +0 -113
  41. package/dist/providers/codex/hooks.js.map +0 -1
  42. package/dist/providers/codex/index.js +0 -40
  43. package/dist/providers/codex/index.js.map +0 -1
  44. package/dist/providers/codex/install.js +0 -132
  45. package/dist/providers/codex/install.js.map +0 -1
  46. package/dist/providers/codex/spawn.js +0 -203
  47. package/dist/providers/codex/spawn.js.map +0 -1
  48. package/dist/providers/cursor/adapter.js +0 -151
  49. package/dist/providers/cursor/adapter.js.map +0 -1
  50. package/dist/providers/cursor/hooks.js +0 -208
  51. package/dist/providers/cursor/hooks.js.map +0 -1
  52. package/dist/providers/cursor/index.js +0 -36
  53. package/dist/providers/cursor/index.js.map +0 -1
  54. package/dist/providers/cursor/install.js +0 -281
  55. package/dist/providers/cursor/install.js.map +0 -1
  56. package/dist/providers/cursor/spawn.js +0 -59
  57. package/dist/providers/cursor/spawn.js.map +0 -1
  58. package/dist/providers/gemini-cli/adapter.js +0 -158
  59. package/dist/providers/gemini-cli/adapter.js.map +0 -1
  60. package/dist/providers/gemini-cli/hooks.js +0 -128
  61. package/dist/providers/gemini-cli/hooks.js.map +0 -1
  62. package/dist/providers/gemini-cli/index.js +0 -40
  63. package/dist/providers/gemini-cli/index.js.map +0 -1
  64. package/dist/providers/gemini-cli/install.js +0 -124
  65. package/dist/providers/gemini-cli/install.js.map +0 -1
  66. package/dist/providers/gemini-cli/spawn.js +0 -195
  67. package/dist/providers/gemini-cli/spawn.js.map +0 -1
  68. package/dist/providers/kimi/adapter.js +0 -145
  69. package/dist/providers/kimi/adapter.js.map +0 -1
  70. package/dist/providers/kimi/hooks.js +0 -79
  71. package/dist/providers/kimi/hooks.js.map +0 -1
  72. package/dist/providers/kimi/index.js +0 -40
  73. package/dist/providers/kimi/index.js.map +0 -1
  74. package/dist/providers/kimi/install.js +0 -124
  75. package/dist/providers/kimi/install.js.map +0 -1
  76. package/dist/providers/kimi/spawn.js +0 -225
  77. package/dist/providers/kimi/spawn.js.map +0 -1
  78. package/dist/providers/openai-sdk/adapter.js +0 -121
  79. package/dist/providers/openai-sdk/adapter.js.map +0 -1
  80. package/dist/providers/openai-sdk/guardrails.js +0 -174
  81. package/dist/providers/openai-sdk/guardrails.js.map +0 -1
  82. package/dist/providers/openai-sdk/handoff.js +0 -128
  83. package/dist/providers/openai-sdk/handoff.js.map +0 -1
  84. package/dist/providers/openai-sdk/index.js +0 -40
  85. package/dist/providers/openai-sdk/index.js.map +0 -1
  86. package/dist/providers/openai-sdk/install.js +0 -120
  87. package/dist/providers/openai-sdk/install.js.map +0 -1
  88. package/dist/providers/openai-sdk/spawn.js +0 -361
  89. package/dist/providers/openai-sdk/spawn.js.map +0 -1
  90. package/dist/providers/openai-sdk/tracing.js +0 -159
  91. package/dist/providers/openai-sdk/tracing.js.map +0 -1
  92. package/dist/providers/opencode/adapter.js +0 -166
  93. package/dist/providers/opencode/adapter.js.map +0 -1
  94. package/dist/providers/opencode/hooks.js +0 -206
  95. package/dist/providers/opencode/hooks.js.map +0 -1
  96. package/dist/providers/opencode/index.js +0 -37
  97. package/dist/providers/opencode/index.js.map +0 -1
  98. package/dist/providers/opencode/install.js +0 -242
  99. package/dist/providers/opencode/install.js.map +0 -1
  100. package/dist/providers/opencode/spawn.js +0 -257
  101. package/dist/providers/opencode/spawn.js.map +0 -1
  102. package/dist/providers/pi/adapter.js +0 -220
  103. package/dist/providers/pi/adapter.js.map +0 -1
  104. package/dist/providers/pi/hooks.js +0 -223
  105. package/dist/providers/pi/hooks.js.map +0 -1
  106. package/dist/providers/pi/index.js +0 -38
  107. package/dist/providers/pi/index.js.map +0 -1
  108. package/dist/providers/pi/install.js +0 -183
  109. package/dist/providers/pi/install.js.map +0 -1
  110. package/dist/providers/pi/spawn.js +0 -187
  111. package/dist/providers/pi/spawn.js.map +0 -1
  112. package/dist/providers/shared/conduit-trace-writer.js +0 -65
  113. package/dist/providers/shared/conduit-trace-writer.js.map +0 -1
  114. package/dist/providers/shared/hook-template-installer.js +0 -209
  115. package/dist/providers/shared/hook-template-installer.js.map +0 -1
  116. package/dist/providers/shared/paths.js +0 -77
  117. package/dist/providers/shared/paths.js.map +0 -1
  118. package/dist/providers/shared/sdk-result-mapper.js +0 -55
  119. package/dist/providers/shared/sdk-result-mapper.js.map +0 -1
  120. package/dist/providers/shared/transcript-reader.js +0 -124
  121. package/dist/providers/shared/transcript-reader.js.map +0 -1
  122. package/dist/registry.js +0 -92
  123. package/dist/registry.js.map +0 -1
@@ -1,257 +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 { 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
- import { getCleoTemplatesTildePath } from '../shared/paths.js';
18
- const execAsync = promisify(exec);
19
- /** Name used for the CLEO subagent definition in OpenCode's agent directory. */
20
- const OPENCODE_SUBAGENT_NAME = 'cleo-subagent';
21
- /** Fallback agent name when custom agent definition cannot be created. */
22
- const OPENCODE_FALLBACK_AGENT = 'general';
23
- /**
24
- * Build the markdown content for an OpenCode agent definition file.
25
- *
26
- * OpenCode agents are defined as markdown files with YAML frontmatter
27
- * in the .opencode/agent/ directory.
28
- *
29
- * @remarks
30
- * The generated markdown uses YAML frontmatter with `mode: subagent`
31
- * and `hidden: true` so the agent does not appear in OpenCode's
32
- * interactive agent selection menu.
33
- *
34
- * @param description - Agent description for frontmatter
35
- * @param instructions - Markdown instructions body
36
- * @returns Complete agent definition markdown with YAML frontmatter
37
- *
38
- * @example
39
- * ```typescript
40
- * import { buildOpenCodeAgentMarkdown } from '@cleocode/adapters/providers/opencode/spawn';
41
- *
42
- * const md = buildOpenCodeAgentMarkdown(
43
- * 'CLEO task executor',
44
- * '# Subagent\n\nExecute the delegated task.',
45
- * );
46
- * ```
47
- */
48
- export function buildOpenCodeAgentMarkdown(description, instructions) {
49
- const normalizedDesc = description.replace(/\s+/g, ' ').trim();
50
- return [
51
- '---',
52
- `description: ${JSON.stringify(normalizedDesc)}`,
53
- 'mode: subagent',
54
- 'hidden: true',
55
- '---',
56
- '',
57
- instructions.trim(),
58
- '',
59
- ].join('\n');
60
- }
61
- /**
62
- * Ensure the CLEO subagent definition exists in the project's
63
- * .opencode/agent/ directory.
64
- *
65
- * Creates or updates the agent definition file if the content has changed.
66
- *
67
- * @param workingDirectory - Project root directory
68
- * @returns The agent name to use for spawning
69
- */
70
- async function ensureSubagentDefinition(workingDirectory, enrichedInstructions) {
71
- const agentDir = join(workingDirectory, '.opencode', 'agent');
72
- const agentPath = join(agentDir, `${OPENCODE_SUBAGENT_NAME}.md`);
73
- const description = 'CLEO task executor with protocol compliance and CANT context.';
74
- const instructions = enrichedInstructions ??
75
- [
76
- '# CLEO Subagent',
77
- '',
78
- 'You are a CLEO subagent executing a delegated task.',
79
- 'Follow the CLEO protocol and complete the assigned work.',
80
- '',
81
- `@${getCleoTemplatesTildePath()}/CLEO-INJECTION.md`,
82
- ].join('\n');
83
- const content = buildOpenCodeAgentMarkdown(description, instructions);
84
- await mkdir(agentDir, { recursive: true });
85
- let existing = null;
86
- try {
87
- existing = await readFile(agentPath, 'utf-8');
88
- }
89
- catch {
90
- existing = null;
91
- }
92
- if (existing !== content) {
93
- await writeFile(agentPath, content, 'utf-8');
94
- }
95
- return OPENCODE_SUBAGENT_NAME;
96
- }
97
- /**
98
- * Spawn provider for OpenCode.
99
- *
100
- * Spawns detached OpenCode CLI processes for subagent execution.
101
- * Each spawn ensures a CLEO subagent definition exists, then runs
102
- * `opencode run --format json --agent <name> --title <title> <prompt>`
103
- * as a detached, unref'd child process.
104
- *
105
- * @remarks
106
- * Before spawning, the provider ensures a `cleo-subagent` agent definition
107
- * exists in `.opencode/agent/`. If the definition cannot be created, it
108
- * falls back to the built-in `general` agent. Processes are tracked by
109
- * instance ID in an in-memory map and verified via `kill(pid, 0)` liveness
110
- * checks.
111
- */
112
- export class OpenCodeSpawnProvider {
113
- /** Map of instance IDs to tracked process info. */
114
- processMap = new Map();
115
- /**
116
- * Check if the OpenCode CLI is available in PATH.
117
- *
118
- * @returns true if `opencode` is found via `which`
119
- */
120
- async canSpawn() {
121
- try {
122
- await execAsync('which opencode');
123
- return true;
124
- }
125
- catch {
126
- return false;
127
- }
128
- }
129
- /**
130
- * Spawn a subagent via OpenCode CLI.
131
- *
132
- * Ensures the CLEO subagent definition exists in the project's
133
- * .opencode/agent/ directory, then spawns a detached OpenCode
134
- * process. The process runs independently of the parent.
135
- *
136
- * @param context - Spawn context with taskId, prompt, and options
137
- * @returns Spawn result with instance ID and status
138
- */
139
- async spawn(context) {
140
- const instanceId = `opencode-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;
141
- const startTime = new Date().toISOString();
142
- const workingDirectory = context.workingDirectory ?? process.cwd();
143
- try {
144
- // Enrich prompt with CANT bundle, memory bridge, and mental model (T555).
145
- // Best-effort: if CANT context is unavailable, the raw prompt is used.
146
- let enrichedInstructions;
147
- try {
148
- const { buildCantEnrichedPrompt } = await import('../../cant-context.js');
149
- enrichedInstructions = await buildCantEnrichedPrompt({
150
- projectDir: workingDirectory,
151
- basePrompt: context.prompt,
152
- agentName: context.options?.agentName ?? undefined,
153
- });
154
- }
155
- catch {
156
- // CANT enrichment unavailable — use raw prompt
157
- }
158
- let agentName;
159
- try {
160
- agentName = await ensureSubagentDefinition(workingDirectory, enrichedInstructions);
161
- }
162
- catch {
163
- agentName = OPENCODE_FALLBACK_AGENT;
164
- }
165
- const child = nodeSpawn('opencode', [
166
- 'run',
167
- '--format',
168
- 'json',
169
- '--agent',
170
- agentName,
171
- '--title',
172
- `CLEO ${context.taskId}`,
173
- context.prompt,
174
- ], {
175
- cwd: workingDirectory,
176
- detached: true,
177
- stdio: 'ignore',
178
- });
179
- child.unref();
180
- if (child.pid) {
181
- this.processMap.set(instanceId, {
182
- pid: child.pid,
183
- taskId: context.taskId,
184
- startTime,
185
- });
186
- }
187
- child.on('exit', () => {
188
- this.processMap.delete(instanceId);
189
- });
190
- return {
191
- instanceId,
192
- taskId: context.taskId,
193
- providerId: 'opencode',
194
- status: 'running',
195
- startTime,
196
- };
197
- }
198
- catch {
199
- return {
200
- instanceId,
201
- taskId: context.taskId,
202
- providerId: 'opencode',
203
- status: 'failed',
204
- startTime,
205
- endTime: new Date().toISOString(),
206
- };
207
- }
208
- }
209
- /**
210
- * List currently running OpenCode subagent processes.
211
- *
212
- * Checks each tracked process via kill(pid, 0) to verify it is still alive.
213
- * Dead processes are automatically cleaned from the tracking map.
214
- *
215
- * @returns Array of spawn results for running processes
216
- */
217
- async listRunning() {
218
- const running = [];
219
- for (const [instanceId, tracked] of this.processMap.entries()) {
220
- try {
221
- process.kill(tracked.pid, 0);
222
- running.push({
223
- instanceId,
224
- taskId: tracked.taskId,
225
- providerId: 'opencode',
226
- status: 'running',
227
- startTime: tracked.startTime,
228
- });
229
- }
230
- catch {
231
- this.processMap.delete(instanceId);
232
- }
233
- }
234
- return running;
235
- }
236
- /**
237
- * Terminate a running spawn by instance ID.
238
- *
239
- * Sends SIGTERM to the tracked process. If the process is not found
240
- * or has already exited, this is a no-op.
241
- *
242
- * @param instanceId - ID of the spawn instance to terminate
243
- */
244
- async terminate(instanceId) {
245
- const tracked = this.processMap.get(instanceId);
246
- if (!tracked)
247
- return;
248
- try {
249
- process.kill(tracked.pid, 'SIGTERM');
250
- }
251
- catch {
252
- // Process may have already exited
253
- }
254
- this.processMap.delete(instanceId);
255
- }
256
- }
257
- //# sourceMappingURL=spawn.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"spawn.js","sourceRoot":"","sources":["../../../src/providers/opencode/spawn.ts"],"names":[],"mappings":"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"}
@@ -1,220 +0,0 @@
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 { exec } from 'node:child_process';
19
- import { existsSync } from 'node:fs';
20
- import { homedir } from 'node:os';
21
- import { join } from 'node:path';
22
- import { promisify } from 'node:util';
23
- import { PiHookProvider } from './hooks.js';
24
- import { PiInstallProvider } from './install.js';
25
- import { PiSpawnProvider } from './spawn.js';
26
- const execAsync = promisify(exec);
27
- /**
28
- * Resolve the Pi global state root directory.
29
- *
30
- * Honours `PI_CODING_AGENT_DIR` env var when set (with `~` expansion),
31
- * then `PI_HOME`, then falls back to `~/.pi/agent`.
32
- */
33
- function getPiAgentDir() {
34
- const env = process.env['PI_CODING_AGENT_DIR'];
35
- if (env !== undefined && env.length > 0) {
36
- if (env === '~')
37
- return homedir();
38
- if (env.startsWith('~/'))
39
- return join(homedir(), env.slice(2));
40
- return env;
41
- }
42
- const piHome = process.env['PI_HOME'];
43
- if (piHome !== undefined && piHome.length > 0) {
44
- return join(piHome, 'agent');
45
- }
46
- return join(homedir(), '.pi', 'agent');
47
- }
48
- /**
49
- * CLEO provider adapter for Pi coding agent.
50
- *
51
- * Bridges CLEO's adapter system with Pi's native capabilities:
52
- * - Hooks: Maps Pi events (session_start, tool_call, etc.) to CAAMP events
53
- * - Spawn: Launches subagent processes via the `pi` CLI
54
- * - Install: Manages AGENTS.md instruction files and global Pi state root
55
- *
56
- * @remarks
57
- * Pi is CAAMP's first-class primary harness (ADR-035). It supports 11 of 16
58
- * canonical hook events through its TypeScript extension system. Extensions
59
- * live at `~/.pi/agent/extensions/` (global) or `<projectDir>/.pi/extensions/`
60
- * (project scope).
61
- *
62
- * The session_shutdown event handler in `cleo-cant-bridge.ts` clears module
63
- * cache. The adapter's hook mapping ensures that Pi's session lifecycle events
64
- * are visible in the CAAMP event stream for downstream listeners (e.g. memory
65
- * refresh triggers, backup triggers).
66
- *
67
- * Detection hierarchy (first match wins):
68
- * 1. `PI_CLI_PATH` env var set
69
- * 2. `PI_CODING_AGENT_DIR` env var set
70
- * 3. `PI_HOME` env var set
71
- * 4. `~/.pi/agent/` directory exists
72
- * 5. `pi` CLI available in PATH
73
- */
74
- export class PiAdapter {
75
- /** Unique provider identifier. */
76
- id = 'pi';
77
- /** Human-readable provider name. */
78
- name = 'Pi';
79
- /** Adapter version string. */
80
- version = '1.0.0';
81
- /** Declared capabilities for this provider. */
82
- capabilities = {
83
- supportsHooks: true,
84
- // 11/16 canonical events — derived from piEventCatalog in CAAMP hook-mappings.json.
85
- // ResponseComplete, PostToolUseFailure, PermissionRequest, PostModel, PostCompact,
86
- // and ConfigChange are not supported by Pi's extension system.
87
- supportedHookEvents: [
88
- 'SessionStart',
89
- 'SessionEnd',
90
- 'PromptSubmit',
91
- 'Notification',
92
- 'PreToolUse',
93
- 'PostToolUse',
94
- 'SubagentStart',
95
- 'SubagentStop',
96
- 'PreModel',
97
- 'PreCompact',
98
- ],
99
- supportsSpawn: true,
100
- supportsInstall: true,
101
- supportsInstructionFiles: true,
102
- instructionFilePattern: 'AGENTS.md',
103
- supportsContextMonitor: false,
104
- supportsStatusline: false,
105
- supportsProviderPaths: true,
106
- supportsTransport: false,
107
- supportsTaskSync: false,
108
- };
109
- /** Hook provider for CAAMP event mapping and registration. */
110
- hooks;
111
- /** Spawn provider for launching subagent processes via `pi` CLI. */
112
- spawn;
113
- /** Install provider for managing AGENTS.md instruction files. */
114
- install;
115
- /** Project directory this adapter was initialized with, or null. */
116
- projectDir = null;
117
- /** Whether {@link initialize} has been called. */
118
- initialized = false;
119
- constructor() {
120
- this.hooks = new PiHookProvider();
121
- this.spawn = new PiSpawnProvider();
122
- this.install = new PiInstallProvider();
123
- }
124
- /**
125
- * Initialize the adapter for a given project directory.
126
- *
127
- * Validates the environment by checking for the Pi CLI and Pi state root.
128
- *
129
- * @param projectDir - Root directory of the project
130
- */
131
- async initialize(projectDir) {
132
- this.projectDir = projectDir;
133
- this.initialized = true;
134
- }
135
- /**
136
- * Dispose the adapter and clean up resources.
137
- *
138
- * Unregisters hooks and releases any tracked state.
139
- */
140
- async dispose() {
141
- if (this.hooks.isRegistered()) {
142
- await this.hooks.unregisterNativeHooks();
143
- }
144
- this.initialized = false;
145
- this.projectDir = null;
146
- }
147
- /**
148
- * Run a health check to verify Pi is accessible.
149
- *
150
- * Checks:
151
- * 1. Adapter has been initialized
152
- * 2. Pi CLI is available (via PI_CLI_PATH or `which pi`)
153
- * 3. Pi global state root (~/.pi/agent/ or PI_CODING_AGENT_DIR) exists
154
- *
155
- * @returns Health status with details about each check
156
- */
157
- async healthCheck() {
158
- const details = {};
159
- if (!this.initialized) {
160
- return {
161
- healthy: false,
162
- provider: this.id,
163
- details: { error: 'Adapter not initialized' },
164
- };
165
- }
166
- // Check Pi CLI availability
167
- let cliAvailable = false;
168
- const cliPath = process.env['PI_CLI_PATH'] ?? 'pi';
169
- try {
170
- if (cliPath !== 'pi') {
171
- const { stdout } = await execAsync(`test -x "${cliPath}" && echo ok`);
172
- cliAvailable = stdout.trim() === 'ok';
173
- details.cliPath = cliPath;
174
- }
175
- else {
176
- const { stdout } = await execAsync('which pi');
177
- cliAvailable = stdout.trim().length > 0;
178
- details.cliPath = stdout.trim();
179
- }
180
- }
181
- catch {
182
- details.cliAvailable = false;
183
- }
184
- // Check for Pi global state root
185
- const agentDir = getPiAgentDir();
186
- const agentDirExists = existsSync(agentDir);
187
- details.agentDirExists = agentDirExists;
188
- details.agentDir = agentDir;
189
- // Check for project-level .pi/ directory
190
- if (this.projectDir) {
191
- const projectPiDir = join(this.projectDir, '.pi');
192
- details.projectPiDirExists = existsSync(projectPiDir);
193
- }
194
- // Check detection env vars
195
- details.piCodingAgentDirSet = process.env['PI_CODING_AGENT_DIR'] !== undefined;
196
- details.piHomeSet = process.env['PI_HOME'] !== undefined;
197
- details.piCliPathSet = process.env['PI_CLI_PATH'] !== undefined;
198
- // Healthy if either CLI is available or global state root exists
199
- const healthy = cliAvailable || agentDirExists;
200
- details.cliAvailable = cliAvailable;
201
- return {
202
- healthy,
203
- provider: this.id,
204
- details,
205
- };
206
- }
207
- /**
208
- * Check whether the adapter has been initialized.
209
- */
210
- isInitialized() {
211
- return this.initialized;
212
- }
213
- /**
214
- * Get the project directory this adapter was initialized with.
215
- */
216
- getProjectDir() {
217
- return this.projectDir;
218
- }
219
- }
220
- //# sourceMappingURL=adapter.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/pi/adapter.ts"],"names":[],"mappings":"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"}