@cleocode/adapters 2026.4.10 → 2026.4.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/package.json +3 -3
  2. package/src/__tests__/claude-code-adapter.test.ts +1 -3
  3. package/src/__tests__/cursor-adapter.test.ts +1 -3
  4. package/src/__tests__/opencode-adapter.test.ts +1 -3
  5. package/src/providers/claude-code/__tests__/adapter.test.ts +0 -12
  6. package/src/providers/claude-code/adapter.ts +0 -1
  7. package/src/providers/claude-code/install.ts +0 -1
  8. package/src/providers/codex/adapter.ts +0 -1
  9. package/src/providers/codex/install.ts +0 -1
  10. package/src/providers/cursor/__tests__/adapter.test.ts +0 -12
  11. package/src/providers/cursor/adapter.ts +0 -1
  12. package/src/providers/cursor/install.ts +0 -1
  13. package/src/providers/gemini-cli/adapter.ts +0 -1
  14. package/src/providers/gemini-cli/install.ts +0 -1
  15. package/src/providers/kimi/adapter.ts +0 -1
  16. package/src/providers/kimi/install.ts +0 -1
  17. package/src/providers/opencode/__tests__/adapter.test.ts +0 -12
  18. package/src/providers/opencode/adapter.ts +0 -1
  19. package/src/providers/opencode/install.ts +0 -1
  20. package/dist/index.d.ts +0 -23
  21. package/dist/index.d.ts.map +0 -1
  22. package/dist/index.js +0 -3258
  23. package/dist/index.js.map +0 -7
  24. package/dist/providers/claude-code/adapter.d.ts +0 -95
  25. package/dist/providers/claude-code/adapter.d.ts.map +0 -1
  26. package/dist/providers/claude-code/context-monitor.d.ts +0 -35
  27. package/dist/providers/claude-code/context-monitor.d.ts.map +0 -1
  28. package/dist/providers/claude-code/hooks.d.ts +0 -146
  29. package/dist/providers/claude-code/hooks.d.ts.map +0 -1
  30. package/dist/providers/claude-code/index.d.ts +0 -39
  31. package/dist/providers/claude-code/index.d.ts.map +0 -1
  32. package/dist/providers/claude-code/install.d.ts +0 -67
  33. package/dist/providers/claude-code/install.d.ts.map +0 -1
  34. package/dist/providers/claude-code/paths.d.ts +0 -32
  35. package/dist/providers/claude-code/paths.d.ts.map +0 -1
  36. package/dist/providers/claude-code/spawn.d.ts +0 -67
  37. package/dist/providers/claude-code/spawn.d.ts.map +0 -1
  38. package/dist/providers/claude-code/statusline.d.ts +0 -68
  39. package/dist/providers/claude-code/statusline.d.ts.map +0 -1
  40. package/dist/providers/claude-code/task-sync.d.ts +0 -32
  41. package/dist/providers/claude-code/task-sync.d.ts.map +0 -1
  42. package/dist/providers/claude-code/transport.d.ts +0 -25
  43. package/dist/providers/claude-code/transport.d.ts.map +0 -1
  44. package/dist/providers/codex/adapter.d.ts +0 -83
  45. package/dist/providers/codex/adapter.d.ts.map +0 -1
  46. package/dist/providers/codex/hooks.d.ts +0 -91
  47. package/dist/providers/codex/hooks.d.ts.map +0 -1
  48. package/dist/providers/codex/index.d.ts +0 -37
  49. package/dist/providers/codex/index.d.ts.map +0 -1
  50. package/dist/providers/codex/install.d.ts +0 -65
  51. package/dist/providers/codex/install.d.ts.map +0 -1
  52. package/dist/providers/cursor/adapter.d.ts +0 -76
  53. package/dist/providers/cursor/adapter.d.ts.map +0 -1
  54. package/dist/providers/cursor/hooks.d.ts +0 -140
  55. package/dist/providers/cursor/hooks.d.ts.map +0 -1
  56. package/dist/providers/cursor/index.d.ts +0 -34
  57. package/dist/providers/cursor/index.d.ts.map +0 -1
  58. package/dist/providers/cursor/install.d.ts +0 -87
  59. package/dist/providers/cursor/install.d.ts.map +0 -1
  60. package/dist/providers/cursor/spawn.d.ts +0 -50
  61. package/dist/providers/cursor/spawn.d.ts.map +0 -1
  62. package/dist/providers/gemini-cli/adapter.d.ts +0 -84
  63. package/dist/providers/gemini-cli/adapter.d.ts.map +0 -1
  64. package/dist/providers/gemini-cli/hooks.d.ts +0 -99
  65. package/dist/providers/gemini-cli/hooks.d.ts.map +0 -1
  66. package/dist/providers/gemini-cli/index.d.ts +0 -37
  67. package/dist/providers/gemini-cli/index.d.ts.map +0 -1
  68. package/dist/providers/gemini-cli/install.d.ts +0 -65
  69. package/dist/providers/gemini-cli/install.d.ts.map +0 -1
  70. package/dist/providers/kimi/adapter.d.ts +0 -85
  71. package/dist/providers/kimi/adapter.d.ts.map +0 -1
  72. package/dist/providers/kimi/hooks.d.ts +0 -70
  73. package/dist/providers/kimi/hooks.d.ts.map +0 -1
  74. package/dist/providers/kimi/index.d.ts +0 -37
  75. package/dist/providers/kimi/index.d.ts.map +0 -1
  76. package/dist/providers/kimi/install.d.ts +0 -65
  77. package/dist/providers/kimi/install.d.ts.map +0 -1
  78. package/dist/providers/opencode/adapter.d.ts +0 -83
  79. package/dist/providers/opencode/adapter.d.ts.map +0 -1
  80. package/dist/providers/opencode/hooks.d.ts +0 -136
  81. package/dist/providers/opencode/hooks.d.ts.map +0 -1
  82. package/dist/providers/opencode/index.d.ts +0 -35
  83. package/dist/providers/opencode/index.d.ts.map +0 -1
  84. package/dist/providers/opencode/install.d.ts +0 -56
  85. package/dist/providers/opencode/install.d.ts.map +0 -1
  86. package/dist/providers/opencode/spawn.d.ts +0 -94
  87. package/dist/providers/opencode/spawn.d.ts.map +0 -1
  88. package/dist/providers/shared/transcript-reader.d.ts +0 -58
  89. package/dist/providers/shared/transcript-reader.d.ts.map +0 -1
  90. package/dist/registry.d.ts +0 -88
  91. package/dist/registry.d.ts.map +0 -1
@@ -1,83 +0,0 @@
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: Ensures AGENTS.md references for CLEO instruction files
20
- *
21
- * @remarks
22
- * OpenCode is the second-most feature-complete adapter after Claude Code,
23
- * supporting 10 canonical events through its JavaScript plugin system,
24
- * subagent spawning via the `opencode run` CLI command, and instruction
25
- * file management via AGENTS.md. It uniquely supports PreModel via the
26
- * `chat.params` event, which allows pre-inference parameter injection.
27
- */
28
- export declare class OpenCodeAdapter implements CLEOProviderAdapter {
29
- /** Unique provider identifier. */
30
- readonly id = "opencode";
31
- /** Human-readable provider name. */
32
- readonly name = "OpenCode";
33
- /** Adapter version string. */
34
- readonly version = "1.0.0";
35
- /** Declared capabilities for this provider. */
36
- capabilities: AdapterCapabilities;
37
- /** Hook provider for CAAMP event mapping via OpenCode's plugin system. */
38
- hooks: OpenCodeHookProvider;
39
- /** Spawn provider for launching subagent processes via `opencode run`. */
40
- spawn: OpenCodeSpawnProvider;
41
- /** Install provider for managing AGENTS.md instruction files. */
42
- install: OpenCodeInstallProvider;
43
- /** Project directory this adapter was initialized with, or null. */
44
- private projectDir;
45
- /** Whether {@link initialize} has been called. */
46
- private initialized;
47
- constructor();
48
- /**
49
- * Initialize the adapter for a given project directory.
50
- *
51
- * Validates the environment by checking for the OpenCode CLI
52
- * and OpenCode configuration directory.
53
- *
54
- * @param projectDir - Root directory of the project
55
- */
56
- initialize(projectDir: string): Promise<void>;
57
- /**
58
- * Dispose the adapter and clean up resources.
59
- *
60
- * Unregisters hooks and releases any tracked state.
61
- */
62
- dispose(): Promise<void>;
63
- /**
64
- * Run a health check to verify OpenCode is accessible.
65
- *
66
- * Checks:
67
- * 1. Adapter has been initialized
68
- * 2. OpenCode CLI is available in PATH
69
- * 3. .opencode/ configuration directory exists in the project
70
- *
71
- * @returns Health status with details about each check
72
- */
73
- healthCheck(): Promise<AdapterHealthStatus>;
74
- /**
75
- * Check whether the adapter has been initialized.
76
- */
77
- isInitialized(): boolean;
78
- /**
79
- * Get the project directory this adapter was initialized with.
80
- */
81
- getProjectDir(): string | null;
82
- }
83
- //# sourceMappingURL=adapter.d.ts.map
@@ -1 +0,0 @@
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;;;;;;;;;;;;;;GAcG;AACH,qBAAa,eAAgB,YAAW,mBAAmB;IACzD,kCAAkC;IAClC,QAAQ,CAAC,EAAE,cAAc;IACzB,oCAAoC;IACpC,QAAQ,CAAC,IAAI,cAAc;IAC3B,8BAA8B;IAC9B,QAAQ,CAAC,OAAO,WAAW;IAE3B,+CAA+C;IAC/C,YAAY,EAAE,mBAAmB,CA2B/B;IAEF,0EAA0E;IAC1E,KAAK,EAAE,oBAAoB,CAAC;IAC5B,0EAA0E;IAC1E,KAAK,EAAE,qBAAqB,CAAC;IAC7B,iEAAiE;IACjE,OAAO,EAAE,uBAAuB,CAAC;IAEjC,oEAAoE;IACpE,OAAO,CAAC,UAAU,CAAuB;IACzC,kDAAkD;IAClD,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"}
@@ -1,136 +0,0 @@
1
- /**
2
- * OpenCode Hook Provider
3
- *
4
- * Maps OpenCode's native hook events to CAAMP canonical hook events.
5
- * OpenCode supports 10 of 16 canonical events through its plugin system.
6
- *
7
- * Event translation uses CAAMP normalizer APIs:
8
- * - `toCanonical(nativeName, 'opencode')` for runtime event name resolution
9
- * - `getSupportedEvents('opencode')` to enumerate supported canonical events
10
- * - `getProviderHookProfile('opencode')` for the full provider profile
11
- *
12
- * OpenCode uses a JavaScript plugin system with event-prefixed names
13
- * (e.g. `event:session.created`) for some hooks and bare names for others.
14
- * The map is derived from `getProviderHookProfile('opencode').mappings` in
15
- * CAAMP 1.9.1. PostToolUseFailure, SubagentStart, SubagentStop, Notification,
16
- * and ConfigChange are not supported by OpenCode.
17
- *
18
- * @task T164
19
- * @epic T134
20
- */
21
- import type { AdapterHookProvider } from '@cleocode/contracts';
22
- /**
23
- * Hook provider for OpenCode.
24
- *
25
- * OpenCode registers hooks via its JavaScript plugin system at
26
- * `.opencode/plugins/`. Supported handler type: plugin (JavaScript).
27
- *
28
- * Event mapping is based on `getProviderHookProfile('opencode')` from
29
- * CAAMP 1.9.1. Async accessors (`getSupportedCanonicalEvents`,
30
- * `getProviderProfile`) call CAAMP directly when available.
31
- *
32
- * Since hooks are registered through the plugin system (managed by the install
33
- * provider), `registerNativeHooks` and `unregisterNativeHooks` track registration
34
- * state without performing filesystem operations.
35
- *
36
- * @remarks
37
- * OpenCode uses dot-delimited and `event:`-prefixed event names
38
- * (e.g. `event:session.created`, `tool.execute.before`) which differ
39
- * significantly from the PascalCase CAAMP canonical names. The static
40
- * event map covers all 10 supported events. Async CAAMP accessors
41
- * (`getSupportedCanonicalEvents`, `getProviderProfile`, `toNativeEvent`)
42
- * call the normalizer directly when available and fall back to the static map.
43
- *
44
- * @task T164
45
- * @epic T134
46
- */
47
- export declare class OpenCodeHookProvider implements AdapterHookProvider {
48
- /** Whether hooks have been registered for the current session. */
49
- private registered;
50
- /**
51
- * Map an OpenCode native event name to a CAAMP canonical hook event name.
52
- *
53
- * Looks up the native event name in the map derived from
54
- * `getProviderHookProfile('opencode').mappings` (CAAMP 1.9.1).
55
- * Returns null for unsupported events (PostToolUseFailure, SubagentStart,
56
- * SubagentStop, Notification, ConfigChange).
57
- *
58
- * @param providerEvent - OpenCode native event (e.g. "event:session.created", "tool.execute.before")
59
- * @returns CAAMP canonical event name, or null if unmapped
60
- * @task T164
61
- */
62
- mapProviderEvent(providerEvent: string): string | null;
63
- /**
64
- * Register native hooks for a project.
65
- *
66
- * For OpenCode, hooks are registered via the plugin system
67
- * (`.opencode/plugins/`), managed by the install provider.
68
- * This method marks hooks as registered without performing filesystem operations.
69
- *
70
- * Iterating supported events is handled at install time using
71
- * `getSupportedCanonicalEvents()` to enumerate all 10 supported hooks.
72
- *
73
- * @param _projectDir - Project directory (unused; config manages registration)
74
- * @task T164
75
- */
76
- registerNativeHooks(_projectDir: string): Promise<void>;
77
- /**
78
- * Unregister native hooks.
79
- *
80
- * For OpenCode, this is a no-op since hooks are managed through the plugin
81
- * system. Unregistration happens via the install provider's uninstall method.
82
- *
83
- * @task T164
84
- */
85
- unregisterNativeHooks(): Promise<void>;
86
- /**
87
- * Check whether hooks have been registered via `registerNativeHooks`.
88
- */
89
- isRegistered(): boolean;
90
- /**
91
- * Get the native→canonical event mapping for introspection and debugging.
92
- *
93
- * Returns the map derived from `getProviderHookProfile('opencode').mappings`
94
- * (CAAMP 1.9.1). Use `getSupportedCanonicalEvents()` to enumerate canonical
95
- * names via live CAAMP APIs.
96
- *
97
- * @returns Immutable record of native event name → canonical event name
98
- */
99
- getEventMap(): Readonly<Record<string, string>>;
100
- /**
101
- * Enumerate supported canonical events via CAAMP's `getSupportedEvents()`.
102
- *
103
- * Calls `getSupportedEvents('opencode')` from the CAAMP normalizer to get the
104
- * authoritative list. OpenCode supports 10 of 16 canonical events via its
105
- * plugin system. Falls back to the values of the static event map when
106
- * CAAMP is unavailable at runtime.
107
- *
108
- * @returns Array of CAAMP canonical event names supported by OpenCode
109
- * @task T164
110
- */
111
- getSupportedCanonicalEvents(): Promise<string[]>;
112
- /**
113
- * Retrieve the full provider hook profile from CAAMP.
114
- *
115
- * Calls `getProviderHookProfile('opencode')` from the CAAMP normalizer to
116
- * get the complete profile: hook system type (`plugin`), config path
117
- * (`.opencode/plugins/`), handler types, and all event mappings.
118
- * Returns null when CAAMP is unavailable at runtime.
119
- *
120
- * @returns Provider hook profile or null if CAAMP is unavailable
121
- * @task T164
122
- */
123
- getProviderProfile(): Promise<unknown | null>;
124
- /**
125
- * Translate a CAAMP canonical event to its OpenCode native name via CAAMP.
126
- *
127
- * Calls `toNative(canonical, 'opencode')` from the CAAMP normalizer.
128
- * Returns null for unsupported events or when CAAMP is unavailable.
129
- *
130
- * @param canonical - CAAMP canonical event name (e.g. "PreToolUse")
131
- * @returns OpenCode native event name or null
132
- * @task T164
133
- */
134
- toNativeEvent(canonical: string): Promise<string | null>;
135
- }
136
- //# sourceMappingURL=hooks.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAuC/D;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,qBAAa,oBAAqB,YAAW,mBAAmB;IAC9D,kEAAkE;IAClE,OAAO,CAAC,UAAU,CAAS;IAE3B;;;;;;;;;;;OAWG;IACH,gBAAgB,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAItD;;;;;;;;;;;;OAYG;IACG,mBAAmB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7D;;;;;;;OAOG;IACG,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5C;;OAEG;IACH,YAAY,IAAI,OAAO;IAIvB;;;;;;;;OAQG;IACH,WAAW,IAAI,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAI/C;;;;;;;;;;OAUG;IACG,2BAA2B,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAStD;;;;;;;;;;OAUG;IACG,kBAAkB,IAAI,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;IASnD;;;;;;;;;OASG;IACG,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;CAU/D"}
@@ -1,35 +0,0 @@
1
- /**
2
- * @packageDocumentation
3
- *
4
- * CLEO provider adapter for OpenCode AI coding assistant.
5
- * Default export is the adapter class for dynamic loading by AdapterManager.
6
- *
7
- * @task T5240
8
- */
9
- import { OpenCodeAdapter } from './adapter.js';
10
- export { OpenCodeAdapter } from './adapter.js';
11
- export { OpenCodeHookProvider } from './hooks.js';
12
- export { OpenCodeInstallProvider } from './install.js';
13
- export { OpenCodeSpawnProvider } from './spawn.js';
14
- export default OpenCodeAdapter;
15
- /**
16
- * Factory function for creating adapter instances.
17
- * Used by AdapterManager's dynamic import fallback.
18
- *
19
- * @remarks
20
- * This is the primary entry point for dynamic adapter loading.
21
- * AdapterManager calls this function when it resolves the opencode
22
- * provider via its import-based discovery mechanism.
23
- *
24
- * @returns A new {@link OpenCodeAdapter} instance ready for initialization
25
- *
26
- * @example
27
- * ```typescript
28
- * import { createAdapter } from '@cleocode/adapters/providers/opencode';
29
- *
30
- * const adapter = createAdapter();
31
- * await adapter.initialize('/path/to/project');
32
- * ```
33
- */
34
- export declare function createAdapter(): OpenCodeAdapter;
35
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE/C,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAEnD,eAAe,eAAe,CAAC;AAE/B;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,aAAa,IAAI,eAAe,CAE/C"}
@@ -1,56 +0,0 @@
1
- /**
2
- * OpenCode Install Provider
3
- *
4
- * Handles CLEO installation into OpenCode environments:
5
- * - Ensures AGENTS.md has CLEO @-references
6
- *
7
- * @task T5240
8
- */
9
- import type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';
10
- /**
11
- * Install provider for OpenCode.
12
- *
13
- * Manages CLEO's integration with OpenCode by:
14
- * 1. Ensuring AGENTS.md contains @-references to CLEO instruction files
15
- *
16
- * @remarks
17
- * Installation is idempotent -- running install multiple times on the same
18
- * project produces the same result. Only AGENTS.md is managed; OpenCode's
19
- * plugin system is handled separately by the hook provider.
20
- */
21
- export declare class OpenCodeInstallProvider implements AdapterInstallProvider {
22
- /**
23
- * Install CLEO into an OpenCode project.
24
- *
25
- * @param options - Installation options including project directory
26
- * @returns Result describing what was installed
27
- */
28
- install(options: InstallOptions): Promise<InstallResult>;
29
- /**
30
- * Uninstall CLEO from the current OpenCode project.
31
- *
32
- * Does not remove AGENTS.md references (they are harmless if CLEO is not present).
33
- */
34
- uninstall(): Promise<void>;
35
- /**
36
- * Check whether CLEO is installed in the current environment.
37
- *
38
- * Checks for CLEO references in AGENTS.md.
39
- */
40
- isInstalled(): Promise<boolean>;
41
- /**
42
- * Ensure AGENTS.md contains @-references to CLEO instruction files.
43
- *
44
- * Creates AGENTS.md if it does not exist. Appends any missing references.
45
- *
46
- * @param projectDir - Project root directory
47
- */
48
- ensureInstructionReferences(projectDir: string): Promise<void>;
49
- /**
50
- * Update AGENTS.md with CLEO @-references.
51
- *
52
- * @returns true if the file was created or modified
53
- */
54
- private updateInstructionFile;
55
- }
56
- //# sourceMappingURL=install.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/install.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,KAAK,EAAE,sBAAsB,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAKjG;;;;;;;;;;GAUG;AACH,qBAAa,uBAAwB,YAAW,sBAAsB;IACpE;;;;;OAKG;IACG,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC;IAqB9D;;;;OAIG;IACG,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAEhC;;;;OAIG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAgBrC;;;;;;OAMG;IACG,2BAA2B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;CA8B9B"}
@@ -1,94 +0,0 @@
1
- /**
2
- * OpenCode Spawn Provider
3
- *
4
- * Implements AdapterSpawnProvider for OpenCode CLI.
5
- * Migrated from src/core/spawn/adapters/opencode-adapter.ts
6
- *
7
- * Uses `opencode run --agent ... --format json` to spawn subagent
8
- * processes. Processes run detached and are tracked by PID for
9
- * listing and termination.
10
- *
11
- * @task T5240
12
- */
13
- import type { AdapterSpawnProvider, SpawnContext, SpawnResult } from '@cleocode/contracts';
14
- /**
15
- * Build the markdown content for an OpenCode agent definition file.
16
- *
17
- * OpenCode agents are defined as markdown files with YAML frontmatter
18
- * in the .opencode/agent/ directory.
19
- *
20
- * @remarks
21
- * The generated markdown uses YAML frontmatter with `mode: subagent`
22
- * and `hidden: true` so the agent does not appear in OpenCode's
23
- * interactive agent selection menu.
24
- *
25
- * @param description - Agent description for frontmatter
26
- * @param instructions - Markdown instructions body
27
- * @returns Complete agent definition markdown with YAML frontmatter
28
- *
29
- * @example
30
- * ```typescript
31
- * import { buildOpenCodeAgentMarkdown } from '@cleocode/adapters/providers/opencode/spawn';
32
- *
33
- * const md = buildOpenCodeAgentMarkdown(
34
- * 'CLEO task executor',
35
- * '# Subagent\n\nExecute the delegated task.',
36
- * );
37
- * ```
38
- */
39
- export declare function buildOpenCodeAgentMarkdown(description: string, instructions: string): string;
40
- /**
41
- * Spawn provider for OpenCode.
42
- *
43
- * Spawns detached OpenCode CLI processes for subagent execution.
44
- * Each spawn ensures a CLEO subagent definition exists, then runs
45
- * `opencode run --format json --agent <name> --title <title> <prompt>`
46
- * as a detached, unref'd child process.
47
- *
48
- * @remarks
49
- * Before spawning, the provider ensures a `cleo-subagent` agent definition
50
- * exists in `.opencode/agent/`. If the definition cannot be created, it
51
- * falls back to the built-in `general` agent. Processes are tracked by
52
- * instance ID in an in-memory map and verified via `kill(pid, 0)` liveness
53
- * checks.
54
- */
55
- export declare class OpenCodeSpawnProvider implements AdapterSpawnProvider {
56
- /** Map of instance IDs to tracked process info. */
57
- private processMap;
58
- /**
59
- * Check if the OpenCode CLI is available in PATH.
60
- *
61
- * @returns true if `opencode` is found via `which`
62
- */
63
- canSpawn(): Promise<boolean>;
64
- /**
65
- * Spawn a subagent via OpenCode CLI.
66
- *
67
- * Ensures the CLEO subagent definition exists in the project's
68
- * .opencode/agent/ directory, then spawns a detached OpenCode
69
- * process. The process runs independently of the parent.
70
- *
71
- * @param context - Spawn context with taskId, prompt, and options
72
- * @returns Spawn result with instance ID and status
73
- */
74
- spawn(context: SpawnContext): Promise<SpawnResult>;
75
- /**
76
- * List currently running OpenCode subagent processes.
77
- *
78
- * Checks each tracked process via kill(pid, 0) to verify it is still alive.
79
- * Dead processes are automatically cleaned from the tracking map.
80
- *
81
- * @returns Array of spawn results for running processes
82
- */
83
- listRunning(): Promise<SpawnResult[]>;
84
- /**
85
- * Terminate a running spawn by instance ID.
86
- *
87
- * Sends SIGTERM to the tracked process. If the process is not found
88
- * or has already exited, this is a no-op.
89
- *
90
- * @param instanceId - ID of the spawn instance to terminate
91
- */
92
- terminate(instanceId: string): Promise<void>;
93
- }
94
- //# sourceMappingURL=spawn.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"spawn.d.ts","sourceRoot":"","sources":["../../../src/providers/opencode/spawn.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAMH,OAAO,KAAK,EAAE,oBAAoB,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAiB3F;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,wBAAgB,0BAA0B,CAAC,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,MAAM,CAY5F;AA0CD;;;;;;;;;;;;;;GAcG;AACH,qBAAa,qBAAsB,YAAW,oBAAoB;IAChE,mDAAmD;IACnD,OAAO,CAAC,UAAU,CAAqC;IAEvD;;;;OAIG;IACG,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC;IASlC;;;;;;;;;OASG;IACG,KAAK,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC;IAiExD;;;;;;;OAOG;IACG,WAAW,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAqB3C;;;;;;;OAOG;IACG,SAAS,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAWnD"}
@@ -1,58 +0,0 @@
1
- /**
2
- * Shared transcript-reading utility for provider hook adapters.
3
- *
4
- * Several providers (Gemini CLI, Codex CLI) store session data in a
5
- * flat directory of JSON/JSONL files using the same role/content schema.
6
- * This module centralises the "find most-recent file, parse turns"
7
- * logic to avoid duplicating it in each hook provider.
8
- *
9
- * Usage:
10
- * ```ts
11
- * import { readLatestTranscript } from '../shared/transcript-reader.js';
12
- *
13
- * async getTranscript(_sessionId: string, _projectDir: string) {
14
- * return readLatestTranscript(join(homedir(), '.gemini'));
15
- * }
16
- * ```
17
- *
18
- * @task T161
19
- * @epic T134
20
- */
21
- /**
22
- * Read the most recent JSON or JSONL session file from `providerDir` and
23
- * return its contents as a flat transcript string.
24
- *
25
- * Files are sorted in descending order by filename — this works naturally
26
- * for providers that embed timestamps in filenames. The most recently named
27
- * file is read first.
28
- *
29
- * Returns `null` when:
30
- * - `providerDir` does not exist or cannot be read
31
- * - No JSON/JSONL files are present
32
- * - The most recent file contains no parseable turns
33
- *
34
- * @remarks
35
- * This utility is shared by Gemini CLI and Codex CLI hook providers which
36
- * both store session data in the same flat JSON/JSONL format. Only the
37
- * most recent file is read to keep memory usage bounded.
38
- *
39
- * @param providerDir - Absolute path to the provider's session directory
40
- * (e.g. `~/.gemini` or `~/.codex`).
41
- * @returns A plain-text transcript with lines of the form `role: content`,
42
- * or `null` if no transcript could be extracted.
43
- *
44
- * @example
45
- * ```typescript
46
- * import { readLatestTranscript } from '../shared/transcript-reader.js';
47
- *
48
- * const transcript = await readLatestTranscript('/home/user/.gemini');
49
- * if (transcript) {
50
- * console.log(transcript);
51
- * }
52
- * ```
53
- *
54
- * @task T161
55
- * @epic T134
56
- */
57
- export declare function readLatestTranscript(providerDir: string): Promise<string | null>;
58
- //# sourceMappingURL=transcript-reader.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transcript-reader.d.ts","sourceRoot":"","sources":["../../../src/providers/shared/transcript-reader.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAoDH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACH,wBAAsB,oBAAoB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CA8BtF"}
@@ -1,88 +0,0 @@
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
- /**
10
- * Minimal manifest shape for provider discovery.
11
- *
12
- * @remarks
13
- * Each provider adapter ships a `manifest.json` in its directory under
14
- * `providers/`. The registry reads these at startup to populate the
15
- * adapter discovery surface. The shape is intentionally minimal -- only
16
- * the fields needed for dynamic loading and detection are required.
17
- */
18
- export interface AdapterManifest {
19
- /** Unique provider identifier (e.g. "claude-code", "cursor"). */
20
- id: string;
21
- /** Human-readable display name for the provider. */
22
- name: string;
23
- /** Semantic version of the adapter. */
24
- version: string;
25
- /** Short description of what the provider integrates with. */
26
- description: string;
27
- /** Provider slug used for directory lookups. */
28
- provider: string;
29
- /** Relative path to the adapter's entry point module. */
30
- entryPoint: string;
31
- /** Capability flags declared by the adapter. */
32
- capabilities: Record<string, unknown>;
33
- /** Patterns used to auto-detect the provider in a project. */
34
- detectionPatterns: Array<{
35
- /** Detection strategy type (e.g. "file", "env"). */
36
- type: string;
37
- /** Glob or regex pattern to match. */
38
- pattern: string;
39
- /** Human-readable explanation of this detection rule. */
40
- description: string;
41
- }>;
42
- }
43
- /**
44
- * Get the manifests for all bundled provider adapters.
45
- *
46
- * @remarks
47
- * Scans the known provider directories for `manifest.json` files.
48
- * Providers whose manifests cannot be loaded (missing or malformed)
49
- * are silently skipped.
50
- *
51
- * @returns Array of adapter manifests for successfully loaded providers
52
- *
53
- * @example
54
- * ```typescript
55
- * import { getProviderManifests } from '@cleocode/adapters';
56
- *
57
- * const manifests = getProviderManifests();
58
- * for (const m of manifests) {
59
- * console.log(`${m.id}: ${m.name} v${m.version}`);
60
- * }
61
- * ```
62
- */
63
- export declare function getProviderManifests(): AdapterManifest[];
64
- /**
65
- * Discover all available provider adapters.
66
- *
67
- * Returns a map of provider ID to adapter factory function.
68
- *
69
- * @remarks
70
- * Each factory lazily imports the provider module and constructs a new
71
- * adapter instance. This avoids loading all provider code upfront and
72
- * keeps startup fast.
73
- *
74
- * @returns Map of provider ID to async factory function that creates an adapter instance
75
- *
76
- * @example
77
- * ```typescript
78
- * import { discoverProviders } from '@cleocode/adapters';
79
- *
80
- * const providers = await discoverProviders();
81
- * const factory = providers.get('claude-code');
82
- * if (factory) {
83
- * const adapter = await factory();
84
- * }
85
- * ```
86
- */
87
- export declare function discoverProviders(): Promise<Map<string, () => Promise<unknown>>>;
88
- //# sourceMappingURL=registry.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../src/registry.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH;;;;;;;;GAQG;AACH,MAAM,WAAW,eAAe;IAC9B,iEAAiE;IACjE,EAAE,EAAE,MAAM,CAAC;IACX,oDAAoD;IACpD,IAAI,EAAE,MAAM,CAAC;IACb,uCAAuC;IACvC,OAAO,EAAE,MAAM,CAAC;IAChB,8DAA8D;IAC9D,WAAW,EAAE,MAAM,CAAC;IACpB,gDAAgD;IAChD,QAAQ,EAAE,MAAM,CAAC;IACjB,yDAAyD;IACzD,UAAU,EAAE,MAAM,CAAC;IACnB,gDAAgD;IAChD,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACtC,8DAA8D;IAC9D,iBAAiB,EAAE,KAAK,CAAC;QACvB,oDAAoD;QACpD,IAAI,EAAE,MAAM,CAAC;QACb,sCAAsC;QACtC,OAAO,EAAE,MAAM,CAAC;QAChB,yDAAyD;QACzD,WAAW,EAAE,MAAM,CAAC;KACrB,CAAC,CAAC;CACJ;AAKD;;;;;;;;;;;;;;;;;;;GAmBG;AACH,wBAAgB,oBAAoB,IAAI,eAAe,EAAE,CAexD;AAED;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAsB,iBAAiB,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAmBtF"}