goalforge-claude 1.0.0

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 (54) hide show
  1. package/README.md +343 -0
  2. package/dist/components/claude-cli.d.ts +14 -0
  3. package/dist/components/claude-cli.d.ts.map +1 -0
  4. package/dist/components/claude-cli.js +50 -0
  5. package/dist/components/claude-cli.js.map +1 -0
  6. package/dist/components/cost-optimizer.d.ts +43 -0
  7. package/dist/components/cost-optimizer.d.ts.map +1 -0
  8. package/dist/components/cost-optimizer.js +140 -0
  9. package/dist/components/cost-optimizer.js.map +1 -0
  10. package/dist/components/executor.d.ts +18 -0
  11. package/dist/components/executor.d.ts.map +1 -0
  12. package/dist/components/executor.js +154 -0
  13. package/dist/components/executor.js.map +1 -0
  14. package/dist/components/memory-store.d.ts +47 -0
  15. package/dist/components/memory-store.d.ts.map +1 -0
  16. package/dist/components/memory-store.js +168 -0
  17. package/dist/components/memory-store.js.map +1 -0
  18. package/dist/components/planner.d.ts +22 -0
  19. package/dist/components/planner.d.ts.map +1 -0
  20. package/dist/components/planner.js +164 -0
  21. package/dist/components/planner.js.map +1 -0
  22. package/dist/components/reviewer.d.ts +19 -0
  23. package/dist/components/reviewer.d.ts.map +1 -0
  24. package/dist/components/reviewer.js +162 -0
  25. package/dist/components/reviewer.js.map +1 -0
  26. package/dist/components/task-queue.d.ts +36 -0
  27. package/dist/components/task-queue.d.ts.map +1 -0
  28. package/dist/components/task-queue.js +156 -0
  29. package/dist/components/task-queue.js.map +1 -0
  30. package/dist/components/test-runner.d.ts +20 -0
  31. package/dist/components/test-runner.d.ts.map +1 -0
  32. package/dist/components/test-runner.js +201 -0
  33. package/dist/components/test-runner.js.map +1 -0
  34. package/dist/core/config.d.ts +5 -0
  35. package/dist/core/config.d.ts.map +1 -0
  36. package/dist/core/config.js +38 -0
  37. package/dist/core/config.js.map +1 -0
  38. package/dist/core/logger.d.ts +16 -0
  39. package/dist/core/logger.d.ts.map +1 -0
  40. package/dist/core/logger.js +78 -0
  41. package/dist/core/logger.js.map +1 -0
  42. package/dist/core/types.d.ts +122 -0
  43. package/dist/core/types.d.ts.map +1 -0
  44. package/dist/core/types.js +4 -0
  45. package/dist/core/types.js.map +1 -0
  46. package/dist/index.d.ts +3 -0
  47. package/dist/index.d.ts.map +1 -0
  48. package/dist/index.js +137 -0
  49. package/dist/index.js.map +1 -0
  50. package/dist/loop-controller.d.ts +39 -0
  51. package/dist/loop-controller.d.ts.map +1 -0
  52. package/dist/loop-controller.js +272 -0
  53. package/dist/loop-controller.js.map +1 -0
  54. package/package.json +50 -0
@@ -0,0 +1,272 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LoopController = void 0;
4
+ const config_1 = require("./core/config");
5
+ const logger_1 = require("./core/logger");
6
+ const memory_store_1 = require("./components/memory-store");
7
+ const task_queue_1 = require("./components/task-queue");
8
+ const cost_optimizer_1 = require("./components/cost-optimizer");
9
+ const planner_1 = require("./components/planner");
10
+ const executor_1 = require("./components/executor");
11
+ const reviewer_1 = require("./components/reviewer");
12
+ const test_runner_1 = require("./components/test-runner");
13
+ /**
14
+ * LoopController is the autonomous development loop.
15
+ *
16
+ * while (project_not_complete) {
17
+ * planner() → produce tasks
18
+ * executor() → implement tasks
19
+ * testRunner() → validate coverage
20
+ * reviewer() → critique output
21
+ * costOptimizer() → check budget
22
+ * updateMemory() → persist state
23
+ * }
24
+ */
25
+ class LoopController {
26
+ constructor(config) {
27
+ this.config = config;
28
+ this.log = (0, logger_1.createLogger)('LoopController');
29
+ this.memory = new memory_store_1.MemoryStore(config.memoryDir);
30
+ this.queue = new task_queue_1.TaskQueue(this.memory);
31
+ this.optimizer = new cost_optimizer_1.CostOptimizer(config_1.DEFAULT_BUDGET, this.memory);
32
+ this.planner = new planner_1.Planner(this.optimizer, this.memory, config.dryRun);
33
+ this.executor = new executor_1.Executor(config.workspaceDir, this.optimizer, this.memory, config.dryRun);
34
+ this.reviewer = new reviewer_1.Reviewer(this.optimizer, this.memory, config.dryRun);
35
+ this.testRunner = new test_runner_1.TestRunner(config.workspaceDir);
36
+ this.state = {
37
+ projectId: config.projectId,
38
+ goal: config.goal,
39
+ currentPhase: 'init',
40
+ iterationCount: 0,
41
+ totalInputTokens: 0,
42
+ totalOutputTokens: 0,
43
+ totalCostUsd: 0,
44
+ coveragePercent: 0,
45
+ testsPassing: false,
46
+ criticalIssueCount: 0,
47
+ completedTaskIds: [],
48
+ failedTaskIds: [],
49
+ startedAt: new Date().toISOString(),
50
+ lastUpdatedAt: new Date().toISOString(),
51
+ };
52
+ }
53
+ // ── Public API ─────────────────────────────────────────────────────────────
54
+ async run() {
55
+ this.log.info('=== AUTONOMOUS LOOP STARTING ===', {
56
+ projectId: this.config.projectId,
57
+ goal: this.config.goal.slice(0, 80),
58
+ dryRun: this.config.dryRun,
59
+ });
60
+ this.state = this.initState();
61
+ this.persistState();
62
+ let iteration = 0;
63
+ while (iteration < this.config.maxIterations) {
64
+ iteration++;
65
+ this.state.iterationCount = iteration;
66
+ this.log.info(`\n── Iteration ${iteration} ──────────────────────────────────`);
67
+ // ── 1. Plan ────────────────────────────────────────────────────────────
68
+ const exitAfterPlan = await this.planPhase();
69
+ if (exitAfterPlan)
70
+ return exitAfterPlan;
71
+ // ── 2. Execute ─────────────────────────────────────────────────────────
72
+ const exitAfterExec = await this.executePhase();
73
+ if (exitAfterExec)
74
+ return exitAfterExec;
75
+ // ── 3. Test ────────────────────────────────────────────────────────────
76
+ const testReport = await this.testPhase();
77
+ // ── 4. Review ──────────────────────────────────────────────────────────
78
+ await this.reviewPhase();
79
+ // ── 5. Cost check ──────────────────────────────────────────────────────
80
+ const exitAfterCost = this.costCheckPhase();
81
+ if (exitAfterCost)
82
+ return exitAfterCost;
83
+ // ── 6. Update memory / check exit conditions ───────────────────────────
84
+ this.updateMemoryPhase(testReport);
85
+ const exitCondition = this.checkExitConditions();
86
+ if (exitCondition)
87
+ return exitCondition;
88
+ }
89
+ return this.buildExit('max-iterations', `Reached max iteration limit of ${this.config.maxIterations}`);
90
+ }
91
+ getState() {
92
+ return { ...this.state };
93
+ }
94
+ // ── Phases ─────────────────────────────────────────────────────────────────
95
+ async planPhase() {
96
+ this.state.currentPhase = 'planning';
97
+ if (this.queue.nextEligible() !== null) {
98
+ this.log.debug('Eligible tasks already in queue — skipping re-planning');
99
+ return null;
100
+ }
101
+ this.log.info('Phase: PLAN');
102
+ try {
103
+ const plans = await this.planner.plan(this.config.goal, this.state);
104
+ if (plans.length === 0) {
105
+ this.log.info('Planner returned no tasks');
106
+ if (this.queue.isComplete()) {
107
+ return this.buildExit('all-tasks-complete', 'All tasks complete and planner produced nothing new');
108
+ }
109
+ return null;
110
+ }
111
+ this.queue.enqueueBatch(plans);
112
+ this.log.info('Tasks enqueued', { count: plans.length });
113
+ }
114
+ catch (err) {
115
+ this.log.error('Planner failed', { err: String(err) });
116
+ }
117
+ return null;
118
+ }
119
+ async executePhase() {
120
+ this.state.currentPhase = 'executing';
121
+ let task = this.queue.nextEligible();
122
+ if (!task) {
123
+ this.log.warn('No eligible tasks to execute');
124
+ return null;
125
+ }
126
+ this.log.info('Phase: EXECUTE', {
127
+ queueStats: this.queue.stats(),
128
+ });
129
+ // Execute up to 3 tasks per iteration to allow interleaved review/test cycles
130
+ let executed = 0;
131
+ while (task && executed < 3) {
132
+ if (this.optimizer.isBudgetExceeded()) {
133
+ return this.buildExit('cost-exceeded', 'Budget exceeded during execution');
134
+ }
135
+ this.log.info('Starting task', { taskId: task.id, objective: task.objective });
136
+ this.queue.start(task.id);
137
+ try {
138
+ const result = await this.executor.execute(task);
139
+ task = this.queue.update(task.id, { result });
140
+ this.queue.complete(task.id);
141
+ this.state.completedTaskIds.push(task.id);
142
+ this.log.info('Task complete', { taskId: task.id, output: result.output });
143
+ }
144
+ catch (err) {
145
+ this.log.error('Execution failed', { taskId: task.id, err: String(err) });
146
+ this.queue.fail(task.id, String(err));
147
+ this.state.failedTaskIds.push(task.id);
148
+ }
149
+ executed++;
150
+ task = this.queue.nextEligible();
151
+ }
152
+ return null;
153
+ }
154
+ async testPhase() {
155
+ this.state.currentPhase = 'testing';
156
+ this.log.info('Phase: TEST');
157
+ const report = await this.testRunner.run();
158
+ this.state.coveragePercent = report.coveragePercent;
159
+ this.state.testsPassing = report.failed === 0;
160
+ this.log.info('Test report', {
161
+ total: report.totalTests,
162
+ passed: report.passed,
163
+ failed: report.failed,
164
+ coverage: `${report.coveragePercent}%`,
165
+ });
166
+ return report;
167
+ }
168
+ async reviewPhase() {
169
+ this.state.currentPhase = 'reviewing';
170
+ this.log.info('Phase: REVIEW');
171
+ const recentlyCompleted = this.memory
172
+ .loadAllTasks()
173
+ .filter((t) => t.status === 'COMPLETE' &&
174
+ t.result &&
175
+ !this.state.completedTaskIds.slice(0, -3).includes(t.id) // only review last 3
176
+ );
177
+ for (const task of recentlyCompleted.slice(-3)) {
178
+ try {
179
+ const review = await this.reviewer.review(task);
180
+ this.log.info('Review result', {
181
+ taskId: task.id,
182
+ score: review.score,
183
+ passed: review.passed,
184
+ critiques: review.critiques.length,
185
+ });
186
+ // If review fails, retry the task
187
+ if (!review.passed && task.retryCount < 2) {
188
+ this.log.warn('Review failed — requeueing task', { taskId: task.id });
189
+ this.queue.retry(task.id);
190
+ this.state.completedTaskIds = this.state.completedTaskIds.filter((id) => id !== task.id);
191
+ }
192
+ }
193
+ catch (err) {
194
+ this.log.warn('Review error (non-fatal)', { taskId: task.id, err: String(err) });
195
+ }
196
+ }
197
+ this.state.criticalIssueCount = this.reviewer.countCriticalIssues();
198
+ }
199
+ costCheckPhase() {
200
+ const stats = this.optimizer.getStats();
201
+ this.state.totalInputTokens = stats.totalInputTokens;
202
+ this.state.totalOutputTokens = stats.totalOutputTokens;
203
+ this.state.totalCostUsd = stats.totalSpendUsd;
204
+ this.log.info('Phase: COST', {
205
+ spentUsd: stats.totalSpendUsd.toFixed(4),
206
+ remainingUsd: stats.remainingBudgetUsd.toFixed(4),
207
+ cacheHits: stats.cacheEntries,
208
+ });
209
+ if (this.optimizer.isBudgetExceeded()) {
210
+ return this.buildExit('cost-exceeded', `Total spend $${stats.totalSpendUsd.toFixed(4)} exceeds budget $${this.config.maxCostUsd}`);
211
+ }
212
+ return null;
213
+ }
214
+ updateMemoryPhase(testReport) {
215
+ this.state.currentPhase = 'idle';
216
+ this.state.lastUpdatedAt = new Date().toISOString();
217
+ this.persistState();
218
+ this.log.info('Phase: MEMORY UPDATED', this.memory.getSummary());
219
+ }
220
+ // ── Exit conditions ────────────────────────────────────────────────────────
221
+ checkExitConditions() {
222
+ const { coveragePercent, testsPassing, criticalIssueCount, completedTaskIds, } = this.state;
223
+ if (coveragePercent >= this.config.targetCoveragePercent &&
224
+ testsPassing &&
225
+ criticalIssueCount <= this.config.maxCriticalIssues) {
226
+ return this.buildExit('no-critical-issues', `All exit conditions met: coverage ${coveragePercent}%, tests passing, ` +
227
+ `${criticalIssueCount} critical issues`);
228
+ }
229
+ if (this.queue.isComplete() && completedTaskIds.length > 0) {
230
+ return this.buildExit('all-tasks-complete', `All ${completedTaskIds.length} tasks completed`);
231
+ }
232
+ return null;
233
+ }
234
+ // ── Helpers ────────────────────────────────────────────────────────────────
235
+ initState() {
236
+ const existing = this.memory.loadState(this.config.projectId);
237
+ if (existing) {
238
+ this.log.info('Resuming project from persisted state', {
239
+ projectId: this.config.projectId,
240
+ iteration: existing.iterationCount,
241
+ });
242
+ this.optimizer.restoreFromState(existing.totalInputTokens, existing.totalOutputTokens);
243
+ return existing;
244
+ }
245
+ return {
246
+ projectId: this.config.projectId,
247
+ goal: this.config.goal,
248
+ currentPhase: 'init',
249
+ iterationCount: 0,
250
+ totalInputTokens: 0,
251
+ totalOutputTokens: 0,
252
+ totalCostUsd: 0,
253
+ coveragePercent: 0,
254
+ testsPassing: false,
255
+ criticalIssueCount: 0,
256
+ completedTaskIds: [],
257
+ failedTaskIds: [],
258
+ startedAt: new Date().toISOString(),
259
+ lastUpdatedAt: new Date().toISOString(),
260
+ };
261
+ }
262
+ persistState() {
263
+ this.memory.saveState(this.state);
264
+ }
265
+ buildExit(reason, detail) {
266
+ this.log.info(`\n=== LOOP EXIT: ${reason.toUpperCase()} ===`, { detail });
267
+ this.persistState();
268
+ return { reason, detail, finalState: { ...this.state } };
269
+ }
270
+ }
271
+ exports.LoopController = LoopController;
272
+ //# sourceMappingURL=loop-controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loop-controller.js","sourceRoot":"","sources":["../src/loop-controller.ts"],"names":[],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,50 @@
1
+ {
2
+ "name": "goalforge-claude",
3
+ "version": "1.0.0",
4
+ "description": "Describe what you want. Claude builds it. No API key needed.",
5
+ "main": "dist/index.js",
6
+ "bin": {
7
+ "goalforge": "./dist/index.js"
8
+ },
9
+ "repository": {
10
+ "type": "git",
11
+ "url": "https://github.com/oztek22/goalforge-claude.git"
12
+ },
13
+ "homepage": "https://github.com/oztek22/goalforge-claude#readme",
14
+ "bugs": {
15
+ "url": "https://github.com/oztek22/goalforge-claude/issues"
16
+ },
17
+ "keywords": [
18
+ "ai",
19
+ "claude",
20
+ "autonomous",
21
+ "codegen",
22
+ "goalforge",
23
+ "llm",
24
+ "cli"
25
+ ],
26
+ "author": "Yash Dave",
27
+ "license": "MIT",
28
+ "files": [
29
+ "dist/",
30
+ "README.md"
31
+ ],
32
+ "scripts": {
33
+ "build": "tsc && chmod +x dist/index.js",
34
+ "start": "node dist/index.js",
35
+ "dev": "ts-node src/index.ts",
36
+ "test": "jest --coverage --passWithNoTests",
37
+ "test:watch": "jest --watch",
38
+ "lint": "eslint src tests --ext .ts",
39
+ "dry-run": "DRY_RUN=true ts-node src/index.ts"
40
+ },
41
+ "dependencies": {},
42
+ "devDependencies": {
43
+ "@types/jest": "^29.5.12",
44
+ "@types/node": "^20.14.0",
45
+ "jest": "^29.7.0",
46
+ "ts-jest": "^29.1.4",
47
+ "ts-node": "^10.9.2",
48
+ "typescript": "^5.4.5"
49
+ }
50
+ }