@cleocode/adapters 2026.4.11 → 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 (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,25 +0,0 @@
1
- /**
2
- * Transport provider for the Claude Code adapter.
3
- *
4
- * Implements AdapterTransportProvider to supply Claude Code's
5
- * native inter-agent transport mechanism.
6
- *
7
- * @task T5240
8
- */
9
- import type { AdapterTransportProvider } from '@cleocode/contracts';
10
- /**
11
- * Transport provider for Claude Code inter-agent communication.
12
- *
13
- * @remarks
14
- * Currently returns null from {@link createTransport} because actual transport
15
- * creation is handled by the signaldock factory which checks for this adapter's
16
- * transport capability flag. Full wiring will be completed in Phase 5 of the
17
- * adapter system rollout.
18
- */
19
- export declare class ClaudeCodeTransportProvider implements AdapterTransportProvider {
20
- /** Provider-specific transport name used for capability negotiation. */
21
- readonly transportName = "claude-code";
22
- /** Create a transport instance for inter-agent messaging. */
23
- createTransport(): unknown;
24
- }
25
- //# sourceMappingURL=transport.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transport.d.ts","sourceRoot":"","sources":["../../../src/providers/claude-code/transport.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAC;AAEpE;;;;;;;;GAQG;AACH,qBAAa,2BAA4B,YAAW,wBAAwB;IAC1E,wEAAwE;IACxE,QAAQ,CAAC,aAAa,iBAAiB;IAEvC,6DAA6D;IAC7D,eAAe,IAAI,OAAO;CAM3B"}
@@ -1,29 +0,0 @@
1
- /**
2
- * Transport provider for the Claude Code adapter.
3
- *
4
- * Implements AdapterTransportProvider to supply Claude Code's
5
- * native inter-agent transport mechanism.
6
- *
7
- * @task T5240
8
- */
9
- /**
10
- * Transport provider for Claude Code inter-agent communication.
11
- *
12
- * @remarks
13
- * Currently returns null from {@link createTransport} because actual transport
14
- * creation is handled by the signaldock factory which checks for this adapter's
15
- * transport capability flag. Full wiring will be completed in Phase 5 of the
16
- * adapter system rollout.
17
- */
18
- export class ClaudeCodeTransportProvider {
19
- /** Provider-specific transport name used for capability negotiation. */
20
- transportName = 'claude-code';
21
- /** Create a transport instance for inter-agent messaging. */
22
- createTransport() {
23
- // Returns null — actual transport creation is handled by the signaldock factory
24
- // which checks for this adapter's transport capability.
25
- // Full wiring will be completed in Phase 5.
26
- return null;
27
- }
28
- }
29
- //# sourceMappingURL=transport.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transport.js","sourceRoot":"","sources":["../../../src/providers/claude-code/transport.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH;;;;;;;;GAQG;AACH,MAAM,OAAO,2BAA2B;IACtC,wEAAwE;IAC/D,aAAa,GAAG,aAAa,CAAC;IAEvC,6DAA6D;IAC7D,eAAe;QACb,gFAAgF;QAChF,wDAAwD;QACxD,4CAA4C;QAC5C,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -1,83 +0,0 @@
1
- /**
2
- * Codex CLI Adapter
3
- *
4
- * Main CLEOProviderAdapter implementation for OpenAI Codex CLI.
5
- * Provides hooks and install capabilities for CLEO integration.
6
- *
7
- * @task T162
8
- * @epic T134
9
- */
10
- import type { AdapterCapabilities, AdapterHealthStatus, CLEOProviderAdapter } from '@cleocode/contracts';
11
- import { CodexHookProvider } from './hooks.js';
12
- import { CodexInstallProvider } from './install.js';
13
- /**
14
- * CLEO provider adapter for OpenAI Codex CLI.
15
- *
16
- * Bridges CLEO's adapter system with Codex CLI's native capabilities:
17
- * - Hooks: Maps Codex events (SessionStart, PromptSubmit, ResponseComplete) to CAAMP events
18
- * - Install: Ensures AGENTS.md references for CLEO instruction files
19
- *
20
- * @remarks
21
- * Codex CLI supports only 3 canonical events (SessionStart, PromptSubmit,
22
- * ResponseComplete) and has no spawn or transport capabilities. Integration
23
- * is primarily through instruction files (AGENTS.md).
24
- *
25
- * @task T162
26
- * @epic T134
27
- */
28
- export declare class CodexAdapter implements CLEOProviderAdapter {
29
- /** Unique provider identifier. */
30
- readonly id = "codex";
31
- /** Human-readable provider name. */
32
- readonly name = "Codex";
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. */
38
- hooks: CodexHookProvider;
39
- /** Install provider for managing instruction files. */
40
- install: CodexInstallProvider;
41
- /** Project directory this adapter was initialized with, or null. */
42
- private projectDir;
43
- /** Whether {@link initialize} has been called. */
44
- private initialized;
45
- constructor();
46
- /**
47
- * Initialize the adapter for a given project directory.
48
- *
49
- * @param projectDir - Root directory of the project
50
- * @task T162
51
- */
52
- initialize(projectDir: string): Promise<void>;
53
- /**
54
- * Dispose the adapter and clean up resources.
55
- *
56
- * Unregisters hooks and releases any tracked state.
57
- * @task T162
58
- */
59
- dispose(): Promise<void>;
60
- /**
61
- * Run a health check to verify Codex CLI is accessible.
62
- *
63
- * Checks:
64
- * 1. Adapter has been initialized
65
- * 2. Codex CLI binary is available in PATH
66
- * 3. ~/.codex/ configuration directory exists
67
- *
68
- * @returns Health status with details about each check
69
- * @task T162
70
- */
71
- healthCheck(): Promise<AdapterHealthStatus>;
72
- /**
73
- * Check whether the adapter has been initialized.
74
- * @task T162
75
- */
76
- isInitialized(): boolean;
77
- /**
78
- * Get the project directory this adapter was initialized with.
79
- * @task T162
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/codex/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAOH,OAAO,KAAK,EACV,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAIpD;;;;;;;;;;;;;;GAcG;AACH,qBAAa,YAAa,YAAW,mBAAmB;IACtD,kCAAkC;IAClC,QAAQ,CAAC,EAAE,WAAW;IACtB,oCAAoC;IACpC,QAAQ,CAAC,IAAI,WAAW;IACxB,8BAA8B;IAC9B,QAAQ,CAAC,OAAO,WAAW;IAE3B,+CAA+C;IAC/C,YAAY,EAAE,mBAAmB,CAY/B;IAEF,6CAA6C;IAC7C,KAAK,EAAE,iBAAiB,CAAC;IACzB,uDAAuD;IACvD,OAAO,EAAE,oBAAoB,CAAC;IAE9B,oEAAoE;IACpE,OAAO,CAAC,UAAU,CAAuB;IACzC,kDAAkD;IAClD,OAAO,CAAC,WAAW,CAAS;;IAO5B;;;;;OAKG;IACG,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnD;;;;;OAKG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAQ9B;;;;;;;;;;OAUG;IACG,WAAW,IAAI,OAAO,CAAC,mBAAmB,CAAC;IAqCjD;;;OAGG;IACH,aAAa,IAAI,OAAO;IAIxB;;;OAGG;IACH,aAAa,IAAI,MAAM,GAAG,IAAI;CAG/B"}
@@ -1,147 +0,0 @@
1
- /**
2
- * Codex CLI Adapter
3
- *
4
- * Main CLEOProviderAdapter implementation for OpenAI Codex CLI.
5
- * Provides hooks and install capabilities for CLEO integration.
6
- *
7
- * @task T162
8
- * @epic T134
9
- */
10
- import { exec } from 'node:child_process';
11
- import { existsSync } from 'node:fs';
12
- import { homedir } from 'node:os';
13
- import { join } from 'node:path';
14
- import { promisify } from 'node:util';
15
- import { CodexHookProvider } from './hooks.js';
16
- import { CodexInstallProvider } from './install.js';
17
- const execAsync = promisify(exec);
18
- /**
19
- * CLEO provider adapter for OpenAI Codex CLI.
20
- *
21
- * Bridges CLEO's adapter system with Codex CLI's native capabilities:
22
- * - Hooks: Maps Codex events (SessionStart, PromptSubmit, ResponseComplete) to CAAMP events
23
- * - Install: Ensures AGENTS.md references for CLEO instruction files
24
- *
25
- * @remarks
26
- * Codex CLI supports only 3 canonical events (SessionStart, PromptSubmit,
27
- * ResponseComplete) and has no spawn or transport capabilities. Integration
28
- * is primarily through instruction files (AGENTS.md).
29
- *
30
- * @task T162
31
- * @epic T134
32
- */
33
- export class CodexAdapter {
34
- /** Unique provider identifier. */
35
- id = 'codex';
36
- /** Human-readable provider name. */
37
- name = 'Codex';
38
- /** Adapter version string. */
39
- version = '1.0.0';
40
- /** Declared capabilities for this provider. */
41
- capabilities = {
42
- supportsHooks: true,
43
- supportedHookEvents: ['SessionStart', 'UserPromptSubmit', 'Stop'],
44
- supportsSpawn: false,
45
- supportsInstall: true,
46
- supportsMcp: false,
47
- supportsInstructionFiles: false,
48
- supportsContextMonitor: false,
49
- supportsStatusline: false,
50
- supportsProviderPaths: false,
51
- supportsTransport: false,
52
- supportsTaskSync: false,
53
- };
54
- /** Hook provider for CAAMP event mapping. */
55
- hooks;
56
- /** Install provider for managing instruction files. */
57
- install;
58
- /** Project directory this adapter was initialized with, or null. */
59
- projectDir = null;
60
- /** Whether {@link initialize} has been called. */
61
- initialized = false;
62
- constructor() {
63
- this.hooks = new CodexHookProvider();
64
- this.install = new CodexInstallProvider();
65
- }
66
- /**
67
- * Initialize the adapter for a given project directory.
68
- *
69
- * @param projectDir - Root directory of the project
70
- * @task T162
71
- */
72
- async initialize(projectDir) {
73
- this.projectDir = projectDir;
74
- this.initialized = true;
75
- }
76
- /**
77
- * Dispose the adapter and clean up resources.
78
- *
79
- * Unregisters hooks and releases any tracked state.
80
- * @task T162
81
- */
82
- async dispose() {
83
- if (this.hooks.isRegistered()) {
84
- await this.hooks.unregisterNativeHooks();
85
- }
86
- this.initialized = false;
87
- this.projectDir = null;
88
- }
89
- /**
90
- * Run a health check to verify Codex CLI is accessible.
91
- *
92
- * Checks:
93
- * 1. Adapter has been initialized
94
- * 2. Codex CLI binary is available in PATH
95
- * 3. ~/.codex/ configuration directory exists
96
- *
97
- * @returns Health status with details about each check
98
- * @task T162
99
- */
100
- async healthCheck() {
101
- const details = {};
102
- if (!this.initialized) {
103
- return {
104
- healthy: false,
105
- provider: this.id,
106
- details: { error: 'Adapter not initialized' },
107
- };
108
- }
109
- // Check Codex CLI availability
110
- let cliAvailable = false;
111
- try {
112
- const { stdout } = await execAsync('which codex');
113
- cliAvailable = stdout.trim().length > 0;
114
- details.cliPath = stdout.trim();
115
- }
116
- catch {
117
- details.cliAvailable = false;
118
- }
119
- // Check for Codex CLI config directory
120
- const codexConfigDir = join(homedir(), '.codex');
121
- const configExists = existsSync(codexConfigDir);
122
- details.configDirExists = configExists;
123
- // Healthy if CLI is available (primary requirement)
124
- const healthy = cliAvailable;
125
- details.cliAvailable = cliAvailable;
126
- return {
127
- healthy,
128
- provider: this.id,
129
- details,
130
- };
131
- }
132
- /**
133
- * Check whether the adapter has been initialized.
134
- * @task T162
135
- */
136
- isInitialized() {
137
- return this.initialized;
138
- }
139
- /**
140
- * Get the project directory this adapter was initialized with.
141
- * @task T162
142
- */
143
- getProjectDir() {
144
- return this.projectDir;
145
- }
146
- }
147
- //# sourceMappingURL=adapter.js.map
@@ -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,WAAW,EAAE,KAAK;QAClB,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,91 +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 type { AdapterHookProvider } from '@cleocode/contracts';
16
- /**
17
- * Hook provider for Codex CLI.
18
- *
19
- * Codex CLI registers hooks via its configuration system at
20
- * ~/.codex/. Hook handlers are shell commands or script paths that
21
- * execute when the corresponding event fires.
22
- *
23
- * Since hooks are registered through the config system (managed by
24
- * the install provider), registerNativeHooks and unregisterNativeHooks
25
- * track registration state without performing filesystem operations.
26
- *
27
- * @remarks
28
- * Codex CLI has a minimal hook surface with only 3 canonical events.
29
- * Registration state is tracked in-memory because Codex CLI manages
30
- * hooks through its own configuration system at `~/.codex/`.
31
- *
32
- * @task T162
33
- * @epic T134
34
- */
35
- export declare class CodexHookProvider implements AdapterHookProvider {
36
- /** Whether hooks have been registered for the current session. */
37
- private registered;
38
- /**
39
- * Map a Codex CLI native event name to a CAAMP hook event name.
40
- *
41
- * @param providerEvent - Codex CLI event name (e.g. "SessionStart", "PromptSubmit")
42
- * @returns CAAMP event name or null if unmapped
43
- * @task T162
44
- */
45
- mapProviderEvent(providerEvent: string): string | null;
46
- /**
47
- * Register native hooks for a project.
48
- *
49
- * For Codex CLI, hooks are registered via the config system
50
- * (~/.codex/), which is handled by the install provider.
51
- * This method marks hooks as registered without performing
52
- * filesystem operations.
53
- *
54
- * @param _projectDir - Project directory (unused; hooks are global)
55
- * @task T162
56
- */
57
- registerNativeHooks(_projectDir: string): Promise<void>;
58
- /**
59
- * Unregister native hooks.
60
- *
61
- * For Codex CLI, this is a no-op since hooks are managed through
62
- * the config system. Unregistration happens via the install
63
- * provider's uninstall method.
64
- * @task T162
65
- */
66
- unregisterNativeHooks(): Promise<void>;
67
- /**
68
- * Check whether hooks have been registered via registerNativeHooks.
69
- * @task T162
70
- */
71
- isRegistered(): boolean;
72
- /**
73
- * Get the full event mapping for introspection/debugging.
74
- * @task T162
75
- */
76
- getEventMap(): Readonly<Record<string, string>>;
77
- /**
78
- * Extract a plain-text transcript from Codex CLI session data.
79
- *
80
- * Reads the most recent JSON/JSONL session file under `~/.codex/`
81
- * and returns its turns as a flat string for brain observation extraction.
82
- *
83
- * Returns null when no session data is found or on any read error.
84
- *
85
- * @param _sessionId - CLEO session ID (unused; reads the most recent file)
86
- * @param _projectDir - Project directory (unused; Codex CLI uses global paths)
87
- * @task T162 @epic T134
88
- */
89
- getTranscript(_sessionId: string, _projectDir: string): Promise<string | null>;
90
- }
91
- //# sourceMappingURL=hooks.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/providers/codex/hooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAIH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAY/D;;;;;;;;;;;;;;;;;;GAkBG;AACH,qBAAa,iBAAkB,YAAW,mBAAmB;IAC3D,kEAAkE;IAClE,OAAO,CAAC,UAAU,CAAS;IAE3B;;;;;;OAMG;IACH,gBAAgB,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAItD;;;;;;;;;;OAUG;IACG,mBAAmB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7D;;;;;;;OAOG;IACG,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5C;;;OAGG;IACH,YAAY,IAAI,OAAO;IAIvB;;;OAGG;IACH,WAAW,IAAI,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAI/C;;;;;;;;;;;OAWG;IACG,aAAa,CAAC,UAAU,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;CAGrF"}
@@ -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,37 +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 declare function createAdapter(): CodexAdapter;
37
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","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,wBAAgB,aAAa,IAAI,YAAY,CAE5C"}
@@ -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,65 +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 type { AdapterInstallProvider, InstallOptions, InstallResult } from '@cleocode/contracts';
11
- /**
12
- * Install provider for Codex CLI.
13
- *
14
- * Manages CLEO's integration with Codex CLI by:
15
- * 1. Ensuring AGENTS.md contains @-references to CLEO instruction files
16
- *
17
- * @remarks
18
- * Installation is idempotent -- running install multiple times on the same
19
- * project produces the same result. Only AGENTS.md is managed; Codex CLI
20
- * does not have an MCP or plugin registration mechanism.
21
- *
22
- * @task T162
23
- * @epic T134
24
- */
25
- export declare class CodexInstallProvider implements AdapterInstallProvider {
26
- /**
27
- * Install CLEO into a Codex CLI environment.
28
- *
29
- * @param options - Installation options including project directory
30
- * @returns Result describing what was installed
31
- * @task T162
32
- */
33
- install(options: InstallOptions): Promise<InstallResult>;
34
- /**
35
- * Uninstall CLEO from the Codex CLI environment.
36
- *
37
- * Does not remove AGENTS.md references (they are harmless if CLEO is not present).
38
- * @task T162
39
- */
40
- uninstall(): Promise<void>;
41
- /**
42
- * Check whether CLEO is installed in the Codex CLI environment.
43
- *
44
- * Checks for CLEO references in AGENTS.md.
45
- * @task T162
46
- */
47
- isInstalled(): Promise<boolean>;
48
- /**
49
- * Ensure AGENTS.md contains @-references to CLEO instruction files.
50
- *
51
- * Creates AGENTS.md if it does not exist. Appends any missing references.
52
- *
53
- * @param projectDir - Project root directory
54
- * @task T162
55
- */
56
- ensureInstructionReferences(projectDir: string): Promise<void>;
57
- /**
58
- * Update AGENTS.md with CLEO @-references.
59
- *
60
- * @param projectDir - Project root directory
61
- * @returns true if the file was created or modified
62
- */
63
- private updateInstructionFile;
64
- }
65
- //# sourceMappingURL=install.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/providers/codex/install.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAIH,OAAO,KAAK,EAAE,sBAAsB,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAKjG;;;;;;;;;;;;;GAaG;AACH,qBAAa,oBAAqB,YAAW,sBAAsB;IACjE;;;;;;OAMG;IACG,OAAO,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC;IAqB9D;;;;;OAKG;IACG,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAIhC;;;;;OAKG;IACG,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAgBrC;;;;;;;OAOG;IACG,2BAA2B,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpE;;;;;OAKG;IACH,OAAO,CAAC,qBAAqB;CA4B9B"}