@cleocode/adapters 2026.4.11 → 2026.4.13

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 (159) 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/adapter.js +0 -185
  27. package/dist/providers/claude-code/adapter.js.map +0 -1
  28. package/dist/providers/claude-code/context-monitor.d.ts +0 -35
  29. package/dist/providers/claude-code/context-monitor.d.ts.map +0 -1
  30. package/dist/providers/claude-code/context-monitor.js +0 -159
  31. package/dist/providers/claude-code/context-monitor.js.map +0 -1
  32. package/dist/providers/claude-code/hooks.d.ts +0 -146
  33. package/dist/providers/claude-code/hooks.d.ts.map +0 -1
  34. package/dist/providers/claude-code/hooks.js +0 -286
  35. package/dist/providers/claude-code/hooks.js.map +0 -1
  36. package/dist/providers/claude-code/index.d.ts +0 -39
  37. package/dist/providers/claude-code/index.d.ts.map +0 -1
  38. package/dist/providers/claude-code/index.js +0 -41
  39. package/dist/providers/claude-code/index.js.map +0 -1
  40. package/dist/providers/claude-code/install.d.ts +0 -67
  41. package/dist/providers/claude-code/install.d.ts.map +0 -1
  42. package/dist/providers/claude-code/install.js +0 -161
  43. package/dist/providers/claude-code/install.js.map +0 -1
  44. package/dist/providers/claude-code/paths.d.ts +0 -32
  45. package/dist/providers/claude-code/paths.d.ts.map +0 -1
  46. package/dist/providers/claude-code/paths.js +0 -41
  47. package/dist/providers/claude-code/paths.js.map +0 -1
  48. package/dist/providers/claude-code/spawn.d.ts +0 -67
  49. package/dist/providers/claude-code/spawn.d.ts.map +0 -1
  50. package/dist/providers/claude-code/spawn.js +0 -171
  51. package/dist/providers/claude-code/spawn.js.map +0 -1
  52. package/dist/providers/claude-code/statusline.d.ts +0 -68
  53. package/dist/providers/claude-code/statusline.d.ts.map +0 -1
  54. package/dist/providers/claude-code/statusline.js +0 -130
  55. package/dist/providers/claude-code/statusline.js.map +0 -1
  56. package/dist/providers/claude-code/task-sync.d.ts +0 -32
  57. package/dist/providers/claude-code/task-sync.d.ts.map +0 -1
  58. package/dist/providers/claude-code/task-sync.js +0 -119
  59. package/dist/providers/claude-code/task-sync.js.map +0 -1
  60. package/dist/providers/claude-code/transport.d.ts +0 -25
  61. package/dist/providers/claude-code/transport.d.ts.map +0 -1
  62. package/dist/providers/claude-code/transport.js +0 -29
  63. package/dist/providers/claude-code/transport.js.map +0 -1
  64. package/dist/providers/codex/adapter.d.ts +0 -83
  65. package/dist/providers/codex/adapter.d.ts.map +0 -1
  66. package/dist/providers/codex/adapter.js +0 -147
  67. package/dist/providers/codex/adapter.js.map +0 -1
  68. package/dist/providers/codex/hooks.d.ts +0 -91
  69. package/dist/providers/codex/hooks.d.ts.map +0 -1
  70. package/dist/providers/codex/hooks.js +0 -113
  71. package/dist/providers/codex/hooks.js.map +0 -1
  72. package/dist/providers/codex/index.d.ts +0 -37
  73. package/dist/providers/codex/index.d.ts.map +0 -1
  74. package/dist/providers/codex/index.js +0 -39
  75. package/dist/providers/codex/index.js.map +0 -1
  76. package/dist/providers/codex/install.d.ts +0 -65
  77. package/dist/providers/codex/install.d.ts.map +0 -1
  78. package/dist/providers/codex/install.js +0 -125
  79. package/dist/providers/codex/install.js.map +0 -1
  80. package/dist/providers/cursor/adapter.d.ts +0 -76
  81. package/dist/providers/cursor/adapter.d.ts.map +0 -1
  82. package/dist/providers/cursor/adapter.js +0 -152
  83. package/dist/providers/cursor/adapter.js.map +0 -1
  84. package/dist/providers/cursor/hooks.d.ts +0 -140
  85. package/dist/providers/cursor/hooks.d.ts.map +0 -1
  86. package/dist/providers/cursor/hooks.js +0 -208
  87. package/dist/providers/cursor/hooks.js.map +0 -1
  88. package/dist/providers/cursor/index.d.ts +0 -34
  89. package/dist/providers/cursor/index.d.ts.map +0 -1
  90. package/dist/providers/cursor/index.js +0 -36
  91. package/dist/providers/cursor/index.js.map +0 -1
  92. package/dist/providers/cursor/install.d.ts +0 -87
  93. package/dist/providers/cursor/install.d.ts.map +0 -1
  94. package/dist/providers/cursor/install.js +0 -181
  95. package/dist/providers/cursor/install.js.map +0 -1
  96. package/dist/providers/cursor/spawn.d.ts +0 -50
  97. package/dist/providers/cursor/spawn.d.ts.map +0 -1
  98. package/dist/providers/cursor/spawn.js +0 -59
  99. package/dist/providers/cursor/spawn.js.map +0 -1
  100. package/dist/providers/gemini-cli/adapter.d.ts +0 -84
  101. package/dist/providers/gemini-cli/adapter.d.ts.map +0 -1
  102. package/dist/providers/gemini-cli/adapter.js +0 -159
  103. package/dist/providers/gemini-cli/adapter.js.map +0 -1
  104. package/dist/providers/gemini-cli/hooks.d.ts +0 -99
  105. package/dist/providers/gemini-cli/hooks.d.ts.map +0 -1
  106. package/dist/providers/gemini-cli/hooks.js +0 -128
  107. package/dist/providers/gemini-cli/hooks.js.map +0 -1
  108. package/dist/providers/gemini-cli/index.d.ts +0 -37
  109. package/dist/providers/gemini-cli/index.d.ts.map +0 -1
  110. package/dist/providers/gemini-cli/index.js +0 -39
  111. package/dist/providers/gemini-cli/index.js.map +0 -1
  112. package/dist/providers/gemini-cli/install.d.ts +0 -65
  113. package/dist/providers/gemini-cli/install.d.ts.map +0 -1
  114. package/dist/providers/gemini-cli/install.js +0 -125
  115. package/dist/providers/gemini-cli/install.js.map +0 -1
  116. package/dist/providers/kimi/adapter.d.ts +0 -85
  117. package/dist/providers/kimi/adapter.d.ts.map +0 -1
  118. package/dist/providers/kimi/adapter.js +0 -146
  119. package/dist/providers/kimi/adapter.js.map +0 -1
  120. package/dist/providers/kimi/hooks.d.ts +0 -70
  121. package/dist/providers/kimi/hooks.d.ts.map +0 -1
  122. package/dist/providers/kimi/hooks.js +0 -79
  123. package/dist/providers/kimi/hooks.js.map +0 -1
  124. package/dist/providers/kimi/index.d.ts +0 -37
  125. package/dist/providers/kimi/index.d.ts.map +0 -1
  126. package/dist/providers/kimi/index.js +0 -39
  127. package/dist/providers/kimi/index.js.map +0 -1
  128. package/dist/providers/kimi/install.d.ts +0 -65
  129. package/dist/providers/kimi/install.d.ts.map +0 -1
  130. package/dist/providers/kimi/install.js +0 -125
  131. package/dist/providers/kimi/install.js.map +0 -1
  132. package/dist/providers/opencode/adapter.d.ts +0 -83
  133. package/dist/providers/opencode/adapter.d.ts.map +0 -1
  134. package/dist/providers/opencode/adapter.js +0 -167
  135. package/dist/providers/opencode/adapter.js.map +0 -1
  136. package/dist/providers/opencode/hooks.d.ts +0 -136
  137. package/dist/providers/opencode/hooks.d.ts.map +0 -1
  138. package/dist/providers/opencode/hooks.js +0 -206
  139. package/dist/providers/opencode/hooks.js.map +0 -1
  140. package/dist/providers/opencode/index.d.ts +0 -35
  141. package/dist/providers/opencode/index.d.ts.map +0 -1
  142. package/dist/providers/opencode/index.js +0 -37
  143. package/dist/providers/opencode/index.js.map +0 -1
  144. package/dist/providers/opencode/install.d.ts +0 -56
  145. package/dist/providers/opencode/install.d.ts.map +0 -1
  146. package/dist/providers/opencode/install.js +0 -116
  147. package/dist/providers/opencode/install.js.map +0 -1
  148. package/dist/providers/opencode/spawn.d.ts +0 -94
  149. package/dist/providers/opencode/spawn.d.ts.map +0 -1
  150. package/dist/providers/opencode/spawn.js +0 -241
  151. package/dist/providers/opencode/spawn.js.map +0 -1
  152. package/dist/providers/shared/transcript-reader.d.ts +0 -58
  153. package/dist/providers/shared/transcript-reader.d.ts.map +0 -1
  154. package/dist/providers/shared/transcript-reader.js +0 -124
  155. package/dist/providers/shared/transcript-reader.js.map +0 -1
  156. package/dist/registry.d.ts +0 -88
  157. package/dist/registry.d.ts.map +0 -1
  158. package/dist/registry.js +0 -88
  159. package/dist/registry.js.map +0 -1
@@ -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"}
@@ -1,34 +0,0 @@
1
- /**
2
- * @packageDocumentation
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
- * @remarks
19
- * This is the primary entry point for dynamic adapter loading.
20
- * AdapterManager calls this function when it resolves the cursor
21
- * provider via its import-based discovery mechanism.
22
- *
23
- * @returns A new {@link CursorAdapter} instance ready for initialization
24
- *
25
- * @example
26
- * ```typescript
27
- * import { createAdapter } from '@cleocode/adapters/providers/cursor';
28
- *
29
- * const adapter = createAdapter();
30
- * await adapter.initialize('/path/to/project');
31
- * ```
32
- */
33
- export declare function createAdapter(): CursorAdapter;
34
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
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;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,aAAa,IAAI,aAAa,CAE7C"}
@@ -1,36 +0,0 @@
1
- /**
2
- * @packageDocumentation
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
- * @remarks
19
- * This is the primary entry point for dynamic adapter loading.
20
- * AdapterManager calls this function when it resolves the cursor
21
- * provider via its import-based discovery mechanism.
22
- *
23
- * @returns A new {@link CursorAdapter} instance ready for initialization
24
- *
25
- * @example
26
- * ```typescript
27
- * import { createAdapter } from '@cleocode/adapters/providers/cursor';
28
- *
29
- * const adapter = createAdapter();
30
- * await adapter.initialize('/path/to/project');
31
- * ```
32
- */
33
- export function createAdapter() {
34
- return new CursorAdapter();
35
- }
36
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","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;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,aAAa,EAAE,CAAC;AAC7B,CAAC"}
@@ -1,87 +0,0 @@
1
- /**
2
- * Cursor Install Provider
3
- *
4
- * Handles CLEO installation into Cursor environments:
5
- * - Ensures .cursorrules has CLEO @-references (legacy format)
6
- * - Creates .cursor/rules/cleo.mdc with CLEO references (modern format)
7
- *
8
- * Cursor supports two instruction file formats:
9
- * 1. Legacy: .cursorrules (flat file, project root)
10
- * 2. Modern: .cursor/rules/*.mdc (MDC format, per-rule files)
11
- *
12
- * This provider writes to both for maximum compatibility.
13
- *
14
- * @task T5240
15
- */
16
- import type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';
17
- /**
18
- * Install provider for Cursor.
19
- *
20
- * Manages CLEO's integration with Cursor by:
21
- * 1. Creating/updating .cursorrules with @-references (legacy)
22
- * 2. Creating .cursor/rules/cleo.mdc with @-references (modern)
23
- *
24
- * @remarks
25
- * Installation is idempotent and writes to both instruction file formats
26
- * for maximum compatibility. The legacy `.cursorrules` file is only modified
27
- * if it already exists (never created from scratch). The modern MDC file
28
- * is always created or updated to ensure Cursor's rule engine picks it up.
29
- */
30
- export declare class CursorInstallProvider implements AdapterInstallProvider {
31
- /**
32
- * Install CLEO into a Cursor project.
33
- *
34
- * @param options - Installation options including project directory
35
- * @returns Result describing what was installed
36
- */
37
- install(options: InstallOptions): Promise<InstallResult>;
38
- /**
39
- * Uninstall CLEO from the current Cursor project.
40
- *
41
- * Does not remove instruction file references (they are harmless if CLEO is not present).
42
- */
43
- uninstall(): Promise<void>;
44
- /**
45
- * Check whether CLEO is installed in the current environment.
46
- *
47
- * Checks for .cursor/rules/cleo.mdc or .cursorrules with CLEO references.
48
- */
49
- isInstalled(): Promise<boolean>;
50
- /**
51
- * Ensure instruction files contain @-references to CLEO.
52
- *
53
- * Updates .cursorrules (legacy) and creates .cursor/rules/cleo.mdc (modern).
54
- *
55
- * @param projectDir - Project root directory
56
- */
57
- ensureInstructionReferences(projectDir: string): Promise<void>;
58
- /**
59
- * Update instruction files with CLEO @-references.
60
- *
61
- * Handles both legacy (.cursorrules) and modern (.cursor/rules/cleo.mdc) formats.
62
- *
63
- * @returns true if any file was created or modified
64
- */
65
- private updateInstructionFiles;
66
- /**
67
- * Update legacy .cursorrules file with @-references.
68
- * Only modifies the file if it already exists (does not create it).
69
- *
70
- * @returns true if the file was modified
71
- */
72
- private updateLegacyRules;
73
- /**
74
- * Create or update .cursor/rules/cleo.mdc with CLEO references.
75
- *
76
- * MDC (Markdown Component) format is Cursor's modern rule file format.
77
- * Each .mdc file in .cursor/rules/ is loaded as a rule set.
78
- *
79
- * @returns true if the file was created or modified
80
- */
81
- private updateModernRules;
82
- /**
83
- * Get list of instruction files that were updated.
84
- */
85
- private getUpdatedFileList;
86
- }
87
- //# sourceMappingURL=install.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/providers/cursor/install.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAIH,OAAO,KAAK,EAAE,sBAAsB,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAKjG;;;;;;;;;;;;GAYG;AACH,qBAAa,qBAAsB,YAAW,sBAAsB;IAClE;;;;;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;IAqBrC;;;;;;OAMG;IACG,2BAA2B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE;;;;;;OAMG;IACH,OAAO,CAAC,sBAAsB;IAgB9B;;;;;OAKG;IACH,OAAO,CAAC,iBAAiB;IAmBzB;;;;;;;OAOG;IACH,OAAO,CAAC,iBAAiB;IA2BzB;;OAEG;IACH,OAAO,CAAC,kBAAkB;CAQ3B"}
@@ -1,181 +0,0 @@
1
- /**
2
- * Cursor Install Provider
3
- *
4
- * Handles CLEO installation into Cursor environments:
5
- * - Ensures .cursorrules has CLEO @-references (legacy format)
6
- * - Creates .cursor/rules/cleo.mdc with CLEO references (modern format)
7
- *
8
- * Cursor supports two instruction file formats:
9
- * 1. Legacy: .cursorrules (flat file, project root)
10
- * 2. Modern: .cursor/rules/*.mdc (MDC format, per-rule files)
11
- *
12
- * This provider writes to both for maximum compatibility.
13
- *
14
- * @task T5240
15
- */
16
- import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
17
- import { join } from 'node:path';
18
- /** Lines that should appear in instruction files to reference CLEO. */
19
- const INSTRUCTION_REFERENCES = ['@~/.cleo/templates/CLEO-INJECTION.md', '@.cleo/memory-bridge.md'];
20
- /**
21
- * Install provider for Cursor.
22
- *
23
- * Manages CLEO's integration with Cursor by:
24
- * 1. Creating/updating .cursorrules with @-references (legacy)
25
- * 2. Creating .cursor/rules/cleo.mdc with @-references (modern)
26
- *
27
- * @remarks
28
- * Installation is idempotent and writes to both instruction file formats
29
- * for maximum compatibility. The legacy `.cursorrules` file is only modified
30
- * if it already exists (never created from scratch). The modern MDC file
31
- * is always created or updated to ensure Cursor's rule engine picks it up.
32
- */
33
- export class CursorInstallProvider {
34
- /**
35
- * Install CLEO into a Cursor project.
36
- *
37
- * @param options - Installation options including project directory
38
- * @returns Result describing what was installed
39
- */
40
- async install(options) {
41
- const { projectDir } = options;
42
- const installedAt = new Date().toISOString();
43
- let instructionFileUpdated = false;
44
- const details = {};
45
- // Step 1: Ensure instruction files have @-references
46
- instructionFileUpdated = this.updateInstructionFiles(projectDir);
47
- if (instructionFileUpdated) {
48
- details.instructionFiles = this.getUpdatedFileList(projectDir);
49
- }
50
- return {
51
- success: true,
52
- installedAt,
53
- instructionFileUpdated,
54
- mcpRegistered: false,
55
- details,
56
- };
57
- }
58
- /**
59
- * Uninstall CLEO from the current Cursor project.
60
- *
61
- * Does not remove instruction file references (they are harmless if CLEO is not present).
62
- */
63
- async uninstall() { }
64
- /**
65
- * Check whether CLEO is installed in the current environment.
66
- *
67
- * Checks for .cursor/rules/cleo.mdc or .cursorrules with CLEO references.
68
- */
69
- async isInstalled() {
70
- const mdcPath = join(process.cwd(), '.cursor', 'rules', 'cleo.mdc');
71
- if (existsSync(mdcPath)) {
72
- return true;
73
- }
74
- const rulesPath = join(process.cwd(), '.cursorrules');
75
- if (existsSync(rulesPath)) {
76
- try {
77
- const content = readFileSync(rulesPath, 'utf-8');
78
- if (INSTRUCTION_REFERENCES.some((ref) => content.includes(ref))) {
79
- return true;
80
- }
81
- }
82
- catch {
83
- // Fall through
84
- }
85
- }
86
- return false;
87
- }
88
- /**
89
- * Ensure instruction files contain @-references to CLEO.
90
- *
91
- * Updates .cursorrules (legacy) and creates .cursor/rules/cleo.mdc (modern).
92
- *
93
- * @param projectDir - Project root directory
94
- */
95
- async ensureInstructionReferences(projectDir) {
96
- this.updateInstructionFiles(projectDir);
97
- }
98
- /**
99
- * Update instruction files with CLEO @-references.
100
- *
101
- * Handles both legacy (.cursorrules) and modern (.cursor/rules/cleo.mdc) formats.
102
- *
103
- * @returns true if any file was created or modified
104
- */
105
- updateInstructionFiles(projectDir) {
106
- let updated = false;
107
- // Update legacy .cursorrules if it exists
108
- if (this.updateLegacyRules(projectDir)) {
109
- updated = true;
110
- }
111
- // Create/update modern .cursor/rules/cleo.mdc
112
- if (this.updateModernRules(projectDir)) {
113
- updated = true;
114
- }
115
- return updated;
116
- }
117
- /**
118
- * Update legacy .cursorrules file with @-references.
119
- * Only modifies the file if it already exists (does not create it).
120
- *
121
- * @returns true if the file was modified
122
- */
123
- updateLegacyRules(projectDir) {
124
- const rulesPath = join(projectDir, '.cursorrules');
125
- if (!existsSync(rulesPath)) {
126
- return false;
127
- }
128
- let content = readFileSync(rulesPath, 'utf-8');
129
- const missingRefs = INSTRUCTION_REFERENCES.filter((ref) => !content.includes(ref));
130
- if (missingRefs.length === 0) {
131
- return false;
132
- }
133
- const separator = content.endsWith('\n') ? '' : '\n';
134
- content = content + separator + missingRefs.join('\n') + '\n';
135
- writeFileSync(rulesPath, content, 'utf-8');
136
- return true;
137
- }
138
- /**
139
- * Create or update .cursor/rules/cleo.mdc with CLEO references.
140
- *
141
- * MDC (Markdown Component) format is Cursor's modern rule file format.
142
- * Each .mdc file in .cursor/rules/ is loaded as a rule set.
143
- *
144
- * @returns true if the file was created or modified
145
- */
146
- updateModernRules(projectDir) {
147
- const rulesDir = join(projectDir, '.cursor', 'rules');
148
- const mdcPath = join(rulesDir, 'cleo.mdc');
149
- const expectedContent = [
150
- '---',
151
- 'description: CLEO task management protocol references',
152
- 'globs: "**/*"',
153
- 'alwaysApply: true',
154
- '---',
155
- '',
156
- ...INSTRUCTION_REFERENCES,
157
- '',
158
- ].join('\n');
159
- if (existsSync(mdcPath)) {
160
- const existing = readFileSync(mdcPath, 'utf-8');
161
- if (existing === expectedContent) {
162
- return false;
163
- }
164
- }
165
- mkdirSync(rulesDir, { recursive: true });
166
- writeFileSync(mdcPath, expectedContent, 'utf-8');
167
- return true;
168
- }
169
- /**
170
- * Get list of instruction files that were updated.
171
- */
172
- getUpdatedFileList(projectDir) {
173
- const files = [];
174
- if (existsSync(join(projectDir, '.cursorrules'))) {
175
- files.push(join(projectDir, '.cursorrules'));
176
- }
177
- files.push(join(projectDir, '.cursor', 'rules', 'cleo.mdc'));
178
- return files;
179
- }
180
- }
181
- //# sourceMappingURL=install.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"install.js","sourceRoot":"","sources":["../../../src/providers/cursor/install.ts"],"names":[],"mappings":"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"}
@@ -1,50 +0,0 @@
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
@@ -1 +0,0 @@
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"}