@oflow-ai/oflow-cli 0.1.0 → 0.1.2

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.
package/dist/cli.js CHANGED
@@ -43,8 +43,78 @@ const chalk_1 = __importDefault(require("chalk"));
43
43
  const ora_1 = __importDefault(require("ora"));
44
44
  const core_1 = require("@oflow-ai/core");
45
45
  const commands_1 = require("./commands");
46
+ const updater_1 = require("./updater");
46
47
  let sandboxExecutor = null;
47
- let showThinking = false;
48
+ let currentShowThinking = false;
49
+ let sessionStats = {
50
+ toolCallsCount: 0,
51
+ filesRead: [],
52
+ filesWritten: [],
53
+ commandsRun: [],
54
+ startTime: new Date()
55
+ };
56
+ let contextTokens = 0;
57
+ let maxContextTokens = 128000;
58
+ function drawStatusBar(model) {
59
+ const terminalWidth = process.stdout.columns || 80;
60
+ const contextPercent = Math.min(100, Math.round((contextTokens / maxContextTokens) * 100));
61
+ const contextColor = contextPercent > 80 ? chalk_1.default.red : contextPercent > 50 ? chalk_1.default.yellow : chalk_1.default.green;
62
+ const thinkingStatus = currentShowThinking ? chalk_1.default.cyan('ON') : chalk_1.default.gray('OFF');
63
+ const statusLine1 = [
64
+ `${chalk_1.default.blue('Model:')} ${chalk_1.default.white(model)}`,
65
+ `${chalk_1.default.blue('Context:')} ${contextColor(contextPercent + '%')}`,
66
+ `${chalk_1.default.blue('Thinking:')} ${thinkingStatus}`
67
+ ].join(' | ');
68
+ const currentDir = process.cwd();
69
+ const dirDisplay = currentDir.length > terminalWidth - 10
70
+ ? '...' + currentDir.slice(-(terminalWidth - 13))
71
+ : currentDir;
72
+ const statusLine2 = `${chalk_1.default.blue('Dir:')} ${chalk_1.default.gray(dirDisplay)}`;
73
+ console.log('');
74
+ console.log(chalk_1.default.gray('─'.repeat(Math.min(terminalWidth, 60))));
75
+ console.log(statusLine1);
76
+ console.log(statusLine2);
77
+ console.log(chalk_1.default.gray('─'.repeat(Math.min(terminalWidth, 60))));
78
+ }
79
+ function showTaskSummary() {
80
+ const duration = Math.round((Date.now() - sessionStats.startTime.getTime()) / 1000);
81
+ const minutes = Math.floor(duration / 60);
82
+ const seconds = duration % 60;
83
+ console.log('');
84
+ console.log(chalk_1.default.bold.cyan('═══════════════════════════════════════'));
85
+ console.log(chalk_1.default.bold.cyan(' Task Summary'));
86
+ console.log(chalk_1.default.bold.cyan('═══════════════════════════════════════'));
87
+ console.log('');
88
+ console.log(`${chalk_1.default.white('Duration:')} ${chalk_1.default.yellow(minutes + 'm ' + seconds + 's')}`);
89
+ console.log(`${chalk_1.default.white('Tool calls:')} ${chalk_1.default.yellow(sessionStats.toolCallsCount.toString())}`);
90
+ if (sessionStats.filesRead.length > 0) {
91
+ console.log(`${chalk_1.default.white('Files read:')} ${chalk_1.default.yellow(sessionStats.filesRead.length.toString())}`);
92
+ sessionStats.filesRead.slice(0, 5).forEach(f => console.log(chalk_1.default.gray(' - ' + f)));
93
+ if (sessionStats.filesRead.length > 5) {
94
+ console.log(chalk_1.default.gray(' ... and ' + (sessionStats.filesRead.length - 5) + ' more'));
95
+ }
96
+ }
97
+ if (sessionStats.filesWritten.length > 0) {
98
+ console.log(`${chalk_1.default.white('Files modified:')} ${chalk_1.default.yellow(sessionStats.filesWritten.length.toString())}`);
99
+ sessionStats.filesWritten.slice(0, 5).forEach(f => console.log(chalk_1.default.gray(' - ' + f)));
100
+ if (sessionStats.filesWritten.length > 5) {
101
+ console.log(chalk_1.default.gray(' ... and ' + (sessionStats.filesWritten.length - 5) + ' more'));
102
+ }
103
+ }
104
+ if (sessionStats.commandsRun.length > 0) {
105
+ console.log(`${chalk_1.default.white('Commands run:')} ${chalk_1.default.yellow(sessionStats.commandsRun.length.toString())}`);
106
+ }
107
+ console.log('');
108
+ console.log(chalk_1.default.bold.cyan('═══════════════════════════════════════'));
109
+ console.log('');
110
+ sessionStats = {
111
+ toolCallsCount: 0,
112
+ filesRead: [],
113
+ filesWritten: [],
114
+ commandsRun: [],
115
+ startTime: new Date()
116
+ };
117
+ }
48
118
  async function startInteractiveMode(options) {
49
119
  const configManager = (0, core_1.getConfigManager)();
50
120
  const auth = configManager.getAuth();
@@ -52,68 +122,116 @@ async function startInteractiveMode(options) {
52
122
  console.log(chalk_1.default.red('Not authenticated. Run `oflow auth` first.'));
53
123
  return;
54
124
  }
55
- // 初始化沙箱执行器
125
+ // Check for updates
126
+ const updateInfo = await (0, updater_1.checkForUpdates)();
127
+ if (updateInfo.hasUpdate) {
128
+ console.log('');
129
+ console.log(chalk_1.default.yellow('New version available: ' + updateInfo.latestVersion));
130
+ console.log(chalk_1.default.yellow('Run /update to update'));
131
+ console.log('');
132
+ }
56
133
  if (options.sandbox || configManager.get('sandbox')) {
57
- sandboxExecutor = await (0, core_1.createSandboxExecutor)();
58
- console.log(chalk_1.default.gray(`Sandbox mode: ${sandboxExecutor ? 'enabled' : 'unavailable'}`));
134
+ try {
135
+ sandboxExecutor = await (0, core_1.createSandboxExecutor)();
136
+ }
137
+ catch { }
59
138
  }
60
- // 获取思考过程显示设置
61
- showThinking = options.showThinking ?? configManager.getShowThinking();
139
+ currentShowThinking = options.showThinking ?? configManager.getShowThinking();
62
140
  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';
63
- const provider = (0, core_1.createAIProvider)(auth, model);
64
- const agentFactory = new core_1.AgentFactory(provider, process.cwd());
141
+ if (model.includes('gpt-4') || model.includes('gpt-4o')) {
142
+ maxContextTokens = 128000;
143
+ }
144
+ else if (model.includes('deepseek')) {
145
+ maxContextTokens = 64000;
146
+ }
147
+ else {
148
+ maxContextTokens = 128000;
149
+ }
150
+ let provider;
151
+ try {
152
+ provider = (0, core_1.createAIProvider)(auth, model);
153
+ }
154
+ catch (error) {
155
+ console.log(chalk_1.default.red('Failed to create AI provider: ' + (error instanceof Error ? error.message : String(error))));
156
+ return;
157
+ }
65
158
  const conversation = new core_1.Conversation({
66
159
  provider,
67
160
  workingDirectory: process.cwd(),
68
161
  maxTokens: configManager.get('maxTokens'),
69
162
  temperature: configManager.get('temperature'),
70
- showThinking: showThinking,
163
+ showThinking: currentShowThinking,
71
164
  onContent: (content) => {
72
165
  process.stdout.write(chalk_1.default.white(content));
73
166
  },
74
167
  onThinking: (thinking) => {
75
- // 显示思考过程,使用不同的颜色
76
- process.stdout.write(chalk_1.default.magenta(thinking));
168
+ if (currentShowThinking) {
169
+ process.stdout.write(chalk_1.default.magenta(thinking));
170
+ }
77
171
  },
78
172
  onToolCall: (toolCall) => {
79
- console.log(chalk_1.default.cyan(`\n🔧 Using tool: ${toolCall.function.name}`));
173
+ sessionStats.toolCallsCount++;
174
+ console.log(chalk_1.default.cyan('\nUsing tool: ' + toolCall.function.name));
175
+ try {
176
+ const args = JSON.parse(toolCall.function.arguments);
177
+ if (toolCall.function.name === 'read_file' && args.absolute_path) {
178
+ if (!sessionStats.filesRead.includes(args.absolute_path)) {
179
+ sessionStats.filesRead.push(args.absolute_path);
180
+ }
181
+ }
182
+ else if ((toolCall.function.name === 'write_file' || toolCall.function.name === 'replace') && args.file_path) {
183
+ if (!sessionStats.filesWritten.includes(args.file_path)) {
184
+ sessionStats.filesWritten.push(args.file_path);
185
+ }
186
+ }
187
+ else if (toolCall.function.name === 'run_shell_command' && args.command) {
188
+ sessionStats.commandsRun.push(args.command);
189
+ }
190
+ }
191
+ catch { }
80
192
  },
81
193
  onToolResult: (result) => {
82
- // Tool result is handled silently
194
+ contextTokens += Math.ceil(result.length / 4);
83
195
  }
84
196
  });
85
- // Set system prompt
86
197
  conversation.setSystemPrompt(getSystemPrompt());
87
- console.log(chalk_1.default.bold.blue('\n╔═══════════════════════════════════════╗'));
88
- console.log(chalk_1.default.bold.blue('║ Welcome to oflow CLI ║'));
89
- console.log(chalk_1.default.bold.blue('╚═══════════════════════════════════════╝'));
90
- console.log('');
91
- console.log(chalk_1.default.gray(`Model: ${model}`));
92
- console.log(chalk_1.default.gray(`Working directory: ${process.cwd()}`));
93
- if (sandboxExecutor) {
94
- console.log(chalk_1.default.gray(`Sandbox: enabled`));
95
- }
96
- console.log(chalk_1.default.gray(`Thinking: ${showThinking ? 'ON' : 'OFF'} (use /thinking to toggle)`));
97
- console.log('');
98
- console.log(chalk_1.default.gray('Type your message and press Enter to chat.'));
99
- console.log(chalk_1.default.gray('Type /help for available commands.'));
100
- console.log(chalk_1.default.gray('Type $agent-name to call a sub-agent.'));
101
- console.log(chalk_1.default.gray('Type /exit or press Ctrl+C to exit.'));
198
+ console.log(chalk_1.default.bold.blue('\nWelcome to oflow CLI'));
199
+ console.log(chalk_1.default.gray('Type /help for commands, /exit to quit'));
102
200
  console.log('');
103
201
  const rl = readline.createInterface({
104
202
  input: process.stdin,
105
- output: process.stdout,
106
- prompt: chalk_1.default.green('> ')
203
+ output: process.stdout
107
204
  });
108
- rl.prompt();
205
+ const showPrompt = () => {
206
+ drawStatusBar(model);
207
+ rl.setPrompt(chalk_1.default.green('\n> '));
208
+ rl.prompt();
209
+ };
210
+ showPrompt();
109
211
  rl.on('line', async (line) => {
110
212
  const input = line.trim();
111
213
  if (!input) {
112
- rl.prompt();
214
+ showPrompt();
113
215
  return;
114
216
  }
115
- // Check for slash commands
116
217
  if ((0, commands_1.isSlashCommand)(input)) {
218
+ if (input.toLowerCase() === '/thinking') {
219
+ currentShowThinking = !currentShowThinking;
220
+ configManager.setShowThinking(currentShowThinking);
221
+ console.log(chalk_1.default.green('Thinking: ' + (currentShowThinking ? 'ON' : 'OFF')));
222
+ showPrompt();
223
+ return;
224
+ }
225
+ if (input.toLowerCase() === '/summary') {
226
+ showTaskSummary();
227
+ showPrompt();
228
+ return;
229
+ }
230
+ if (input.toLowerCase() === '/update') {
231
+ await (0, updater_1.performUpdate)();
232
+ showPrompt();
233
+ return;
234
+ }
117
235
  const shouldContinue = await (0, commands_1.executeSlashCommand)(input, {
118
236
  conversation,
119
237
  rl,
@@ -123,65 +241,76 @@ async function startInteractiveMode(options) {
123
241
  rl.close();
124
242
  return;
125
243
  }
126
- rl.prompt();
244
+ showPrompt();
127
245
  return;
128
246
  }
129
- // Check for agent calls (starting with $)
130
247
  if (input.startsWith('$')) {
131
- await handleAgentCall(input, agentFactory, options);
132
- rl.prompt();
248
+ await handleAgentCall(input, provider);
249
+ showPrompt();
133
250
  return;
134
251
  }
135
- // Check for shell commands (starting with !)
136
252
  if (input.startsWith('!')) {
137
253
  await executeShellCommand(input.slice(1), sandboxExecutor);
138
- rl.prompt();
254
+ showPrompt();
139
255
  return;
140
256
  }
141
- // Check for file reference (starting with @)
142
257
  const processedInput = await processFileReferences(input);
143
- // Send to AI
144
258
  const spinner = (0, ora_1.default)('Thinking...').start();
145
259
  try {
146
260
  const response = await conversation.sendMessage(processedInput);
147
261
  spinner.stop();
148
- console.log(''); // New line after response
149
- rl.prompt();
262
+ console.log('');
263
+ if (sessionStats.toolCallsCount >= 3) {
264
+ showTaskSummary();
265
+ }
266
+ else {
267
+ contextTokens += Math.ceil(response.length / 4);
268
+ }
269
+ showPrompt();
150
270
  }
151
271
  catch (error) {
152
272
  spinner.fail('Error');
153
- console.log(chalk_1.default.red(error instanceof Error ? error.message : String(error)));
154
- rl.prompt();
273
+ const errorMessage = error instanceof Error ? error.message : String(error);
274
+ console.log(chalk_1.default.red(errorMessage));
275
+ if (errorMessage.includes('400')) {
276
+ console.log(chalk_1.default.yellow('Check API key and model name, or run "oflow auth"'));
277
+ }
278
+ else if (errorMessage.includes('401')) {
279
+ console.log(chalk_1.default.yellow('Authentication failed, run "oflow auth"'));
280
+ }
281
+ else if (errorMessage.includes('429')) {
282
+ console.log(chalk_1.default.yellow('Rate limit, please wait and retry'));
283
+ }
284
+ showPrompt();
155
285
  }
156
286
  });
157
287
  rl.on('close', () => {
158
- console.log(chalk_1.default.bold('\nGoodbye! 👋\n'));
288
+ console.log(chalk_1.default.bold('\nGoodbye!\n'));
159
289
  process.exit(0);
160
290
  });
161
- // Handle Ctrl+C
162
291
  process.on('SIGINT', () => {
163
- console.log(chalk_1.default.bold('\nGoodbye! 👋\n'));
292
+ console.log(chalk_1.default.bold('\nGoodbye!\n'));
164
293
  process.exit(0);
165
294
  });
166
295
  }
167
- async function handleAgentCall(input, agentFactory, options) {
168
- // Parse agent call: $agent-type "task description"
296
+ async function handleAgentCall(input, provider) {
169
297
  const match = input.match(/^\$(\w+(?:-\w+)*)\s*(.*)$/);
170
298
  if (!match) {
171
- console.log(chalk_1.default.yellow('Invalid agent call format. Use: $agent-type "task"'));
172
- console.log(chalk_1.default.gray('Available agents: general-purpose, plan-agent, explore-agent, code-reviewer, frontend-tester'));
299
+ console.log(chalk_1.default.yellow('Invalid format. Use: $agent-type "task"'));
300
+ console.log(chalk_1.default.gray('Agents: general-purpose, plan-agent, explore-agent, code-reviewer, frontend-tester'));
173
301
  return;
174
302
  }
175
303
  const agentType = match[1];
176
304
  const task = match[2].replace(/^["']|["']$/g, '');
177
305
  if (!task) {
178
- console.log(chalk_1.default.yellow('Please provide a task for the agent.'));
306
+ console.log(chalk_1.default.yellow('Please provide a task.'));
179
307
  return;
180
308
  }
181
309
  try {
310
+ const agentFactory = new core_1.AgentFactory(provider, process.cwd());
182
311
  const agent = agentFactory.createAgent(agentType);
183
- console.log(chalk_1.default.cyan(`\n🤖 Starting ${agentType} agent...`));
184
- console.log(chalk_1.default.gray(`Task: ${task}\n`));
312
+ console.log(chalk_1.default.cyan('\nStarting ' + agentType + ' agent...'));
313
+ console.log(chalk_1.default.gray('Task: ' + task + '\n'));
185
314
  const spinner = (0, ora_1.default)('Agent working...').start();
186
315
  const result = await agent.execute(task, (update) => {
187
316
  spinner.stop();
@@ -190,20 +319,22 @@ async function handleAgentCall(input, agentFactory, options) {
190
319
  });
191
320
  spinner.stop();
192
321
  if (result.success) {
193
- console.log(chalk_1.default.green('\n\n✓ Agent completed successfully'));
322
+ console.log(chalk_1.default.green('\nAgent completed successfully'));
194
323
  if (result.filesModified && result.filesModified.length > 0) {
195
324
  console.log(chalk_1.default.gray('Files modified:'));
196
- result.filesModified.forEach(f => console.log(chalk_1.default.gray(` - ${f}`)));
325
+ result.filesModified.forEach(f => console.log(chalk_1.default.gray(' - ' + f)));
326
+ sessionStats.filesWritten.push(...result.filesModified);
197
327
  }
198
328
  }
199
329
  else {
200
- console.log(chalk_1.default.red('\n\n✗ Agent encountered errors:'));
201
- result.errors?.forEach(e => console.log(chalk_1.default.red(` - ${e}`)));
330
+ console.log(chalk_1.default.red('\nAgent encountered errors:'));
331
+ result.errors?.forEach(e => console.log(chalk_1.default.red(' - ' + e)));
202
332
  }
203
333
  if (result.output) {
204
334
  console.log(chalk_1.default.gray('\nOutput:'));
205
335
  console.log(result.output);
206
336
  }
337
+ showTaskSummary();
207
338
  }
208
339
  catch (error) {
209
340
  console.log(chalk_1.default.red(error instanceof Error ? error.message : String(error)));
@@ -216,9 +347,11 @@ async function runSingleCommand(prompt, options) {
216
347
  console.log(chalk_1.default.red('Not authenticated. Run `oflow auth` first.'));
217
348
  return;
218
349
  }
219
- // 初始化沙箱执行器
220
350
  if (options.sandbox || configManager.get('sandbox')) {
221
- sandboxExecutor = await (0, core_1.createSandboxExecutor)();
351
+ try {
352
+ sandboxExecutor = await (0, core_1.createSandboxExecutor)();
353
+ }
354
+ catch { }
222
355
  }
223
356
  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';
224
357
  const provider = (0, core_1.createAIProvider)(auth, model);
@@ -245,17 +378,21 @@ async function runSingleCommand(prompt, options) {
245
378
  }
246
379
  }
247
380
  async function executeShellCommand(command, sandbox) {
248
- const { spawn } = require('child_modules');
381
+ const { spawn } = require('child_process');
382
+ sessionStats.commandsRun.push(command);
249
383
  if (sandbox && sandbox['config']?.backend !== 'none') {
250
- // Use sandbox execution
251
- const result = await sandbox.execute(command, process.cwd());
252
- if (result.stdout)
253
- console.log(result.stdout);
254
- if (result.stderr)
255
- console.error(result.stderr);
256
- if (result.timedOut)
257
- console.log(chalk_1.default.yellow('Command timed out'));
258
- return;
384
+ try {
385
+ const result = await sandbox.execute(command, process.cwd());
386
+ if (result.stdout)
387
+ console.log(result.stdout);
388
+ if (result.stderr)
389
+ console.error(result.stderr);
390
+ return;
391
+ }
392
+ catch (error) {
393
+ console.log(chalk_1.default.red(error instanceof Error ? error.message : String(error)));
394
+ return;
395
+ }
259
396
  }
260
397
  return new Promise((resolve) => {
261
398
  const isWindows = process.platform === 'win32';
@@ -265,7 +402,9 @@ async function executeShellCommand(command, sandbox) {
265
402
  stdio: 'inherit',
266
403
  cwd: process.cwd()
267
404
  });
268
- proc.on('close', () => {
405
+ proc.on('close', () => resolve());
406
+ proc.on('error', (err) => {
407
+ console.log(chalk_1.default.red('Failed: ' + err.message));
269
408
  resolve();
270
409
  });
271
410
  });
@@ -275,15 +414,15 @@ async function processFileReferences(input) {
275
414
  const matches = input.matchAll(fileRefRegex);
276
415
  let result = input;
277
416
  const fs = require('fs');
278
- const path = require('path');
279
417
  for (const match of matches) {
280
418
  const filePath = match[1];
281
419
  try {
282
420
  const content = fs.readFileSync(filePath, 'utf-8');
283
- result = result.replace(match[0], `\n[File: ${filePath}]\n${content}\n[End of file]\n`);
421
+ result = result.replace(match[0], '\n[File: ' + filePath + ']\n' + content + '\n[End of file]\n');
422
+ sessionStats.filesRead.push(filePath);
284
423
  }
285
424
  catch {
286
- // File not found, keep original reference
425
+ console.log(chalk_1.default.yellow('Warning: Could not read file ' + filePath));
287
426
  }
288
427
  }
289
428
  return result;
@@ -317,13 +456,6 @@ Your primary goal is to help users safely and efficiently complete programming t
317
456
  - task: Launch sub-agents
318
457
  - save_memory: Save information for future sessions
319
458
 
320
- # Sub-Agents (use $agent-name to call)
321
- - general-purpose: Complex multi-step tasks
322
- - plan-agent: Planning and analysis
323
- - explore-agent: Codebase exploration
324
- - code-reviewer: Code review
325
- - frontend-tester: UI testing
326
-
327
459
  # Guidelines
328
460
  1. Be concise and helpful
329
461
  2. Always explain what you're doing before using tools
@@ -331,9 +463,9 @@ Your primary goal is to help users safely and efficiently complete programming t
331
463
  4. Prefer editing existing files over creating new ones
332
464
  5. Use appropriate tools for each task
333
465
  6. Verify changes after making them
334
- 7. Provide actionable suggestions
466
+ 7. After completing a complex task, provide a brief summary
335
467
 
336
468
  Current working directory: ${process.cwd()}
337
469
  `;
338
470
  }
339
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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","sourcesContent":["import * as readline from 'readline';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport {\n  getConfigManager,\n  createAIProvider,\n  Conversation,\n  Message,\n  AgentFactory,\n  Agent,\n  AgentType,\n  createSandboxExecutor,\n  SandboxExecutor\n} from '@oflow-ai/core';\nimport { isSlashCommand, executeSlashCommand } from './commands';\nimport { renderMarkdown } from './utils/markdown';\n\nexport interface CLIOptions {\n  model?: string;\n  yolo?: boolean;\n  sandbox?: boolean;\n  showThinking?: boolean;\n}\n\nlet sandboxExecutor: SandboxExecutor | null = null;\nlet showThinking = false;\n\nexport async function startInteractiveMode(options: CLIOptions): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  if (!auth) {\n    console.log(chalk.red('Not authenticated. Run `oflow auth` first.'));\n    return;\n  }\n\n  // 初始化沙箱执行器\n  if (options.sandbox || configManager.get('sandbox')) {\n    sandboxExecutor = await createSandboxExecutor();\n    console.log(chalk.gray(`Sandbox mode: ${sandboxExecutor ? 'enabled' : 'unavailable'}`));\n  }\n\n  // 获取思考过程显示设置\n  showThinking = options.showThinking ?? configManager.getShowThinking();\n\n  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';\n  const provider = createAIProvider(auth, model);\n  const agentFactory = new AgentFactory(provider, process.cwd());\n\n  const conversation = new Conversation({\n    provider,\n    workingDirectory: process.cwd(),\n    maxTokens: configManager.get('maxTokens'),\n    temperature: configManager.get('temperature'),\n    showThinking: showThinking,\n    onContent: (content) => {\n      process.stdout.write(chalk.white(content));\n    },\n    onThinking: (thinking) => {\n      // 显示思考过程，使用不同的颜色\n      process.stdout.write(chalk.magenta(thinking));\n    },\n    onToolCall: (toolCall) => {\n      console.log(chalk.cyan(`\\n🔧 Using tool: ${toolCall.function.name}`));\n    },\n    onToolResult: (result) => {\n      // Tool result is handled silently\n    }\n  });\n\n  // Set system prompt\n  conversation.setSystemPrompt(getSystemPrompt());\n\n  console.log(chalk.bold.blue('\\n╔═══════════════════════════════════════╗'));\n  console.log(chalk.bold.blue('║         Welcome to oflow CLI          ║'));\n  console.log(chalk.bold.blue('╚═══════════════════════════════════════╝'));\n  console.log('');\n  console.log(chalk.gray(`Model: ${model}`));\n  console.log(chalk.gray(`Working directory: ${process.cwd()}`));\n  if (sandboxExecutor) {\n    console.log(chalk.gray(`Sandbox: enabled`));\n  }\n  console.log(chalk.gray(`Thinking: ${showThinking ? 'ON' : 'OFF'} (use /thinking to toggle)`));\n  console.log('');\n  console.log(chalk.gray('Type your message and press Enter to chat.'));\n  console.log(chalk.gray('Type /help for available commands.'));\n  console.log(chalk.gray('Type $agent-name to call a sub-agent.'));\n  console.log(chalk.gray('Type /exit or press Ctrl+C to exit.'));\n  console.log('');\n\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n    prompt: chalk.green('> ')\n  });\n\n  rl.prompt();\n\n  rl.on('line', async (line) => {\n    const input = line.trim();\n    \n    if (!input) {\n      rl.prompt();\n      return;\n    }\n\n    // Check for slash commands\n    if (isSlashCommand(input)) {\n      const shouldContinue = await executeSlashCommand(input, {\n        conversation,\n        rl,\n        configManager\n      });\n      \n      if (!shouldContinue) {\n        rl.close();\n        return;\n      }\n      \n      rl.prompt();\n      return;\n    }\n\n    // Check for agent calls (starting with $)\n    if (input.startsWith('$')) {\n      await handleAgentCall(input, agentFactory, options);\n      rl.prompt();\n      return;\n    }\n\n    // Check for shell commands (starting with !)\n    if (input.startsWith('!')) {\n      await executeShellCommand(input.slice(1), sandboxExecutor);\n      rl.prompt();\n      return;\n    }\n\n    // Check for file reference (starting with @)\n    const processedInput = await processFileReferences(input);\n\n    // Send to AI\n    const spinner = ora('Thinking...').start();\n    \n    try {\n      const response = await conversation.sendMessage(processedInput);\n      spinner.stop();\n      \n      console.log(''); // New line after response\n      rl.prompt();\n    } catch (error) {\n      spinner.fail('Error');\n      console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n      rl.prompt();\n    }\n  });\n\n  rl.on('close', () => {\n    console.log(chalk.bold('\\nGoodbye! 👋\\n'));\n    process.exit(0);\n  });\n\n  // Handle Ctrl+C\n  process.on('SIGINT', () => {\n    console.log(chalk.bold('\\nGoodbye! 👋\\n'));\n    process.exit(0);\n  });\n}\n\nasync function handleAgentCall(\n  input: string, \n  agentFactory: AgentFactory,\n  options: CLIOptions\n): Promise<void> {\n  // Parse agent call: $agent-type \"task description\"\n  const match = input.match(/^\\$(\\w+(?:-\\w+)*)\\s*(.*)$/);\n  \n  if (!match) {\n    console.log(chalk.yellow('Invalid agent call format. Use: $agent-type \"task\"'));\n    console.log(chalk.gray('Available agents: general-purpose, plan-agent, explore-agent, code-reviewer, frontend-tester'));\n    return;\n  }\n\n  const agentType = match[1] as AgentType;\n  const task = match[2].replace(/^[\"']|[\"']$/g, '');\n\n  if (!task) {\n    console.log(chalk.yellow('Please provide a task for the agent.'));\n    return;\n  }\n\n  try {\n    const agent = agentFactory.createAgent(agentType);\n    console.log(chalk.cyan(`\\n🤖 Starting ${agentType} agent...`));\n    console.log(chalk.gray(`Task: ${task}\\n`));\n\n    const spinner = ora('Agent working...').start();\n    \n    const result = await agent.execute(task, (update) => {\n      spinner.stop();\n      process.stdout.write(update);\n      spinner.start();\n    });\n\n    spinner.stop();\n    \n    if (result.success) {\n      console.log(chalk.green('\\n\\n✓ Agent completed successfully'));\n      if (result.filesModified && result.filesModified.length > 0) {\n        console.log(chalk.gray('Files modified:'));\n        result.filesModified.forEach(f => console.log(chalk.gray(`  - ${f}`)));\n      }\n    } else {\n      console.log(chalk.red('\\n\\n✗ Agent encountered errors:'));\n      result.errors?.forEach(e => console.log(chalk.red(`  - ${e}`)));\n    }\n\n    if (result.output) {\n      console.log(chalk.gray('\\nOutput:'));\n      console.log(result.output);\n    }\n\n  } catch (error) {\n    console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n  }\n}\n\nexport async function runSingleCommand(prompt: string, options: CLIOptions): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  if (!auth) {\n    console.log(chalk.red('Not authenticated. Run `oflow auth` first.'));\n    return;\n  }\n\n  // 初始化沙箱执行器\n  if (options.sandbox || configManager.get('sandbox')) {\n    sandboxExecutor = await createSandboxExecutor();\n  }\n\n  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';\n  const provider = createAIProvider(auth, model);\n  const conversation = new Conversation({\n    provider,\n    workingDirectory: process.cwd(),\n    maxTokens: configManager.get('maxTokens'),\n    temperature: configManager.get('temperature'),\n    onContent: (content) => {\n      process.stdout.write(chalk.white(content));\n    }\n  });\n\n  conversation.setSystemPrompt(getSystemPrompt());\n\n  const processedInput = await processFileReferences(prompt);\n  const spinner = ora('Processing...').start();\n\n  try {\n    await conversation.sendMessage(processedInput);\n    spinner.stop();\n    console.log('');\n  } catch (error) {\n    spinner.fail('Error');\n    console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n  }\n}\n\nasync function executeShellCommand(command: string, sandbox?: SandboxExecutor | null): Promise<void> {\n  const { spawn } = require('child_modules');\n  \n  if (sandbox && sandbox['config']?.backend !== 'none') {\n    // Use sandbox execution\n    const result = await sandbox.execute(command, process.cwd());\n    if (result.stdout) console.log(result.stdout);\n    if (result.stderr) console.error(result.stderr);\n    if (result.timedOut) console.log(chalk.yellow('Command timed out'));\n    return;\n  }\n  \n  return new Promise((resolve) => {\n    const isWindows = process.platform === 'win32';\n    const shell = isWindows ? 'powershell.exe' : '/bin/bash';\n    const args = isWindows ? ['-NoProfile', '-Command', command] : ['-c', command];\n\n    const proc = spawn(shell, args, {\n      stdio: 'inherit',\n      cwd: process.cwd()\n    });\n\n    proc.on('close', () => {\n      resolve();\n    });\n  });\n}\n\nasync function processFileReferences(input: string): Promise<string> {\n  const fileRefRegex = /@([^\\s]+)/g;\n  const matches = input.matchAll(fileRefRegex);\n  \n  let result = input;\n  const fs = require('fs');\n  const path = require('path');\n\n  for (const match of matches) {\n    const filePath = match[1];\n    try {\n      const content = fs.readFileSync(filePath, 'utf-8');\n      result = result.replace(match[0], `\\n[File: ${filePath}]\\n${content}\\n[End of file]\\n`);\n    } catch {\n      // File not found, keep original reference\n    }\n  }\n\n  return result;\n}\n\nfunction getSystemPrompt(): string {\n  return `You are oflow CLI, an interactive CLI agent specializing in software engineering tasks.\n\nYour primary goal is to help users safely and efficiently complete programming tasks.\n\n# Core Capabilities\n- Read, write, and edit files\n- Execute shell commands\n- Search and analyze code\n- Web search and fetch content\n- Manage project structure\n- Launch specialized sub-agents\n\n# Tools Available\n- read_file: Read file contents\n- write_file: Write to files\n- list_directory: List directory contents\n- glob: Find files by pattern\n- search_file_content: Search within files\n- run_shell_command: Execute shell commands\n- web_search: Search the web\n- web_fetch: Fetch web content\n- replace: Replace text in files\n- image_read: Analyze images\n- pdf_extract: Extract content from PDFs\n- ask_user_question: Ask user for input\n- task: Launch sub-agents\n- save_memory: Save information for future sessions\n\n# Sub-Agents (use $agent-name to call)\n- general-purpose: Complex multi-step tasks\n- plan-agent: Planning and analysis\n- explore-agent: Codebase exploration\n- code-reviewer: Code review\n- frontend-tester: UI testing\n\n# Guidelines\n1. Be concise and helpful\n2. Always explain what you're doing before using tools\n3. Ask for clarification when needed\n4. Prefer editing existing files over creating new ones\n5. Use appropriate tools for each task\n6. Verify changes after making them\n7. Provide actionable suggestions\n\nCurrent working directory: ${process.cwd()}\n`;\n}"]}
471
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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","sourcesContent":["import * as readline from 'readline';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport {\n  getConfigManager,\n  createAIProvider,\n  Conversation,\n  AgentFactory,\n  AgentType,\n  createSandboxExecutor,\n  SandboxExecutor\n} from '@oflow-ai/core';\nimport { isSlashCommand, executeSlashCommand } from './commands';\nimport { checkForUpdates, performUpdate } from './updater';\n\nexport interface CLIOptions {\n  model?: string;\n  yolo?: boolean;\n  sandbox?: boolean;\n  showThinking?: boolean;\n}\n\ninterface SessionStats {\n  toolCallsCount: number;\n  filesRead: string[];\n  filesWritten: string[];\n  commandsRun: string[];\n  startTime: Date;\n}\n\nlet sandboxExecutor: SandboxExecutor | null = null;\nlet currentShowThinking = false;\nlet sessionStats: SessionStats = {\n  toolCallsCount: 0,\n  filesRead: [],\n  filesWritten: [],\n  commandsRun: [],\n  startTime: new Date()\n};\nlet contextTokens = 0;\nlet maxContextTokens = 128000;\n\nfunction drawStatusBar(model: string): void {\n  const terminalWidth = process.stdout.columns || 80;\n  const contextPercent = Math.min(100, Math.round((contextTokens / maxContextTokens) * 100));\n  const contextColor = contextPercent > 80 ? chalk.red : contextPercent > 50 ? chalk.yellow : chalk.green;\n  const thinkingStatus = currentShowThinking ? chalk.cyan('ON') : chalk.gray('OFF');\n  \n  const statusLine1 = [\n    `${chalk.blue('Model:')} ${chalk.white(model)}`,\n    `${chalk.blue('Context:')} ${contextColor(contextPercent + '%')}`,\n    `${chalk.blue('Thinking:')} ${thinkingStatus}`\n  ].join('  |  ');\n  \n  const currentDir = process.cwd();\n  const dirDisplay = currentDir.length > terminalWidth - 10 \n    ? '...' + currentDir.slice(-(terminalWidth - 13))\n    : currentDir;\n  const statusLine2 = `${chalk.blue('Dir:')} ${chalk.gray(dirDisplay)}`;\n  \n  console.log('');\n  console.log(chalk.gray('─'.repeat(Math.min(terminalWidth, 60))));\n  console.log(statusLine1);\n  console.log(statusLine2);\n  console.log(chalk.gray('─'.repeat(Math.min(terminalWidth, 60))));\n}\n\nfunction showTaskSummary(): void {\n  const duration = Math.round((Date.now() - sessionStats.startTime.getTime()) / 1000);\n  const minutes = Math.floor(duration / 60);\n  const seconds = duration % 60;\n  \n  console.log('');\n  console.log(chalk.bold.cyan('═══════════════════════════════════════'));\n  console.log(chalk.bold.cyan('           Task Summary'));\n  console.log(chalk.bold.cyan('═══════════════════════════════════════'));\n  console.log('');\n  \n  console.log(`${chalk.white('Duration:')} ${chalk.yellow(minutes + 'm ' + seconds + 's')}`);\n  console.log(`${chalk.white('Tool calls:')} ${chalk.yellow(sessionStats.toolCallsCount.toString())}`);\n  \n  if (sessionStats.filesRead.length > 0) {\n    console.log(`${chalk.white('Files read:')} ${chalk.yellow(sessionStats.filesRead.length.toString())}`);\n    sessionStats.filesRead.slice(0, 5).forEach(f => console.log(chalk.gray('    - ' + f)));\n    if (sessionStats.filesRead.length > 5) {\n      console.log(chalk.gray('    ... and ' + (sessionStats.filesRead.length - 5) + ' more'));\n    }\n  }\n  \n  if (sessionStats.filesWritten.length > 0) {\n    console.log(`${chalk.white('Files modified:')} ${chalk.yellow(sessionStats.filesWritten.length.toString())}`);\n    sessionStats.filesWritten.slice(0, 5).forEach(f => console.log(chalk.gray('    - ' + f)));\n    if (sessionStats.filesWritten.length > 5) {\n      console.log(chalk.gray('    ... and ' + (sessionStats.filesWritten.length - 5) + ' more'));\n    }\n  }\n  \n  if (sessionStats.commandsRun.length > 0) {\n    console.log(`${chalk.white('Commands run:')} ${chalk.yellow(sessionStats.commandsRun.length.toString())}`);\n  }\n  \n  console.log('');\n  console.log(chalk.bold.cyan('═══════════════════════════════════════'));\n  console.log('');\n  \n  sessionStats = {\n    toolCallsCount: 0,\n    filesRead: [],\n    filesWritten: [],\n    commandsRun: [],\n    startTime: new Date()\n  };\n}\n\nexport async function startInteractiveMode(options: CLIOptions): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  if (!auth) {\n    console.log(chalk.red('Not authenticated. Run `oflow auth` first.'));\n    return;\n  }\n\n  // Check for updates\n  const updateInfo = await checkForUpdates();\n  if (updateInfo.hasUpdate) {\n    console.log('');\n    console.log(chalk.yellow('New version available: ' + updateInfo.latestVersion));\n    console.log(chalk.yellow('Run /update to update'));\n    console.log('');\n  }\n\n  if (options.sandbox || configManager.get('sandbox')) {\n    try {\n      sandboxExecutor = await createSandboxExecutor();\n    } catch {}\n  }\n\n  currentShowThinking = options.showThinking ?? configManager.getShowThinking();\n  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';\n\n  if (model.includes('gpt-4') || model.includes('gpt-4o')) {\n    maxContextTokens = 128000;\n  } else if (model.includes('deepseek')) {\n    maxContextTokens = 64000;\n  } else {\n    maxContextTokens = 128000;\n  }\n\n  let provider;\n  try {\n    provider = createAIProvider(auth, model);\n  } catch (error) {\n    console.log(chalk.red('Failed to create AI provider: ' + (error instanceof Error ? error.message : String(error))));\n    return;\n  }\n\n  const conversation = new Conversation({\n    provider,\n    workingDirectory: process.cwd(),\n    maxTokens: configManager.get('maxTokens'),\n    temperature: configManager.get('temperature'),\n    showThinking: currentShowThinking,\n    onContent: (content) => {\n      process.stdout.write(chalk.white(content));\n    },\n    onThinking: (thinking) => {\n      if (currentShowThinking) {\n        process.stdout.write(chalk.magenta(thinking));\n      }\n    },\n    onToolCall: (toolCall) => {\n      sessionStats.toolCallsCount++;\n      console.log(chalk.cyan('\\nUsing tool: ' + toolCall.function.name));\n      try {\n        const args = JSON.parse(toolCall.function.arguments);\n        if (toolCall.function.name === 'read_file' && args.absolute_path) {\n          if (!sessionStats.filesRead.includes(args.absolute_path)) {\n            sessionStats.filesRead.push(args.absolute_path);\n          }\n        } else if ((toolCall.function.name === 'write_file' || toolCall.function.name === 'replace') && args.file_path) {\n          if (!sessionStats.filesWritten.includes(args.file_path)) {\n            sessionStats.filesWritten.push(args.file_path);\n          }\n        } else if (toolCall.function.name === 'run_shell_command' && args.command) {\n          sessionStats.commandsRun.push(args.command);\n        }\n      } catch {}\n    },\n    onToolResult: (result) => {\n      contextTokens += Math.ceil(result.length / 4);\n    }\n  });\n\n  conversation.setSystemPrompt(getSystemPrompt());\n\n  console.log(chalk.bold.blue('\\nWelcome to oflow CLI'));\n  console.log(chalk.gray('Type /help for commands, /exit to quit'));\n  console.log('');\n\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout\n  });\n\n  const showPrompt = () => {\n    drawStatusBar(model);\n    rl.setPrompt(chalk.green('\\n> '));\n    rl.prompt();\n  };\n\n  showPrompt();\n\n  rl.on('line', async (line) => {\n    const input = line.trim();\n    \n    if (!input) {\n      showPrompt();\n      return;\n    }\n\n    if (isSlashCommand(input)) {\n      if (input.toLowerCase() === '/thinking') {\n        currentShowThinking = !currentShowThinking;\n        configManager.setShowThinking(currentShowThinking);\n        console.log(chalk.green('Thinking: ' + (currentShowThinking ? 'ON' : 'OFF')));\n        showPrompt();\n        return;\n      }\n\n      if (input.toLowerCase() === '/summary') {\n        showTaskSummary();\n        showPrompt();\n        return;\n      }\n\n      if (input.toLowerCase() === '/update') {\n        await performUpdate();\n        showPrompt();\n        return;\n      }\n\n      const shouldContinue = await executeSlashCommand(input, {\n        conversation,\n        rl,\n        configManager\n      });\n      \n      if (!shouldContinue) {\n        rl.close();\n        return;\n      }\n      \n      showPrompt();\n      return;\n    }\n\n    if (input.startsWith('$')) {\n      await handleAgentCall(input, provider);\n      showPrompt();\n      return;\n    }\n\n    if (input.startsWith('!')) {\n      await executeShellCommand(input.slice(1), sandboxExecutor);\n      showPrompt();\n      return;\n    }\n\n    const processedInput = await processFileReferences(input);\n    const spinner = ora('Thinking...').start();\n    \n    try {\n      const response = await conversation.sendMessage(processedInput);\n      spinner.stop();\n      console.log('');\n      \n      if (sessionStats.toolCallsCount >= 3) {\n        showTaskSummary();\n      } else {\n        contextTokens += Math.ceil(response.length / 4);\n      }\n      \n      showPrompt();\n    } catch (error) {\n      spinner.fail('Error');\n      const errorMessage = error instanceof Error ? error.message : String(error);\n      console.log(chalk.red(errorMessage));\n      \n      if (errorMessage.includes('400')) {\n        console.log(chalk.yellow('Check API key and model name, or run \"oflow auth\"'));\n      } else if (errorMessage.includes('401')) {\n        console.log(chalk.yellow('Authentication failed, run \"oflow auth\"'));\n      } else if (errorMessage.includes('429')) {\n        console.log(chalk.yellow('Rate limit, please wait and retry'));\n      }\n      \n      showPrompt();\n    }\n  });\n\n  rl.on('close', () => {\n    console.log(chalk.bold('\\nGoodbye!\\n'));\n    process.exit(0);\n  });\n\n  process.on('SIGINT', () => {\n    console.log(chalk.bold('\\nGoodbye!\\n'));\n    process.exit(0);\n  });\n}\n\nasync function handleAgentCall(input: string, provider: any): Promise<void> {\n  const match = input.match(/^\\$(\\w+(?:-\\w+)*)\\s*(.*)$/);\n  \n  if (!match) {\n    console.log(chalk.yellow('Invalid format. Use: $agent-type \"task\"'));\n    console.log(chalk.gray('Agents: general-purpose, plan-agent, explore-agent, code-reviewer, frontend-tester'));\n    return;\n  }\n\n  const agentType = match[1] as AgentType;\n  const task = match[2].replace(/^[\"']|[\"']$/g, '');\n\n  if (!task) {\n    console.log(chalk.yellow('Please provide a task.'));\n    return;\n  }\n\n  try {\n    const agentFactory = new AgentFactory(provider, process.cwd());\n    const agent = agentFactory.createAgent(agentType);\n    console.log(chalk.cyan('\\nStarting ' + agentType + ' agent...'));\n    console.log(chalk.gray('Task: ' + task + '\\n'));\n\n    const spinner = ora('Agent working...').start();\n    const result = await agent.execute(task, (update) => {\n      spinner.stop();\n      process.stdout.write(update);\n      spinner.start();\n    });\n\n    spinner.stop();\n    \n    if (result.success) {\n      console.log(chalk.green('\\nAgent completed successfully'));\n      if (result.filesModified && result.filesModified.length > 0) {\n        console.log(chalk.gray('Files modified:'));\n        result.filesModified.forEach(f => console.log(chalk.gray('  - ' + f)));\n        sessionStats.filesWritten.push(...result.filesModified);\n      }\n    } else {\n      console.log(chalk.red('\\nAgent encountered errors:'));\n      result.errors?.forEach(e => console.log(chalk.red('  - ' + e)));\n    }\n\n    if (result.output) {\n      console.log(chalk.gray('\\nOutput:'));\n      console.log(result.output);\n    }\n\n    showTaskSummary();\n  } catch (error) {\n    console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n  }\n}\n\nexport async function runSingleCommand(prompt: string, options: CLIOptions): Promise<void> {\n  const configManager = getConfigManager();\n  const auth = configManager.getAuth();\n\n  if (!auth) {\n    console.log(chalk.red('Not authenticated. Run `oflow auth` first.'));\n    return;\n  }\n\n  if (options.sandbox || configManager.get('sandbox')) {\n    try {\n      sandboxExecutor = await createSandboxExecutor();\n    } catch {}\n  }\n\n  const model = options.model || configManager.getDefaultModel() || 'gpt-4o';\n  const provider = createAIProvider(auth, model);\n  const conversation = new Conversation({\n    provider,\n    workingDirectory: process.cwd(),\n    maxTokens: configManager.get('maxTokens'),\n    temperature: configManager.get('temperature'),\n    onContent: (content) => {\n      process.stdout.write(chalk.white(content));\n    }\n  });\n\n  conversation.setSystemPrompt(getSystemPrompt());\n  const processedInput = await processFileReferences(prompt);\n  const spinner = ora('Processing...').start();\n\n  try {\n    await conversation.sendMessage(processedInput);\n    spinner.stop();\n    console.log('');\n  } catch (error) {\n    spinner.fail('Error');\n    console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n  }\n}\n\nasync function executeShellCommand(command: string, sandbox?: SandboxExecutor | null): Promise<void> {\n  const { spawn } = require('child_process');\n  sessionStats.commandsRun.push(command);\n  \n  if (sandbox && sandbox['config']?.backend !== 'none') {\n    try {\n      const result = await sandbox.execute(command, process.cwd());\n      if (result.stdout) console.log(result.stdout);\n      if (result.stderr) console.error(result.stderr);\n      return;\n    } catch (error) {\n      console.log(chalk.red(error instanceof Error ? error.message : String(error)));\n      return;\n    }\n  }\n  \n  return new Promise((resolve) => {\n    const isWindows = process.platform === 'win32';\n    const shell = isWindows ? 'powershell.exe' : '/bin/bash';\n    const args = isWindows ? ['-NoProfile', '-Command', command] : ['-c', command];\n\n    const proc = spawn(shell, args, {\n      stdio: 'inherit',\n      cwd: process.cwd()\n    });\n\n    proc.on('close', () => resolve());\n    proc.on('error', (err: Error) => {\n      console.log(chalk.red('Failed: ' + err.message));\n      resolve();\n    });\n  });\n}\n\nasync function processFileReferences(input: string): Promise<string> {\n  const fileRefRegex = /@([^\\s]+)/g;\n  const matches = input.matchAll(fileRefRegex);\n  let result = input;\n  const fs = require('fs');\n\n  for (const match of matches) {\n    const filePath = match[1];\n    try {\n      const content = fs.readFileSync(filePath, 'utf-8');\n      result = result.replace(match[0], '\\n[File: ' + filePath + ']\\n' + content + '\\n[End of file]\\n');\n      sessionStats.filesRead.push(filePath);\n    } catch {\n      console.log(chalk.yellow('Warning: Could not read file ' + filePath));\n    }\n  }\n\n  return result;\n}\n\nfunction getSystemPrompt(): string {\n  return `You are oflow CLI, an interactive CLI agent specializing in software engineering tasks.\n\nYour primary goal is to help users safely and efficiently complete programming tasks.\n\n# Core Capabilities\n- Read, write, and edit files\n- Execute shell commands\n- Search and analyze code\n- Web search and fetch content\n- Manage project structure\n- Launch specialized sub-agents\n\n# Tools Available\n- read_file: Read file contents\n- write_file: Write to files\n- list_directory: List directory contents\n- glob: Find files by pattern\n- search_file_content: Search within files\n- run_shell_command: Execute shell commands\n- web_search: Search the web\n- web_fetch: Fetch web content\n- replace: Replace text in files\n- image_read: Analyze images\n- pdf_extract: Extract content from PDFs\n- ask_user_question: Ask user for input\n- task: Launch sub-agents\n- save_memory: Save information for future sessions\n\n# Guidelines\n1. Be concise and helpful\n2. Always explain what you're doing before using tools\n3. Ask for clarification when needed\n4. Prefer editing existing files over creating new ones\n5. Use appropriate tools for each task\n6. Verify changes after making them\n7. After completing a complex task, provide a brief summary\n\nCurrent working directory: ${process.cwd()}\n`;\n}\n"]}