yzcode-cli 1.0.1 → 1.0.3

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 (117) hide show
  1. package/assistant/sessionHistory.ts +87 -0
  2. package/bootstrap/state.ts +1769 -0
  3. package/bridge/bridgeApi.ts +539 -0
  4. package/bridge/bridgeConfig.ts +48 -0
  5. package/bridge/bridgeDebug.ts +135 -0
  6. package/bridge/bridgeEnabled.ts +202 -0
  7. package/bridge/bridgeMain.ts +2999 -0
  8. package/bridge/bridgeMessaging.ts +461 -0
  9. package/bridge/bridgePermissionCallbacks.ts +43 -0
  10. package/bridge/bridgePointer.ts +210 -0
  11. package/bridge/bridgeStatusUtil.ts +163 -0
  12. package/bridge/bridgeUI.ts +530 -0
  13. package/bridge/capacityWake.ts +56 -0
  14. package/bridge/codeSessionApi.ts +168 -0
  15. package/bridge/createSession.ts +384 -0
  16. package/bridge/debugUtils.ts +141 -0
  17. package/bridge/envLessBridgeConfig.ts +165 -0
  18. package/bridge/flushGate.ts +71 -0
  19. package/bridge/inboundAttachments.ts +175 -0
  20. package/bridge/inboundMessages.ts +80 -0
  21. package/bridge/initReplBridge.ts +569 -0
  22. package/bridge/jwtUtils.ts +256 -0
  23. package/bridge/pollConfig.ts +110 -0
  24. package/bridge/pollConfigDefaults.ts +82 -0
  25. package/bridge/remoteBridgeCore.ts +1008 -0
  26. package/bridge/replBridge.ts +2406 -0
  27. package/bridge/replBridgeHandle.ts +36 -0
  28. package/bridge/replBridgeTransport.ts +370 -0
  29. package/bridge/sessionIdCompat.ts +57 -0
  30. package/bridge/sessionRunner.ts +550 -0
  31. package/bridge/trustedDevice.ts +210 -0
  32. package/bridge/types.ts +262 -0
  33. package/bridge/workSecret.ts +127 -0
  34. package/buddy/CompanionSprite.tsx +371 -0
  35. package/buddy/companion.ts +133 -0
  36. package/buddy/prompt.ts +36 -0
  37. package/buddy/sprites.ts +514 -0
  38. package/buddy/types.ts +148 -0
  39. package/buddy/useBuddyNotification.tsx +98 -0
  40. package/coordinator/coordinatorMode.ts +369 -0
  41. package/memdir/findRelevantMemories.ts +141 -0
  42. package/memdir/memdir.ts +507 -0
  43. package/memdir/memoryAge.ts +53 -0
  44. package/memdir/memoryScan.ts +94 -0
  45. package/memdir/memoryTypes.ts +271 -0
  46. package/memdir/paths.ts +278 -0
  47. package/memdir/teamMemPaths.ts +292 -0
  48. package/memdir/teamMemPrompts.ts +100 -0
  49. package/migrations/migrateAutoUpdatesToSettings.ts +61 -0
  50. package/migrations/migrateBypassPermissionsAcceptedToSettings.ts +40 -0
  51. package/migrations/migrateEnableAllProjectMcpServersToSettings.ts +118 -0
  52. package/migrations/migrateFennecToOpus.ts +45 -0
  53. package/migrations/migrateLegacyOpusToCurrent.ts +57 -0
  54. package/migrations/migrateOpusToOpus1m.ts +43 -0
  55. package/migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.ts +22 -0
  56. package/migrations/migrateSonnet1mToSonnet45.ts +48 -0
  57. package/migrations/migrateSonnet45ToSonnet46.ts +67 -0
  58. package/migrations/resetAutoModeOptInForDefaultOffer.ts +51 -0
  59. package/migrations/resetProToOpusDefault.ts +51 -0
  60. package/native-ts/color-diff/index.ts +999 -0
  61. package/native-ts/file-index/index.ts +370 -0
  62. package/native-ts/yoga-layout/enums.ts +134 -0
  63. package/native-ts/yoga-layout/index.ts +2578 -0
  64. package/outputStyles/loadOutputStylesDir.ts +98 -0
  65. package/package.json +22 -5
  66. package/plugins/builtinPlugins.ts +159 -0
  67. package/plugins/bundled/index.ts +23 -0
  68. package/schemas/hooks.ts +222 -0
  69. package/screens/Doctor.tsx +575 -0
  70. package/screens/REPL.tsx +5006 -0
  71. package/screens/ResumeConversation.tsx +399 -0
  72. package/server/createDirectConnectSession.ts +88 -0
  73. package/server/directConnectManager.ts +213 -0
  74. package/server/types.ts +57 -0
  75. package/skills/bundled/batch.ts +124 -0
  76. package/skills/bundled/claudeApi.ts +196 -0
  77. package/skills/bundled/claudeApiContent.ts +75 -0
  78. package/skills/bundled/claudeInChrome.ts +34 -0
  79. package/skills/bundled/debug.ts +103 -0
  80. package/skills/bundled/index.ts +79 -0
  81. package/skills/bundled/keybindings.ts +339 -0
  82. package/skills/bundled/loop.ts +92 -0
  83. package/skills/bundled/loremIpsum.ts +282 -0
  84. package/skills/bundled/remember.ts +82 -0
  85. package/skills/bundled/scheduleRemoteAgents.ts +447 -0
  86. package/skills/bundled/simplify.ts +69 -0
  87. package/skills/bundled/skillify.ts +197 -0
  88. package/skills/bundled/stuck.ts +79 -0
  89. package/skills/bundled/updateConfig.ts +475 -0
  90. package/skills/bundled/verify/SKILL.md +3 -0
  91. package/skills/bundled/verify/examples/cli.md +3 -0
  92. package/skills/bundled/verify/examples/server.md +3 -0
  93. package/skills/bundled/verify.ts +30 -0
  94. package/skills/bundled/verifyContent.ts +13 -0
  95. package/skills/bundledSkills.ts +220 -0
  96. package/skills/loadSkillsDir.ts +1086 -0
  97. package/skills/mcpSkillBuilders.ts +44 -0
  98. package/tasks/DreamTask/DreamTask.ts +157 -0
  99. package/tasks/InProcessTeammateTask/InProcessTeammateTask.tsx +126 -0
  100. package/tasks/InProcessTeammateTask/types.ts +121 -0
  101. package/tasks/LocalAgentTask/LocalAgentTask.tsx +683 -0
  102. package/tasks/LocalMainSessionTask.ts +479 -0
  103. package/tasks/LocalShellTask/LocalShellTask.tsx +523 -0
  104. package/tasks/LocalShellTask/guards.ts +41 -0
  105. package/tasks/LocalShellTask/killShellTasks.ts +76 -0
  106. package/tasks/RemoteAgentTask/RemoteAgentTask.tsx +856 -0
  107. package/tasks/pillLabel.ts +82 -0
  108. package/tasks/stopTask.ts +100 -0
  109. package/tasks/types.ts +46 -0
  110. package/upstreamproxy/relay.ts +455 -0
  111. package/upstreamproxy/upstreamproxy.ts +285 -0
  112. package/vim/motions.ts +82 -0
  113. package/vim/operators.ts +556 -0
  114. package/vim/textObjects.ts +186 -0
  115. package/vim/transitions.ts +490 -0
  116. package/vim/types.ts +199 -0
  117. package/voice/voiceModeEnabled.ts +54 -0
@@ -0,0 +1,399 @@
1
+ import { c as _c } from "react/compiler-runtime";
2
+ import { feature } from 'bun:bundle';
3
+ import { dirname } from 'path';
4
+ import React from 'react';
5
+ import { useTerminalSize } from 'src/hooks/useTerminalSize.js';
6
+ import { getOriginalCwd, switchSession } from '../bootstrap/state.js';
7
+ import type { Command } from '../commands.js';
8
+ import { LogSelector } from '../components/LogSelector.js';
9
+ import { Spinner } from '../components/Spinner.js';
10
+ import { restoreCostStateForSession } from '../cost-tracker.js';
11
+ import { setClipboard } from '../ink/termio/osc.js';
12
+ import { Box, Text } from '../ink.js';
13
+ import { useKeybinding } from '../keybindings/useKeybinding.js';
14
+ import { type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS, logEvent } from '../services/analytics/index.js';
15
+ import type { MCPServerConnection, ScopedMcpServerConfig } from '../services/mcp/types.js';
16
+ import { useAppState, useSetAppState } from '../state/AppState.js';
17
+ import type { Tool } from '../Tool.js';
18
+ import type { AgentColorName } from '../tools/AgentTool/agentColorManager.js';
19
+ import type { AgentDefinition } from '../tools/AgentTool/loadAgentsDir.js';
20
+ import { asSessionId } from '../types/ids.js';
21
+ import type { LogOption } from '../types/logs.js';
22
+ import type { Message } from '../types/message.js';
23
+ import { agenticSessionSearch } from '../utils/agenticSessionSearch.js';
24
+ import { renameRecordingForSession } from '../utils/asciicast.js';
25
+ import { updateSessionName } from '../utils/concurrentSessions.js';
26
+ import { loadConversationForResume } from '../utils/conversationRecovery.js';
27
+ import { checkCrossProjectResume } from '../utils/crossProjectResume.js';
28
+ import type { FileHistorySnapshot } from '../utils/fileHistory.js';
29
+ import { logError } from '../utils/log.js';
30
+ import { createSystemMessage } from '../utils/messages.js';
31
+ import { computeStandaloneAgentContext, restoreAgentFromSession, restoreWorktreeForResume } from '../utils/sessionRestore.js';
32
+ import { adoptResumedSessionFile, enrichLogs, isCustomTitleEnabled, loadAllProjectsMessageLogsProgressive, loadSameRepoMessageLogsProgressive, recordContentReplacement, resetSessionFilePointer, restoreSessionMetadata, type SessionLogResult } from '../utils/sessionStorage.js';
33
+ import type { ThinkingConfig } from '../utils/thinking.js';
34
+ import type { ContentReplacementRecord } from '../utils/toolResultStorage.js';
35
+ import { REPL } from './REPL.js';
36
+ function parsePrIdentifier(value: string): number | null {
37
+ const directNumber = parseInt(value, 10);
38
+ if (!isNaN(directNumber) && directNumber > 0) {
39
+ return directNumber;
40
+ }
41
+ const urlMatch = value.match(/github\.com\/[^/]+\/[^/]+\/pull\/(\d+)/);
42
+ if (urlMatch?.[1]) {
43
+ return parseInt(urlMatch[1], 10);
44
+ }
45
+ return null;
46
+ }
47
+ type Props = {
48
+ commands: Command[];
49
+ worktreePaths: string[];
50
+ initialTools: Tool[];
51
+ mcpClients?: MCPServerConnection[];
52
+ dynamicMcpConfig?: Record<string, ScopedMcpServerConfig>;
53
+ debug: boolean;
54
+ mainThreadAgentDefinition?: AgentDefinition;
55
+ autoConnectIdeFlag?: boolean;
56
+ strictMcpConfig?: boolean;
57
+ systemPrompt?: string;
58
+ appendSystemPrompt?: string;
59
+ initialSearchQuery?: string;
60
+ disableSlashCommands?: boolean;
61
+ forkSession?: boolean;
62
+ taskListId?: string;
63
+ filterByPr?: boolean | number | string;
64
+ thinkingConfig: ThinkingConfig;
65
+ onTurnComplete?: (messages: Message[]) => void | Promise<void>;
66
+ };
67
+ export function ResumeConversation({
68
+ commands,
69
+ worktreePaths,
70
+ initialTools,
71
+ mcpClients,
72
+ dynamicMcpConfig,
73
+ debug,
74
+ mainThreadAgentDefinition,
75
+ autoConnectIdeFlag,
76
+ strictMcpConfig = false,
77
+ systemPrompt,
78
+ appendSystemPrompt,
79
+ initialSearchQuery,
80
+ disableSlashCommands = false,
81
+ forkSession,
82
+ taskListId,
83
+ filterByPr,
84
+ thinkingConfig,
85
+ onTurnComplete
86
+ }: Props): React.ReactNode {
87
+ const {
88
+ rows
89
+ } = useTerminalSize();
90
+ const agentDefinitions = useAppState(s => s.agentDefinitions);
91
+ const setAppState = useSetAppState();
92
+ const [logs, setLogs] = React.useState<LogOption[]>([]);
93
+ const [loading, setLoading] = React.useState(true);
94
+ const [resuming, setResuming] = React.useState(false);
95
+ const [showAllProjects, setShowAllProjects] = React.useState(false);
96
+ const [resumeData, setResumeData] = React.useState<{
97
+ messages: Message[];
98
+ fileHistorySnapshots?: FileHistorySnapshot[];
99
+ contentReplacements?: ContentReplacementRecord[];
100
+ agentName?: string;
101
+ agentColor?: AgentColorName;
102
+ mainThreadAgentDefinition?: AgentDefinition;
103
+ } | null>(null);
104
+ const [crossProjectCommand, setCrossProjectCommand] = React.useState<string | null>(null);
105
+ const sessionLogResultRef = React.useRef<SessionLogResult | null>(null);
106
+ // Mirror of logs.length so loadMoreLogs can compute value indices outside
107
+ // the setLogs updater (keeping it pure per React's contract).
108
+ const logCountRef = React.useRef(0);
109
+ const filteredLogs = React.useMemo(() => {
110
+ let result = logs.filter(l => !l.isSidechain);
111
+ if (filterByPr !== undefined) {
112
+ if (filterByPr === true) {
113
+ result = result.filter(l_0 => l_0.prNumber !== undefined);
114
+ } else if (typeof filterByPr === 'number') {
115
+ result = result.filter(l_1 => l_1.prNumber === filterByPr);
116
+ } else if (typeof filterByPr === 'string') {
117
+ const prNumber = parsePrIdentifier(filterByPr);
118
+ if (prNumber !== null) {
119
+ result = result.filter(l_2 => l_2.prNumber === prNumber);
120
+ }
121
+ }
122
+ }
123
+ return result;
124
+ }, [logs, filterByPr]);
125
+ const isResumeWithRenameEnabled = isCustomTitleEnabled();
126
+ React.useEffect(() => {
127
+ loadSameRepoMessageLogsProgressive(worktreePaths).then(result_0 => {
128
+ sessionLogResultRef.current = result_0;
129
+ logCountRef.current = result_0.logs.length;
130
+ setLogs(result_0.logs);
131
+ setLoading(false);
132
+ }).catch(error => {
133
+ logError(error);
134
+ setLoading(false);
135
+ });
136
+ }, [worktreePaths]);
137
+ const loadMoreLogs = React.useCallback((count: number) => {
138
+ const ref = sessionLogResultRef.current;
139
+ if (!ref || ref.nextIndex >= ref.allStatLogs.length) return;
140
+ void enrichLogs(ref.allStatLogs, ref.nextIndex, count).then(result_1 => {
141
+ ref.nextIndex = result_1.nextIndex;
142
+ if (result_1.logs.length > 0) {
143
+ // enrichLogs returns fresh unshared objects — safe to mutate in place.
144
+ // Offset comes from logCountRef so the setLogs updater stays pure.
145
+ const offset = logCountRef.current;
146
+ result_1.logs.forEach((log, i) => {
147
+ log.value = offset + i;
148
+ });
149
+ setLogs(prev => prev.concat(result_1.logs));
150
+ logCountRef.current += result_1.logs.length;
151
+ } else if (ref.nextIndex < ref.allStatLogs.length) {
152
+ loadMoreLogs(count);
153
+ }
154
+ });
155
+ }, []);
156
+ const loadLogs = React.useCallback((allProjects: boolean) => {
157
+ setLoading(true);
158
+ const promise = allProjects ? loadAllProjectsMessageLogsProgressive() : loadSameRepoMessageLogsProgressive(worktreePaths);
159
+ promise.then(result_2 => {
160
+ sessionLogResultRef.current = result_2;
161
+ logCountRef.current = result_2.logs.length;
162
+ setLogs(result_2.logs);
163
+ }).catch(error_0 => {
164
+ logError(error_0);
165
+ }).finally(() => {
166
+ setLoading(false);
167
+ });
168
+ }, [worktreePaths]);
169
+ const handleToggleAllProjects = React.useCallback(() => {
170
+ const newValue = !showAllProjects;
171
+ setShowAllProjects(newValue);
172
+ loadLogs(newValue);
173
+ }, [showAllProjects, loadLogs]);
174
+ function onCancel() {
175
+ // eslint-disable-next-line custom-rules/no-process-exit
176
+ process.exit(1);
177
+ }
178
+ async function onSelect(log_0: LogOption) {
179
+ setResuming(true);
180
+ const resumeStart = performance.now();
181
+ const crossProjectCheck = checkCrossProjectResume(log_0, showAllProjects, worktreePaths);
182
+ if (crossProjectCheck.isCrossProject) {
183
+ if (!crossProjectCheck.isSameRepoWorktree) {
184
+ const raw = await setClipboard(crossProjectCheck.command);
185
+ if (raw) process.stdout.write(raw);
186
+ setCrossProjectCommand(crossProjectCheck.command);
187
+ return;
188
+ }
189
+ }
190
+ try {
191
+ const result_3 = await loadConversationForResume(log_0, undefined);
192
+ if (!result_3) {
193
+ throw new Error('Failed to load conversation');
194
+ }
195
+ if (feature('COORDINATOR_MODE')) {
196
+ /* eslint-disable @typescript-eslint/no-require-imports */
197
+ const coordinatorModule = require('../coordinator/coordinatorMode.js') as typeof import('../coordinator/coordinatorMode.js');
198
+ /* eslint-enable @typescript-eslint/no-require-imports */
199
+ const warning = coordinatorModule.matchSessionMode(result_3.mode);
200
+ if (warning) {
201
+ /* eslint-disable @typescript-eslint/no-require-imports */
202
+ const {
203
+ getAgentDefinitionsWithOverrides,
204
+ getActiveAgentsFromList
205
+ } = require('../tools/AgentTool/loadAgentsDir.js') as typeof import('../tools/AgentTool/loadAgentsDir.js');
206
+ /* eslint-enable @typescript-eslint/no-require-imports */
207
+ getAgentDefinitionsWithOverrides.cache.clear?.();
208
+ const freshAgentDefs = await getAgentDefinitionsWithOverrides(getOriginalCwd());
209
+ setAppState(prev_0 => ({
210
+ ...prev_0,
211
+ agentDefinitions: {
212
+ ...freshAgentDefs,
213
+ allAgents: freshAgentDefs.allAgents,
214
+ activeAgents: getActiveAgentsFromList(freshAgentDefs.allAgents)
215
+ }
216
+ }));
217
+ result_3.messages.push(createSystemMessage(warning, 'warning'));
218
+ }
219
+ }
220
+ if (result_3.sessionId && !forkSession) {
221
+ switchSession(asSessionId(result_3.sessionId), log_0.fullPath ? dirname(log_0.fullPath) : null);
222
+ await renameRecordingForSession();
223
+ await resetSessionFilePointer();
224
+ restoreCostStateForSession(result_3.sessionId);
225
+ } else if (forkSession && result_3.contentReplacements?.length) {
226
+ await recordContentReplacement(result_3.contentReplacements);
227
+ }
228
+ const {
229
+ agentDefinition: resolvedAgentDef
230
+ } = restoreAgentFromSession(result_3.agentSetting, mainThreadAgentDefinition, agentDefinitions);
231
+ setAppState(prev_1 => ({
232
+ ...prev_1,
233
+ agent: resolvedAgentDef?.agentType
234
+ }));
235
+ if (feature('COORDINATOR_MODE')) {
236
+ /* eslint-disable @typescript-eslint/no-require-imports */
237
+ const {
238
+ saveMode
239
+ } = require('../utils/sessionStorage.js');
240
+ const {
241
+ isCoordinatorMode
242
+ } = require('../coordinator/coordinatorMode.js') as typeof import('../coordinator/coordinatorMode.js');
243
+ /* eslint-enable @typescript-eslint/no-require-imports */
244
+ saveMode(isCoordinatorMode() ? 'coordinator' : 'normal');
245
+ }
246
+ const standaloneAgentContext = computeStandaloneAgentContext(result_3.agentName, result_3.agentColor);
247
+ if (standaloneAgentContext) {
248
+ setAppState(prev_2 => ({
249
+ ...prev_2,
250
+ standaloneAgentContext
251
+ }));
252
+ }
253
+ void updateSessionName(result_3.agentName);
254
+ restoreSessionMetadata(forkSession ? {
255
+ ...result_3,
256
+ worktreeSession: undefined
257
+ } : result_3);
258
+ if (!forkSession) {
259
+ restoreWorktreeForResume(result_3.worktreeSession);
260
+ if (result_3.sessionId) {
261
+ adoptResumedSessionFile();
262
+ }
263
+ }
264
+ if (feature('CONTEXT_COLLAPSE')) {
265
+ /* eslint-disable @typescript-eslint/no-require-imports */
266
+ ;
267
+ (require('../services/contextCollapse/persist.js') as typeof import('../services/contextCollapse/persist.js')).restoreFromEntries(result_3.contextCollapseCommits ?? [], result_3.contextCollapseSnapshot);
268
+ /* eslint-enable @typescript-eslint/no-require-imports */
269
+ }
270
+ logEvent('tengu_session_resumed', {
271
+ entrypoint: 'picker' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
272
+ success: true,
273
+ resume_duration_ms: Math.round(performance.now() - resumeStart)
274
+ });
275
+ setLogs([]);
276
+ setResumeData({
277
+ messages: result_3.messages,
278
+ fileHistorySnapshots: result_3.fileHistorySnapshots,
279
+ contentReplacements: result_3.contentReplacements,
280
+ agentName: result_3.agentName,
281
+ agentColor: (result_3.agentColor === 'default' ? undefined : result_3.agentColor) as AgentColorName | undefined,
282
+ mainThreadAgentDefinition: resolvedAgentDef
283
+ });
284
+ } catch (e) {
285
+ logEvent('tengu_session_resumed', {
286
+ entrypoint: 'picker' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
287
+ success: false
288
+ });
289
+ logError(e as Error);
290
+ throw e;
291
+ }
292
+ }
293
+ if (crossProjectCommand) {
294
+ return <CrossProjectMessage command={crossProjectCommand} />;
295
+ }
296
+ if (resumeData) {
297
+ return <REPL debug={debug} commands={commands} initialTools={initialTools} initialMessages={resumeData.messages} initialFileHistorySnapshots={resumeData.fileHistorySnapshots} initialContentReplacements={resumeData.contentReplacements} initialAgentName={resumeData.agentName} initialAgentColor={resumeData.agentColor} mcpClients={mcpClients} dynamicMcpConfig={dynamicMcpConfig} strictMcpConfig={strictMcpConfig} systemPrompt={systemPrompt} appendSystemPrompt={appendSystemPrompt} mainThreadAgentDefinition={resumeData.mainThreadAgentDefinition} autoConnectIdeFlag={autoConnectIdeFlag} disableSlashCommands={disableSlashCommands} taskListId={taskListId} thinkingConfig={thinkingConfig} onTurnComplete={onTurnComplete} />;
298
+ }
299
+ if (loading) {
300
+ return <Box>
301
+ <Spinner />
302
+ <Text> Loading conversations…</Text>
303
+ </Box>;
304
+ }
305
+ if (resuming) {
306
+ return <Box>
307
+ <Spinner />
308
+ <Text> Resuming conversation…</Text>
309
+ </Box>;
310
+ }
311
+ if (filteredLogs.length === 0) {
312
+ return <NoConversationsMessage />;
313
+ }
314
+ return <LogSelector logs={filteredLogs} maxHeight={rows} onCancel={onCancel} onSelect={onSelect} onLogsChanged={isResumeWithRenameEnabled ? () => loadLogs(showAllProjects) : undefined} onLoadMore={loadMoreLogs} initialSearchQuery={initialSearchQuery} showAllProjects={showAllProjects} onToggleAllProjects={handleToggleAllProjects} onAgenticSearch={agenticSessionSearch} />;
315
+ }
316
+ function NoConversationsMessage() {
317
+ const $ = _c(2);
318
+ let t0;
319
+ if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
320
+ t0 = {
321
+ context: "Global"
322
+ };
323
+ $[0] = t0;
324
+ } else {
325
+ t0 = $[0];
326
+ }
327
+ useKeybinding("app:interrupt", _temp, t0);
328
+ let t1;
329
+ if ($[1] === Symbol.for("react.memo_cache_sentinel")) {
330
+ t1 = <Box flexDirection="column"><Text>No conversations found to resume.</Text><Text dimColor={true}>Press Ctrl+C to exit and start a new conversation.</Text></Box>;
331
+ $[1] = t1;
332
+ } else {
333
+ t1 = $[1];
334
+ }
335
+ return t1;
336
+ }
337
+ function _temp() {
338
+ process.exit(1);
339
+ }
340
+ function CrossProjectMessage(t0) {
341
+ const $ = _c(8);
342
+ const {
343
+ command
344
+ } = t0;
345
+ let t1;
346
+ if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
347
+ t1 = [];
348
+ $[0] = t1;
349
+ } else {
350
+ t1 = $[0];
351
+ }
352
+ React.useEffect(_temp3, t1);
353
+ let t2;
354
+ if ($[1] === Symbol.for("react.memo_cache_sentinel")) {
355
+ t2 = <Text>This conversation is from a different directory.</Text>;
356
+ $[1] = t2;
357
+ } else {
358
+ t2 = $[1];
359
+ }
360
+ let t3;
361
+ if ($[2] === Symbol.for("react.memo_cache_sentinel")) {
362
+ t3 = <Text>To resume, run:</Text>;
363
+ $[2] = t3;
364
+ } else {
365
+ t3 = $[2];
366
+ }
367
+ let t4;
368
+ if ($[3] !== command) {
369
+ t4 = <Box flexDirection="column">{t3}<Text> {command}</Text></Box>;
370
+ $[3] = command;
371
+ $[4] = t4;
372
+ } else {
373
+ t4 = $[4];
374
+ }
375
+ let t5;
376
+ if ($[5] === Symbol.for("react.memo_cache_sentinel")) {
377
+ t5 = <Text dimColor={true}>(Command copied to clipboard)</Text>;
378
+ $[5] = t5;
379
+ } else {
380
+ t5 = $[5];
381
+ }
382
+ let t6;
383
+ if ($[6] !== t4) {
384
+ t6 = <Box flexDirection="column" gap={1}>{t2}{t4}{t5}</Box>;
385
+ $[6] = t4;
386
+ $[7] = t6;
387
+ } else {
388
+ t6 = $[7];
389
+ }
390
+ return t6;
391
+ }
392
+ function _temp3() {
393
+ const timeout = setTimeout(_temp2, 100);
394
+ return () => clearTimeout(timeout);
395
+ }
396
+ function _temp2() {
397
+ process.exit(0);
398
+ }
399
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["feature","dirname","React","useTerminalSize","getOriginalCwd","switchSession","Command","LogSelector","Spinner","restoreCostStateForSession","setClipboard","Box","Text","useKeybinding","AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS","logEvent","MCPServerConnection","ScopedMcpServerConfig","useAppState","useSetAppState","Tool","AgentColorName","AgentDefinition","asSessionId","LogOption","Message","agenticSessionSearch","renameRecordingForSession","updateSessionName","loadConversationForResume","checkCrossProjectResume","FileHistorySnapshot","logError","createSystemMessage","computeStandaloneAgentContext","restoreAgentFromSession","restoreWorktreeForResume","adoptResumedSessionFile","enrichLogs","isCustomTitleEnabled","loadAllProjectsMessageLogsProgressive","loadSameRepoMessageLogsProgressive","recordContentReplacement","resetSessionFilePointer","restoreSessionMetadata","SessionLogResult","ThinkingConfig","ContentReplacementRecord","REPL","parsePrIdentifier","value","directNumber","parseInt","isNaN","urlMatch","match","Props","commands","worktreePaths","initialTools","mcpClients","dynamicMcpConfig","Record","debug","mainThreadAgentDefinition","autoConnectIdeFlag","strictMcpConfig","systemPrompt","appendSystemPrompt","initialSearchQuery","disableSlashCommands","forkSession","taskListId","filterByPr","thinkingConfig","onTurnComplete","messages","Promise","ResumeConversation","ReactNode","rows","agentDefinitions","s","setAppState","logs","setLogs","useState","loading","setLoading","resuming","setResuming","showAllProjects","setShowAllProjects","resumeData","setResumeData","fileHistorySnapshots","contentReplacements","agentName","agentColor","crossProjectCommand","setCrossProjectCommand","sessionLogResultRef","useRef","logCountRef","filteredLogs","useMemo","result","filter","l","isSidechain","undefined","prNumber","isResumeWithRenameEnabled","useEffect","then","current","length","catch","error","loadMoreLogs","useCallback","count","ref","nextIndex","allStatLogs","offset","forEach","log","i","prev","concat","loadLogs","allProjects","promise","finally","handleToggleAllProjects","newValue","onCancel","process","exit","onSelect","resumeStart","performance","now","crossProjectCheck","isCrossProject","isSameRepoWorktree","raw","command","stdout","write","Error","coordinatorModule","require","warning","matchSessionMode","mode","getAgentDefinitionsWithOverrides","getActiveAgentsFromList","cache","clear","freshAgentDefs","allAgents","activeAgents","push","sessionId","fullPath","agentDefinition","resolvedAgentDef","agentSetting","agent","agentType","saveMode","isCoordinatorMode","standaloneAgentContext","worktreeSession","restoreFromEntries","contextCollapseCommits","contextCollapseSnapshot","entrypoint","success","resume_duration_ms","Math","round","e","NoConversationsMessage","$","_c","t0","Symbol","for","context","_temp","t1","CrossProjectMessage","_temp3","t2","t3","t4","t5","t6","timeout","setTimeout","_temp2","clearTimeout"],"sources":["ResumeConversation.tsx"],"sourcesContent":["import { feature } from 'bun:bundle'\nimport { dirname } from 'path'\nimport React from 'react'\nimport { useTerminalSize } from 'src/hooks/useTerminalSize.js'\nimport { getOriginalCwd, switchSession } from '../bootstrap/state.js'\nimport type { Command } from '../commands.js'\nimport { LogSelector } from '../components/LogSelector.js'\nimport { Spinner } from '../components/Spinner.js'\nimport { restoreCostStateForSession } from '../cost-tracker.js'\nimport { setClipboard } from '../ink/termio/osc.js'\nimport { Box, Text } from '../ink.js'\nimport { useKeybinding } from '../keybindings/useKeybinding.js'\nimport {\n  type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n  logEvent,\n} from '../services/analytics/index.js'\nimport type {\n  MCPServerConnection,\n  ScopedMcpServerConfig,\n} from '../services/mcp/types.js'\nimport { useAppState, useSetAppState } from '../state/AppState.js'\nimport type { Tool } from '../Tool.js'\nimport type { AgentColorName } from '../tools/AgentTool/agentColorManager.js'\nimport type { AgentDefinition } from '../tools/AgentTool/loadAgentsDir.js'\nimport { asSessionId } from '../types/ids.js'\nimport type { LogOption } from '../types/logs.js'\nimport type { Message } from '../types/message.js'\nimport { agenticSessionSearch } from '../utils/agenticSessionSearch.js'\nimport { renameRecordingForSession } from '../utils/asciicast.js'\nimport { updateSessionName } from '../utils/concurrentSessions.js'\nimport { loadConversationForResume } from '../utils/conversationRecovery.js'\nimport { checkCrossProjectResume } from '../utils/crossProjectResume.js'\nimport type { FileHistorySnapshot } from '../utils/fileHistory.js'\nimport { logError } from '../utils/log.js'\nimport { createSystemMessage } from '../utils/messages.js'\nimport {\n  computeStandaloneAgentContext,\n  restoreAgentFromSession,\n  restoreWorktreeForResume,\n} from '../utils/sessionRestore.js'\nimport {\n  adoptResumedSessionFile,\n  enrichLogs,\n  isCustomTitleEnabled,\n  loadAllProjectsMessageLogsProgressive,\n  loadSameRepoMessageLogsProgressive,\n  recordContentReplacement,\n  resetSessionFilePointer,\n  restoreSessionMetadata,\n  type SessionLogResult,\n} from '../utils/sessionStorage.js'\nimport type { ThinkingConfig } from '../utils/thinking.js'\nimport type { ContentReplacementRecord } from '../utils/toolResultStorage.js'\nimport { REPL } from './REPL.js'\n\nfunction parsePrIdentifier(value: string): number | null {\n  const directNumber = parseInt(value, 10)\n  if (!isNaN(directNumber) && directNumber > 0) {\n    return directNumber\n  }\n  const urlMatch = value.match(/github\\.com\\/[^/]+\\/[^/]+\\/pull\\/(\\d+)/)\n  if (urlMatch?.[1]) {\n    return parseInt(urlMatch[1], 10)\n  }\n  return null\n}\n\ntype Props = {\n  commands: Command[]\n  worktreePaths: string[]\n  initialTools: Tool[]\n  mcpClients?: MCPServerConnection[]\n  dynamicMcpConfig?: Record<string, ScopedMcpServerConfig>\n  debug: boolean\n  mainThreadAgentDefinition?: AgentDefinition\n  autoConnectIdeFlag?: boolean\n  strictMcpConfig?: boolean\n  systemPrompt?: string\n  appendSystemPrompt?: string\n  initialSearchQuery?: string\n  disableSlashCommands?: boolean\n  forkSession?: boolean\n  taskListId?: string\n  filterByPr?: boolean | number | string\n  thinkingConfig: ThinkingConfig\n  onTurnComplete?: (messages: Message[]) => void | Promise<void>\n}\n\nexport function ResumeConversation({\n  commands,\n  worktreePaths,\n  initialTools,\n  mcpClients,\n  dynamicMcpConfig,\n  debug,\n  mainThreadAgentDefinition,\n  autoConnectIdeFlag,\n  strictMcpConfig = false,\n  systemPrompt,\n  appendSystemPrompt,\n  initialSearchQuery,\n  disableSlashCommands = false,\n  forkSession,\n  taskListId,\n  filterByPr,\n  thinkingConfig,\n  onTurnComplete,\n}: Props): React.ReactNode {\n  const { rows } = useTerminalSize()\n  const agentDefinitions = useAppState(s => s.agentDefinitions)\n  const setAppState = useSetAppState()\n  const [logs, setLogs] = React.useState<LogOption[]>([])\n  const [loading, setLoading] = React.useState(true)\n  const [resuming, setResuming] = React.useState(false)\n  const [showAllProjects, setShowAllProjects] = React.useState(false)\n  const [resumeData, setResumeData] = React.useState<{\n    messages: Message[]\n    fileHistorySnapshots?: FileHistorySnapshot[]\n    contentReplacements?: ContentReplacementRecord[]\n    agentName?: string\n    agentColor?: AgentColorName\n    mainThreadAgentDefinition?: AgentDefinition\n  } | null>(null)\n  const [crossProjectCommand, setCrossProjectCommand] = React.useState<\n    string | null\n  >(null)\n  const sessionLogResultRef = React.useRef<SessionLogResult | null>(null)\n  // Mirror of logs.length so loadMoreLogs can compute value indices outside\n  // the setLogs updater (keeping it pure per React's contract).\n  const logCountRef = React.useRef(0)\n\n  const filteredLogs = React.useMemo(() => {\n    let result = logs.filter(l => !l.isSidechain)\n    if (filterByPr !== undefined) {\n      if (filterByPr === true) {\n        result = result.filter(l => l.prNumber !== undefined)\n      } else if (typeof filterByPr === 'number') {\n        result = result.filter(l => l.prNumber === filterByPr)\n      } else if (typeof filterByPr === 'string') {\n        const prNumber = parsePrIdentifier(filterByPr)\n        if (prNumber !== null) {\n          result = result.filter(l => l.prNumber === prNumber)\n        }\n      }\n    }\n    return result\n  }, [logs, filterByPr])\n  const isResumeWithRenameEnabled = isCustomTitleEnabled()\n\n  React.useEffect(() => {\n    loadSameRepoMessageLogsProgressive(worktreePaths)\n      .then(result => {\n        sessionLogResultRef.current = result\n        logCountRef.current = result.logs.length\n        setLogs(result.logs)\n        setLoading(false)\n      })\n      .catch(error => {\n        logError(error)\n        setLoading(false)\n      })\n  }, [worktreePaths])\n\n  const loadMoreLogs = React.useCallback((count: number) => {\n    const ref = sessionLogResultRef.current\n    if (!ref || ref.nextIndex >= ref.allStatLogs.length) return\n\n    void enrichLogs(ref.allStatLogs, ref.nextIndex, count).then(result => {\n      ref.nextIndex = result.nextIndex\n      if (result.logs.length > 0) {\n        // enrichLogs returns fresh unshared objects — safe to mutate in place.\n        // Offset comes from logCountRef so the setLogs updater stays pure.\n        const offset = logCountRef.current\n        result.logs.forEach((log, i) => {\n          log.value = offset + i\n        })\n        setLogs(prev => prev.concat(result.logs))\n        logCountRef.current += result.logs.length\n      } else if (ref.nextIndex < ref.allStatLogs.length) {\n        loadMoreLogs(count)\n      }\n    })\n  }, [])\n\n  const loadLogs = React.useCallback(\n    (allProjects: boolean) => {\n      setLoading(true)\n      const promise = allProjects\n        ? loadAllProjectsMessageLogsProgressive()\n        : loadSameRepoMessageLogsProgressive(worktreePaths)\n      promise\n        .then(result => {\n          sessionLogResultRef.current = result\n          logCountRef.current = result.logs.length\n          setLogs(result.logs)\n        })\n        .catch(error => {\n          logError(error)\n        })\n        .finally(() => {\n          setLoading(false)\n        })\n    },\n    [worktreePaths],\n  )\n\n  const handleToggleAllProjects = React.useCallback(() => {\n    const newValue = !showAllProjects\n    setShowAllProjects(newValue)\n    loadLogs(newValue)\n  }, [showAllProjects, loadLogs])\n\n  function onCancel() {\n    // eslint-disable-next-line custom-rules/no-process-exit\n    process.exit(1)\n  }\n\n  async function onSelect(log: LogOption) {\n    setResuming(true)\n    const resumeStart = performance.now()\n\n    const crossProjectCheck = checkCrossProjectResume(\n      log,\n      showAllProjects,\n      worktreePaths,\n    )\n    if (crossProjectCheck.isCrossProject) {\n      if (!crossProjectCheck.isSameRepoWorktree) {\n        const raw = await setClipboard(crossProjectCheck.command)\n        if (raw) process.stdout.write(raw)\n        setCrossProjectCommand(crossProjectCheck.command)\n        return\n      }\n    }\n\n    try {\n      const result = await loadConversationForResume(log, undefined)\n      if (!result) {\n        throw new Error('Failed to load conversation')\n      }\n\n      if (feature('COORDINATOR_MODE')) {\n        /* eslint-disable @typescript-eslint/no-require-imports */\n        const coordinatorModule =\n          require('../coordinator/coordinatorMode.js') as typeof import('../coordinator/coordinatorMode.js')\n        /* eslint-enable @typescript-eslint/no-require-imports */\n        const warning = coordinatorModule.matchSessionMode(result.mode)\n        if (warning) {\n          /* eslint-disable @typescript-eslint/no-require-imports */\n          const { getAgentDefinitionsWithOverrides, getActiveAgentsFromList } =\n            require('../tools/AgentTool/loadAgentsDir.js') as typeof import('../tools/AgentTool/loadAgentsDir.js')\n          /* eslint-enable @typescript-eslint/no-require-imports */\n          getAgentDefinitionsWithOverrides.cache.clear?.()\n          const freshAgentDefs = await getAgentDefinitionsWithOverrides(\n            getOriginalCwd(),\n          )\n          setAppState(prev => ({\n            ...prev,\n            agentDefinitions: {\n              ...freshAgentDefs,\n              allAgents: freshAgentDefs.allAgents,\n              activeAgents: getActiveAgentsFromList(freshAgentDefs.allAgents),\n            },\n          }))\n          result.messages.push(createSystemMessage(warning, 'warning'))\n        }\n      }\n\n      if (result.sessionId && !forkSession) {\n        switchSession(\n          asSessionId(result.sessionId),\n          log.fullPath ? dirname(log.fullPath) : null,\n        )\n        await renameRecordingForSession()\n        await resetSessionFilePointer()\n        restoreCostStateForSession(result.sessionId)\n      } else if (forkSession && result.contentReplacements?.length) {\n        await recordContentReplacement(result.contentReplacements)\n      }\n\n      const { agentDefinition: resolvedAgentDef } = restoreAgentFromSession(\n        result.agentSetting,\n        mainThreadAgentDefinition,\n        agentDefinitions,\n      )\n      setAppState(prev => ({ ...prev, agent: resolvedAgentDef?.agentType }))\n\n      if (feature('COORDINATOR_MODE')) {\n        /* eslint-disable @typescript-eslint/no-require-imports */\n        const { saveMode } = require('../utils/sessionStorage.js')\n        const { isCoordinatorMode } =\n          require('../coordinator/coordinatorMode.js') as typeof import('../coordinator/coordinatorMode.js')\n        /* eslint-enable @typescript-eslint/no-require-imports */\n        saveMode(isCoordinatorMode() ? 'coordinator' : 'normal')\n      }\n\n      const standaloneAgentContext = computeStandaloneAgentContext(\n        result.agentName,\n        result.agentColor,\n      )\n      if (standaloneAgentContext) {\n        setAppState(prev => ({ ...prev, standaloneAgentContext }))\n      }\n      void updateSessionName(result.agentName)\n\n      restoreSessionMetadata(\n        forkSession ? { ...result, worktreeSession: undefined } : result,\n      )\n\n      if (!forkSession) {\n        restoreWorktreeForResume(result.worktreeSession)\n        if (result.sessionId) {\n          adoptResumedSessionFile()\n        }\n      }\n\n      if (feature('CONTEXT_COLLAPSE')) {\n        /* eslint-disable @typescript-eslint/no-require-imports */\n        ;(\n          require('../services/contextCollapse/persist.js') as typeof import('../services/contextCollapse/persist.js')\n        ).restoreFromEntries(\n          result.contextCollapseCommits ?? [],\n          result.contextCollapseSnapshot,\n        )\n        /* eslint-enable @typescript-eslint/no-require-imports */\n      }\n\n      logEvent('tengu_session_resumed', {\n        entrypoint:\n          'picker' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        success: true,\n        resume_duration_ms: Math.round(performance.now() - resumeStart),\n      })\n\n      setLogs([])\n      setResumeData({\n        messages: result.messages,\n        fileHistorySnapshots: result.fileHistorySnapshots,\n        contentReplacements: result.contentReplacements,\n        agentName: result.agentName,\n        agentColor: (result.agentColor === 'default'\n          ? undefined\n          : result.agentColor) as AgentColorName | undefined,\n        mainThreadAgentDefinition: resolvedAgentDef,\n      })\n    } catch (e) {\n      logEvent('tengu_session_resumed', {\n        entrypoint:\n          'picker' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        success: false,\n      })\n      logError(e as Error)\n      throw e\n    }\n  }\n\n  if (crossProjectCommand) {\n    return <CrossProjectMessage command={crossProjectCommand} />\n  }\n\n  if (resumeData) {\n    return (\n      <REPL\n        debug={debug}\n        commands={commands}\n        initialTools={initialTools}\n        initialMessages={resumeData.messages}\n        initialFileHistorySnapshots={resumeData.fileHistorySnapshots}\n        initialContentReplacements={resumeData.contentReplacements}\n        initialAgentName={resumeData.agentName}\n        initialAgentColor={resumeData.agentColor}\n        mcpClients={mcpClients}\n        dynamicMcpConfig={dynamicMcpConfig}\n        strictMcpConfig={strictMcpConfig}\n        systemPrompt={systemPrompt}\n        appendSystemPrompt={appendSystemPrompt}\n        mainThreadAgentDefinition={resumeData.mainThreadAgentDefinition}\n        autoConnectIdeFlag={autoConnectIdeFlag}\n        disableSlashCommands={disableSlashCommands}\n        taskListId={taskListId}\n        thinkingConfig={thinkingConfig}\n        onTurnComplete={onTurnComplete}\n      />\n    )\n  }\n\n  if (loading) {\n    return (\n      <Box>\n        <Spinner />\n        <Text> Loading conversations…</Text>\n      </Box>\n    )\n  }\n\n  if (resuming) {\n    return (\n      <Box>\n        <Spinner />\n        <Text> Resuming conversation…</Text>\n      </Box>\n    )\n  }\n\n  if (filteredLogs.length === 0) {\n    return <NoConversationsMessage />\n  }\n\n  return (\n    <LogSelector\n      logs={filteredLogs}\n      maxHeight={rows}\n      onCancel={onCancel}\n      onSelect={onSelect}\n      onLogsChanged={\n        isResumeWithRenameEnabled ? () => loadLogs(showAllProjects) : undefined\n      }\n      onLoadMore={loadMoreLogs}\n      initialSearchQuery={initialSearchQuery}\n      showAllProjects={showAllProjects}\n      onToggleAllProjects={handleToggleAllProjects}\n      onAgenticSearch={agenticSessionSearch}\n    />\n  )\n}\n\nfunction NoConversationsMessage(): React.ReactNode {\n  useKeybinding(\n    'app:interrupt',\n    () => {\n      // eslint-disable-next-line custom-rules/no-process-exit\n      process.exit(1)\n    },\n    { context: 'Global' },\n  )\n\n  return (\n    <Box flexDirection=\"column\">\n      <Text>No conversations found to resume.</Text>\n      <Text dimColor>Press Ctrl+C to exit and start a new conversation.</Text>\n    </Box>\n  )\n}\n\nfunction CrossProjectMessage({\n  command,\n}: {\n  command: string\n}): React.ReactNode {\n  React.useEffect(() => {\n    const timeout = setTimeout(() => {\n      // eslint-disable-next-line custom-rules/no-process-exit\n      process.exit(0)\n    }, 100)\n    return () => clearTimeout(timeout)\n  }, [])\n\n  return (\n    <Box flexDirection=\"column\" gap={1}>\n      <Text>This conversation is from a different directory.</Text>\n      <Box flexDirection=\"column\">\n        <Text>To resume, run:</Text>\n        <Text> {command}</Text>\n      </Box>\n      <Text dimColor>(Command copied to clipboard)</Text>\n    </Box>\n  )\n}\n"],"mappings":";AAAA,SAASA,OAAO,QAAQ,YAAY;AACpC,SAASC,OAAO,QAAQ,MAAM;AAC9B,OAAOC,KAAK,MAAM,OAAO;AACzB,SAASC,eAAe,QAAQ,8BAA8B;AAC9D,SAASC,cAAc,EAAEC,aAAa,QAAQ,uBAAuB;AACrE,cAAcC,OAAO,QAAQ,gBAAgB;AAC7C,SAASC,WAAW,QAAQ,8BAA8B;AAC1D,SAASC,OAAO,QAAQ,0BAA0B;AAClD,SAASC,0BAA0B,QAAQ,oBAAoB;AAC/D,SAASC,YAAY,QAAQ,sBAAsB;AACnD,SAASC,GAAG,EAAEC,IAAI,QAAQ,WAAW;AACrC,SAASC,aAAa,QAAQ,iCAAiC;AAC/D,SACE,KAAKC,0DAA0D,EAC/DC,QAAQ,QACH,gCAAgC;AACvC,cACEC,mBAAmB,EACnBC,qBAAqB,QAChB,0BAA0B;AACjC,SAASC,WAAW,EAAEC,cAAc,QAAQ,sBAAsB;AAClE,cAAcC,IAAI,QAAQ,YAAY;AACtC,cAAcC,cAAc,QAAQ,yCAAyC;AAC7E,cAAcC,eAAe,QAAQ,qCAAqC;AAC1E,SAASC,WAAW,QAAQ,iBAAiB;AAC7C,cAAcC,SAAS,QAAQ,kBAAkB;AACjD,cAAcC,OAAO,QAAQ,qBAAqB;AAClD,SAASC,oBAAoB,QAAQ,kCAAkC;AACvE,SAASC,yBAAyB,QAAQ,uBAAuB;AACjE,SAASC,iBAAiB,QAAQ,gCAAgC;AAClE,SAASC,yBAAyB,QAAQ,kCAAkC;AAC5E,SAASC,uBAAuB,QAAQ,gCAAgC;AACxE,cAAcC,mBAAmB,QAAQ,yBAAyB;AAClE,SAASC,QAAQ,QAAQ,iBAAiB;AAC1C,SAASC,mBAAmB,QAAQ,sBAAsB;AAC1D,SACEC,6BAA6B,EAC7BC,uBAAuB,EACvBC,wBAAwB,QACnB,4BAA4B;AACnC,SACEC,uBAAuB,EACvBC,UAAU,EACVC,oBAAoB,EACpBC,qCAAqC,EACrCC,kCAAkC,EAClCC,wBAAwB,EACxBC,uBAAuB,EACvBC,sBAAsB,EACtB,KAAKC,gBAAgB,QAChB,4BAA4B;AACnC,cAAcC,cAAc,QAAQ,sBAAsB;AAC1D,cAAcC,wBAAwB,QAAQ,+BAA+B;AAC7E,SAASC,IAAI,QAAQ,WAAW;AAEhC,SAASC,iBAAiBA,CAACC,KAAK,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;EACvD,MAAMC,YAAY,GAAGC,QAAQ,CAACF,KAAK,EAAE,EAAE,CAAC;EACxC,IAAI,CAACG,KAAK,CAACF,YAAY,CAAC,IAAIA,YAAY,GAAG,CAAC,EAAE;IAC5C,OAAOA,YAAY;EACrB;EACA,MAAMG,QAAQ,GAAGJ,KAAK,CAACK,KAAK,CAAC,wCAAwC,CAAC;EACtE,IAAID,QAAQ,GAAG,CAAC,CAAC,EAAE;IACjB,OAAOF,QAAQ,CAACE,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;EAClC;EACA,OAAO,IAAI;AACb;AAEA,KAAKE,KAAK,GAAG;EACXC,QAAQ,EAAEnD,OAAO,EAAE;EACnBoD,aAAa,EAAE,MAAM,EAAE;EACvBC,YAAY,EAAEvC,IAAI,EAAE;EACpBwC,UAAU,CAAC,EAAE5C,mBAAmB,EAAE;EAClC6C,gBAAgB,CAAC,EAAEC,MAAM,CAAC,MAAM,EAAE7C,qBAAqB,CAAC;EACxD8C,KAAK,EAAE,OAAO;EACdC,yBAAyB,CAAC,EAAE1C,eAAe;EAC3C2C,kBAAkB,CAAC,EAAE,OAAO;EAC5BC,eAAe,CAAC,EAAE,OAAO;EACzBC,YAAY,CAAC,EAAE,MAAM;EACrBC,kBAAkB,CAAC,EAAE,MAAM;EAC3BC,kBAAkB,CAAC,EAAE,MAAM;EAC3BC,oBAAoB,CAAC,EAAE,OAAO;EAC9BC,WAAW,CAAC,EAAE,OAAO;EACrBC,UAAU,CAAC,EAAE,MAAM;EACnBC,UAAU,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,MAAM;EACtCC,cAAc,EAAE5B,cAAc;EAC9B6B,cAAc,CAAC,EAAE,CAACC,QAAQ,EAAEnD,OAAO,EAAE,EAAE,GAAG,IAAI,GAAGoD,OAAO,CAAC,IAAI,CAAC;AAChE,CAAC;AAED,OAAO,SAASC,kBAAkBA,CAAC;EACjCrB,QAAQ;EACRC,aAAa;EACbC,YAAY;EACZC,UAAU;EACVC,gBAAgB;EAChBE,KAAK;EACLC,yBAAyB;EACzBC,kBAAkB;EAClBC,eAAe,GAAG,KAAK;EACvBC,YAAY;EACZC,kBAAkB;EAClBC,kBAAkB;EAClBC,oBAAoB,GAAG,KAAK;EAC5BC,WAAW;EACXC,UAAU;EACVC,UAAU;EACVC,cAAc;EACdC;AACK,CAAN,EAAEnB,KAAK,CAAC,EAAEtD,KAAK,CAAC6E,SAAS,CAAC;EACzB,MAAM;IAAEC;EAAK,CAAC,GAAG7E,eAAe,CAAC,CAAC;EAClC,MAAM8E,gBAAgB,GAAG/D,WAAW,CAACgE,CAAC,IAAIA,CAAC,CAACD,gBAAgB,CAAC;EAC7D,MAAME,WAAW,GAAGhE,cAAc,CAAC,CAAC;EACpC,MAAM,CAACiE,IAAI,EAAEC,OAAO,CAAC,GAAGnF,KAAK,CAACoF,QAAQ,CAAC9D,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC;EACvD,MAAM,CAAC+D,OAAO,EAAEC,UAAU,CAAC,GAAGtF,KAAK,CAACoF,QAAQ,CAAC,IAAI,CAAC;EAClD,MAAM,CAACG,QAAQ,EAAEC,WAAW,CAAC,GAAGxF,KAAK,CAACoF,QAAQ,CAAC,KAAK,CAAC;EACrD,MAAM,CAACK,eAAe,EAAEC,kBAAkB,CAAC,GAAG1F,KAAK,CAACoF,QAAQ,CAAC,KAAK,CAAC;EACnE,MAAM,CAACO,UAAU,EAAEC,aAAa,CAAC,GAAG5F,KAAK,CAACoF,QAAQ,CAAC;IACjDV,QAAQ,EAAEnD,OAAO,EAAE;IACnBsE,oBAAoB,CAAC,EAAEhE,mBAAmB,EAAE;IAC5CiE,mBAAmB,CAAC,EAAEjD,wBAAwB,EAAE;IAChDkD,SAAS,CAAC,EAAE,MAAM;IAClBC,UAAU,CAAC,EAAE7E,cAAc;IAC3B2C,yBAAyB,CAAC,EAAE1C,eAAe;EAC7C,CAAC,GAAG,IAAI,CAAC,CAAC,IAAI,CAAC;EACf,MAAM,CAAC6E,mBAAmB,EAAEC,sBAAsB,CAAC,GAAGlG,KAAK,CAACoF,QAAQ,CAClE,MAAM,GAAG,IAAI,CACd,CAAC,IAAI,CAAC;EACP,MAAMe,mBAAmB,GAAGnG,KAAK,CAACoG,MAAM,CAACzD,gBAAgB,GAAG,IAAI,CAAC,CAAC,IAAI,CAAC;EACvE;EACA;EACA,MAAM0D,WAAW,GAAGrG,KAAK,CAACoG,MAAM,CAAC,CAAC,CAAC;EAEnC,MAAME,YAAY,GAAGtG,KAAK,CAACuG,OAAO,CAAC,MAAM;IACvC,IAAIC,MAAM,GAAGtB,IAAI,CAACuB,MAAM,CAACC,CAAC,IAAI,CAACA,CAAC,CAACC,WAAW,CAAC;IAC7C,IAAIpC,UAAU,KAAKqC,SAAS,EAAE;MAC5B,IAAIrC,UAAU,KAAK,IAAI,EAAE;QACvBiC,MAAM,GAAGA,MAAM,CAACC,MAAM,CAACC,GAAC,IAAIA,GAAC,CAACG,QAAQ,KAAKD,SAAS,CAAC;MACvD,CAAC,MAAM,IAAI,OAAOrC,UAAU,KAAK,QAAQ,EAAE;QACzCiC,MAAM,GAAGA,MAAM,CAACC,MAAM,CAACC,GAAC,IAAIA,GAAC,CAACG,QAAQ,KAAKtC,UAAU,CAAC;MACxD,CAAC,MAAM,IAAI,OAAOA,UAAU,KAAK,QAAQ,EAAE;QACzC,MAAMsC,QAAQ,GAAG9D,iBAAiB,CAACwB,UAAU,CAAC;QAC9C,IAAIsC,QAAQ,KAAK,IAAI,EAAE;UACrBL,MAAM,GAAGA,MAAM,CAACC,MAAM,CAACC,GAAC,IAAIA,GAAC,CAACG,QAAQ,KAAKA,QAAQ,CAAC;QACtD;MACF;IACF;IACA,OAAOL,MAAM;EACf,CAAC,EAAE,CAACtB,IAAI,EAAEX,UAAU,CAAC,CAAC;EACtB,MAAMuC,yBAAyB,GAAGzE,oBAAoB,CAAC,CAAC;EAExDrC,KAAK,CAAC+G,SAAS,CAAC,MAAM;IACpBxE,kCAAkC,CAACiB,aAAa,CAAC,CAC9CwD,IAAI,CAACR,QAAM,IAAI;MACdL,mBAAmB,CAACc,OAAO,GAAGT,QAAM;MACpCH,WAAW,CAACY,OAAO,GAAGT,QAAM,CAACtB,IAAI,CAACgC,MAAM;MACxC/B,OAAO,CAACqB,QAAM,CAACtB,IAAI,CAAC;MACpBI,UAAU,CAAC,KAAK,CAAC;IACnB,CAAC,CAAC,CACD6B,KAAK,CAACC,KAAK,IAAI;MACdtF,QAAQ,CAACsF,KAAK,CAAC;MACf9B,UAAU,CAAC,KAAK,CAAC;IACnB,CAAC,CAAC;EACN,CAAC,EAAE,CAAC9B,aAAa,CAAC,CAAC;EAEnB,MAAM6D,YAAY,GAAGrH,KAAK,CAACsH,WAAW,CAAC,CAACC,KAAK,EAAE,MAAM,KAAK;IACxD,MAAMC,GAAG,GAAGrB,mBAAmB,CAACc,OAAO;IACvC,IAAI,CAACO,GAAG,IAAIA,GAAG,CAACC,SAAS,IAAID,GAAG,CAACE,WAAW,CAACR,MAAM,EAAE;IAErD,KAAK9E,UAAU,CAACoF,GAAG,CAACE,WAAW,EAAEF,GAAG,CAACC,SAAS,EAAEF,KAAK,CAAC,CAACP,IAAI,CAACR,QAAM,IAAI;MACpEgB,GAAG,CAACC,SAAS,GAAGjB,QAAM,CAACiB,SAAS;MAChC,IAAIjB,QAAM,CAACtB,IAAI,CAACgC,MAAM,GAAG,CAAC,EAAE;QAC1B;QACA;QACA,MAAMS,MAAM,GAAGtB,WAAW,CAACY,OAAO;QAClCT,QAAM,CAACtB,IAAI,CAAC0C,OAAO,CAAC,CAACC,GAAG,EAAEC,CAAC,KAAK;UAC9BD,GAAG,CAAC7E,KAAK,GAAG2E,MAAM,GAAGG,CAAC;QACxB,CAAC,CAAC;QACF3C,OAAO,CAAC4C,IAAI,IAAIA,IAAI,CAACC,MAAM,CAACxB,QAAM,CAACtB,IAAI,CAAC,CAAC;QACzCmB,WAAW,CAACY,OAAO,IAAIT,QAAM,CAACtB,IAAI,CAACgC,MAAM;MAC3C,CAAC,MAAM,IAAIM,GAAG,CAACC,SAAS,GAAGD,GAAG,CAACE,WAAW,CAACR,MAAM,EAAE;QACjDG,YAAY,CAACE,KAAK,CAAC;MACrB;IACF,CAAC,CAAC;EACJ,CAAC,EAAE,EAAE,CAAC;EAEN,MAAMU,QAAQ,GAAGjI,KAAK,CAACsH,WAAW,CAChC,CAACY,WAAW,EAAE,OAAO,KAAK;IACxB5C,UAAU,CAAC,IAAI,CAAC;IAChB,MAAM6C,OAAO,GAAGD,WAAW,GACvB5F,qCAAqC,CAAC,CAAC,GACvCC,kCAAkC,CAACiB,aAAa,CAAC;IACrD2E,OAAO,CACJnB,IAAI,CAACR,QAAM,IAAI;MACdL,mBAAmB,CAACc,OAAO,GAAGT,QAAM;MACpCH,WAAW,CAACY,OAAO,GAAGT,QAAM,CAACtB,IAAI,CAACgC,MAAM;MACxC/B,OAAO,CAACqB,QAAM,CAACtB,IAAI,CAAC;IACtB,CAAC,CAAC,CACDiC,KAAK,CAACC,OAAK,IAAI;MACdtF,QAAQ,CAACsF,OAAK,CAAC;IACjB,CAAC,CAAC,CACDgB,OAAO,CAAC,MAAM;MACb9C,UAAU,CAAC,KAAK,CAAC;IACnB,CAAC,CAAC;EACN,CAAC,EACD,CAAC9B,aAAa,CAChB,CAAC;EAED,MAAM6E,uBAAuB,GAAGrI,KAAK,CAACsH,WAAW,CAAC,MAAM;IACtD,MAAMgB,QAAQ,GAAG,CAAC7C,eAAe;IACjCC,kBAAkB,CAAC4C,QAAQ,CAAC;IAC5BL,QAAQ,CAACK,QAAQ,CAAC;EACpB,CAAC,EAAE,CAAC7C,eAAe,EAAEwC,QAAQ,CAAC,CAAC;EAE/B,SAASM,QAAQA,CAAA,EAAG;IAClB;IACAC,OAAO,CAACC,IAAI,CAAC,CAAC,CAAC;EACjB;EAEA,eAAeC,QAAQA,CAACb,KAAG,EAAEvG,SAAS,EAAE;IACtCkE,WAAW,CAAC,IAAI,CAAC;IACjB,MAAMmD,WAAW,GAAGC,WAAW,CAACC,GAAG,CAAC,CAAC;IAErC,MAAMC,iBAAiB,GAAGlH,uBAAuB,CAC/CiG,KAAG,EACHpC,eAAe,EACfjC,aACF,CAAC;IACD,IAAIsF,iBAAiB,CAACC,cAAc,EAAE;MACpC,IAAI,CAACD,iBAAiB,CAACE,kBAAkB,EAAE;QACzC,MAAMC,GAAG,GAAG,MAAMzI,YAAY,CAACsI,iBAAiB,CAACI,OAAO,CAAC;QACzD,IAAID,GAAG,EAAET,OAAO,CAACW,MAAM,CAACC,KAAK,CAACH,GAAG,CAAC;QAClC/C,sBAAsB,CAAC4C,iBAAiB,CAACI,OAAO,CAAC;QACjD;MACF;IACF;IAEA,IAAI;MACF,MAAM1C,QAAM,GAAG,MAAM7E,yBAAyB,CAACkG,KAAG,EAAEjB,SAAS,CAAC;MAC9D,IAAI,CAACJ,QAAM,EAAE;QACX,MAAM,IAAI6C,KAAK,CAAC,6BAA6B,CAAC;MAChD;MAEA,IAAIvJ,OAAO,CAAC,kBAAkB,CAAC,EAAE;QAC/B;QACA,MAAMwJ,iBAAiB,GACrBC,OAAO,CAAC,mCAAmC,CAAC,IAAI,OAAO,OAAO,mCAAmC,CAAC;QACpG;QACA,MAAMC,OAAO,GAAGF,iBAAiB,CAACG,gBAAgB,CAACjD,QAAM,CAACkD,IAAI,CAAC;QAC/D,IAAIF,OAAO,EAAE;UACX;UACA,MAAM;YAAEG,gCAAgC;YAAEC;UAAwB,CAAC,GACjEL,OAAO,CAAC,qCAAqC,CAAC,IAAI,OAAO,OAAO,qCAAqC,CAAC;UACxG;UACAI,gCAAgC,CAACE,KAAK,CAACC,KAAK,GAAG,CAAC;UAChD,MAAMC,cAAc,GAAG,MAAMJ,gCAAgC,CAC3DzJ,cAAc,CAAC,CACjB,CAAC;UACD+E,WAAW,CAAC8C,MAAI,KAAK;YACnB,GAAGA,MAAI;YACPhD,gBAAgB,EAAE;cAChB,GAAGgF,cAAc;cACjBC,SAAS,EAAED,cAAc,CAACC,SAAS;cACnCC,YAAY,EAAEL,uBAAuB,CAACG,cAAc,CAACC,SAAS;YAChE;UACF,CAAC,CAAC,CAAC;UACHxD,QAAM,CAAC9B,QAAQ,CAACwF,IAAI,CAACnI,mBAAmB,CAACyH,OAAO,EAAE,SAAS,CAAC,CAAC;QAC/D;MACF;MAEA,IAAIhD,QAAM,CAAC2D,SAAS,IAAI,CAAC9F,WAAW,EAAE;QACpClE,aAAa,CACXkB,WAAW,CAACmF,QAAM,CAAC2D,SAAS,CAAC,EAC7BtC,KAAG,CAACuC,QAAQ,GAAGrK,OAAO,CAAC8H,KAAG,CAACuC,QAAQ,CAAC,GAAG,IACzC,CAAC;QACD,MAAM3I,yBAAyB,CAAC,CAAC;QACjC,MAAMgB,uBAAuB,CAAC,CAAC;QAC/BlC,0BAA0B,CAACiG,QAAM,CAAC2D,SAAS,CAAC;MAC9C,CAAC,MAAM,IAAI9F,WAAW,IAAImC,QAAM,CAACV,mBAAmB,EAAEoB,MAAM,EAAE;QAC5D,MAAM1E,wBAAwB,CAACgE,QAAM,CAACV,mBAAmB,CAAC;MAC5D;MAEA,MAAM;QAAEuE,eAAe,EAAEC;MAAiB,CAAC,GAAGrI,uBAAuB,CACnEuE,QAAM,CAAC+D,YAAY,EACnBzG,yBAAyB,EACzBiB,gBACF,CAAC;MACDE,WAAW,CAAC8C,MAAI,KAAK;QAAE,GAAGA,MAAI;QAAEyC,KAAK,EAAEF,gBAAgB,EAAEG;MAAU,CAAC,CAAC,CAAC;MAEtE,IAAI3K,OAAO,CAAC,kBAAkB,CAAC,EAAE;QAC/B;QACA,MAAM;UAAE4K;QAAS,CAAC,GAAGnB,OAAO,CAAC,4BAA4B,CAAC;QAC1D,MAAM;UAAEoB;QAAkB,CAAC,GACzBpB,OAAO,CAAC,mCAAmC,CAAC,IAAI,OAAO,OAAO,mCAAmC,CAAC;QACpG;QACAmB,QAAQ,CAACC,iBAAiB,CAAC,CAAC,GAAG,aAAa,GAAG,QAAQ,CAAC;MAC1D;MAEA,MAAMC,sBAAsB,GAAG5I,6BAA6B,CAC1DwE,QAAM,CAACT,SAAS,EAChBS,QAAM,CAACR,UACT,CAAC;MACD,IAAI4E,sBAAsB,EAAE;QAC1B3F,WAAW,CAAC8C,MAAI,KAAK;UAAE,GAAGA,MAAI;UAAE6C;QAAuB,CAAC,CAAC,CAAC;MAC5D;MACA,KAAKlJ,iBAAiB,CAAC8E,QAAM,CAACT,SAAS,CAAC;MAExCrD,sBAAsB,CACpB2B,WAAW,GAAG;QAAE,GAAGmC,QAAM;QAAEqE,eAAe,EAAEjE;MAAU,CAAC,GAAGJ,QAC5D,CAAC;MAED,IAAI,CAACnC,WAAW,EAAE;QAChBnC,wBAAwB,CAACsE,QAAM,CAACqE,eAAe,CAAC;QAChD,IAAIrE,QAAM,CAAC2D,SAAS,EAAE;UACpBhI,uBAAuB,CAAC,CAAC;QAC3B;MACF;MAEA,IAAIrC,OAAO,CAAC,kBAAkB,CAAC,EAAE;QAC/B;QACA;QAAC,CACCyJ,OAAO,CAAC,wCAAwC,CAAC,IAAI,OAAO,OAAO,wCAAwC,CAAC,EAC5GuB,kBAAkB,CAClBtE,QAAM,CAACuE,sBAAsB,IAAI,EAAE,EACnCvE,QAAM,CAACwE,uBACT,CAAC;QACD;MACF;MAEAnK,QAAQ,CAAC,uBAAuB,EAAE;QAChCoK,UAAU,EACR,QAAQ,IAAIrK,0DAA0D;QACxEsK,OAAO,EAAE,IAAI;QACbC,kBAAkB,EAAEC,IAAI,CAACC,KAAK,CAACzC,WAAW,CAACC,GAAG,CAAC,CAAC,GAAGF,WAAW;MAChE,CAAC,CAAC;MAEFxD,OAAO,CAAC,EAAE,CAAC;MACXS,aAAa,CAAC;QACZlB,QAAQ,EAAE8B,QAAM,CAAC9B,QAAQ;QACzBmB,oBAAoB,EAAEW,QAAM,CAACX,oBAAoB;QACjDC,mBAAmB,EAAEU,QAAM,CAACV,mBAAmB;QAC/CC,SAAS,EAAES,QAAM,CAACT,SAAS;QAC3BC,UAAU,EAAE,CAACQ,QAAM,CAACR,UAAU,KAAK,SAAS,GACxCY,SAAS,GACTJ,QAAM,CAACR,UAAU,KAAK7E,cAAc,GAAG,SAAS;QACpD2C,yBAAyB,EAAEwG;MAC7B,CAAC,CAAC;IACJ,CAAC,CAAC,OAAOgB,CAAC,EAAE;MACVzK,QAAQ,CAAC,uBAAuB,EAAE;QAChCoK,UAAU,EACR,QAAQ,IAAIrK,0DAA0D;QACxEsK,OAAO,EAAE;MACX,CAAC,CAAC;MACFpJ,QAAQ,CAACwJ,CAAC,IAAIjC,KAAK,CAAC;MACpB,MAAMiC,CAAC;IACT;EACF;EAEA,IAAIrF,mBAAmB,EAAE;IACvB,OAAO,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAACA,mBAAmB,CAAC,GAAG;EAC9D;EAEA,IAAIN,UAAU,EAAE;IACd,OACE,CAAC,IAAI,CACH,KAAK,CAAC,CAAC9B,KAAK,CAAC,CACb,QAAQ,CAAC,CAACN,QAAQ,CAAC,CACnB,YAAY,CAAC,CAACE,YAAY,CAAC,CAC3B,eAAe,CAAC,CAACkC,UAAU,CAACjB,QAAQ,CAAC,CACrC,2BAA2B,CAAC,CAACiB,UAAU,CAACE,oBAAoB,CAAC,CAC7D,0BAA0B,CAAC,CAACF,UAAU,CAACG,mBAAmB,CAAC,CAC3D,gBAAgB,CAAC,CAACH,UAAU,CAACI,SAAS,CAAC,CACvC,iBAAiB,CAAC,CAACJ,UAAU,CAACK,UAAU,CAAC,CACzC,UAAU,CAAC,CAACtC,UAAU,CAAC,CACvB,gBAAgB,CAAC,CAACC,gBAAgB,CAAC,CACnC,eAAe,CAAC,CAACK,eAAe,CAAC,CACjC,YAAY,CAAC,CAACC,YAAY,CAAC,CAC3B,kBAAkB,CAAC,CAACC,kBAAkB,CAAC,CACvC,yBAAyB,CAAC,CAACyB,UAAU,CAAC7B,yBAAyB,CAAC,CAChE,kBAAkB,CAAC,CAACC,kBAAkB,CAAC,CACvC,oBAAoB,CAAC,CAACK,oBAAoB,CAAC,CAC3C,UAAU,CAAC,CAACE,UAAU,CAAC,CACvB,cAAc,CAAC,CAACE,cAAc,CAAC,CAC/B,cAAc,CAAC,CAACC,cAAc,CAAC,GAC/B;EAEN;EAEA,IAAIY,OAAO,EAAE;IACX,OACE,CAAC,GAAG;AACV,QAAQ,CAAC,OAAO;AAChB,QAAQ,CAAC,IAAI,CAAC,uBAAuB,EAAE,IAAI;AAC3C,MAAM,EAAE,GAAG,CAAC;EAEV;EAEA,IAAIE,QAAQ,EAAE;IACZ,OACE,CAAC,GAAG;AACV,QAAQ,CAAC,OAAO;AAChB,QAAQ,CAAC,IAAI,CAAC,uBAAuB,EAAE,IAAI;AAC3C,MAAM,EAAE,GAAG,CAAC;EAEV;EAEA,IAAIe,YAAY,CAACY,MAAM,KAAK,CAAC,EAAE;IAC7B,OAAO,CAAC,sBAAsB,GAAG;EACnC;EAEA,OACE,CAAC,WAAW,CACV,IAAI,CAAC,CAACZ,YAAY,CAAC,CACnB,SAAS,CAAC,CAACxB,IAAI,CAAC,CAChB,QAAQ,CAAC,CAACyD,QAAQ,CAAC,CACnB,QAAQ,CAAC,CAACG,QAAQ,CAAC,CACnB,aAAa,CAAC,CACZ5B,yBAAyB,GAAG,MAAMmB,QAAQ,CAACxC,eAAe,CAAC,GAAGmB,SAChE,CAAC,CACD,UAAU,CAAC,CAACS,YAAY,CAAC,CACzB,kBAAkB,CAAC,CAAClD,kBAAkB,CAAC,CACvC,eAAe,CAAC,CAACsB,eAAe,CAAC,CACjC,mBAAmB,CAAC,CAAC4C,uBAAuB,CAAC,CAC7C,eAAe,CAAC,CAAC7G,oBAAoB,CAAC,GACtC;AAEN;AAEA,SAAA+J,uBAAA;EAAA,MAAAC,CAAA,GAAAC,EAAA;EAAA,IAAAC,EAAA;EAAA,IAAAF,CAAA,QAAAG,MAAA,CAAAC,GAAA;IAOIF,EAAA;MAAAG,OAAA,EAAW;IAAS,CAAC;IAAAL,CAAA,MAAAE,EAAA;EAAA;IAAAA,EAAA,GAAAF,CAAA;EAAA;EANvB7K,aAAa,CACX,eAAe,EACfmL,KAGC,EACDJ,EACF,CAAC;EAAA,IAAAK,EAAA;EAAA,IAAAP,CAAA,QAAAG,MAAA,CAAAC,GAAA;IAGCG,EAAA,IAAC,GAAG,CAAe,aAAQ,CAAR,QAAQ,CACzB,CAAC,IAAI,CAAC,iCAAiC,EAAtC,IAAI,CACL,CAAC,IAAI,CAAC,QAAQ,CAAR,KAAO,CAAC,CAAC,kDAAkD,EAAhE,IAAI,CACP,EAHC,GAAG,CAGE;IAAAP,CAAA,MAAAO,EAAA;EAAA;IAAAA,EAAA,GAAAP,CAAA;EAAA;EAAA,OAHNO,EAGM;AAAA;AAdV,SAAAD,MAAA;EAKMtD,OAAO,CAAAC,IAAK,CAAC,CAAC,CAAC;AAAA;AAarB,SAAAuD,oBAAAN,EAAA;EAAA,MAAAF,CAAA,GAAAC,EAAA;EAA6B;IAAAvC;EAAA,IAAAwC,EAI5B;EAAA,IAAAK,EAAA;EAAA,IAAAP,CAAA,QAAAG,MAAA,CAAAC,GAAA;IAOIG,EAAA,KAAE;IAAAP,CAAA,MAAAO,EAAA;EAAA;IAAAA,EAAA,GAAAP,CAAA;EAAA;EANLxL,KAAK,CAAA+G,SAAU,CAACkF,MAMf,EAAEF,EAAE,CAAC;EAAA,IAAAG,EAAA;EAAA,IAAAV,CAAA,QAAAG,MAAA,CAAAC,GAAA;IAIFM,EAAA,IAAC,IAAI,CAAC,gDAAgD,EAArD,IAAI,CAAwD;IAAAV,CAAA,MAAAU,EAAA;EAAA;IAAAA,EAAA,GAAAV,CAAA;EAAA;EAAA,IAAAW,EAAA;EAAA,IAAAX,CAAA,QAAAG,MAAA,CAAAC,GAAA;IAE3DO,EAAA,IAAC,IAAI,CAAC,eAAe,EAApB,IAAI,CAAuB;IAAAX,CAAA,MAAAW,EAAA;EAAA;IAAAA,EAAA,GAAAX,CAAA;EAAA;EAAA,IAAAY,EAAA;EAAA,IAAAZ,CAAA,QAAAtC,OAAA;IAD9BkD,EAAA,IAAC,GAAG,CAAe,aAAQ,CAAR,QAAQ,CACzB,CAAAD,EAA2B,CAC3B,CAAC,IAAI,CAAC,CAAEjD,QAAM,CAAE,EAAf,IAAI,CACP,EAHC,GAAG,CAGE;IAAAsC,CAAA,MAAAtC,OAAA;IAAAsC,CAAA,MAAAY,EAAA;EAAA;IAAAA,EAAA,GAAAZ,CAAA;EAAA;EAAA,IAAAa,EAAA;EAAA,IAAAb,CAAA,QAAAG,MAAA,CAAAC,GAAA;IACNS,EAAA,IAAC,IAAI,CAAC,QAAQ,CAAR,KAAO,CAAC,CAAC,6BAA6B,EAA3C,IAAI,CAA8C;IAAAb,CAAA,MAAAa,EAAA;EAAA;IAAAA,EAAA,GAAAb,CAAA;EAAA;EAAA,IAAAc,EAAA;EAAA,IAAAd,CAAA,QAAAY,EAAA;IANrDE,EAAA,IAAC,GAAG,CAAe,aAAQ,CAAR,QAAQ,CAAM,GAAC,CAAD,GAAC,CAChC,CAAAJ,EAA4D,CAC5D,CAAAE,EAGK,CACL,CAAAC,EAAkD,CACpD,EAPC,GAAG,CAOE;IAAAb,CAAA,MAAAY,EAAA;IAAAZ,CAAA,MAAAc,EAAA;EAAA;IAAAA,EAAA,GAAAd,CAAA;EAAA;EAAA,OAPNc,EAOM;AAAA;AArBV,SAAAL,OAAA;EAMI,MAAAM,OAAA,GAAgBC,UAAU,CAACC,MAG1B,EAAE,GAAG,CAAC;EAAA,OACA,MAAMC,YAAY,CAACH,OAAO,CAAC;AAAA;AAVtC,SAAAE,OAAA;EAQMjE,OAAO,CAAAC,IAAK,CAAC,CAAC,CAAC;AAAA","ignoreList":[]}
@@ -0,0 +1,88 @@
1
+ /* eslint-disable eslint-plugin-n/no-unsupported-features/node-builtins */
2
+
3
+ import { errorMessage } from '../utils/errors.js'
4
+ import { jsonStringify } from '../utils/slowOperations.js'
5
+ import type { DirectConnectConfig } from './directConnectManager.js'
6
+ import { connectResponseSchema } from './types.js'
7
+
8
+ /**
9
+ * Errors thrown by createDirectConnectSession when the connection fails.
10
+ */
11
+ export class DirectConnectError extends Error {
12
+ constructor(message: string) {
13
+ super(message)
14
+ this.name = 'DirectConnectError'
15
+ }
16
+ }
17
+
18
+ /**
19
+ * Create a session on a direct-connect server.
20
+ *
21
+ * Posts to `${serverUrl}/sessions`, validates the response, and returns
22
+ * a DirectConnectConfig ready for use by the REPL or headless runner.
23
+ *
24
+ * Throws DirectConnectError on network, HTTP, or response-parsing failures.
25
+ */
26
+ export async function createDirectConnectSession({
27
+ serverUrl,
28
+ authToken,
29
+ cwd,
30
+ dangerouslySkipPermissions,
31
+ }: {
32
+ serverUrl: string
33
+ authToken?: string
34
+ cwd: string
35
+ dangerouslySkipPermissions?: boolean
36
+ }): Promise<{
37
+ config: DirectConnectConfig
38
+ workDir?: string
39
+ }> {
40
+ const headers: Record<string, string> = {
41
+ 'content-type': 'application/json',
42
+ }
43
+ if (authToken) {
44
+ headers['authorization'] = `Bearer ${authToken}`
45
+ }
46
+
47
+ let resp: Response
48
+ try {
49
+ resp = await fetch(`${serverUrl}/sessions`, {
50
+ method: 'POST',
51
+ headers,
52
+ body: jsonStringify({
53
+ cwd,
54
+ ...(dangerouslySkipPermissions && {
55
+ dangerously_skip_permissions: true,
56
+ }),
57
+ }),
58
+ })
59
+ } catch (err) {
60
+ throw new DirectConnectError(
61
+ `Failed to connect to server at ${serverUrl}: ${errorMessage(err)}`,
62
+ )
63
+ }
64
+
65
+ if (!resp.ok) {
66
+ throw new DirectConnectError(
67
+ `Failed to create session: ${resp.status} ${resp.statusText}`,
68
+ )
69
+ }
70
+
71
+ const result = connectResponseSchema().safeParse(await resp.json())
72
+ if (!result.success) {
73
+ throw new DirectConnectError(
74
+ `Invalid session response: ${result.error.message}`,
75
+ )
76
+ }
77
+
78
+ const data = result.data
79
+ return {
80
+ config: {
81
+ serverUrl,
82
+ sessionId: data.session_id,
83
+ wsUrl: data.ws_url,
84
+ authToken,
85
+ },
86
+ workDir: data.work_dir,
87
+ }
88
+ }