@rxpm/forge-cli 0.0.1

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 (63) hide show
  1. package/.dockerignore +6 -0
  2. package/.prettierrc +9 -0
  3. package/AGENT_RULES.md +42 -0
  4. package/Dockerfile +32 -0
  5. package/README.md +117 -0
  6. package/REQUIREMENTS.md +233 -0
  7. package/assets/preview_explain.webp +0 -0
  8. package/dist/agent/loop.d.ts +6 -0
  9. package/dist/agent/loop.js +62 -0
  10. package/dist/agent/loop.js.map +1 -0
  11. package/dist/cli/commands.d.ts +3 -0
  12. package/dist/cli/commands.js +40 -0
  13. package/dist/cli/commands.js.map +1 -0
  14. package/dist/config/env.d.ts +9 -0
  15. package/dist/config/env.js +16 -0
  16. package/dist/config/env.js.map +1 -0
  17. package/dist/index.d.ts +7 -0
  18. package/dist/index.js +20 -0
  19. package/dist/index.js.map +1 -0
  20. package/dist/llm/provider.d.ts +4 -0
  21. package/dist/llm/provider.js +12 -0
  22. package/dist/llm/provider.js.map +1 -0
  23. package/dist/tools/code.d.ts +15 -0
  24. package/dist/tools/code.js +53 -0
  25. package/dist/tools/code.js.map +1 -0
  26. package/dist/tools/fs.d.ts +18 -0
  27. package/dist/tools/fs.js +70 -0
  28. package/dist/tools/fs.js.map +1 -0
  29. package/dist/tools/git.d.ts +15 -0
  30. package/dist/tools/git.js +61 -0
  31. package/dist/tools/git.js.map +1 -0
  32. package/dist/tools/index.d.ts +35 -0
  33. package/dist/tools/index.js +22 -0
  34. package/dist/tools/index.js.map +1 -0
  35. package/dist/tools/shell.d.ts +9 -0
  36. package/dist/tools/shell.js +31 -0
  37. package/dist/tools/shell.js.map +1 -0
  38. package/dist/ui/activity.d.ts +49 -0
  39. package/dist/ui/activity.js +421 -0
  40. package/dist/ui/activity.js.map +1 -0
  41. package/dist/utils/logger.d.ts +8 -0
  42. package/dist/utils/logger.js +10 -0
  43. package/dist/utils/logger.js.map +1 -0
  44. package/dist/utils/logger2.d.ts +16 -0
  45. package/dist/utils/logger2.js +55 -0
  46. package/dist/utils/logger2.js.map +1 -0
  47. package/dist/utils/test-tools.d.ts +1 -0
  48. package/dist/utils/test-tools.js +31 -0
  49. package/dist/utils/test-tools.js.map +1 -0
  50. package/package.json +43 -0
  51. package/src/agent/loop.ts +68 -0
  52. package/src/cli/commands.ts +44 -0
  53. package/src/config/env.ts +17 -0
  54. package/src/index.ts +22 -0
  55. package/src/llm/provider.ts +13 -0
  56. package/src/tools/code.ts +53 -0
  57. package/src/tools/fs.ts +71 -0
  58. package/src/tools/git.ts +60 -0
  59. package/src/tools/index.ts +23 -0
  60. package/src/tools/shell.ts +32 -0
  61. package/src/ui/activity.ts +504 -0
  62. package/src/utils/logger.ts +10 -0
  63. package/tsconfig.json +18 -0
@@ -0,0 +1,421 @@
1
+ /**
2
+ * File: activity.ts
3
+ * Author: Rajat Sharma
4
+ * Description: Gemini-inspired terminal activity display for the AI agent.
5
+ */
6
+ import { execSync } from 'node:child_process';
7
+ import { homedir } from 'node:os';
8
+ import { relative } from 'node:path';
9
+ import chalk from 'chalk';
10
+ import ora from 'ora';
11
+ import { defaultModel } from '../llm/provider.js';
12
+ const ANSI_PATTERN = /\x1B\[[0-9;]*m/g;
13
+ const box = {
14
+ topLeft: '╭',
15
+ topRight: '╮',
16
+ bottomLeft: '╰',
17
+ bottomRight: '╯',
18
+ horizontal: '─',
19
+ vertical: '│',
20
+ teeLeft: '┤',
21
+ teeRight: '├',
22
+ };
23
+ const theme = {
24
+ accent: chalk.yellowBright,
25
+ accentStrong: chalk.yellowBright.bold,
26
+ success: chalk.greenBright,
27
+ error: chalk.red,
28
+ warning: chalk.yellow,
29
+ info: chalk.blue,
30
+ text: chalk.white,
31
+ soft: chalk.white,
32
+ muted: chalk.dim,
33
+ border: chalk.gray,
34
+ panel: chalk.gray,
35
+ strong: chalk.bold,
36
+ };
37
+ function terminalWidth() {
38
+ const width = process.stdout.columns || 100;
39
+ return Math.max(76, Math.min(width, 118));
40
+ }
41
+ function contentWidth(totalWidth = terminalWidth()) {
42
+ return totalWidth - 4;
43
+ }
44
+ function visibleLength(value) {
45
+ return value.replace(ANSI_PATTERN, '').length;
46
+ }
47
+ function padLine(value, width) {
48
+ const gap = Math.max(0, width - visibleLength(value));
49
+ return value + ' '.repeat(gap);
50
+ }
51
+ function truncate(value, maxLen) {
52
+ if (value.length <= maxLen)
53
+ return value;
54
+ if (maxLen <= 1)
55
+ return value.slice(0, maxLen);
56
+ return value.slice(0, maxLen - 1) + '…';
57
+ }
58
+ function wrapText(value, width) {
59
+ if (!value)
60
+ return [''];
61
+ const chunks = value.replace(/\t/g, ' ').split('\n');
62
+ const lines = [];
63
+ for (const chunk of chunks) {
64
+ if (!chunk.trim()) {
65
+ lines.push('');
66
+ continue;
67
+ }
68
+ let current = '';
69
+ const words = chunk.split(/\s+/);
70
+ for (const word of words) {
71
+ if (!current) {
72
+ current = word;
73
+ continue;
74
+ }
75
+ const next = `${current} ${word}`;
76
+ if (next.length <= width) {
77
+ current = next;
78
+ continue;
79
+ }
80
+ lines.push(current);
81
+ if (word.length <= width) {
82
+ current = word;
83
+ continue;
84
+ }
85
+ let remaining = word;
86
+ while (remaining.length > width) {
87
+ lines.push(remaining.slice(0, width - 1) + '…');
88
+ remaining = remaining.slice(width - 1);
89
+ }
90
+ current = remaining;
91
+ }
92
+ if (current)
93
+ lines.push(current);
94
+ }
95
+ return lines.length > 0 ? lines : [''];
96
+ }
97
+ function formatDuration(ms) {
98
+ if (ms < 1000)
99
+ return `${ms}ms`;
100
+ return `${(ms / 1000).toFixed(1)}s`;
101
+ }
102
+ function safeStringify(value) {
103
+ if (typeof value === 'string')
104
+ return value;
105
+ try {
106
+ return JSON.stringify(value);
107
+ }
108
+ catch {
109
+ return String(value);
110
+ }
111
+ }
112
+ function formatResultPreview(result) {
113
+ if (!result)
114
+ return 'No output';
115
+ const trimmed = result.trim();
116
+ if (!trimmed)
117
+ return 'No output';
118
+ const lines = trimmed.split('\n');
119
+ const firstLine = truncate(lines[0], 72);
120
+ return lines.length > 1 ? `${firstLine} (+${lines.length - 1} lines)` : firstLine;
121
+ }
122
+ function getToolResultValue(result) {
123
+ if (!result)
124
+ return undefined;
125
+ if ('output' in result && result.output !== undefined)
126
+ return result.output;
127
+ return result.result;
128
+ }
129
+ function formatToolBody(call, result) {
130
+ const rawValue = getToolResultValue(result);
131
+ if (rawValue === undefined)
132
+ return [theme.warning('No output captured')];
133
+ const text = safeStringify(rawValue).trim();
134
+ if (!text)
135
+ return [theme.muted('No output')];
136
+ const lines = text.split('\n');
137
+ const isError = text.toLowerCase().startsWith('error');
138
+ const colorize = isError ? theme.error : theme.muted;
139
+ if (call.toolName === 'run_command' || call.toolName === 'RunCommand') {
140
+ const preview = lines.slice(0, 6).map((line) => colorize(line));
141
+ if (lines.length > 6) {
142
+ preview.push(theme.muted(`... (+${lines.length - 6} more lines)`));
143
+ }
144
+ return preview;
145
+ }
146
+ return [colorize(formatResultPreview(text))];
147
+ }
148
+ function getWorkspaceLabel() {
149
+ const cwd = process.cwd();
150
+ const home = homedir();
151
+ if (cwd.startsWith(home)) {
152
+ const rel = relative(home, cwd);
153
+ return rel ? `~/${rel}` : '~';
154
+ }
155
+ return cwd;
156
+ }
157
+ function getBranchName() {
158
+ try {
159
+ return (execSync('git branch --show-current', {
160
+ cwd: process.cwd(),
161
+ stdio: ['ignore', 'pipe', 'ignore'],
162
+ encoding: 'utf8',
163
+ }).trim() || 'detached');
164
+ }
165
+ catch {
166
+ return 'unknown';
167
+ }
168
+ }
169
+ function summarizeTool(toolName, args) {
170
+ switch (toolName) {
171
+ case 'ReadFile':
172
+ case 'read_file':
173
+ return args.path ? truncate(args.path, 54) : 'Inspect file';
174
+ case 'WriteFile':
175
+ case 'write_file':
176
+ return args.path ? truncate(args.path, 54) : 'Write file';
177
+ case 'ListFiles':
178
+ case 'list_files':
179
+ return args.path ? truncate(args.path, 54) : '.';
180
+ case 'SearchCode':
181
+ case 'search_code':
182
+ return args.query ? `"${truncate(args.query, 42)}"` : 'Search codebase';
183
+ case 'OpenFileLines':
184
+ case 'open_file_lines':
185
+ return args.path ? `${truncate(args.path, 36)}:${args.start}-${args.end}` : 'Open file range';
186
+ case 'RunCommand':
187
+ case 'run_command':
188
+ return args.command ? truncate(args.command, 54) : 'Run command';
189
+ case 'GitDiff':
190
+ case 'git_diff':
191
+ return args.staged ? 'staged changes' : 'working tree';
192
+ case 'GitCommit':
193
+ case 'git_commit':
194
+ return args.message ? `"${truncate(args.message, 42)}"` : 'Create commit';
195
+ default:
196
+ return Object.keys(args).length > 0 ? truncate(safeStringify(args), 54) : 'Working';
197
+ }
198
+ }
199
+ function formatToolLabel(toolName) {
200
+ switch (toolName) {
201
+ case 'ReadFile':
202
+ case 'read_file':
203
+ return 'Read';
204
+ case 'WriteFile':
205
+ case 'write_file':
206
+ return 'Edit';
207
+ case 'ListFiles':
208
+ case 'list_files':
209
+ return 'List';
210
+ case 'SearchCode':
211
+ case 'search_code':
212
+ return 'Search';
213
+ case 'OpenFileLines':
214
+ case 'open_file_lines':
215
+ return 'Inspect';
216
+ case 'RunCommand':
217
+ case 'run_command':
218
+ return 'Shell';
219
+ case 'GitStatus':
220
+ case 'git_status':
221
+ return 'Git status';
222
+ case 'GitDiff':
223
+ case 'git_diff':
224
+ return 'Git diff';
225
+ case 'GitCommit':
226
+ case 'git_commit':
227
+ return 'Commit';
228
+ default:
229
+ return toolName.replace(/_/g, ' ');
230
+ }
231
+ }
232
+ function buildTopBorder(title, width = terminalWidth()) {
233
+ const plain = ` ${title} `;
234
+ const fill = Math.max(0, width - visibleLength(plain) - 1);
235
+ return theme.border(`${box.topLeft}${box.horizontal}${title}${box.horizontal.repeat(fill)}${box.topRight}`);
236
+ }
237
+ function buildBottomBorder(width = terminalWidth()) {
238
+ return theme.border(`${box.bottomLeft}${box.horizontal.repeat(width - 2)}${box.bottomRight}`);
239
+ }
240
+ function renderPanel(title, rows, width = terminalWidth()) {
241
+ const innerWidth = contentWidth(width);
242
+ console.log(buildTopBorder(title, width));
243
+ for (const row of rows) {
244
+ const wrapped = wrapText(row, innerWidth);
245
+ for (const line of wrapped) {
246
+ console.log(`${theme.border(box.vertical)} ${padLine(line, innerWidth)} ${theme.border(box.vertical)}`);
247
+ }
248
+ }
249
+ console.log(buildBottomBorder(width));
250
+ }
251
+ function createMetaRow(label, value, width) {
252
+ const left = theme.muted(`${label.padEnd(10)} `);
253
+ const wrapped = wrapText(value, width - 11);
254
+ return wrapped.map((line, index) => {
255
+ if (index === 0)
256
+ return `${left}${theme.text(line)}`;
257
+ return `${' '.repeat(11)}${theme.text(line)}`;
258
+ });
259
+ }
260
+ function renderStatusLine(label, status, meta) {
261
+ const color = status === 'success' ? theme.success : status === 'error' ? theme.error : theme.info;
262
+ const summary = meta ? `${label} ${theme.muted(meta)}` : label;
263
+ console.log(`${color('●')} ${theme.text(summary)}`);
264
+ }
265
+ export class ActivityDisplay {
266
+ spinner = null;
267
+ stepCount = 0;
268
+ toolCalls = [];
269
+ startTime = Date.now();
270
+ branch = getBranchName();
271
+ startThinking() {
272
+ if (!process.stdout.isTTY || !process.stderr.isTTY)
273
+ return;
274
+ if (this.spinner)
275
+ return;
276
+ this.spinner = ora({
277
+ text: theme.soft('Forge is working...'),
278
+ spinner: 'dots',
279
+ color: 'yellow',
280
+ stream: process.stdout,
281
+ }).start();
282
+ }
283
+ stopThinking() {
284
+ if (!this.spinner)
285
+ return;
286
+ this.spinner.clear();
287
+ this.spinner.stop();
288
+ this.spinner = null;
289
+ }
290
+ onStepStart() {
291
+ this.stopThinking();
292
+ }
293
+ onToolCall(call) {
294
+ this.stopThinking();
295
+ const entry = {
296
+ id: call.toolCallId,
297
+ name: call.toolName,
298
+ displayName: formatToolLabel(call.toolName),
299
+ args: call.args,
300
+ startTime: Date.now(),
301
+ status: 'running',
302
+ };
303
+ this.toolCalls.push(entry);
304
+ const label = `${entry.displayName} ${summarizeTool(call.toolName, call.args)}`;
305
+ renderStatusLine(label, 'info');
306
+ }
307
+ onToolResult(result) {
308
+ const entry = this.toolCalls.find((item) => item.id === result.toolCallId);
309
+ if (entry) {
310
+ entry.endTime = Date.now();
311
+ entry.result = safeStringify(getToolResultValue(result));
312
+ entry.status = entry.result.toLowerCase().startsWith('error') ? 'error' : 'done';
313
+ const duration = formatDuration(entry.endTime - entry.startTime);
314
+ const preview = formatResultPreview(entry.result);
315
+ renderStatusLine(preview, entry.status === 'error' ? 'error' : 'success', `· ${duration}`);
316
+ }
317
+ this.startThinking();
318
+ }
319
+ onText(text) {
320
+ this.stopThinking();
321
+ if (!text.trim())
322
+ return;
323
+ const width = terminalWidth();
324
+ const rows = [];
325
+ for (const block of text.trim().split('\n')) {
326
+ const prefix = block.trim() ? `${theme.accent('✦')} ${theme.text(block.trim())}` : '';
327
+ rows.push(prefix);
328
+ }
329
+ renderPanel(theme.panel(' Response '), rows, width);
330
+ }
331
+ onStepFinish(step) {
332
+ this.stopThinking();
333
+ this.stepCount++;
334
+ const width = terminalWidth();
335
+ const rows = [];
336
+ const resultsById = new Map(step.toolResults.map((result) => [result.toolCallId, result]));
337
+ for (const call of step.toolCalls) {
338
+ const args = call.args || {};
339
+ const label = call.title || formatToolLabel(call.toolName);
340
+ const summary = summarizeTool(call.toolName, args);
341
+ const result = resultsById.get(call.toolCallId);
342
+ const resultValue = getToolResultValue(result);
343
+ const resultText = formatResultPreview(safeStringify(resultValue ?? ''));
344
+ const isError = safeStringify(resultValue ?? '')
345
+ .toLowerCase()
346
+ .startsWith('error');
347
+ const existing = this.toolCalls.find((entry) => entry.id === call.toolCallId);
348
+ if (!existing) {
349
+ this.toolCalls.push({
350
+ id: call.toolCallId,
351
+ name: call.toolName,
352
+ displayName: label,
353
+ args,
354
+ startTime: Date.now(),
355
+ endTime: Date.now(),
356
+ result: safeStringify(resultValue ?? ''),
357
+ status: isError ? 'error' : 'done',
358
+ });
359
+ }
360
+ const icon = isError ? theme.error('✕') : theme.success('✓');
361
+ rows.push(`${icon} ${theme.strong(label)} ${theme.soft(summary)}`);
362
+ for (const bodyLine of formatToolBody(call, result)) {
363
+ rows.push(` ${bodyLine}`);
364
+ }
365
+ rows.push('');
366
+ }
367
+ if (rows.length > 0 && rows[rows.length - 1] === '') {
368
+ rows.pop();
369
+ }
370
+ if (rows.length > 0) {
371
+ renderPanel(`${theme.text(` Step ${this.stepCount} `)}${theme.muted(`· ${step.toolCalls.length} tool${step.toolCalls.length === 1 ? '' : 's'}`)} `, rows, width);
372
+ }
373
+ if (step.text?.trim()) {
374
+ const responseRows = [];
375
+ for (const line of step.text.trim().split('\n')) {
376
+ if (!line.trim()) {
377
+ responseRows.push('');
378
+ continue;
379
+ }
380
+ responseRows.push(`${theme.accent('✦')} ${theme.text(line.trim())}`);
381
+ }
382
+ renderPanel(theme.panel(' Response '), responseRows, width);
383
+ }
384
+ this.startThinking();
385
+ }
386
+ printSummary(status, message) {
387
+ this.stopThinking();
388
+ const elapsed = formatDuration(Date.now() - this.startTime);
389
+ const title = status === 'success'
390
+ ? `${theme.success(' Task complete ')}${theme.muted(`· ${this.stepCount} steps · ${elapsed}`)}`
391
+ : `${theme.error(' Task failed ')}${theme.muted(`· ${this.stepCount} steps · ${elapsed}`)}`;
392
+ const rows = status === 'error' && message ? [theme.error(message)] : [theme.soft('Session finished. You can run another task with `forge "<task>"`.')];
393
+ console.log('');
394
+ renderPanel(title, rows);
395
+ this.renderFooter();
396
+ }
397
+ renderFooter() {
398
+ const width = terminalWidth();
399
+ const inner = contentWidth(width);
400
+ const rows = [
401
+ ...createMetaRow('workspace', getWorkspaceLabel(), inner),
402
+ ...createMetaRow('branch', this.branch, inner),
403
+ ...createMetaRow('provider', 'Ollama', inner),
404
+ ...createMetaRow('model', defaultModel, inner),
405
+ ];
406
+ renderPanel(theme.panel(' Session '), rows, width);
407
+ }
408
+ static printBanner(task) {
409
+ const width = terminalWidth();
410
+ const inner = contentWidth(width);
411
+ const rows = [
412
+ ...createMetaRow('task', task, inner),
413
+ ...createMetaRow('workspace', getWorkspaceLabel(), inner),
414
+ ...createMetaRow('branch', getBranchName(), inner),
415
+ ...createMetaRow('model', `${defaultModel} via Ollama`, inner),
416
+ ];
417
+ console.log('');
418
+ renderPanel(`${theme.accentStrong(' Forge ')}${theme.muted('· terminal coding agent')}`, rows, width);
419
+ }
420
+ }
421
+ //# sourceMappingURL=activity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"activity.js","sourceRoot":"","sources":["../../src/ui/activity.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ export declare const logger: {
2
+ info: (msg: string) => void;
3
+ success: (msg: string) => void;
4
+ error: (msg: string) => void;
5
+ warn: (msg: string) => void;
6
+ tool: (name: string, params: any) => void;
7
+ step: (msg: string) => void;
8
+ };
@@ -0,0 +1,10 @@
1
+ import chalk from 'chalk';
2
+ export const logger = {
3
+ info: (msg) => console.log(chalk.blue('ℹ'), msg),
4
+ success: (msg) => console.log(chalk.green('✔'), msg),
5
+ error: (msg) => console.log(chalk.red('✖'), msg),
6
+ warn: (msg) => console.log(chalk.yellow('⚠'), msg),
7
+ tool: (name, params) => console.log(chalk.cyan('⚒'), chalk.bold(name), chalk.gray(JSON.stringify(params))),
8
+ step: (msg) => console.log(chalk.magenta('➜'), msg),
9
+ };
10
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,CAAC,MAAM,MAAM,GAAG;IAClB,IAAI,EAAE,CAAC,GAAW,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC;IACxD,OAAO,EAAE,CAAC,GAAW,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC;IAC5D,KAAK,EAAE,CAAC,GAAW,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC;IACxD,IAAI,EAAE,CAAC,GAAW,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC;IAC1D,IAAI,EAAE,CAAC,IAAY,EAAE,MAAW,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;IACvH,IAAI,EAAE,CAAC,GAAW,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC;CAC9D,CAAC"}
@@ -0,0 +1,16 @@
1
+ type LogMeta = Record<string, any>;
2
+ declare class Logger {
3
+ private indentLevel;
4
+ private prefix;
5
+ private line;
6
+ step(message: string, meta?: LogMeta): void;
7
+ start(tool: string, meta?: LogMeta): void;
8
+ success(tool: string, meta?: LogMeta): void;
9
+ error(tool: string, error: unknown): void;
10
+ toolCall(name: string, args?: LogMeta): void;
11
+ toolResult(result?: any): void;
12
+ info(message: string, meta?: LogMeta): void;
13
+ done(message?: string): void;
14
+ }
15
+ export declare const logger: Logger;
16
+ export {};
@@ -0,0 +1,55 @@
1
+ // src/utils/logger.ts
2
+ import util from 'node:util';
3
+ const INDENT = ' ';
4
+ function formatMeta(meta) {
5
+ if (!meta || Object.keys(meta).length === 0)
6
+ return '';
7
+ const clean = JSON.stringify(meta, null, 0);
8
+ return ` ${clean}`;
9
+ }
10
+ function now() {
11
+ return new Date().toISOString().split('T')[1].replace('Z', '');
12
+ }
13
+ class Logger {
14
+ indentLevel = 0;
15
+ prefix() {
16
+ return INDENT.repeat(this.indentLevel);
17
+ }
18
+ line(symbol, message, meta) {
19
+ const time = now();
20
+ process.stdout.write(`${this.prefix()}${symbol} ${message}${formatMeta(meta)}\n`);
21
+ }
22
+ // ---- Public API ----
23
+ step(message, meta) {
24
+ this.line('●', message, meta);
25
+ }
26
+ start(tool, meta) {
27
+ this.line('●', `Using ${tool}`, meta);
28
+ this.indentLevel++;
29
+ }
30
+ success(tool, meta) {
31
+ this.indentLevel = Math.max(0, this.indentLevel - 1);
32
+ this.line('✔', `${tool} done`, meta);
33
+ }
34
+ error(tool, error) {
35
+ this.indentLevel = Math.max(0, this.indentLevel - 1);
36
+ this.line('✖', `${tool} failed`, {
37
+ error: error instanceof Error ? error.message : String(error),
38
+ });
39
+ }
40
+ toolCall(name, args) {
41
+ this.line('→', `${name}`, args);
42
+ }
43
+ toolResult(result) {
44
+ const preview = typeof result === 'string' ? result.slice(0, 120) : util.inspect(result, { depth: 1 });
45
+ this.line('←', 'result', { preview });
46
+ }
47
+ info(message, meta) {
48
+ this.line('ℹ', message, meta);
49
+ }
50
+ done(message = 'Done') {
51
+ this.line('✔', message);
52
+ }
53
+ }
54
+ export const logger = new Logger();
55
+ //# sourceMappingURL=logger2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger2.js","sourceRoot":"","sources":["../../src/utils/logger2.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,31 @@
1
+ import { tools } from '../tools/index.js';
2
+ import { logger } from './logger.js';
3
+ import fs from 'fs/promises';
4
+ async function testTools() {
5
+ logger.info('Testing tools...');
6
+ // 1. Test list_files
7
+ logger.step('Testing list_files...');
8
+ const files = await tools.list_files.execute({ path: '.' }, { toolCallId: 'test', messages: [] });
9
+ console.log(files);
10
+ // 2. Test write_file
11
+ logger.step('Testing write_file...');
12
+ const writeRes = await tools.write_file.execute({ path: 'test_file.txt', content: 'hello world' }, { toolCallId: 'test', messages: [] });
13
+ logger.success(writeRes);
14
+ // 3. Test read_file
15
+ logger.step('Testing read_file...');
16
+ const readRes = await tools.read_file.execute({ path: 'test_file.txt' }, { toolCallId: 'test', messages: [] });
17
+ logger.success(`Read content: ${readRes}`);
18
+ // 4. Test search_code
19
+ logger.step('Testing search_code...');
20
+ const searchRes = await tools.search_code.execute({ query: 'hello world' }, { toolCallId: 'test', messages: [] });
21
+ console.log(searchRes);
22
+ // 5. Test run_command
23
+ logger.step('Testing run_command...');
24
+ const cmdRes = await tools.run_command.execute({ command: 'ls -l test_file.txt' }, { toolCallId: 'test', messages: [] });
25
+ console.log(cmdRes);
26
+ // Cleanup
27
+ await fs.unlink('test_file.txt');
28
+ logger.success('Cleaned up test_file.txt');
29
+ }
30
+ testTools().catch(err => logger.error(err.message));
31
+ //# sourceMappingURL=test-tools.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"test-tools.js","sourceRoot":"","sources":["../../src/utils/test-tools.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,MAAM,aAAa,CAAC;AAE7B,KAAK,UAAU,SAAS;IACtB,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAEhC,qBAAqB;IACrB,MAAM,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;IACrC,MAAM,KAAK,GAAG,MAAM,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;IAClG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAEnB,qBAAqB;IACrB,MAAM,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;IACrC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,OAAO,EAAE,aAAa,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;IACzI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAEzB,oBAAoB;IACpB,MAAM,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IACpC,MAAM,OAAO,GAAG,MAAM,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;IAC/G,MAAM,CAAC,OAAO,CAAC,iBAAiB,OAAO,EAAE,CAAC,CAAC;IAE3C,sBAAsB;IACtB,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;IACtC,MAAM,SAAS,GAAG,MAAM,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,aAAa,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;IAClH,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IAEvB,sBAAsB;IACtB,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;IACtC,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,qBAAqB,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;IACzH,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAEpB,UAAU;IACV,MAAM,EAAE,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;IACjC,MAAM,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC;AAC7C,CAAC;AAED,SAAS,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC"}
package/package.json ADDED
@@ -0,0 +1,43 @@
1
+ {
2
+ "name": "@rxpm/forge-cli",
3
+ "version": "0.0.1",
4
+ "description": "Open source AI coding agent",
5
+ "type": "module",
6
+ "bin": {
7
+ "forge": "./dist/index.js"
8
+ },
9
+ "scripts": {
10
+ "start": "tsx src/index.ts",
11
+ "build": "tsc",
12
+ "dev": "tsx watch src/index.ts"
13
+ },
14
+ "keywords": [
15
+ "cli",
16
+ "ollama",
17
+ "ai",
18
+ "agent",
19
+ "llm"
20
+ ],
21
+ "author": {
22
+ "name": "Rajat Sharma",
23
+ "email": "rajatxt@proton.me",
24
+ "url": "https://gitlab.com/rajatxs"
25
+ },
26
+ "license": "ISC",
27
+ "dependencies": {
28
+ "ai": "^6.0.137",
29
+ "chalk": "^5.6.2",
30
+ "commander": "^13.1.0",
31
+ "execa": "^9.6.1",
32
+ "glob": "^11.1.0",
33
+ "ollama": "^0.6.3",
34
+ "ollama-ai-provider-v2": "^3.5.0",
35
+ "ora": "^9.3.0",
36
+ "zod": "^4.3.6"
37
+ },
38
+ "devDependencies": {
39
+ "@types/node": "^25.5.0",
40
+ "tsx": "^4.19.2",
41
+ "typescript": "^6.0.2"
42
+ }
43
+ }