@cleocode/adapters 2026.3.42 → 2026.3.43

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 (45) hide show
  1. package/dist/index.d.ts +12 -0
  2. package/dist/index.d.ts.map +1 -0
  3. package/dist/providers/claude-code/adapter.d.ts +75 -0
  4. package/dist/providers/claude-code/adapter.d.ts.map +1 -0
  5. package/dist/providers/claude-code/context-monitor.d.ts +24 -0
  6. package/dist/providers/claude-code/context-monitor.d.ts.map +1 -0
  7. package/dist/providers/claude-code/hooks.d.ts +59 -0
  8. package/dist/providers/claude-code/hooks.d.ts.map +1 -0
  9. package/dist/providers/claude-code/index.d.ts +24 -0
  10. package/dist/providers/claude-code/index.d.ts.map +1 -0
  11. package/dist/providers/claude-code/install.d.ts +75 -0
  12. package/dist/providers/claude-code/install.d.ts.map +1 -0
  13. package/dist/providers/claude-code/paths.d.ts +24 -0
  14. package/dist/providers/claude-code/paths.d.ts.map +1 -0
  15. package/dist/providers/claude-code/spawn.d.ts +60 -0
  16. package/dist/providers/claude-code/spawn.d.ts.map +1 -0
  17. package/dist/providers/claude-code/statusline.d.ts +24 -0
  18. package/dist/providers/claude-code/statusline.d.ts.map +1 -0
  19. package/dist/providers/claude-code/task-sync.d.ts +24 -0
  20. package/dist/providers/claude-code/task-sync.d.ts.map +1 -0
  21. package/dist/providers/claude-code/transport.d.ts +14 -0
  22. package/dist/providers/claude-code/transport.d.ts.map +1 -0
  23. package/dist/providers/cursor/adapter.d.ts +62 -0
  24. package/dist/providers/cursor/adapter.d.ts.map +1 -0
  25. package/dist/providers/cursor/hooks.d.ts +48 -0
  26. package/dist/providers/cursor/hooks.d.ts.map +1 -0
  27. package/dist/providers/cursor/index.d.ts +19 -0
  28. package/dist/providers/cursor/index.d.ts.map +1 -0
  29. package/dist/providers/cursor/install.d.ts +94 -0
  30. package/dist/providers/cursor/install.d.ts.map +1 -0
  31. package/dist/providers/cursor/spawn.d.ts +50 -0
  32. package/dist/providers/cursor/spawn.d.ts.map +1 -0
  33. package/dist/providers/opencode/adapter.d.ts +67 -0
  34. package/dist/providers/opencode/adapter.d.ts.map +1 -0
  35. package/dist/providers/opencode/hooks.d.ts +66 -0
  36. package/dist/providers/opencode/hooks.d.ts.map +1 -0
  37. package/dist/providers/opencode/index.d.ts +20 -0
  38. package/dist/providers/opencode/index.d.ts.map +1 -0
  39. package/dist/providers/opencode/install.d.ts +65 -0
  40. package/dist/providers/opencode/install.d.ts.map +1 -0
  41. package/dist/providers/opencode/spawn.d.ts +72 -0
  42. package/dist/providers/opencode/spawn.d.ts.map +1 -0
  43. package/dist/registry.d.ts +36 -0
  44. package/dist/registry.d.ts.map +1 -0
  45. package/package.json +2 -2
@@ -0,0 +1,12 @@
1
+ /**
2
+ * @cleocode/adapters
3
+ *
4
+ * Unified provider adapter package for CLEO.
5
+ * Exports all provider adapters and a registry for manifest discovery.
6
+ */
7
+ export { ClaudeCodeAdapter, ClaudeCodeContextMonitorProvider, ClaudeCodeHookProvider, ClaudeCodeInstallProvider, ClaudeCodePathProvider, ClaudeCodeSpawnProvider, ClaudeCodeTransportProvider, checkStatuslineIntegration, createAdapter as createClaudeCodeAdapter, getSetupInstructions, getStatuslineConfig, } from './providers/claude-code/index.js';
8
+ export { CursorAdapter, CursorHookProvider, CursorInstallProvider, createAdapter as createCursorAdapter, } from './providers/cursor/index.js';
9
+ export { createAdapter as createOpenCodeAdapter, OpenCodeAdapter, OpenCodeHookProvider, OpenCodeInstallProvider, OpenCodeSpawnProvider, } from './providers/opencode/index.js';
10
+ export type { AdapterManifest } from './registry.js';
11
+ export { discoverProviders, getProviderManifests } from './registry.js';
12
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,EACL,iBAAiB,EACjB,gCAAgC,EAChC,sBAAsB,EACtB,yBAAyB,EACzB,sBAAsB,EACtB,uBAAuB,EACvB,2BAA2B,EAC3B,0BAA0B,EAC1B,aAAa,IAAI,uBAAuB,EACxC,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EACL,aAAa,EACb,kBAAkB,EAClB,qBAAqB,EACrB,aAAa,IAAI,mBAAmB,GACrC,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACL,aAAa,IAAI,qBAAqB,EACtC,eAAe,EACf,oBAAoB,EACpB,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,+BAA+B,CAAC;AACvC,YAAY,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC"}
@@ -0,0 +1,75 @@
1
+ /**
2
+ * Claude Code Adapter
3
+ *
4
+ * Main CLEOProviderAdapter implementation for Anthropic's Claude Code CLI.
5
+ * Provides spawn, hooks, and install capabilities for CLEO integration.
6
+ *
7
+ * @task T5240
8
+ */
9
+ import type { AdapterCapabilities, AdapterHealthStatus, CLEOProviderAdapter } from '@cleocode/contracts';
10
+ import { ClaudeCodeContextMonitorProvider } from './context-monitor.js';
11
+ import { ClaudeCodeHookProvider } from './hooks.js';
12
+ import { ClaudeCodeInstallProvider } from './install.js';
13
+ import { ClaudeCodePathProvider } from './paths.js';
14
+ import { ClaudeCodeSpawnProvider } from './spawn.js';
15
+ import { ClaudeCodeTaskSyncProvider } from './task-sync.js';
16
+ import { ClaudeCodeTransportProvider } from './transport.js';
17
+ /**
18
+ * CLEO provider adapter for Anthropic Claude Code CLI.
19
+ *
20
+ * Bridges CLEO's adapter system with Claude Code's native capabilities:
21
+ * - Hooks: Maps Claude Code events (SessionStart, PostToolUse, etc.) to CAAMP events
22
+ * - Spawn: Launches subagent processes via the `claude` CLI
23
+ * - Install: Registers MCP server, instruction files, and brain observation plugin
24
+ */
25
+ export declare class ClaudeCodeAdapter implements CLEOProviderAdapter {
26
+ readonly id = "claude-code";
27
+ readonly name = "Claude Code";
28
+ readonly version = "1.0.0";
29
+ capabilities: AdapterCapabilities;
30
+ hooks: ClaudeCodeHookProvider;
31
+ spawn: ClaudeCodeSpawnProvider;
32
+ install: ClaudeCodeInstallProvider;
33
+ paths: ClaudeCodePathProvider;
34
+ contextMonitor: ClaudeCodeContextMonitorProvider;
35
+ transport: ClaudeCodeTransportProvider;
36
+ taskSync: ClaudeCodeTaskSyncProvider;
37
+ private projectDir;
38
+ private initialized;
39
+ constructor();
40
+ /**
41
+ * Initialize the adapter for a given project directory.
42
+ *
43
+ * Validates the environment by checking for the Claude CLI
44
+ * and Claude Code configuration directory.
45
+ *
46
+ * @param projectDir - Root directory of the project
47
+ */
48
+ initialize(projectDir: string): Promise<void>;
49
+ /**
50
+ * Dispose the adapter and clean up resources.
51
+ *
52
+ * Unregisters hooks and releases any tracked state.
53
+ */
54
+ dispose(): Promise<void>;
55
+ /**
56
+ * Run a health check to verify Claude Code is accessible.
57
+ *
58
+ * Checks:
59
+ * 1. Adapter has been initialized
60
+ * 2. Claude CLI is available in PATH
61
+ * 3. ~/.claude/ configuration directory exists
62
+ *
63
+ * @returns Health status with details about each check
64
+ */
65
+ healthCheck(): Promise<AdapterHealthStatus>;
66
+ /**
67
+ * Check whether the adapter has been initialized.
68
+ */
69
+ isInitialized(): boolean;
70
+ /**
71
+ * Get the project directory this adapter was initialized with.
72
+ */
73
+ getProjectDir(): string | null;
74
+ }
75
+ //# sourceMappingURL=adapter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAOH,OAAO,KAAK,EACV,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAC7B,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,EAAE,0BAA0B,EAAE,MAAM,gBAAgB,CAAC;AAC5D,OAAO,EAAE,2BAA2B,EAAE,MAAM,gBAAgB,CAAC;AAI7D;;;;;;;GAOG;AACH,qBAAa,iBAAkB,YAAW,mBAAmB;IAC3D,QAAQ,CAAC,EAAE,iBAAiB;IAC5B,QAAQ,CAAC,IAAI,iBAAiB;IAC9B,QAAQ,CAAC,OAAO,WAAW;IAE3B,YAAY,EAAE,mBAAmB,CAmB/B;IAEF,KAAK,EAAE,sBAAsB,CAAC;IAC9B,KAAK,EAAE,uBAAuB,CAAC;IAC/B,OAAO,EAAE,yBAAyB,CAAC;IACnC,KAAK,EAAE,sBAAsB,CAAC;IAC9B,cAAc,EAAE,gCAAgC,CAAC;IACjD,SAAS,EAAE,2BAA2B,CAAC;IACvC,QAAQ,EAAE,0BAA0B,CAAC;IAErC,OAAO,CAAC,UAAU,CAAuB;IACzC,OAAO,CAAC,WAAW,CAAS;;IAY5B;;;;;;;OAOG;IACG,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnD;;;;OAIG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ9B;;;;;;;;;OASG;IACG,WAAW,IAAI,OAAO,CAAC,mBAAmB,CAAC;IAyCjD;;OAEG;IACH,aAAa,IAAI,OAAO;IAIxB;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,IAAI;CAG/B"}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Claude Code context monitor provider.
3
+ *
4
+ * Implements AdapterContextMonitorProvider for Claude Code's context window
5
+ * tracking and statusline integration.
6
+ *
7
+ * @task T5240
8
+ */
9
+ import type { AdapterContextMonitorProvider } from '@cleocode/contracts';
10
+ /**
11
+ * Context monitor provider for Claude Code.
12
+ *
13
+ * Processes context window JSON from Claude Code and writes state files
14
+ * for statusline display. Also provides statusline configuration
15
+ * and setup instructions specific to Claude Code's settings.json.
16
+ */
17
+ export declare class ClaudeCodeContextMonitorProvider implements AdapterContextMonitorProvider {
18
+ private pathProvider;
19
+ processContextInput(input: unknown, cwd?: string): Promise<string>;
20
+ checkStatuslineIntegration(): 'configured' | 'not_configured' | 'custom_no_cleo' | 'no_settings';
21
+ getStatuslineConfig(): Record<string, unknown>;
22
+ getSetupInstructions(): string;
23
+ }
24
+ //# sourceMappingURL=context-monitor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context-monitor.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/context-monitor.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,OAAO,KAAK,EAAE,6BAA6B,EAAE,MAAM,qBAAqB,CAAC;AAkCzE;;;;;;GAMG;AACH,qBAAa,gCAAiC,YAAW,6BAA6B;IACpF,OAAO,CAAC,YAAY,CAAgC;IAE9C,mBAAmB,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IA0DxE,0BAA0B,IAAI,YAAY,GAAG,gBAAgB,GAAG,gBAAgB,GAAG,aAAa;IAsChG,mBAAmB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAS9C,oBAAoB,IAAI,MAAM;CAY/B"}
@@ -0,0 +1,59 @@
1
+ /**
2
+ * Claude Code Hook Provider
3
+ *
4
+ * Maps Claude Code's native hook events to CAAMP hook events.
5
+ * Claude Code uses: SessionStart, PostToolUse, UserPromptSubmit, Stop
6
+ * CAAMP defines: onSessionStart, onToolComplete, onPromptSubmit, onSessionEnd
7
+ *
8
+ * @task T5240
9
+ */
10
+ import type { AdapterHookProvider } from '@cleocode/contracts';
11
+ /**
12
+ * Hook provider for Claude Code.
13
+ *
14
+ * Claude Code registers hooks via a plugin directory
15
+ * with a hooks.json descriptor. The actual hook scripts are shell scripts
16
+ * that invoke CLEO's brain observation system.
17
+ *
18
+ * Since hooks are registered through the plugin system (installed via
19
+ * the install provider), registerNativeHooks and unregisterNativeHooks
20
+ * are effectively no-ops here — the plugin installer handles registration.
21
+ */
22
+ export declare class ClaudeCodeHookProvider implements AdapterHookProvider {
23
+ private registered;
24
+ /**
25
+ * Map a Claude Code native event name to a CAAMP hook event name.
26
+ *
27
+ * @param providerEvent - Claude Code event name (e.g. "SessionStart", "PostToolUse")
28
+ * @returns CAAMP event name or null if unmapped
29
+ */
30
+ mapProviderEvent(providerEvent: string): string | null;
31
+ /**
32
+ * Register native hooks for a project.
33
+ *
34
+ * For Claude Code, hooks are registered via the plugin system
35
+ * (hooks.json descriptor), which is handled by the
36
+ * install provider. This method is a no-op since registration
37
+ * is managed through the plugin install lifecycle.
38
+ *
39
+ * @param _projectDir - Project directory (unused; hooks are global)
40
+ */
41
+ registerNativeHooks(_projectDir: string): Promise<void>;
42
+ /**
43
+ * Unregister native hooks.
44
+ *
45
+ * For Claude Code, this is a no-op since hooks are managed through
46
+ * the plugin system. Unregistration happens via the install provider's
47
+ * uninstall method.
48
+ */
49
+ unregisterNativeHooks(): Promise<void>;
50
+ /**
51
+ * Check whether hooks have been registered via registerNativeHooks.
52
+ */
53
+ isRegistered(): boolean;
54
+ /**
55
+ * Get the full event mapping for introspection/debugging.
56
+ */
57
+ getEventMap(): Readonly<Record<string, string>>;
58
+ }
59
+ //# sourceMappingURL=hooks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAY/D;;;;;;;;;;GAUG;AACH,qBAAa,sBAAuB,YAAW,mBAAmB;IAChE,OAAO,CAAC,UAAU,CAAS;IAE3B;;;;;OAKG;IACH,gBAAgB,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAItD;;;;;;;;;OASG;IACG,mBAAmB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7D;;;;;;OAMG;IACG,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5C;;OAEG;IACH,YAAY,IAAI,OAAO;IAIvB;;OAEG;IACH,WAAW,IAAI,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAGhD"}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Claude Code provider adapter.
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
+ export declare function createAdapter(): ClaudeCodeAdapter;
24
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
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;;;GAGG;AACH,wBAAgB,aAAa,IAAI,iBAAiB,CAEjD"}
@@ -0,0 +1,75 @@
1
+ /**
2
+ * Claude Code Install Provider
3
+ *
4
+ * Handles CLEO installation into Claude Code environments:
5
+ * - Registers CLEO MCP server in .mcp.json
6
+ * - Ensures CLAUDE.md has CLEO @-references
7
+ * - Manages plugin registration in ~/.claude/settings.json
8
+ *
9
+ * Migrated from src/core/install/claude-plugin.ts
10
+ *
11
+ * @task T5240
12
+ */
13
+ import type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';
14
+ /**
15
+ * Install provider for Claude Code.
16
+ *
17
+ * Manages CLEO's integration with Claude Code by:
18
+ * 1. Registering the CLEO MCP server in the project's .mcp.json
19
+ * 2. Ensuring CLAUDE.md contains @-references to CLEO instruction files
20
+ * 3. Registering the brain observation plugin in ~/.claude/settings.json
21
+ */
22
+ export declare class ClaudeCodeInstallProvider implements AdapterInstallProvider {
23
+ private installedProjectDir;
24
+ /**
25
+ * Install CLEO into a Claude Code project.
26
+ *
27
+ * @param options - Installation options including project directory and MCP server path
28
+ * @returns Result describing what was installed
29
+ */
30
+ install(options: InstallOptions): Promise<InstallResult>;
31
+ /**
32
+ * Uninstall CLEO from the current Claude Code project.
33
+ *
34
+ * Removes the MCP server registration from .mcp.json.
35
+ * Does not remove CLAUDE.md references (they are harmless if CLEO is not present).
36
+ */
37
+ uninstall(): Promise<void>;
38
+ /**
39
+ * Check whether CLEO is installed in the current environment.
40
+ *
41
+ * Checks for:
42
+ * 1. MCP server registered in .mcp.json
43
+ * 2. Plugin enabled in ~/.claude/settings.json
44
+ *
45
+ * Returns true if either condition is met (partial install counts).
46
+ */
47
+ isInstalled(): Promise<boolean>;
48
+ /**
49
+ * Ensure CLAUDE.md contains @-references to CLEO instruction files.
50
+ *
51
+ * Creates CLAUDE.md if it does not exist. Appends any missing references.
52
+ *
53
+ * @param projectDir - Project root directory
54
+ */
55
+ ensureInstructionReferences(projectDir: string): Promise<void>;
56
+ /**
57
+ * Register the CLEO MCP server in .mcp.json.
58
+ *
59
+ * @returns true if registration was performed or updated
60
+ */
61
+ private registerMcpServer;
62
+ /**
63
+ * Update CLAUDE.md with CLEO @-references.
64
+ *
65
+ * @returns true if the file was created or modified
66
+ */
67
+ private updateInstructionFile;
68
+ /**
69
+ * Register the CLEO brain plugin in ~/.claude/settings.json.
70
+ *
71
+ * @returns Description of what was registered, or null if no change needed
72
+ */
73
+ private registerPlugin;
74
+ }
75
+ //# sourceMappingURL=install.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/install.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAKH,OAAO,KAAK,EAAE,sBAAsB,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAQjG;;;;;;;GAOG;AACH,qBAAa,yBAA0B,YAAW,sBAAsB;IACtE,OAAO,CAAC,mBAAmB,CAAuB;IAElD;;;;;OAKG;IACG,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC;IAsC9D;;;;;OAKG;IACG,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAqBhC;;;;;;;;OAQG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAgCrC;;;;;;OAMG;IACG,2BAA2B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE;;;;OAIG;IACH,OAAO,CAAC,iBAAiB;IA0BzB;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;IA+B7B;;;;OAIG;IACH,OAAO,CAAC,cAAc;CAiCvB"}
@@ -0,0 +1,24 @@
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
+ export declare class ClaudeCodePathProvider implements AdapterPathProvider {
19
+ getProviderDir(): string;
20
+ getSettingsPath(): string | null;
21
+ getAgentInstallDir(): string | null;
22
+ getMemoryDbPath(): string | null;
23
+ }
24
+ //# sourceMappingURL=paths.d.ts.map
@@ -0,0 +1 @@
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;;;;;;;;GAQG;AACH,qBAAa,sBAAuB,YAAW,mBAAmB;IAChE,cAAc,IAAI,MAAM;IAIxB,eAAe,IAAI,MAAM,GAAG,IAAI;IAIhC,kBAAkB,IAAI,MAAM,GAAG,IAAI;IAInC,eAAe,IAAI,MAAM,GAAG,IAAI;CAGjC"}
@@ -0,0 +1,60 @@
1
+ /**
2
+ * Claude Code Spawn Provider
3
+ *
4
+ * Implements AdapterSpawnProvider for Claude Code CLI.
5
+ * Migrated from src/core/spawn/adapters/claude-code-adapter.ts
6
+ *
7
+ * Uses the native `claude` CLI to spawn subagent processes with prompts
8
+ * written to temporary files. Processes run detached and are tracked
9
+ * by PID for listing and termination.
10
+ *
11
+ * @task T5240
12
+ */
13
+ import type { AdapterSpawnProvider, SpawnContext, SpawnResult } from '@cleocode/contracts';
14
+ /**
15
+ * Spawn provider for Claude Code.
16
+ *
17
+ * Spawns detached Claude CLI processes for subagent execution.
18
+ * Each spawn writes its prompt to a temporary file, then runs
19
+ * `claude --allow-insecure --no-upgrade-check <tmpFile>` as a
20
+ * detached, unref'd child process.
21
+ */
22
+ export declare class ClaudeCodeSpawnProvider implements AdapterSpawnProvider {
23
+ /** Map of instance IDs to tracked process info. */
24
+ private processMap;
25
+ /**
26
+ * Check if the Claude CLI is available in PATH.
27
+ *
28
+ * @returns true if `claude` is found via `which`
29
+ */
30
+ canSpawn(): Promise<boolean>;
31
+ /**
32
+ * Spawn a subagent via Claude CLI.
33
+ *
34
+ * Writes the prompt to a temporary file and spawns a detached Claude
35
+ * process. The process runs independently of the parent.
36
+ *
37
+ * @param context - Spawn context with taskId, prompt, and options
38
+ * @returns Spawn result with instance ID and status
39
+ */
40
+ spawn(context: SpawnContext): Promise<SpawnResult>;
41
+ /**
42
+ * List currently running Claude subagent processes.
43
+ *
44
+ * Checks each tracked process via kill(pid, 0) to verify it is still alive.
45
+ * Dead processes are automatically cleaned from the tracking map.
46
+ *
47
+ * @returns Array of spawn results for running processes
48
+ */
49
+ listRunning(): Promise<SpawnResult[]>;
50
+ /**
51
+ * Terminate a running spawn by instance ID.
52
+ *
53
+ * Sends SIGTERM to the tracked process. If the process is not found
54
+ * or has already exited, this is a no-op.
55
+ *
56
+ * @param instanceId - ID of the spawn instance to terminate
57
+ */
58
+ terminate(instanceId: string): Promise<void>;
59
+ }
60
+ //# sourceMappingURL=spawn.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spawn.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/spawn.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAKH,OAAO,KAAK,EAAE,oBAAoB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAY3F;;;;;;;GAOG;AACH,qBAAa,uBAAwB,YAAW,oBAAoB;IAClE,mDAAmD;IACnD,OAAO,CAAC,UAAU,CAAqC;IAEvD;;;;OAIG;IACG,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC;IASlC;;;;;;;;OAQG;IACG,KAAK,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC;IAuExD;;;;;;;OAOG;IACG,WAAW,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAqB3C;;;;;;;OAOG;IACG,SAAS,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAWnD"}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Statusline integration for the Claude Code adapter.
3
+ *
4
+ * Implements the statusline portion of AdapterContextMonitorProvider.
5
+ * Checks and configures Claude Code status line for context monitoring.
6
+ *
7
+ * @task T5240
8
+ */
9
+ type StatuslineStatus = 'configured' | 'not_configured' | 'custom_no_cleo' | 'no_settings';
10
+ /**
11
+ * Check if statusline integration is configured.
12
+ * Returns the current integration status.
13
+ */
14
+ export declare function checkStatuslineIntegration(): StatuslineStatus;
15
+ /**
16
+ * Get the statusline setup command for Claude Code settings.
17
+ */
18
+ export declare function getStatuslineConfig(cleoHome: string): Record<string, unknown>;
19
+ /**
20
+ * Get human-readable setup instructions.
21
+ */
22
+ export declare function getSetupInstructions(cleoHome: string): string;
23
+ export {};
24
+ //# sourceMappingURL=statusline.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"statusline.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/statusline.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,KAAK,gBAAgB,GAAG,YAAY,GAAG,gBAAgB,GAAG,gBAAgB,GAAG,aAAa,CAAC;AAa3F;;;GAGG;AACH,wBAAgB,0BAA0B,IAAI,gBAAgB,CAwC7D;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAO7E;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAW7D"}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Claude Code TaskSyncProvider — bridges Claude's TodoWrite format
3
+ * to the provider-agnostic reconciliation system.
4
+ *
5
+ * All Claude Code / TodoWrite-specific parsing lives here.
6
+ * The core reconciliation engine never sees TodoWrite formats.
7
+ */
8
+ import type { ExternalTask, ExternalTaskProvider } from '@cleocode/contracts';
9
+ /**
10
+ * Claude Code TaskSyncProvider.
11
+ *
12
+ * Reads Claude's TodoWrite JSON state, parses [T001]-prefixed task IDs
13
+ * and status, and returns normalized ExternalTask[].
14
+ *
15
+ * Optional: accepts a custom file path for testing.
16
+ */
17
+ export declare class ClaudeCodeTaskSyncProvider implements ExternalTaskProvider {
18
+ private readonly customFilePath?;
19
+ constructor(options?: {
20
+ filePath?: string;
21
+ });
22
+ getExternalTasks(projectDir: string): Promise<ExternalTask[]>;
23
+ }
24
+ //# sourceMappingURL=task-sync.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"task-sync.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/task-sync.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAKH,OAAO,KAAK,EAAE,YAAY,EAAE,oBAAoB,EAAsB,MAAM,qBAAqB,CAAC;AAkElG;;;;;;;GAOG;AACH,qBAAa,0BAA2B,YAAW,oBAAoB;IACrE,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAS;gBAE7B,OAAO,CAAC,EAAE;QAAE,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE;IAIrC,gBAAgB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;CAgDpE"}
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Transport provider for the Claude Code adapter.
3
+ *
4
+ * Implements AdapterTransportProvider to supply Claude Code's
5
+ * native inter-agent transport mechanism.
6
+ *
7
+ * @task T5240
8
+ */
9
+ import type { AdapterTransportProvider } from '@cleocode/contracts';
10
+ export declare class ClaudeCodeTransportProvider implements AdapterTransportProvider {
11
+ readonly transportName = "claude-code";
12
+ createTransport(): unknown;
13
+ }
14
+ //# sourceMappingURL=transport.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transport.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/transport.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAC;AAEpE,qBAAa,2BAA4B,YAAW,wBAAwB;IAC1E,QAAQ,CAAC,aAAa,iBAAiB;IAEvC,eAAe,IAAI,OAAO;CAM3B"}
@@ -0,0 +1,62 @@
1
+ /**
2
+ * Cursor Adapter
3
+ *
4
+ * Main CLEOProviderAdapter implementation for Cursor AI code editor.
5
+ * Provides install capabilities for CLEO integration. Hooks and spawn
6
+ * are not supported since Cursor lacks CLI-based lifecycle events
7
+ * and subagent spawning.
8
+ *
9
+ * @task T5240
10
+ */
11
+ import type { AdapterCapabilities, AdapterHealthStatus, CLEOProviderAdapter } from '@cleocode/contracts';
12
+ import { CursorHookProvider } from './hooks.js';
13
+ import { CursorInstallProvider } from './install.js';
14
+ /**
15
+ * CLEO provider adapter for Cursor AI code editor.
16
+ *
17
+ * Bridges CLEO's adapter system with Cursor's capabilities:
18
+ * - Install: Registers MCP server in .cursor/mcp.json and manages rule files
19
+ * - Hooks: Stub provider (Cursor has no lifecycle event system)
20
+ * - Spawn: Not supported (Cursor has no CLI for subagent spawning)
21
+ */
22
+ export declare class CursorAdapter implements CLEOProviderAdapter {
23
+ readonly id = "cursor";
24
+ readonly name = "Cursor";
25
+ readonly version = "1.0.0";
26
+ capabilities: AdapterCapabilities;
27
+ hooks: CursorHookProvider;
28
+ install: CursorInstallProvider;
29
+ private projectDir;
30
+ private initialized;
31
+ constructor();
32
+ /**
33
+ * Initialize the adapter for a given project directory.
34
+ *
35
+ * @param projectDir - Root directory of the project
36
+ */
37
+ initialize(projectDir: string): Promise<void>;
38
+ /**
39
+ * Dispose the adapter and clean up resources.
40
+ */
41
+ dispose(): Promise<void>;
42
+ /**
43
+ * Run a health check to verify Cursor is accessible.
44
+ *
45
+ * Checks:
46
+ * 1. Adapter has been initialized
47
+ * 2. .cursor/ configuration directory exists in the project
48
+ * 3. CURSOR_EDITOR env var is set
49
+ *
50
+ * @returns Health status with details about each check
51
+ */
52
+ healthCheck(): Promise<AdapterHealthStatus>;
53
+ /**
54
+ * Check whether the adapter has been initialized.
55
+ */
56
+ isInitialized(): boolean;
57
+ /**
58
+ * Get the project directory this adapter was initialized with.
59
+ */
60
+ getProjectDir(): string | null;
61
+ }
62
+ //# sourceMappingURL=adapter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../../src/providers/cursor/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAIH,OAAO,KAAK,EACV,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAErD;;;;;;;GAOG;AACH,qBAAa,aAAc,YAAW,mBAAmB;IACvD,QAAQ,CAAC,EAAE,YAAY;IACvB,QAAQ,CAAC,IAAI,YAAY;IACzB,QAAQ,CAAC,OAAO,WAAW;IAE3B,YAAY,EAAE,mBAAmB,CAa/B;IAEF,KAAK,EAAE,kBAAkB,CAAC;IAC1B,OAAO,EAAE,qBAAqB,CAAC;IAE/B,OAAO,CAAC,UAAU,CAAuB;IACzC,OAAO,CAAC,WAAW,CAAS;;IAO5B;;;;OAIG;IACG,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnD;;OAEG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ9B;;;;;;;;;OASG;IACG,WAAW,IAAI,OAAO,CAAC,mBAAmB,CAAC;IAwCjD;;OAEG;IACH,aAAa,IAAI,OAAO;IAIxB;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,IAAI;CAG/B"}
@@ -0,0 +1,48 @@
1
+ /**
2
+ * Cursor Hook Provider
3
+ *
4
+ * Cursor does not have a native hook/event system for external tools.
5
+ * This provider returns null for all event mappings and marks hooks
6
+ * as unsupported. It exists to satisfy the AdapterHookProvider contract
7
+ * so the adapter can be used uniformly by the AdapterManager.
8
+ *
9
+ * @task T5240
10
+ */
11
+ import type { AdapterHookProvider } from '@cleocode/contracts';
12
+ /**
13
+ * Hook provider for Cursor (stub).
14
+ *
15
+ * Cursor lacks a hook-based lifecycle event system. All mapping
16
+ * operations return null. Registration is a no-op.
17
+ */
18
+ export declare class CursorHookProvider implements AdapterHookProvider {
19
+ private registered;
20
+ /**
21
+ * Map a provider event name to a CAAMP hook event name.
22
+ *
23
+ * Always returns null since Cursor does not emit hook events.
24
+ *
25
+ * @param _providerEvent - Ignored; Cursor has no hook events
26
+ * @returns null (no mapping available)
27
+ */
28
+ mapProviderEvent(_providerEvent: string): string | null;
29
+ /**
30
+ * Register native hooks for a project.
31
+ *
32
+ * No-op for Cursor since it has no hook system.
33
+ *
34
+ * @param _projectDir - Ignored
35
+ */
36
+ registerNativeHooks(_projectDir: string): Promise<void>;
37
+ /**
38
+ * Unregister native hooks.
39
+ *
40
+ * No-op for Cursor since it has no hook system.
41
+ */
42
+ unregisterNativeHooks(): Promise<void>;
43
+ /**
44
+ * Check whether hooks have been registered.
45
+ */
46
+ isRegistered(): boolean;
47
+ }
48
+ //# sourceMappingURL=hooks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/providers/cursor/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAE/D;;;;;GAKG;AACH,qBAAa,kBAAmB,YAAW,mBAAmB;IAC5D,OAAO,CAAC,UAAU,CAAS;IAE3B;;;;;;;OAOG;IACH,gBAAgB,CAAC,cAAc,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAIvD;;;;;;OAMG;IACG,mBAAmB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7D;;;;OAIG;IACG,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5C;;OAEG;IACH,YAAY,IAAI,OAAO;CAGxB"}
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Cursor provider adapter.
3
+ *
4
+ * CLEO provider adapter for Cursor AI code editor.
5
+ * Default export is the adapter class for dynamic loading by AdapterManager.
6
+ *
7
+ * @task T5240
8
+ */
9
+ import { CursorAdapter } from './adapter.js';
10
+ export { CursorAdapter } from './adapter.js';
11
+ export { CursorHookProvider } from './hooks.js';
12
+ export { CursorInstallProvider } from './install.js';
13
+ export default CursorAdapter;
14
+ /**
15
+ * Factory function for creating adapter instances.
16
+ * Used by AdapterManager's dynamic import fallback.
17
+ */
18
+ export declare function createAdapter(): CursorAdapter;
19
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/providers/cursor/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAE7C,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAErD,eAAe,aAAa,CAAC;AAE7B;;;GAGG;AACH,wBAAgB,aAAa,IAAI,aAAa,CAE7C"}
@@ -0,0 +1,94 @@
1
+ /**
2
+ * Cursor Install Provider
3
+ *
4
+ * Handles CLEO installation into Cursor environments:
5
+ * - Registers CLEO MCP server in .cursor/mcp.json
6
+ * - Ensures .cursorrules has CLEO @-references (legacy format)
7
+ * - Creates .cursor/rules/cleo.mdc with CLEO references (modern format)
8
+ *
9
+ * Cursor supports two instruction file formats:
10
+ * 1. Legacy: .cursorrules (flat file, project root)
11
+ * 2. Modern: .cursor/rules/*.mdc (MDC format, per-rule files)
12
+ *
13
+ * This provider writes to both for maximum compatibility.
14
+ *
15
+ * @task T5240
16
+ */
17
+ import type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';
18
+ /**
19
+ * Install provider for Cursor.
20
+ *
21
+ * Manages CLEO's integration with Cursor by:
22
+ * 1. Registering the CLEO MCP server in .cursor/mcp.json
23
+ * 2. Creating/updating .cursorrules with @-references (legacy)
24
+ * 3. Creating .cursor/rules/cleo.mdc with @-references (modern)
25
+ */
26
+ export declare class CursorInstallProvider implements AdapterInstallProvider {
27
+ private installedProjectDir;
28
+ /**
29
+ * Install CLEO into a Cursor project.
30
+ *
31
+ * @param options - Installation options including project directory and MCP server path
32
+ * @returns Result describing what was installed
33
+ */
34
+ install(options: InstallOptions): Promise<InstallResult>;
35
+ /**
36
+ * Uninstall CLEO from the current Cursor project.
37
+ *
38
+ * Removes the MCP server registration from .cursor/mcp.json.
39
+ * Does not remove instruction file references (they are harmless if CLEO is not present).
40
+ */
41
+ uninstall(): Promise<void>;
42
+ /**
43
+ * Check whether CLEO is installed in the current environment.
44
+ *
45
+ * Checks for MCP server registered in .cursor/mcp.json.
46
+ */
47
+ isInstalled(): Promise<boolean>;
48
+ /**
49
+ * Ensure instruction files contain @-references to CLEO.
50
+ *
51
+ * Updates .cursorrules (legacy) and creates .cursor/rules/cleo.mdc (modern).
52
+ *
53
+ * @param projectDir - Project root directory
54
+ */
55
+ ensureInstructionReferences(projectDir: string): Promise<void>;
56
+ /**
57
+ * Register the CLEO MCP server in .cursor/mcp.json.
58
+ *
59
+ * Cursor stores MCP server configuration in .cursor/mcp.json
60
+ * under the mcpServers key.
61
+ *
62
+ * @returns true if registration was performed or updated
63
+ */
64
+ private registerMcpServer;
65
+ /**
66
+ * Update instruction files with CLEO @-references.
67
+ *
68
+ * Handles both legacy (.cursorrules) and modern (.cursor/rules/cleo.mdc) formats.
69
+ *
70
+ * @returns true if any file was created or modified
71
+ */
72
+ private updateInstructionFiles;
73
+ /**
74
+ * Update legacy .cursorrules file with @-references.
75
+ * Only modifies the file if it already exists (does not create it).
76
+ *
77
+ * @returns true if the file was modified
78
+ */
79
+ private updateLegacyRules;
80
+ /**
81
+ * Create or update .cursor/rules/cleo.mdc with CLEO references.
82
+ *
83
+ * MDC (Markdown Component) format is Cursor's modern rule file format.
84
+ * Each .mdc file in .cursor/rules/ is loaded as a rule set.
85
+ *
86
+ * @returns true if the file was created or modified
87
+ */
88
+ private updateModernRules;
89
+ /**
90
+ * Get list of instruction files that were updated.
91
+ */
92
+ private getUpdatedFileList;
93
+ }
94
+ //# sourceMappingURL=install.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/providers/cursor/install.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAIH,OAAO,KAAK,EAAE,sBAAsB,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAQjG;;;;;;;GAOG;AACH,qBAAa,qBAAsB,YAAW,sBAAsB;IAClE,OAAO,CAAC,mBAAmB,CAAuB;IAElD;;;;;OAKG;IACG,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC;IAgC9D;;;;;OAKG;IACG,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAqBhC;;;;OAIG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAiBrC;;;;;;OAMG;IACG,2BAA2B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE;;;;;;;OAOG;IACH,OAAO,CAAC,iBAAiB;IA6BzB;;;;;;OAMG;IACH,OAAO,CAAC,sBAAsB;IAgB9B;;;;;OAKG;IACH,OAAO,CAAC,iBAAiB;IAmBzB;;;;;;;OAOG;IACH,OAAO,CAAC,iBAAiB;IA2BzB;;OAEG;IACH,OAAO,CAAC,kBAAkB;CAQ3B"}
@@ -0,0 +1,50 @@
1
+ /**
2
+ * Cursor Spawn Provider
3
+ *
4
+ * Cursor is a GUI-based AI code editor and does not support
5
+ * CLI-based subagent spawning. This provider implements
6
+ * the AdapterSpawnProvider interface with appropriate rejections.
7
+ *
8
+ * @task T5240
9
+ */
10
+ import type { AdapterSpawnProvider, SpawnContext, SpawnResult } from '@cleocode/contracts';
11
+ /**
12
+ * Spawn provider for Cursor.
13
+ *
14
+ * Cursor does not support subagent spawning via CLI. The adapter
15
+ * declares supportsSpawn: false in its capabilities. All methods
16
+ * either reject or return empty results.
17
+ */
18
+ export declare class CursorSpawnProvider implements AdapterSpawnProvider {
19
+ /**
20
+ * Check if Cursor supports spawning subagents.
21
+ *
22
+ * @returns false (Cursor does not support CLI spawning)
23
+ */
24
+ canSpawn(): Promise<boolean>;
25
+ /**
26
+ * Attempt to spawn a subagent via Cursor.
27
+ *
28
+ * Always throws because Cursor does not support subagent spawning.
29
+ * Callers should check canSpawn() before calling this method.
30
+ *
31
+ * @param _context - Unused; spawning is not supported
32
+ * @throws Error explaining that Cursor does not support subagent spawning
33
+ */
34
+ spawn(_context: SpawnContext): Promise<SpawnResult>;
35
+ /**
36
+ * List running Cursor subagent processes.
37
+ *
38
+ * @returns Empty array (no processes can be spawned)
39
+ */
40
+ listRunning(): Promise<SpawnResult[]>;
41
+ /**
42
+ * Terminate a Cursor subagent process.
43
+ *
44
+ * No-op because Cursor cannot spawn processes.
45
+ *
46
+ * @param _instanceId - Unused; no processes to terminate
47
+ */
48
+ terminate(_instanceId: string): Promise<void>;
49
+ }
50
+ //# sourceMappingURL=spawn.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spawn.d.ts","sourceRoot":"","sources":["../../../src/providers/cursor/spawn.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,oBAAoB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAE3F;;;;;;GAMG;AACH,qBAAa,mBAAoB,YAAW,oBAAoB;IAC9D;;;;OAIG;IACG,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC;IAIlC;;;;;;;;OAQG;IACG,KAAK,CAAC,QAAQ,EAAE,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC;IAQzD;;;;OAIG;IACG,WAAW,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAI3C;;;;;;OAMG;IACG,SAAS,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAGpD"}
@@ -0,0 +1,67 @@
1
+ /**
2
+ * OpenCode Adapter
3
+ *
4
+ * Main CLEOProviderAdapter implementation for OpenCode AI coding assistant.
5
+ * Provides spawn, hooks, and install capabilities for CLEO integration.
6
+ *
7
+ * @task T5240
8
+ */
9
+ import type { AdapterCapabilities, AdapterHealthStatus, CLEOProviderAdapter } from '@cleocode/contracts';
10
+ import { OpenCodeHookProvider } from './hooks.js';
11
+ import { OpenCodeInstallProvider } from './install.js';
12
+ import { OpenCodeSpawnProvider } from './spawn.js';
13
+ /**
14
+ * CLEO provider adapter for OpenCode AI coding assistant.
15
+ *
16
+ * Bridges CLEO's adapter system with OpenCode's native capabilities:
17
+ * - Hooks: Maps OpenCode events (session.start, tool.complete, etc.) to CAAMP events
18
+ * - Spawn: Launches subagent processes via the `opencode` CLI
19
+ * - Install: Registers MCP server in .opencode/config.json and ensures AGENTS.md references
20
+ */
21
+ export declare class OpenCodeAdapter implements CLEOProviderAdapter {
22
+ readonly id = "opencode";
23
+ readonly name = "OpenCode";
24
+ readonly version = "1.0.0";
25
+ capabilities: AdapterCapabilities;
26
+ hooks: OpenCodeHookProvider;
27
+ spawn: OpenCodeSpawnProvider;
28
+ install: OpenCodeInstallProvider;
29
+ private projectDir;
30
+ private initialized;
31
+ constructor();
32
+ /**
33
+ * Initialize the adapter for a given project directory.
34
+ *
35
+ * Validates the environment by checking for the OpenCode CLI
36
+ * and OpenCode configuration directory.
37
+ *
38
+ * @param projectDir - Root directory of the project
39
+ */
40
+ initialize(projectDir: string): Promise<void>;
41
+ /**
42
+ * Dispose the adapter and clean up resources.
43
+ *
44
+ * Unregisters hooks and releases any tracked state.
45
+ */
46
+ dispose(): Promise<void>;
47
+ /**
48
+ * Run a health check to verify OpenCode is accessible.
49
+ *
50
+ * Checks:
51
+ * 1. Adapter has been initialized
52
+ * 2. OpenCode CLI is available in PATH
53
+ * 3. .opencode/ configuration directory exists in the project
54
+ *
55
+ * @returns Health status with details about each check
56
+ */
57
+ healthCheck(): Promise<AdapterHealthStatus>;
58
+ /**
59
+ * Check whether the adapter has been initialized.
60
+ */
61
+ isInitialized(): boolean;
62
+ /**
63
+ * Get the project directory this adapter was initialized with.
64
+ */
65
+ getProjectDir(): string | null;
66
+ }
67
+ //# sourceMappingURL=adapter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,OAAO,KAAK,EACV,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAInD;;;;;;;GAOG;AACH,qBAAa,eAAgB,YAAW,mBAAmB;IACzD,QAAQ,CAAC,EAAE,cAAc;IACzB,QAAQ,CAAC,IAAI,cAAc;IAC3B,QAAQ,CAAC,OAAO,WAAW;IAE3B,YAAY,EAAE,mBAAmB,CAoB/B;IAEF,KAAK,EAAE,oBAAoB,CAAC;IAC5B,KAAK,EAAE,qBAAqB,CAAC;IAC7B,OAAO,EAAE,uBAAuB,CAAC;IAEjC,OAAO,CAAC,UAAU,CAAuB;IACzC,OAAO,CAAC,WAAW,CAAS;;IAQ5B;;;;;;;OAOG;IACG,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnD;;;;OAIG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ9B;;;;;;;;;OASG;IACG,WAAW,IAAI,OAAO,CAAC,mBAAmB,CAAC;IA2CjD;;OAEG;IACH,aAAa,IAAI,OAAO;IAIxB;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,IAAI;CAG/B"}
@@ -0,0 +1,66 @@
1
+ /**
2
+ * OpenCode Hook Provider
3
+ *
4
+ * Maps OpenCode's native hook events to CAAMP hook events.
5
+ * OpenCode supports 6 of 8 CAAMP events through its agent/hook system.
6
+ *
7
+ * OpenCode event mapping:
8
+ * - session.start -> onSessionStart
9
+ * - session.end -> onSessionEnd
10
+ * - tool.start -> onToolStart
11
+ * - tool.complete -> onToolComplete
12
+ * - error -> onError
13
+ * - prompt.submit -> onPromptSubmit
14
+ *
15
+ * @task T5240
16
+ */
17
+ import type { AdapterHookProvider } from '@cleocode/contracts';
18
+ /**
19
+ * Hook provider for OpenCode.
20
+ *
21
+ * OpenCode registers hooks via its configuration system at
22
+ * .opencode/config.json. Hook handlers are defined as shell commands
23
+ * or script paths that execute when the corresponding event fires.
24
+ *
25
+ * Since hooks are registered through the config system (managed by
26
+ * the install provider), registerNativeHooks and unregisterNativeHooks
27
+ * track registration state without performing filesystem operations.
28
+ */
29
+ export declare class OpenCodeHookProvider implements AdapterHookProvider {
30
+ private registered;
31
+ /**
32
+ * Map an OpenCode native event name to a CAAMP hook event name.
33
+ *
34
+ * @param providerEvent - OpenCode event name (e.g. "session.start", "tool.complete")
35
+ * @returns CAAMP event name or null if unmapped
36
+ */
37
+ mapProviderEvent(providerEvent: string): string | null;
38
+ /**
39
+ * Register native hooks for a project.
40
+ *
41
+ * For OpenCode, hooks are registered via the config system
42
+ * (.opencode/config.json), which is handled by the install provider.
43
+ * This method marks hooks as registered without performing
44
+ * filesystem operations.
45
+ *
46
+ * @param _projectDir - Project directory (unused; config manages registration)
47
+ */
48
+ registerNativeHooks(_projectDir: string): Promise<void>;
49
+ /**
50
+ * Unregister native hooks.
51
+ *
52
+ * For OpenCode, this is a no-op since hooks are managed through
53
+ * the config system. Unregistration happens via the install
54
+ * provider's uninstall method.
55
+ */
56
+ unregisterNativeHooks(): Promise<void>;
57
+ /**
58
+ * Check whether hooks have been registered via registerNativeHooks.
59
+ */
60
+ isRegistered(): boolean;
61
+ /**
62
+ * Get the full event mapping for introspection/debugging.
63
+ */
64
+ getEventMap(): Readonly<Record<string, string>>;
65
+ }
66
+ //# sourceMappingURL=hooks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAiB/D;;;;;;;;;;GAUG;AACH,qBAAa,oBAAqB,YAAW,mBAAmB;IAC9D,OAAO,CAAC,UAAU,CAAS;IAE3B;;;;;OAKG;IACH,gBAAgB,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAItD;;;;;;;;;OASG;IACG,mBAAmB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7D;;;;;;OAMG;IACG,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5C;;OAEG;IACH,YAAY,IAAI,OAAO;IAIvB;;OAEG;IACH,WAAW,IAAI,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAGhD"}
@@ -0,0 +1,20 @@
1
+ /**
2
+ * OpenCode provider adapter.
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
+ export declare function createAdapter(): OpenCodeAdapter;
20
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
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;;;GAGG;AACH,wBAAgB,aAAa,IAAI,eAAe,CAE/C"}
@@ -0,0 +1,65 @@
1
+ /**
2
+ * OpenCode Install Provider
3
+ *
4
+ * Handles CLEO installation into OpenCode environments:
5
+ * - Registers CLEO MCP server in .opencode/config.json
6
+ * - Ensures AGENTS.md has CLEO @-references
7
+ *
8
+ * @task T5240
9
+ */
10
+ import type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';
11
+ /**
12
+ * Install provider for OpenCode.
13
+ *
14
+ * Manages CLEO's integration with OpenCode by:
15
+ * 1. Registering the CLEO MCP server in .opencode/config.json
16
+ * 2. Ensuring AGENTS.md contains @-references to CLEO instruction files
17
+ */
18
+ export declare class OpenCodeInstallProvider implements AdapterInstallProvider {
19
+ private installedProjectDir;
20
+ /**
21
+ * Install CLEO into an OpenCode project.
22
+ *
23
+ * @param options - Installation options including project directory and MCP server path
24
+ * @returns Result describing what was installed
25
+ */
26
+ install(options: InstallOptions): Promise<InstallResult>;
27
+ /**
28
+ * Uninstall CLEO from the current OpenCode project.
29
+ *
30
+ * Removes the MCP server registration from .opencode/config.json.
31
+ * Does not remove AGENTS.md references (they are harmless if CLEO is not present).
32
+ */
33
+ uninstall(): Promise<void>;
34
+ /**
35
+ * Check whether CLEO is installed in the current environment.
36
+ *
37
+ * Checks for MCP server registered in .opencode/config.json.
38
+ * Returns true if the CLEO MCP server entry is found.
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
+ * Register the CLEO MCP server in .opencode/config.json.
51
+ *
52
+ * OpenCode stores its MCP server configuration in .opencode/config.json
53
+ * under the mcpServers key.
54
+ *
55
+ * @returns true if registration was performed or updated
56
+ */
57
+ private registerMcpServer;
58
+ /**
59
+ * Update AGENTS.md with CLEO @-references.
60
+ *
61
+ * @returns true if the file was created or modified
62
+ */
63
+ private updateInstructionFile;
64
+ }
65
+ //# sourceMappingURL=install.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/install.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAIH,OAAO,KAAK,EAAE,sBAAsB,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAQjG;;;;;;GAMG;AACH,qBAAa,uBAAwB,YAAW,sBAAsB;IACpE,OAAO,CAAC,mBAAmB,CAAuB;IAElD;;;;;OAKG;IACG,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC;IAgC9D;;;;;OAKG;IACG,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAqBhC;;;;;OAKG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAkBrC;;;;;;OAMG;IACG,2BAA2B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE;;;;;;;OAOG;IACH,OAAO,CAAC,iBAAiB;IA6BzB;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;CA8B9B"}
@@ -0,0 +1,72 @@
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
+ * @param description - Agent description for frontmatter
21
+ * @param instructions - Markdown instructions body
22
+ * @returns Complete agent definition markdown
23
+ */
24
+ export declare function buildOpenCodeAgentMarkdown(description: string, instructions: string): string;
25
+ /**
26
+ * Spawn provider for OpenCode.
27
+ *
28
+ * Spawns detached OpenCode CLI processes for subagent execution.
29
+ * Each spawn ensures a CLEO subagent definition exists, then runs
30
+ * `opencode run --format json --agent <name> --title <title> <prompt>`
31
+ * as a detached, unref'd child process.
32
+ */
33
+ export declare class OpenCodeSpawnProvider implements AdapterSpawnProvider {
34
+ /** Map of instance IDs to tracked process info. */
35
+ private processMap;
36
+ /**
37
+ * Check if the OpenCode CLI is available in PATH.
38
+ *
39
+ * @returns true if `opencode` is found via `which`
40
+ */
41
+ canSpawn(): Promise<boolean>;
42
+ /**
43
+ * Spawn a subagent via OpenCode CLI.
44
+ *
45
+ * Ensures the CLEO subagent definition exists in the project's
46
+ * .opencode/agent/ directory, then spawns a detached OpenCode
47
+ * process. The process runs independently of the parent.
48
+ *
49
+ * @param context - Spawn context with taskId, prompt, and options
50
+ * @returns Spawn result with instance ID and status
51
+ */
52
+ spawn(context: SpawnContext): Promise<SpawnResult>;
53
+ /**
54
+ * List currently running OpenCode subagent processes.
55
+ *
56
+ * Checks each tracked process via kill(pid, 0) to verify it is still alive.
57
+ * Dead processes are automatically cleaned from the tracking map.
58
+ *
59
+ * @returns Array of spawn results for running processes
60
+ */
61
+ listRunning(): Promise<SpawnResult[]>;
62
+ /**
63
+ * Terminate a running spawn by instance ID.
64
+ *
65
+ * Sends SIGTERM to the tracked process. If the process is not found
66
+ * or has already exited, this is a no-op.
67
+ *
68
+ * @param instanceId - ID of the spawn instance to terminate
69
+ */
70
+ terminate(instanceId: string): Promise<void>;
71
+ }
72
+ //# sourceMappingURL=spawn.d.ts.map
@@ -0,0 +1 @@
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;;;;;;;;;GASG;AACH,wBAAgB,0BAA0B,CAAC,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,MAAM,CAY5F;AA0CD;;;;;;;GAOG;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"}
@@ -0,0 +1,36 @@
1
+ /**
2
+ * Adapter registry — discovers and provides access to provider manifests.
3
+ *
4
+ * Scans the providers/ directory for manifest.json files and returns
5
+ * the discovered adapter manifests for use by AdapterManager.
6
+ *
7
+ * @task T5240
8
+ */
9
+ /** Minimal manifest shape for provider discovery. */
10
+ export interface AdapterManifest {
11
+ id: string;
12
+ name: string;
13
+ version: string;
14
+ description: string;
15
+ provider: string;
16
+ entryPoint: string;
17
+ capabilities: Record<string, unknown>;
18
+ detectionPatterns: Array<{
19
+ type: string;
20
+ pattern: string;
21
+ description: string;
22
+ }>;
23
+ }
24
+ /**
25
+ * Get the manifests for all bundled provider adapters.
26
+ *
27
+ * @returns Array of adapter manifests
28
+ */
29
+ export declare function getProviderManifests(): AdapterManifest[];
30
+ /**
31
+ * Discover all available provider adapters.
32
+ *
33
+ * Returns a map of provider ID to adapter factory function.
34
+ */
35
+ export declare function discoverProviders(): Promise<Map<string, () => Promise<unknown>>>;
36
+ //# sourceMappingURL=registry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../src/registry.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,qDAAqD;AACrD,MAAM,WAAW,eAAe;IAC9B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACtC,iBAAiB,EAAE,KAAK,CAAC;QACvB,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;QAChB,WAAW,EAAE,MAAM,CAAC;KACrB,CAAC,CAAC;CACJ;AAKD;;;;GAIG;AACH,wBAAgB,oBAAoB,IAAI,eAAe,EAAE,CAexD;AAED;;;;GAIG;AACH,wBAAsB,iBAAiB,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAmBtF"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cleocode/adapters",
3
- "version": "2026.3.42",
3
+ "version": "2026.3.43",
4
4
  "description": "Unified provider adapters for CLEO (Claude Code, OpenCode, Cursor)",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",
@@ -12,7 +12,7 @@
12
12
  }
13
13
  },
14
14
  "dependencies": {
15
- "@cleocode/contracts": "2026.3.42"
15
+ "@cleocode/contracts": "2026.3.43"
16
16
  },
17
17
  "license": "MIT",
18
18
  "engines": {