@cleocode/adapters 2026.4.41 → 2026.4.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 (86) hide show
  1. package/dist/cant-context.d.ts +35 -0
  2. package/dist/cant-context.d.ts.map +1 -1
  3. package/dist/index.js +152 -32
  4. package/dist/index.js.map +3 -3
  5. package/package.json +7 -5
  6. package/src/cant-context.ts +210 -20
  7. package/dist/cant-context.js +0 -284
  8. package/dist/cant-context.js.map +0 -1
  9. package/dist/providers/claude-code/adapter.js +0 -187
  10. package/dist/providers/claude-code/adapter.js.map +0 -1
  11. package/dist/providers/claude-code/context-monitor.js +0 -159
  12. package/dist/providers/claude-code/context-monitor.js.map +0 -1
  13. package/dist/providers/claude-code/hooks.js +0 -389
  14. package/dist/providers/claude-code/hooks.js.map +0 -1
  15. package/dist/providers/claude-code/index.js +0 -41
  16. package/dist/providers/claude-code/index.js.map +0 -1
  17. package/dist/providers/claude-code/install.js +0 -199
  18. package/dist/providers/claude-code/install.js.map +0 -1
  19. package/dist/providers/claude-code/paths.js +0 -41
  20. package/dist/providers/claude-code/paths.js.map +0 -1
  21. package/dist/providers/claude-code/spawn.js +0 -185
  22. package/dist/providers/claude-code/spawn.js.map +0 -1
  23. package/dist/providers/claude-code/statusline.js +0 -130
  24. package/dist/providers/claude-code/statusline.js.map +0 -1
  25. package/dist/providers/claude-code/task-sync.js +0 -119
  26. package/dist/providers/claude-code/task-sync.js.map +0 -1
  27. package/dist/providers/claude-code/transport.js +0 -29
  28. package/dist/providers/claude-code/transport.js.map +0 -1
  29. package/dist/providers/codex/adapter.js +0 -146
  30. package/dist/providers/codex/adapter.js.map +0 -1
  31. package/dist/providers/codex/hooks.js +0 -113
  32. package/dist/providers/codex/hooks.js.map +0 -1
  33. package/dist/providers/codex/index.js +0 -39
  34. package/dist/providers/codex/index.js.map +0 -1
  35. package/dist/providers/codex/install.js +0 -124
  36. package/dist/providers/codex/install.js.map +0 -1
  37. package/dist/providers/cursor/adapter.js +0 -151
  38. package/dist/providers/cursor/adapter.js.map +0 -1
  39. package/dist/providers/cursor/hooks.js +0 -208
  40. package/dist/providers/cursor/hooks.js.map +0 -1
  41. package/dist/providers/cursor/index.js +0 -36
  42. package/dist/providers/cursor/index.js.map +0 -1
  43. package/dist/providers/cursor/install.js +0 -180
  44. package/dist/providers/cursor/install.js.map +0 -1
  45. package/dist/providers/cursor/spawn.js +0 -59
  46. package/dist/providers/cursor/spawn.js.map +0 -1
  47. package/dist/providers/gemini-cli/adapter.js +0 -158
  48. package/dist/providers/gemini-cli/adapter.js.map +0 -1
  49. package/dist/providers/gemini-cli/hooks.js +0 -128
  50. package/dist/providers/gemini-cli/hooks.js.map +0 -1
  51. package/dist/providers/gemini-cli/index.js +0 -39
  52. package/dist/providers/gemini-cli/index.js.map +0 -1
  53. package/dist/providers/gemini-cli/install.js +0 -124
  54. package/dist/providers/gemini-cli/install.js.map +0 -1
  55. package/dist/providers/kimi/adapter.js +0 -145
  56. package/dist/providers/kimi/adapter.js.map +0 -1
  57. package/dist/providers/kimi/hooks.js +0 -79
  58. package/dist/providers/kimi/hooks.js.map +0 -1
  59. package/dist/providers/kimi/index.js +0 -39
  60. package/dist/providers/kimi/index.js.map +0 -1
  61. package/dist/providers/kimi/install.js +0 -124
  62. package/dist/providers/kimi/install.js.map +0 -1
  63. package/dist/providers/opencode/adapter.js +0 -166
  64. package/dist/providers/opencode/adapter.js.map +0 -1
  65. package/dist/providers/opencode/hooks.js +0 -206
  66. package/dist/providers/opencode/hooks.js.map +0 -1
  67. package/dist/providers/opencode/index.js +0 -37
  68. package/dist/providers/opencode/index.js.map +0 -1
  69. package/dist/providers/opencode/install.js +0 -115
  70. package/dist/providers/opencode/install.js.map +0 -1
  71. package/dist/providers/opencode/spawn.js +0 -256
  72. package/dist/providers/opencode/spawn.js.map +0 -1
  73. package/dist/providers/pi/adapter.js +0 -220
  74. package/dist/providers/pi/adapter.js.map +0 -1
  75. package/dist/providers/pi/hooks.js +0 -223
  76. package/dist/providers/pi/hooks.js.map +0 -1
  77. package/dist/providers/pi/index.js +0 -38
  78. package/dist/providers/pi/index.js.map +0 -1
  79. package/dist/providers/pi/install.js +0 -175
  80. package/dist/providers/pi/install.js.map +0 -1
  81. package/dist/providers/pi/spawn.js +0 -187
  82. package/dist/providers/pi/spawn.js.map +0 -1
  83. package/dist/providers/shared/transcript-reader.js +0 -124
  84. package/dist/providers/shared/transcript-reader.js.map +0 -1
  85. package/dist/registry.js +0 -92
  86. package/dist/registry.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/codex/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAMtC,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAEpD,MAAM,SAAS,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;AAElC;;;;;;;;;;;;;;GAcG;AACH,MAAM,OAAO,YAAY;IACvB,kCAAkC;IACzB,EAAE,GAAG,OAAO,CAAC;IACtB,oCAAoC;IAC3B,IAAI,GAAG,OAAO,CAAC;IACxB,8BAA8B;IACrB,OAAO,GAAG,OAAO,CAAC;IAE3B,+CAA+C;IAC/C,YAAY,GAAwB;QAClC,aAAa,EAAE,IAAI;QACnB,mBAAmB,EAAE,CAAC,cAAc,EAAE,kBAAkB,EAAE,MAAM,CAAC;QACjE,aAAa,EAAE,KAAK;QACpB,eAAe,EAAE,IAAI;QACrB,wBAAwB,EAAE,KAAK;QAC/B,sBAAsB,EAAE,KAAK;QAC7B,kBAAkB,EAAE,KAAK;QACzB,qBAAqB,EAAE,KAAK;QAC5B,iBAAiB,EAAE,KAAK;QACxB,gBAAgB,EAAE,KAAK;KACxB,CAAC;IAEF,6CAA6C;IAC7C,KAAK,CAAoB;IACzB,uDAAuD;IACvD,OAAO,CAAuB;IAE9B,oEAAoE;IAC5D,UAAU,GAAkB,IAAI,CAAC;IACzC,kDAAkD;IAC1C,WAAW,GAAG,KAAK,CAAC;IAE5B;QACE,IAAI,CAAC,KAAK,GAAG,IAAI,iBAAiB,EAAE,CAAC;QACrC,IAAI,CAAC,OAAO,GAAG,IAAI,oBAAoB,EAAE,CAAC;IAC5C,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,UAAU,CAAC,UAAkB;QACjC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,OAAO;QACX,IAAI,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,EAAE,CAAC;YAC9B,MAAM,IAAI,CAAC,KAAK,CAAC,qBAAqB,EAAE,CAAC;QAC3C,CAAC;QACD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,WAAW;QACf,MAAM,OAAO,GAA4B,EAAE,CAAC;QAE5C,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,QAAQ,EAAE,IAAI,CAAC,EAAE;gBACjB,OAAO,EAAE,EAAE,KAAK,EAAE,yBAAyB,EAAE;aAC9C,CAAC;QACJ,CAAC;QAED,+BAA+B;QAC/B,IAAI,YAAY,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC;YACH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,SAAS,CAAC,aAAa,CAAC,CAAC;YAClD,YAAY,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC;YACxC,OAAO,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC;QAClC,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,YAAY,GAAG,KAAK,CAAC;QAC/B,CAAC;QAED,uCAAuC;QACvC,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,EAAE,EAAE,QAAQ,CAAC,CAAC;QACjD,MAAM,YAAY,GAAG,UAAU,CAAC,cAAc,CAAC,CAAC;QAChD,OAAO,CAAC,eAAe,GAAG,YAAY,CAAC;QAEvC,oDAAoD;QACpD,MAAM,OAAO,GAAG,YAAY,CAAC;QAC7B,OAAO,CAAC,YAAY,GAAG,YAAY,CAAC;QAEpC,OAAO;YACL,OAAO;YACP,QAAQ,EAAE,IAAI,CAAC,EAAE;YACjB,OAAO;SACR,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,aAAa;QACX,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED;;;OAGG;IACH,aAAa;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;CACF"}
@@ -1,113 +0,0 @@
1
- /**
2
- * Codex CLI Hook Provider
3
- *
4
- * Maps Codex CLI's native hook events to CAAMP canonical hook events.
5
- * Codex CLI supports 3 canonical events through its hook system.
6
- *
7
- * Codex CLI event mapping:
8
- * - SessionStart -> SessionStart
9
- * - PromptSubmit -> UserPromptSubmit
10
- * - ResponseComplete -> Stop
11
- *
12
- * @task T162
13
- * @epic T134
14
- */
15
- import { homedir } from 'node:os';
16
- import { join } from 'node:path';
17
- import { readLatestTranscript } from '../shared/transcript-reader.js';
18
- /**
19
- * Mapping from Codex CLI native event names to CAAMP canonical event names.
20
- */
21
- const CODEX_EVENT_MAP = {
22
- SessionStart: 'SessionStart',
23
- PromptSubmit: 'UserPromptSubmit',
24
- ResponseComplete: 'Stop',
25
- };
26
- /**
27
- * Hook provider for Codex CLI.
28
- *
29
- * Codex CLI registers hooks via its configuration system at
30
- * ~/.codex/. Hook handlers are shell commands or script paths that
31
- * execute when the corresponding event fires.
32
- *
33
- * Since hooks are registered through the config system (managed by
34
- * the install provider), registerNativeHooks and unregisterNativeHooks
35
- * track registration state without performing filesystem operations.
36
- *
37
- * @remarks
38
- * Codex CLI has a minimal hook surface with only 3 canonical events.
39
- * Registration state is tracked in-memory because Codex CLI manages
40
- * hooks through its own configuration system at `~/.codex/`.
41
- *
42
- * @task T162
43
- * @epic T134
44
- */
45
- export class CodexHookProvider {
46
- /** Whether hooks have been registered for the current session. */
47
- registered = false;
48
- /**
49
- * Map a Codex CLI native event name to a CAAMP hook event name.
50
- *
51
- * @param providerEvent - Codex CLI event name (e.g. "SessionStart", "PromptSubmit")
52
- * @returns CAAMP event name or null if unmapped
53
- * @task T162
54
- */
55
- mapProviderEvent(providerEvent) {
56
- return CODEX_EVENT_MAP[providerEvent] ?? null;
57
- }
58
- /**
59
- * Register native hooks for a project.
60
- *
61
- * For Codex CLI, hooks are registered via the config system
62
- * (~/.codex/), which is handled by the install provider.
63
- * This method marks hooks as registered without performing
64
- * filesystem operations.
65
- *
66
- * @param _projectDir - Project directory (unused; hooks are global)
67
- * @task T162
68
- */
69
- async registerNativeHooks(_projectDir) {
70
- this.registered = true;
71
- }
72
- /**
73
- * Unregister native hooks.
74
- *
75
- * For Codex CLI, this is a no-op since hooks are managed through
76
- * the config system. Unregistration happens via the install
77
- * provider's uninstall method.
78
- * @task T162
79
- */
80
- async unregisterNativeHooks() {
81
- this.registered = false;
82
- }
83
- /**
84
- * Check whether hooks have been registered via registerNativeHooks.
85
- * @task T162
86
- */
87
- isRegistered() {
88
- return this.registered;
89
- }
90
- /**
91
- * Get the full event mapping for introspection/debugging.
92
- * @task T162
93
- */
94
- getEventMap() {
95
- return { ...CODEX_EVENT_MAP };
96
- }
97
- /**
98
- * Extract a plain-text transcript from Codex CLI session data.
99
- *
100
- * Reads the most recent JSON/JSONL session file under `~/.codex/`
101
- * and returns its turns as a flat string for brain observation extraction.
102
- *
103
- * Returns null when no session data is found or on any read error.
104
- *
105
- * @param _sessionId - CLEO session ID (unused; reads the most recent file)
106
- * @param _projectDir - Project directory (unused; Codex CLI uses global paths)
107
- * @task T162 @epic T134
108
- */
109
- async getTranscript(_sessionId, _projectDir) {
110
- return readLatestTranscript(join(homedir(), '.codex'));
111
- }
112
- }
113
- //# sourceMappingURL=hooks.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/codex/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,OAAO,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AAEtE;;GAEG;AACH,MAAM,eAAe,GAA2B;IAC9C,YAAY,EAAE,cAAc;IAC5B,YAAY,EAAE,kBAAkB;IAChC,gBAAgB,EAAE,MAAM;CACzB,CAAC;AAEF;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,OAAO,iBAAiB;IAC5B,kEAAkE;IAC1D,UAAU,GAAG,KAAK,CAAC;IAE3B;;;;;;OAMG;IACH,gBAAgB,CAAC,aAAqB;QACpC,OAAO,eAAe,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC;IAChD,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,mBAAmB,CAAC,WAAmB;QAC3C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,qBAAqB;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED;;;OAGG;IACH,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;OAGG;IACH,WAAW;QACT,OAAO,EAAE,GAAG,eAAe,EAAE,CAAC;IAChC,CAAC;IAED;;;;;;;;;;;OAWG;IACH,KAAK,CAAC,aAAa,CAAC,UAAkB,EAAE,WAAmB;QACzD,OAAO,oBAAoB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,QAAQ,CAAC,CAAC,CAAC;IACzD,CAAC;CACF"}
@@ -1,39 +0,0 @@
1
- /**
2
- * @packageDocumentation
3
- *
4
- * CLEO provider adapter for OpenAI Codex CLI.
5
- * Default export is the adapter class for dynamic loading by AdapterManager.
6
- *
7
- * @task T162
8
- * @epic T134
9
- */
10
- import { CodexAdapter } from './adapter.js';
11
- export { CodexAdapter } from './adapter.js';
12
- export { CodexHookProvider } from './hooks.js';
13
- export { CodexInstallProvider } from './install.js';
14
- export default CodexAdapter;
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 codex
22
- * provider via its import-based discovery mechanism.
23
- *
24
- * @returns A new {@link CodexAdapter} instance ready for initialization
25
- *
26
- * @example
27
- * ```typescript
28
- * import { createAdapter } from '@cleocode/adapters/providers/codex';
29
- *
30
- * const adapter = createAdapter();
31
- * await adapter.initialize('/path/to/project');
32
- * ```
33
- *
34
- * @task T162
35
- */
36
- export function createAdapter() {
37
- return new CodexAdapter();
38
- }
39
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/providers/codex/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAE5C,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAEpD,eAAe,YAAY,CAAC;AAE5B;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,YAAY,EAAE,CAAC;AAC5B,CAAC"}
@@ -1,124 +0,0 @@
1
- /**
2
- * Codex CLI Install Provider
3
- *
4
- * Handles CLEO installation into Codex CLI environments:
5
- * - Ensures AGENTS.md has CLEO @-references
6
- *
7
- * @task T162
8
- * @epic T134
9
- */
10
- import { existsSync, readFileSync, writeFileSync } from 'node:fs';
11
- import { join } from 'node:path';
12
- /** Lines that should appear in AGENTS.md to reference CLEO. */
13
- const INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];
14
- /**
15
- * Install provider for Codex CLI.
16
- *
17
- * Manages CLEO's integration with Codex CLI by:
18
- * 1. Ensuring AGENTS.md contains @-references to CLEO instruction files
19
- *
20
- * @remarks
21
- * Installation is idempotent -- running install multiple times on the same
22
- * project produces the same result. Only AGENTS.md is managed; Codex CLI
23
- * does not have an MCP or plugin registration mechanism.
24
- *
25
- * @task T162
26
- * @epic T134
27
- */
28
- export class CodexInstallProvider {
29
- /**
30
- * Install CLEO into a Codex CLI environment.
31
- *
32
- * @param options - Installation options including project directory
33
- * @returns Result describing what was installed
34
- * @task T162
35
- */
36
- async install(options) {
37
- const { projectDir } = options;
38
- const installedAt = new Date().toISOString();
39
- let instructionFileUpdated = false;
40
- const details = {};
41
- // Step 1: Ensure AGENTS.md has @-references
42
- instructionFileUpdated = this.updateInstructionFile(projectDir);
43
- if (instructionFileUpdated) {
44
- details.instructionFile = join(projectDir, 'AGENTS.md');
45
- }
46
- return {
47
- success: true,
48
- installedAt,
49
- instructionFileUpdated,
50
- details,
51
- };
52
- }
53
- /**
54
- * Uninstall CLEO from the Codex CLI environment.
55
- *
56
- * Does not remove AGENTS.md references (they are harmless if CLEO is not present).
57
- * @task T162
58
- */
59
- async uninstall() {
60
- // No-op: no MCP registration to remove
61
- }
62
- /**
63
- * Check whether CLEO is installed in the Codex CLI environment.
64
- *
65
- * Checks for CLEO references in AGENTS.md.
66
- * @task T162
67
- */
68
- async isInstalled() {
69
- const agentsMdPath = join(process.cwd(), 'AGENTS.md');
70
- if (existsSync(agentsMdPath)) {
71
- try {
72
- const content = readFileSync(agentsMdPath, 'utf-8');
73
- if (INSTRUCTION_REFERENCES.some((ref) => content.includes(ref))) {
74
- return true;
75
- }
76
- }
77
- catch {
78
- // Fall through
79
- }
80
- }
81
- return false;
82
- }
83
- /**
84
- * Ensure AGENTS.md contains @-references to CLEO instruction files.
85
- *
86
- * Creates AGENTS.md if it does not exist. Appends any missing references.
87
- *
88
- * @param projectDir - Project root directory
89
- * @task T162
90
- */
91
- async ensureInstructionReferences(projectDir) {
92
- this.updateInstructionFile(projectDir);
93
- }
94
- /**
95
- * Update AGENTS.md with CLEO @-references.
96
- *
97
- * @param projectDir - Project root directory
98
- * @returns true if the file was created or modified
99
- */
100
- updateInstructionFile(projectDir) {
101
- const agentsMdPath = join(projectDir, 'AGENTS.md');
102
- let content = '';
103
- let existed = false;
104
- if (existsSync(agentsMdPath)) {
105
- content = readFileSync(agentsMdPath, 'utf-8');
106
- existed = true;
107
- }
108
- const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
109
- if (missingRefs.length === 0) {
110
- return false;
111
- }
112
- const refsBlock = missingRefs.join('\n');
113
- if (existed) {
114
- const separator = content.endsWith('\n') ? '' : '\n';
115
- content = content + separator + refsBlock + '\n';
116
- }
117
- else {
118
- content = refsBlock + '\n';
119
- }
120
- writeFileSync(agentsMdPath, content, 'utf-8');
121
- return true;
122
- }
123
- }
124
- //# sourceMappingURL=install.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/codex/install.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAClE,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAGjC,+DAA+D;AAC/D,MAAM,sBAAsB,GAAG,CAAC,sCAAsC,EAAE,yBAAyB,CAAC,CAAC;AAEnG;;;;;;;;;;;;;GAaG;AACH,MAAM,OAAO,oBAAoB;IAC/B;;;;;;OAMG;IACH,KAAK,CAAC,OAAO,CAAC,OAAuB;QACnC,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;QAC/B,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QAC7C,IAAI,sBAAsB,GAAG,KAAK,CAAC;QACnC,MAAM,OAAO,GAA4B,EAAE,CAAC;QAE5C,4CAA4C;QAC5C,sBAAsB,GAAG,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC;QAChE,IAAI,sBAAsB,EAAE,CAAC;YAC3B,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;QAC1D,CAAC;QAED,OAAO;YACL,OAAO,EAAE,IAAI;YACb,WAAW;YACX,sBAAsB;YACtB,OAAO;SACR,CAAC;IACJ,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,SAAS;QACb,uCAAuC;IACzC,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,WAAW;QACf,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,WAAW,CAAC,CAAC;QACtD,IAAI,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;YAC7B,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;gBACpD,IAAI,sBAAsB,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBAChE,OAAO,IAAI,CAAC;gBACd,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,eAAe;YACjB,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,2BAA2B,CAAC,UAAkB;QAClD,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC;IACzC,CAAC;IAED;;;;;OAKG;IACK,qBAAqB,CAAC,UAAkB;QAC9C,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;QACnD,IAAI,OAAO,GAAG,EAAE,CAAC;QACjB,IAAI,OAAO,GAAG,KAAK,CAAC;QAEpB,IAAI,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;YAC7B,OAAO,GAAG,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;YAC9C,OAAO,GAAG,IAAI,CAAC;QACjB,CAAC;QAED,MAAM,WAAW,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;QAEnF,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC7B,OAAO,KAAK,CAAC;QACf,CAAC;QAED,MAAM,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEzC,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,SAAS,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;YACrD,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,SAAS,GAAG,IAAI,CAAC;QACnD,CAAC;aAAM,CAAC;YACN,OAAO,GAAG,SAAS,GAAG,IAAI,CAAC;QAC7B,CAAC;QAED,aAAa,CAAC,YAAY,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAC9C,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -1,151 +0,0 @@
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 { existsSync } from 'node:fs';
12
- import { join } from 'node:path';
13
- import { CursorHookProvider } from './hooks.js';
14
- import { CursorInstallProvider } from './install.js';
15
- /**
16
- * CLEO provider adapter for Cursor AI code editor.
17
- *
18
- * Bridges CLEO's adapter system with Cursor's capabilities:
19
- * - Install: Manages .cursorrules and .cursor/rules/cleo.mdc rule files
20
- * - Hooks: Stub provider (Cursor has no lifecycle event system)
21
- * - Spawn: Not supported (Cursor has no CLI for subagent spawning)
22
- *
23
- * @remarks
24
- * Cursor is a GUI-based editor, so many CLI-oriented capabilities
25
- * (spawn, transport, task sync, context monitor) are unsupported.
26
- * Integration is primarily through instruction rule files placed in
27
- * `.cursor/rules/` (modern MDC format) and `.cursorrules` (legacy).
28
- */
29
- export class CursorAdapter {
30
- /** Unique provider identifier. */
31
- id = 'cursor';
32
- /** Human-readable provider name. */
33
- name = 'Cursor';
34
- /** Adapter version string. */
35
- version = '1.0.0';
36
- /** Declared capabilities for this provider. */
37
- capabilities = {
38
- supportsHooks: true,
39
- // 10/16 canonical events — derived from getProviderHookProfile('cursor') in CAAMP 1.9.1.
40
- // PermissionRequest, PreModel, PostModel, PostCompact, Notification, ConfigChange are
41
- // not supported by Cursor's hook system.
42
- supportedHookEvents: [
43
- 'SessionStart',
44
- 'SessionEnd',
45
- 'PromptSubmit',
46
- 'ResponseComplete',
47
- 'PreToolUse',
48
- 'PostToolUse',
49
- 'PostToolUseFailure',
50
- 'SubagentStart',
51
- 'SubagentStop',
52
- 'PreCompact',
53
- ],
54
- supportsSpawn: false,
55
- supportsInstall: true,
56
- supportsInstructionFiles: true,
57
- instructionFilePattern: '.cursor/rules/*.mdc',
58
- supportsContextMonitor: false,
59
- supportsStatusline: false,
60
- supportsProviderPaths: true,
61
- supportsTransport: false,
62
- supportsTaskSync: false,
63
- };
64
- /** Hook provider for CAAMP event mapping. */
65
- hooks;
66
- /** Install provider for managing rule files. */
67
- install;
68
- /** Project directory this adapter was initialized with, or null. */
69
- projectDir = null;
70
- /** Whether {@link initialize} has been called. */
71
- initialized = false;
72
- constructor() {
73
- this.hooks = new CursorHookProvider();
74
- this.install = new CursorInstallProvider();
75
- }
76
- /**
77
- * Initialize the adapter for a given project directory.
78
- *
79
- * @param projectDir - Root directory of the project
80
- */
81
- async initialize(projectDir) {
82
- this.projectDir = projectDir;
83
- this.initialized = true;
84
- }
85
- /**
86
- * Dispose the adapter and clean up resources.
87
- */
88
- async dispose() {
89
- if (this.hooks.isRegistered()) {
90
- await this.hooks.unregisterNativeHooks();
91
- }
92
- this.initialized = false;
93
- this.projectDir = null;
94
- }
95
- /**
96
- * Run a health check to verify Cursor is accessible.
97
- *
98
- * Checks:
99
- * 1. Adapter has been initialized
100
- * 2. .cursor/ configuration directory exists in the project
101
- * 3. CURSOR_EDITOR env var is set
102
- *
103
- * @returns Health status with details about each check
104
- */
105
- async healthCheck() {
106
- const details = {};
107
- if (!this.initialized) {
108
- return {
109
- healthy: false,
110
- provider: this.id,
111
- details: { error: 'Adapter not initialized' },
112
- };
113
- }
114
- // Check for Cursor config directory in the project
115
- let configExists = false;
116
- if (this.projectDir) {
117
- const cursorConfigDir = join(this.projectDir, '.cursor');
118
- configExists = existsSync(cursorConfigDir);
119
- details.configDirExists = configExists;
120
- }
121
- // Check for CURSOR_EDITOR env var
122
- const editorEnvSet = process.env.CURSOR_EDITOR !== undefined;
123
- details.editorEnvSet = editorEnvSet;
124
- // Check for legacy .cursorrules file
125
- if (this.projectDir) {
126
- const legacyRulesExist = existsSync(join(this.projectDir, '.cursorrules'));
127
- details.legacyRulesExist = legacyRulesExist;
128
- }
129
- // Healthy if we detect Cursor presence (config dir or env var)
130
- const healthy = configExists || editorEnvSet;
131
- details.detected = healthy;
132
- return {
133
- healthy,
134
- provider: this.id,
135
- details,
136
- };
137
- }
138
- /**
139
- * Check whether the adapter has been initialized.
140
- */
141
- isInitialized() {
142
- return this.initialized;
143
- }
144
- /**
145
- * Get the project directory this adapter was initialized with.
146
- */
147
- getProjectDir() {
148
- return this.projectDir;
149
- }
150
- }
151
- //# sourceMappingURL=adapter.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"adapter.js","sourceRoot":"","sources":["../../../src/providers/cursor/adapter.ts"],"names":[],"mappings":"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"}
@@ -1,208 +0,0 @@
1
- /**
2
- * Cursor Hook Provider
3
- *
4
- * Maps Cursor's native hook events to CAAMP canonical hook events.
5
- * Cursor supports 10 of 16 canonical events through its config-based hook system.
6
- *
7
- * Event translation uses CAAMP normalizer APIs:
8
- * - `toCanonical(nativeName, 'cursor')` for runtime event name resolution
9
- * - `getSupportedEvents('cursor')` to enumerate supported canonical events
10
- * - `getProviderHookProfile('cursor')` for the full provider profile
11
- *
12
- * Cursor uses camelCase native event names (e.g. `sessionStart`, `preToolUse`).
13
- * Hooks are configured via `.cursor/hooks.json`. Supported handler types:
14
- * command, prompt.
15
- *
16
- * Unsupported events: PermissionRequest, PreModel, PostModel, PostCompact,
17
- * Notification, ConfigChange.
18
- *
19
- * @task T165
20
- * @epic T134
21
- */
22
- /** CAAMP provider identifier for Cursor. */
23
- const PROVIDER_ID = 'cursor';
24
- /**
25
- * Fallback map from Cursor native event names to CAAMP canonical names.
26
- *
27
- * Derived from `getProviderHookProfile('cursor').mappings` in CAAMP 1.9.1.
28
- * Covers all 10 supported events. PermissionRequest, PreModel, PostModel,
29
- * PostCompact, Notification, and ConfigChange are not supported by Cursor.
30
- *
31
- * Cursor uses camelCase names while CAAMP canonical names are PascalCase.
32
- */
33
- const CURSOR_EVENT_MAP = {
34
- // CAAMP: toNative('SessionStart', 'cursor') = 'sessionStart'
35
- sessionStart: 'SessionStart',
36
- // CAAMP: toNative('SessionEnd', 'cursor') = 'sessionEnd'
37
- sessionEnd: 'SessionEnd',
38
- // CAAMP: toNative('PromptSubmit', 'cursor') = 'beforeSubmitPrompt'
39
- beforeSubmitPrompt: 'PromptSubmit',
40
- // CAAMP: toNative('ResponseComplete', 'cursor') = 'stop'
41
- stop: 'ResponseComplete',
42
- // CAAMP: toNative('PreToolUse', 'cursor') = 'preToolUse'
43
- preToolUse: 'PreToolUse',
44
- // CAAMP: toNative('PostToolUse', 'cursor') = 'postToolUse'
45
- postToolUse: 'PostToolUse',
46
- // CAAMP: toNative('PostToolUseFailure', 'cursor') = 'postToolUseFailure'
47
- postToolUseFailure: 'PostToolUseFailure',
48
- // CAAMP: toNative('SubagentStart', 'cursor') = 'subagentStart'
49
- subagentStart: 'SubagentStart',
50
- // CAAMP: toNative('SubagentStop', 'cursor') = 'subagentStop'
51
- subagentStop: 'SubagentStop',
52
- // CAAMP: toNative('PreCompact', 'cursor') = 'preCompact'
53
- preCompact: 'PreCompact',
54
- };
55
- /**
56
- * Hook provider for Cursor.
57
- *
58
- * Cursor registers hooks via its config system at `.cursor/hooks.json`.
59
- * Supported handler types: command, prompt.
60
- *
61
- * CAAMP 1.9.1 reveals Cursor supports 10 of 16 canonical events. Previously
62
- * this provider was a no-op stub. It now provides full event mapping and CAAMP
63
- * normalizer integration.
64
- *
65
- * Event mapping is based on `getProviderHookProfile('cursor')` from CAAMP 1.9.1.
66
- * Async accessors (`getSupportedCanonicalEvents`, `getProviderProfile`) call
67
- * CAAMP directly when available.
68
- *
69
- * Since hooks are registered through the config system (managed by the install
70
- * provider), `registerNativeHooks` and `unregisterNativeHooks` track registration
71
- * state without performing filesystem operations.
72
- *
73
- * @remarks
74
- * This provider was originally a no-op stub. It now provides full event
75
- * mapping for all 10 canonical events supported by Cursor, plus CAAMP
76
- * normalizer integration via async accessors. Registration state is
77
- * tracked in-memory because Cursor manages hooks through its own config.
78
- *
79
- * @task T165
80
- * @epic T134
81
- */
82
- export class CursorHookProvider {
83
- /** Whether hooks have been registered for the current session. */
84
- registered = false;
85
- /**
86
- * Map a Cursor native event name to a CAAMP canonical hook event name.
87
- *
88
- * Looks up the native event name in the map derived from
89
- * `getProviderHookProfile('cursor').mappings` (CAAMP 1.9.1). Cursor uses
90
- * camelCase names (e.g. "preToolUse", "sessionStart").
91
- *
92
- * Returns null for unsupported events (PermissionRequest, PreModel,
93
- * PostModel, PostCompact, Notification, ConfigChange).
94
- *
95
- * @param providerEvent - Cursor native event name (e.g. "preToolUse", "sessionStart")
96
- * @returns CAAMP canonical event name, or null if unmapped
97
- * @task T165
98
- */
99
- mapProviderEvent(providerEvent) {
100
- return CURSOR_EVENT_MAP[providerEvent] ?? null;
101
- }
102
- /**
103
- * Register native hooks for a project.
104
- *
105
- * For Cursor, hooks are registered via the config system
106
- * (`.cursor/hooks.json`), managed by the install provider.
107
- * This method marks hooks as registered without performing filesystem operations.
108
- *
109
- * Iterating supported events is handled at install time using
110
- * `getSupportedCanonicalEvents()` to enumerate all 10 supported hooks.
111
- *
112
- * @param _projectDir - Project directory (unused; Cursor config manages registration)
113
- * @task T165
114
- */
115
- async registerNativeHooks(_projectDir) {
116
- this.registered = true;
117
- }
118
- /**
119
- * Unregister native hooks.
120
- *
121
- * For Cursor, this is a no-op since hooks are managed through the config
122
- * system. Unregistration happens via the install provider's uninstall method.
123
- *
124
- * @task T165
125
- */
126
- async unregisterNativeHooks() {
127
- this.registered = false;
128
- }
129
- /**
130
- * Check whether hooks have been registered via `registerNativeHooks`.
131
- */
132
- isRegistered() {
133
- return this.registered;
134
- }
135
- /**
136
- * Get the native→canonical event mapping for introspection and debugging.
137
- *
138
- * Returns the map derived from `getProviderHookProfile('cursor').mappings`
139
- * (CAAMP 1.9.1). Use `getSupportedCanonicalEvents()` to enumerate canonical
140
- * names via live CAAMP APIs.
141
- *
142
- * @returns Immutable record of native event name → canonical event name
143
- */
144
- getEventMap() {
145
- return { ...CURSOR_EVENT_MAP };
146
- }
147
- /**
148
- * Enumerate supported canonical events via CAAMP's `getSupportedEvents()`.
149
- *
150
- * Calls `getSupportedEvents('cursor')` from the CAAMP normalizer to get the
151
- * authoritative list. Cursor supports 10 of 16 canonical events. Falls back
152
- * to the values of the static event map when CAAMP is unavailable at runtime.
153
- *
154
- * @returns Array of CAAMP canonical event names supported by Cursor
155
- * @task T165
156
- */
157
- async getSupportedCanonicalEvents() {
158
- try {
159
- const { getSupportedEvents } = await import('@cleocode/caamp');
160
- return getSupportedEvents(PROVIDER_ID);
161
- }
162
- catch {
163
- return [...new Set(Object.values(CURSOR_EVENT_MAP))];
164
- }
165
- }
166
- /**
167
- * Retrieve the full provider hook profile from CAAMP.
168
- *
169
- * Calls `getProviderHookProfile('cursor')` from the CAAMP normalizer to
170
- * get the complete profile: hook system type (`config`), config path
171
- * (`.cursor/hooks.json`), handler types (command, prompt), and all event
172
- * mappings. Returns null when CAAMP is unavailable at runtime.
173
- *
174
- * @returns Provider hook profile or null if CAAMP is unavailable
175
- * @task T165
176
- */
177
- async getProviderProfile() {
178
- try {
179
- const { getProviderHookProfile } = await import('@cleocode/caamp');
180
- return getProviderHookProfile(PROVIDER_ID) ?? null;
181
- }
182
- catch {
183
- return null;
184
- }
185
- }
186
- /**
187
- * Translate a CAAMP canonical event to its Cursor native name via CAAMP.
188
- *
189
- * Calls `toNative(canonical, 'cursor')` from the CAAMP normalizer.
190
- * Returns null for unsupported events or when CAAMP is unavailable.
191
- *
192
- * @param canonical - CAAMP canonical event name (e.g. "PreToolUse")
193
- * @returns Cursor native event name (e.g. "preToolUse") or null
194
- * @task T165
195
- */
196
- async toNativeEvent(canonical) {
197
- try {
198
- const { toNative } = await import('@cleocode/caamp');
199
- return toNative(canonical, PROVIDER_ID);
200
- }
201
- catch {
202
- // Invert the static map as fallback
203
- const entry = Object.entries(CURSOR_EVENT_MAP).find(([, v]) => v === canonical);
204
- return entry?.[0] ?? null;
205
- }
206
- }
207
- }
208
- //# sourceMappingURL=hooks.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/providers/cursor/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AAIH,4CAA4C;AAC5C,MAAM,WAAW,GAAG,QAAiB,CAAC;AAEtC;;;;;;;;GAQG;AACH,MAAM,gBAAgB,GAA2B;IAC/C,mEAAmE;IACnE,YAAY,EAAE,cAAc;IAC5B,iEAAiE;IACjE,UAAU,EAAE,YAAY;IACxB,yEAAyE;IACzE,kBAAkB,EAAE,cAAc;IAClC,2DAA2D;IAC3D,IAAI,EAAE,kBAAkB;IACxB,iEAAiE;IACjE,UAAU,EAAE,YAAY;IACxB,kEAAkE;IAClE,WAAW,EAAE,aAAa;IAC1B,yEAAyE;IACzE,kBAAkB,EAAE,oBAAoB;IACxC,oEAAoE;IACpE,aAAa,EAAE,eAAe;IAC9B,mEAAmE;IACnE,YAAY,EAAE,cAAc;IAC5B,iEAAiE;IACjE,UAAU,EAAE,YAAY;CACzB,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,MAAM,OAAO,kBAAkB;IAC7B,kEAAkE;IAC1D,UAAU,GAAG,KAAK,CAAC;IAE3B;;;;;;;;;;;;;OAaG;IACH,gBAAgB,CAAC,aAAqB;QACpC,OAAO,gBAAgB,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC;IACjD,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,KAAK,CAAC,mBAAmB,CAAC,WAAmB;QAC3C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,qBAAqB;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;;;;;;OAQG;IACH,WAAW;QACT,OAAO,EAAE,GAAG,gBAAgB,EAAE,CAAC;IACjC,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,2BAA2B;QAC/B,IAAI,CAAC;YACH,MAAM,EAAE,kBAAkB,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YAC/D,OAAO,kBAAkB,CAAC,WAAW,CAAa,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,kBAAkB;QACtB,IAAI,CAAC;YACH,MAAM,EAAE,sBAAsB,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACnE,OAAO,sBAAsB,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,aAAa,CAAC,SAAiB;QACnC,IAAI,CAAC;YACH,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,CAAC;YACrD,OAAO,QAAQ,CAAC,SAA2C,EAAE,WAAW,CAAC,CAAC;QAC5E,CAAC;QAAC,MAAM,CAAC;YACP,oCAAoC;YACpC,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC;YAChF,OAAO,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAC5B,CAAC;IACH,CAAC;CACF"}