@polka-codes/cli 0.10.23 → 0.10.25
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/bin.cjs +143854 -0
- package/dist/bin.d.ts +2 -0
- package/dist/bin.d.ts.map +1 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +9201 -9195
- package/dist/program.d.ts +3 -0
- package/dist/program.d.ts.map +1 -0
- package/package.json +6 -7
- package/cli.mjs +0 -2
- package/dist/ApiProviderConfig.js +0 -57
- package/dist/ApiProviderConfig.js.map +0 -1
- package/dist/ApiProviderConfig.test.js +0 -278
- package/dist/ApiProviderConfig.test.js.map +0 -1
- package/dist/agent/advanced-discovery.js +0 -604
- package/dist/agent/advanced-discovery.js.map +0 -1
- package/dist/agent/config.js +0 -139
- package/dist/agent/config.js.map +0 -1
- package/dist/agent/config.test.js +0 -140
- package/dist/agent/config.test.js.map +0 -1
- package/dist/agent/constants.js +0 -172
- package/dist/agent/constants.js.map +0 -1
- package/dist/agent/constants.test.js +0 -132
- package/dist/agent/constants.test.js.map +0 -1
- package/dist/agent/debug-logger.js +0 -281
- package/dist/agent/debug-logger.js.map +0 -1
- package/dist/agent/debug-logger.test.js +0 -294
- package/dist/agent/debug-logger.test.js.map +0 -1
- package/dist/agent/error-handling.js +0 -114
- package/dist/agent/error-handling.js.map +0 -1
- package/dist/agent/error-handling.test.js +0 -191
- package/dist/agent/error-handling.test.js.map +0 -1
- package/dist/agent/errors.js +0 -301
- package/dist/agent/errors.js.map +0 -1
- package/dist/agent/executor.js +0 -206
- package/dist/agent/executor.js.map +0 -1
- package/dist/agent/executor.test.js +0 -228
- package/dist/agent/executor.test.js.map +0 -1
- package/dist/agent/goal-decomposer.js +0 -281
- package/dist/agent/goal-decomposer.js.map +0 -1
- package/dist/agent/goal-decomposer.test.js +0 -225
- package/dist/agent/goal-decomposer.test.js.map +0 -1
- package/dist/agent/health-monitor.js +0 -89
- package/dist/agent/health-monitor.js.map +0 -1
- package/dist/agent/improvement-loop.js +0 -177
- package/dist/agent/improvement-loop.js.map +0 -1
- package/dist/agent/index.js +0 -38
- package/dist/agent/index.js.map +0 -1
- package/dist/agent/metrics.js +0 -158
- package/dist/agent/metrics.js.map +0 -1
- package/dist/agent/metrics.test.js +0 -311
- package/dist/agent/metrics.test.js.map +0 -1
- package/dist/agent/orchestrator.js +0 -438
- package/dist/agent/orchestrator.js.map +0 -1
- package/dist/agent/planner.js +0 -199
- package/dist/agent/planner.js.map +0 -1
- package/dist/agent/planner.test.js +0 -135
- package/dist/agent/planner.test.js.map +0 -1
- package/dist/agent/progress.js +0 -298
- package/dist/agent/progress.js.map +0 -1
- package/dist/agent/progress.test.js +0 -255
- package/dist/agent/progress.test.js.map +0 -1
- package/dist/agent/resource-monitor.js +0 -114
- package/dist/agent/resource-monitor.js.map +0 -1
- package/dist/agent/safety/approval.js +0 -178
- package/dist/agent/safety/approval.js.map +0 -1
- package/dist/agent/safety/approval.test.js +0 -142
- package/dist/agent/safety/approval.test.js.map +0 -1
- package/dist/agent/safety/checks.js +0 -152
- package/dist/agent/safety/checks.js.map +0 -1
- package/dist/agent/safety/checks.test.js +0 -89
- package/dist/agent/safety/checks.test.js.map +0 -1
- package/dist/agent/safety/interrupt.js +0 -92
- package/dist/agent/safety/interrupt.js.map +0 -1
- package/dist/agent/safety/interrupt.test.js +0 -53
- package/dist/agent/safety/interrupt.test.js.map +0 -1
- package/dist/agent/session.js +0 -117
- package/dist/agent/session.js.map +0 -1
- package/dist/agent/session.test.js +0 -213
- package/dist/agent/session.test.js.map +0 -1
- package/dist/agent/state-manager.js +0 -287
- package/dist/agent/state-manager.js.map +0 -1
- package/dist/agent/task-discovery.js +0 -433
- package/dist/agent/task-discovery.js.map +0 -1
- package/dist/agent/task-discovery.test.js +0 -40
- package/dist/agent/task-discovery.test.js.map +0 -1
- package/dist/agent/task-history.js +0 -128
- package/dist/agent/task-history.js.map +0 -1
- package/dist/agent/task-prioritizer.js +0 -286
- package/dist/agent/task-prioritizer.js.map +0 -1
- package/dist/agent/test-fixtures.js +0 -112
- package/dist/agent/test-fixtures.js.map +0 -1
- package/dist/agent/types.js +0 -15
- package/dist/agent/types.js.map +0 -1
- package/dist/agent/workflow-adapter.js +0 -219
- package/dist/agent/workflow-adapter.js.map +0 -1
- package/dist/agent/workflow-adapter.test.js +0 -11
- package/dist/agent/workflow-adapter.test.js.map +0 -1
- package/dist/agent/working-dir-discovery.js +0 -54
- package/dist/agent/working-dir-discovery.js.map +0 -1
- package/dist/agent/working-space.js +0 -484
- package/dist/agent/working-space.js.map +0 -1
- package/dist/agent/working-space.test.js +0 -436
- package/dist/agent/working-space.test.js.map +0 -1
- package/dist/api.js +0 -279
- package/dist/api.js.map +0 -1
- package/dist/builtin-commands.js +0 -20
- package/dist/builtin-commands.js.map +0 -1
- package/dist/commandSummarizer.js +0 -96
- package/dist/commandSummarizer.js.map +0 -1
- package/dist/commands/__tests__/command-detection.integration.test.js +0 -238
- package/dist/commands/__tests__/command-detection.integration.test.js.map +0 -1
- package/dist/commands/__tests__/script-generator.integration.test.js +0 -271
- package/dist/commands/__tests__/script-generator.integration.test.js.map +0 -1
- package/dist/commands/agent.js +0 -218
- package/dist/commands/agent.js.map +0 -1
- package/dist/commands/code.js +0 -102
- package/dist/commands/code.js.map +0 -1
- package/dist/commands/command.constants.js +0 -13
- package/dist/commands/command.constants.js.map +0 -1
- package/dist/commands/commit.js +0 -17
- package/dist/commands/commit.js.map +0 -1
- package/dist/commands/fix.js +0 -17
- package/dist/commands/fix.js.map +0 -1
- package/dist/commands/init.js +0 -501
- package/dist/commands/init.js.map +0 -1
- package/dist/commands/mcp-server.js +0 -122
- package/dist/commands/mcp-server.js.map +0 -1
- package/dist/commands/memory.js +0 -410
- package/dist/commands/memory.js.map +0 -1
- package/dist/commands/memory.test.js +0 -453
- package/dist/commands/memory.test.js.map +0 -1
- package/dist/commands/meta.js +0 -142
- package/dist/commands/meta.js.map +0 -1
- package/dist/commands/plan.js +0 -39
- package/dist/commands/plan.js.map +0 -1
- package/dist/commands/pr.js +0 -14
- package/dist/commands/pr.js.map +0 -1
- package/dist/commands/review-json.test.js +0 -33
- package/dist/commands/review-json.test.js.map +0 -1
- package/dist/commands/review.js +0 -137
- package/dist/commands/review.js.map +0 -1
- package/dist/commands/review.usage.test.js +0 -41
- package/dist/commands/review.usage.test.js.map +0 -1
- package/dist/commands/run.js +0 -107
- package/dist/commands/run.js.map +0 -1
- package/dist/commands/skills.js +0 -175
- package/dist/commands/skills.js.map +0 -1
- package/dist/commands/task.js +0 -34
- package/dist/commands/task.js.map +0 -1
- package/dist/commands/workflow.js +0 -117
- package/dist/commands/workflow.js.map +0 -1
- package/dist/configPrompt.js +0 -39
- package/dist/configPrompt.js.map +0 -1
- package/dist/env.js +0 -22
- package/dist/env.js.map +0 -1
- package/dist/errors.js +0 -132
- package/dist/errors.js.map +0 -1
- package/dist/errors.test.js +0 -21
- package/dist/errors.test.js.map +0 -1
- package/dist/file-attachments.js +0 -77
- package/dist/file-attachments.js.map +0 -1
- package/dist/file-attachments.test.js +0 -214
- package/dist/file-attachments.test.js.map +0 -1
- package/dist/getModel.js +0 -229
- package/dist/getModel.js.map +0 -1
- package/dist/getModel.test.js +0 -67
- package/dist/getModel.test.js.map +0 -1
- package/dist/getProviderOptions.js +0 -58
- package/dist/getProviderOptions.js.map +0 -1
- package/dist/git-operations.js +0 -363
- package/dist/git-operations.js.map +0 -1
- package/dist/git-operations.test.js +0 -81
- package/dist/git-operations.test.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/logger.js +0 -41
- package/dist/logger.js.map +0 -1
- package/dist/mcp/client.js +0 -11
- package/dist/mcp/client.js.map +0 -1
- package/dist/mcp/error-scenarios.test.js +0 -206
- package/dist/mcp/error-scenarios.test.js.map +0 -1
- package/dist/mcp/errors.js +0 -63
- package/dist/mcp/errors.js.map +0 -1
- package/dist/mcp/index.js +0 -9
- package/dist/mcp/index.js.map +0 -1
- package/dist/mcp/manager.js +0 -231
- package/dist/mcp/manager.js.map +0 -1
- package/dist/mcp/manager.test.js +0 -40
- package/dist/mcp/manager.test.js.map +0 -1
- package/dist/mcp/sdk-client.js +0 -166
- package/dist/mcp/sdk-client.js.map +0 -1
- package/dist/mcp/shared-types.js +0 -3
- package/dist/mcp/shared-types.js.map +0 -1
- package/dist/mcp/tools-integration.test.js +0 -198
- package/dist/mcp/tools-integration.test.js.map +0 -1
- package/dist/mcp/tools.js +0 -60
- package/dist/mcp/tools.js.map +0 -1
- package/dist/mcp/transport.js +0 -257
- package/dist/mcp/transport.js.map +0 -1
- package/dist/mcp/types.js +0 -3
- package/dist/mcp/types.js.map +0 -1
- package/dist/mcp-server/index.js +0 -5
- package/dist/mcp-server/index.js.map +0 -1
- package/dist/mcp-server/plan-formatting.test.js +0 -74
- package/dist/mcp-server/plan-formatting.test.js.map +0 -1
- package/dist/mcp-server/sdk-server.js +0 -102
- package/dist/mcp-server/sdk-server.js.map +0 -1
- package/dist/mcp-server/sdk-server.test.js +0 -363
- package/dist/mcp-server/sdk-server.test.js.map +0 -1
- package/dist/mcp-server/tools.js +0 -785
- package/dist/mcp-server/tools.js.map +0 -1
- package/dist/mcp-server/types.js +0 -3
- package/dist/mcp-server/types.js.map +0 -1
- package/dist/options.js +0 -85
- package/dist/options.js.map +0 -1
- package/dist/options.test.js +0 -177
- package/dist/options.test.js.map +0 -1
- package/dist/prices.js +0 -61
- package/dist/prices.js.map +0 -1
- package/dist/prices.test.js +0 -148
- package/dist/prices.test.js.map +0 -1
- package/dist/runWorkflow.js +0 -313
- package/dist/runWorkflow.js.map +0 -1
- package/dist/script/__tests__/execution.integration.test.js +0 -274
- package/dist/script/__tests__/execution.integration.test.js.map +0 -1
- package/dist/script/__tests__/runner.test.js +0 -176
- package/dist/script/__tests__/runner.test.js.map +0 -1
- package/dist/script/__tests__/validator.test.js +0 -180
- package/dist/script/__tests__/validator.test.js.map +0 -1
- package/dist/script/executor.js +0 -127
- package/dist/script/executor.js.map +0 -1
- package/dist/script/index.js +0 -4
- package/dist/script/index.js.map +0 -1
- package/dist/script/runner.js +0 -258
- package/dist/script/runner.js.map +0 -1
- package/dist/skillIntegration.js +0 -46
- package/dist/skillIntegration.js.map +0 -1
- package/dist/skillIntegration.test.js +0 -128
- package/dist/skillIntegration.test.js.map +0 -1
- package/dist/test/utils.js +0 -200
- package/dist/test/utils.js.map +0 -1
- package/dist/test/workflow-fixtures.js +0 -120
- package/dist/test/workflow-fixtures.js.map +0 -1
- package/dist/tool-implementations.js +0 -521
- package/dist/tool-implementations.js.map +0 -1
- package/dist/tool-implementations.skill-tools.test.js +0 -106
- package/dist/tool-implementations.skill-tools.test.js.map +0 -1
- package/dist/tools/getTodoItem.js +0 -33
- package/dist/tools/getTodoItem.js.map +0 -1
- package/dist/tools/gitDiff.js +0 -108
- package/dist/tools/gitDiff.js.map +0 -1
- package/dist/tools/index.js +0 -8
- package/dist/tools/index.js.map +0 -1
- package/dist/tools/listMemoryTopics.js +0 -24
- package/dist/tools/listMemoryTopics.js.map +0 -1
- package/dist/tools/listTodoItems.js +0 -35
- package/dist/tools/listTodoItems.js.map +0 -1
- package/dist/tools/listTodoItems.test.js +0 -89
- package/dist/tools/listTodoItems.test.js.map +0 -1
- package/dist/tools/readMemory.js +0 -33
- package/dist/tools/readMemory.js.map +0 -1
- package/dist/tools/updateMemory.js +0 -62
- package/dist/tools/updateMemory.js.map +0 -1
- package/dist/tools/updateMemory.test.js +0 -109
- package/dist/tools/updateMemory.test.js.map +0 -1
- package/dist/tools/updateTodoItem.js +0 -31
- package/dist/tools/updateTodoItem.js.map +0 -1
- package/dist/tools/utils/diffLineNumbers.js +0 -178
- package/dist/tools/utils/diffLineNumbers.js.map +0 -1
- package/dist/utils/cacheControl.js +0 -59
- package/dist/utils/cacheControl.js.map +0 -1
- package/dist/utils/cacheControl.test.js +0 -128
- package/dist/utils/cacheControl.test.js.map +0 -1
- package/dist/utils/command.js +0 -50
- package/dist/utils/command.js.map +0 -1
- package/dist/utils/shell.js +0 -56
- package/dist/utils/shell.js.map +0 -1
- package/dist/utils/userInput.js +0 -47
- package/dist/utils/userInput.js.map +0 -1
- package/dist/workflow-tools.js +0 -21
- package/dist/workflow-tools.js.map +0 -1
- package/dist/workflows/agent-builder.js +0 -90
- package/dist/workflows/agent-builder.js.map +0 -1
- package/dist/workflows/agent-builder.test.js +0 -115
- package/dist/workflows/agent-builder.test.js.map +0 -1
- package/dist/workflows/code.workflow.js +0 -145
- package/dist/workflows/code.workflow.js.map +0 -1
- package/dist/workflows/commit.workflow.js +0 -111
- package/dist/workflows/commit.workflow.js.map +0 -1
- package/dist/workflows/commit.workflow.test.js +0 -141
- package/dist/workflows/commit.workflow.test.js.map +0 -1
- package/dist/workflows/fix.workflow.js +0 -172
- package/dist/workflows/fix.workflow.js.map +0 -1
- package/dist/workflows/fix.workflow.test.js +0 -137
- package/dist/workflows/fix.workflow.test.js.map +0 -1
- package/dist/workflows/git-file-tools.js +0 -408
- package/dist/workflows/git-file-tools.js.map +0 -1
- package/dist/workflows/index.js +0 -12
- package/dist/workflows/index.js.map +0 -1
- package/dist/workflows/init-interactive.workflow.js +0 -198
- package/dist/workflows/init-interactive.workflow.js.map +0 -1
- package/dist/workflows/init.workflow.js +0 -41
- package/dist/workflows/init.workflow.js.map +0 -1
- package/dist/workflows/meta.workflow.js +0 -107
- package/dist/workflows/meta.workflow.js.map +0 -1
- package/dist/workflows/plan.workflow.js +0 -275
- package/dist/workflows/plan.workflow.js.map +0 -1
- package/dist/workflows/plan.workflow.test.js +0 -419
- package/dist/workflows/plan.workflow.test.js.map +0 -1
- package/dist/workflows/pr.workflow.js +0 -54
- package/dist/workflows/pr.workflow.js.map +0 -1
- package/dist/workflows/pr.workflow.test.js +0 -98
- package/dist/workflows/pr.workflow.test.js.map +0 -1
- package/dist/workflows/prompts/coder.js +0 -85
- package/dist/workflows/prompts/coder.js.map +0 -1
- package/dist/workflows/prompts/commit.js +0 -16
- package/dist/workflows/prompts/commit.js.map +0 -1
- package/dist/workflows/prompts/fix.js +0 -44
- package/dist/workflows/prompts/fix.js.map +0 -1
- package/dist/workflows/prompts/index.js +0 -10
- package/dist/workflows/prompts/index.js.map +0 -1
- package/dist/workflows/prompts/init.js +0 -48
- package/dist/workflows/prompts/init.js.map +0 -1
- package/dist/workflows/prompts/meta.js +0 -17
- package/dist/workflows/prompts/meta.js.map +0 -1
- package/dist/workflows/prompts/plan.js +0 -212
- package/dist/workflows/prompts/plan.js.map +0 -1
- package/dist/workflows/prompts/pr.js +0 -15
- package/dist/workflows/prompts/pr.js.map +0 -1
- package/dist/workflows/prompts/review.js +0 -145
- package/dist/workflows/prompts/review.js.map +0 -1
- package/dist/workflows/prompts/shared.js +0 -93
- package/dist/workflows/prompts/shared.js.map +0 -1
- package/dist/workflows/review.workflow.js +0 -357
- package/dist/workflows/review.workflow.js.map +0 -1
- package/dist/workflows/task.workflow.js +0 -47
- package/dist/workflows/task.workflow.js.map +0 -1
- package/dist/workflows/testing/helper.js +0 -41
- package/dist/workflows/testing/helper.js.map +0 -1
- package/dist/workflows/workflow.utils.js +0 -351
- package/dist/workflows/workflow.utils.js.map +0 -1
- package/dist/workflows/workflow.utils.test.js +0 -45
- package/dist/workflows/workflow.utils.test.js.map +0 -1
|
@@ -1,177 +0,0 @@
|
|
|
1
|
-
import { TaskExecutor } from './executor';
|
|
2
|
-
import { createTaskPlanner } from './planner';
|
|
3
|
-
import { createTaskDiscoveryEngine } from './task-discovery';
|
|
4
|
-
import { TaskPrioritizer } from './task-prioritizer';
|
|
5
|
-
export function createContinuousImprovementLoop(context, stateManager, _sessionId) {
|
|
6
|
-
const state = {
|
|
7
|
-
discovery: createTaskDiscoveryEngine(context),
|
|
8
|
-
planner: createTaskPlanner(context),
|
|
9
|
-
executor: new TaskExecutor(context, context.logger),
|
|
10
|
-
prioritizer: new TaskPrioritizer(),
|
|
11
|
-
running: false,
|
|
12
|
-
iterationCount: 0,
|
|
13
|
-
};
|
|
14
|
-
/**
|
|
15
|
-
* Execute a plan phase by phase
|
|
16
|
-
*/
|
|
17
|
-
async function executePlan(plan) {
|
|
18
|
-
context.logger.info(`[Continuous] Executing plan: ${plan.highLevelPlan}`);
|
|
19
|
-
let completedTasks = 0;
|
|
20
|
-
// Add all tasks to the queue first
|
|
21
|
-
await stateManager.updateState({
|
|
22
|
-
taskQueue: plan.tasks,
|
|
23
|
-
});
|
|
24
|
-
// Execute each phase
|
|
25
|
-
for (let i = 0; i < plan.executionOrder.length; i++) {
|
|
26
|
-
const phase = plan.executionOrder[i];
|
|
27
|
-
context.logger.info(`[Continuous] Phase ${i + 1}/${plan.executionOrder.length} (${phase.length} task(s))`);
|
|
28
|
-
// Execute tasks in phase (could be parallel in future)
|
|
29
|
-
for (const taskId of phase) {
|
|
30
|
-
if (!state.running) {
|
|
31
|
-
context.logger.info('[Continuous] Stopping mid-phase');
|
|
32
|
-
return;
|
|
33
|
-
}
|
|
34
|
-
const task = plan.tasks.find((t) => t.id === taskId);
|
|
35
|
-
if (!task) {
|
|
36
|
-
context.logger.warn(`[Continuous] Task not found: ${taskId}`);
|
|
37
|
-
continue;
|
|
38
|
-
}
|
|
39
|
-
try {
|
|
40
|
-
// Get current state
|
|
41
|
-
const currentState = await stateManager.getState();
|
|
42
|
-
if (!currentState) {
|
|
43
|
-
context.logger.error('[Continuous] State is null');
|
|
44
|
-
continue;
|
|
45
|
-
}
|
|
46
|
-
// Execute task
|
|
47
|
-
const result = await state.executor.execute(task, currentState);
|
|
48
|
-
if (result.success) {
|
|
49
|
-
context.logger.info(`[Continuous] ✅ ${task.title}`);
|
|
50
|
-
// Move task from queue to completed
|
|
51
|
-
await stateManager.moveTask(task.id, 'queue', 'completed');
|
|
52
|
-
// Record success for prioritization learning
|
|
53
|
-
state.prioritizer.recordExecution(task.id, true);
|
|
54
|
-
// Record file changes
|
|
55
|
-
for (const file of task.files) {
|
|
56
|
-
state.prioritizer.recordFileChange(file);
|
|
57
|
-
}
|
|
58
|
-
completedTasks++;
|
|
59
|
-
}
|
|
60
|
-
else {
|
|
61
|
-
context.logger.error(`[Continuous] ❌ ${task.title}`, result.error);
|
|
62
|
-
// Move task from queue to failed
|
|
63
|
-
await stateManager.moveTask(task.id, 'queue', 'failed');
|
|
64
|
-
// Record failure for prioritization learning
|
|
65
|
-
state.prioritizer.recordExecution(task.id, false);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
catch (error) {
|
|
69
|
-
context.logger.error(`[Continuous] ❌ ${task.title}`, error);
|
|
70
|
-
// Move task from queue to failed
|
|
71
|
-
await stateManager.moveTask(task.id, 'queue', 'failed');
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
context.logger.info(`[Continuous] Plan execution complete: ${completedTasks}/${plan.tasks.length} task(s) succeeded`);
|
|
76
|
-
}
|
|
77
|
-
/**
|
|
78
|
-
* Single iteration of continuous improvement
|
|
79
|
-
*/
|
|
80
|
-
async function iteration() {
|
|
81
|
-
state.iterationCount++;
|
|
82
|
-
context.logger.info(`[Continuous] Iteration #${state.iterationCount}`);
|
|
83
|
-
try {
|
|
84
|
-
// 1. Discover tasks
|
|
85
|
-
const tasks = await state.discovery.discover({ useCache: true });
|
|
86
|
-
if (tasks.length === 0) {
|
|
87
|
-
context.logger.info('[Continuous] No tasks discovered');
|
|
88
|
-
// CRITICAL v2.1: Don't exit, increase backoff and continue
|
|
89
|
-
state.discovery.increaseBackoff();
|
|
90
|
-
return;
|
|
91
|
-
}
|
|
92
|
-
// Tasks found - reset backoff
|
|
93
|
-
state.discovery.resetBackoff();
|
|
94
|
-
context.logger.info(`[Continuous] Discovered ${tasks.length} task(s)`);
|
|
95
|
-
// 2. Prioritize tasks dynamically
|
|
96
|
-
const prioritizedTasks = state.prioritizer.prioritizeTasks(tasks, tasks);
|
|
97
|
-
context.logger.info(`[Continuous] Prioritized ${prioritizedTasks.length} task(s)`);
|
|
98
|
-
// Log high priority tasks
|
|
99
|
-
const highPriority = state.prioritizer.getCriticalTasks(prioritizedTasks);
|
|
100
|
-
if (highPriority.length > 0) {
|
|
101
|
-
context.logger.info(`[Continuous] Critical tasks: ${highPriority.map((t) => t.title).join(', ')}`);
|
|
102
|
-
}
|
|
103
|
-
// 3. Create plan
|
|
104
|
-
const plan = state.planner.createPlan('Continuous improvement', prioritizedTasks);
|
|
105
|
-
context.logger.info(`[Continuous] Plan created with ${plan.executionOrder.length} phase(s)`);
|
|
106
|
-
// 3. Execute plan
|
|
107
|
-
await executePlan(plan);
|
|
108
|
-
context.logger.info(`[Continuous] Iteration #${state.iterationCount} complete`);
|
|
109
|
-
}
|
|
110
|
-
catch (error) {
|
|
111
|
-
context.logger.error('[Continuous] Iteration failed', error);
|
|
112
|
-
// Continue running even on error (with backoff)
|
|
113
|
-
state.discovery.increaseBackoff();
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
/**
|
|
117
|
-
* Wait between iterations with exponential backoff
|
|
118
|
-
*/
|
|
119
|
-
async function waitBetweenIterations() {
|
|
120
|
-
const seconds = state.discovery.getBackoffSeconds();
|
|
121
|
-
context.logger.info(`[Continuous] Waiting ${seconds}s before next iteration...`);
|
|
122
|
-
// Wait in 1-second increments to check for interrupts
|
|
123
|
-
for (let i = 0; i < seconds; i++) {
|
|
124
|
-
if (!state.running) {
|
|
125
|
-
context.logger.info('[Continuous] Wait interrupted');
|
|
126
|
-
return;
|
|
127
|
-
}
|
|
128
|
-
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
return {
|
|
132
|
-
/**
|
|
133
|
-
* Start continuous improvement loop
|
|
134
|
-
*/
|
|
135
|
-
async start() {
|
|
136
|
-
if (state.running) {
|
|
137
|
-
throw new Error('Loop already running');
|
|
138
|
-
}
|
|
139
|
-
state.running = true;
|
|
140
|
-
state.iterationCount = 0;
|
|
141
|
-
context.logger.info('[Continuous] Starting continuous improvement loop...');
|
|
142
|
-
context.logger.info('[Continuous] Press Ctrl+C to stop');
|
|
143
|
-
// Main loop
|
|
144
|
-
while (state.running) {
|
|
145
|
-
await iteration();
|
|
146
|
-
// Check if should stop
|
|
147
|
-
if (!state.running) {
|
|
148
|
-
break;
|
|
149
|
-
}
|
|
150
|
-
// Wait before next iteration (with exponential backoff)
|
|
151
|
-
await waitBetweenIterations();
|
|
152
|
-
}
|
|
153
|
-
context.logger.info('[Continuous] Loop stopped');
|
|
154
|
-
},
|
|
155
|
-
/**
|
|
156
|
-
* Stop the loop
|
|
157
|
-
*/
|
|
158
|
-
async stop() {
|
|
159
|
-
context.logger.info('[Continuous] Stopping loop...');
|
|
160
|
-
state.running = false;
|
|
161
|
-
state.executor.cancelAll();
|
|
162
|
-
},
|
|
163
|
-
/**
|
|
164
|
-
* Get iteration count
|
|
165
|
-
*/
|
|
166
|
-
getIterationCount() {
|
|
167
|
-
return state.iterationCount;
|
|
168
|
-
},
|
|
169
|
-
/**
|
|
170
|
-
* Check if currently running
|
|
171
|
-
*/
|
|
172
|
-
isRunning() {
|
|
173
|
-
return state.running;
|
|
174
|
-
},
|
|
175
|
-
};
|
|
176
|
-
}
|
|
177
|
-
//# sourceMappingURL=improvement-loop.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"improvement-loop.js","sourceRoot":"","sources":["../../src/agent/improvement-loop.ts"],"names":[],"mappings":"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"}
|
package/dist/agent/index.js
DELETED
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Autonomous Agent Module
|
|
3
|
-
*
|
|
4
|
-
* This module provides an autonomous agent system for the Polka Codes CLI.
|
|
5
|
-
* It can work in two modes:
|
|
6
|
-
* - Goal-directed: Takes a high-level goal and breaks it down into executable tasks
|
|
7
|
-
* - Continuous improvement: Automatically discovers and fixes issues in the codebase
|
|
8
|
-
*/
|
|
9
|
-
// Configuration
|
|
10
|
-
export * from './config';
|
|
11
|
-
export * from './constants';
|
|
12
|
-
// Debug logging and progress tracking
|
|
13
|
-
export { createDebugLoggerFromEnv, DebugLogger, DebugLoggerChild } from './debug-logger';
|
|
14
|
-
export * from './errors';
|
|
15
|
-
export { TaskExecutor } from './executor';
|
|
16
|
-
export { GoalDecomposer } from './goal-decomposer';
|
|
17
|
-
export { HealthMonitor } from './health-monitor';
|
|
18
|
-
export { createContinuousImprovementLoop } from './improvement-loop';
|
|
19
|
-
export { MetricsCollector } from './metrics';
|
|
20
|
-
// Main orchestrator
|
|
21
|
-
export { AutonomousAgent } from './orchestrator';
|
|
22
|
-
export { createTaskPlanner } from './planner';
|
|
23
|
-
export { createMultiProgress, createProgress, createSpinner, formatDuration, MultiProgress, Progress, Spinner } from './progress';
|
|
24
|
-
export { ResourceMonitor } from './resource-monitor';
|
|
25
|
-
// Safety systems
|
|
26
|
-
export { ApprovalManager } from './safety/approval';
|
|
27
|
-
export { SafetyChecker } from './safety/checks';
|
|
28
|
-
export { InterruptHandler } from './safety/interrupt';
|
|
29
|
-
export { SessionManager } from './session';
|
|
30
|
-
// Core components
|
|
31
|
-
export { AgentStateManager } from './state-manager';
|
|
32
|
-
export { createTaskDiscoveryEngine } from './task-discovery';
|
|
33
|
-
export { TaskHistory } from './task-history';
|
|
34
|
-
// Core types and constants
|
|
35
|
-
export * from './types';
|
|
36
|
-
// Phase 2: Execution components
|
|
37
|
-
export { WorkflowAdapter } from './workflow-adapter';
|
|
38
|
-
//# sourceMappingURL=index.js.map
|
package/dist/agent/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/agent/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,gBAAgB;AAChB,cAAc,UAAU,CAAA;AACxB,cAAc,aAAa,CAAA;AAE3B,sCAAsC;AACtC,OAAO,EAAE,wBAAwB,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AACxF,cAAc,UAAU,CAAA;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AAEhD,OAAO,EAAE,+BAA+B,EAAE,MAAM,oBAAoB,CAAA;AACpE,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAA;AAC5C,oBAAoB;AACpB,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AAEhD,OAAO,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAA;AAE7C,OAAO,EAAE,mBAAmB,EAAE,cAAc,EAAE,aAAa,EAAE,cAAc,EAAE,aAAa,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AACjI,OAAO,EAAmD,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACrG,iBAAiB;AACjB,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAA;AAC1C,kBAAkB;AAClB,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAA;AAEnD,OAAO,EAAE,yBAAyB,EAAE,MAAM,kBAAkB,CAAA;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,2BAA2B;AAC3B,cAAc,SAAS,CAAA;AACvB,gCAAgC;AAChC,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA"}
|
package/dist/agent/metrics.js
DELETED
|
@@ -1,158 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Create a default no-op logger for testing
|
|
3
|
-
*/
|
|
4
|
-
function createDefaultLogger() {
|
|
5
|
-
return {
|
|
6
|
-
debug: () => { },
|
|
7
|
-
info: () => { },
|
|
8
|
-
warn: () => { },
|
|
9
|
-
error: () => { },
|
|
10
|
-
};
|
|
11
|
-
}
|
|
12
|
-
/**
|
|
13
|
-
* Collects and tracks agent metrics
|
|
14
|
-
*/
|
|
15
|
-
export class MetricsCollector {
|
|
16
|
-
#metrics;
|
|
17
|
-
#startTime;
|
|
18
|
-
#taskStartTimes = new Map();
|
|
19
|
-
#logger;
|
|
20
|
-
constructor(logger = createDefaultLogger()) {
|
|
21
|
-
this.#startTime = Date.now();
|
|
22
|
-
this.#metrics = this.emptyMetrics();
|
|
23
|
-
this.#logger = logger;
|
|
24
|
-
}
|
|
25
|
-
/**
|
|
26
|
-
* Record task start
|
|
27
|
-
*/
|
|
28
|
-
recordTaskStart(taskId) {
|
|
29
|
-
this.#taskStartTimes.set(taskId, Date.now());
|
|
30
|
-
this.#metrics.totalTasks++;
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* Record task completion
|
|
34
|
-
*/
|
|
35
|
-
recordTaskComplete(taskId) {
|
|
36
|
-
const startTime = this.#taskStartTimes.get(taskId);
|
|
37
|
-
if (!startTime) {
|
|
38
|
-
this.#logger.warn(`[Metrics] No start time for task ${taskId}`);
|
|
39
|
-
return;
|
|
40
|
-
}
|
|
41
|
-
const duration = Date.now() - startTime;
|
|
42
|
-
this.#metrics.tasksCompleted++;
|
|
43
|
-
this.#metrics.totalExecutionTime += duration;
|
|
44
|
-
this.#taskStartTimes.delete(taskId);
|
|
45
|
-
this.updateSuccessRate();
|
|
46
|
-
this.updateAverageTaskTime();
|
|
47
|
-
}
|
|
48
|
-
/**
|
|
49
|
-
* Record task failure
|
|
50
|
-
*/
|
|
51
|
-
recordTaskFailure(taskId) {
|
|
52
|
-
this.#taskStartTimes.delete(taskId);
|
|
53
|
-
this.#metrics.tasksFailed++;
|
|
54
|
-
this.updateSuccessRate();
|
|
55
|
-
}
|
|
56
|
-
/**
|
|
57
|
-
* Record git operation
|
|
58
|
-
*/
|
|
59
|
-
recordGitOperation(operation) {
|
|
60
|
-
if (operation.filesChanged) {
|
|
61
|
-
this.#metrics.git.totalFilesChanged += operation.filesChanged;
|
|
62
|
-
}
|
|
63
|
-
if (operation.insertions) {
|
|
64
|
-
this.#metrics.git.totalInsertions += operation.insertions;
|
|
65
|
-
}
|
|
66
|
-
if (operation.deletions) {
|
|
67
|
-
this.#metrics.git.totalDeletions += operation.deletions;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Record commit
|
|
72
|
-
*/
|
|
73
|
-
recordCommit() {
|
|
74
|
-
this.#metrics.git.totalCommits++;
|
|
75
|
-
}
|
|
76
|
-
/**
|
|
77
|
-
* Record test results
|
|
78
|
-
*/
|
|
79
|
-
recordTestResults(results) {
|
|
80
|
-
this.#metrics.tests.testsPassed += results.passed;
|
|
81
|
-
this.#metrics.tests.testsFailed += results.failed;
|
|
82
|
-
this.#metrics.tests.totalTestsRun += results.passed + results.failed;
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Update coverage percentage
|
|
86
|
-
*/
|
|
87
|
-
updateCoverage(percentage) {
|
|
88
|
-
this.#metrics.tests.currentCoverage = percentage;
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* Get current metrics
|
|
92
|
-
*/
|
|
93
|
-
getMetrics() {
|
|
94
|
-
this.#metrics.totalExecutionTime = Date.now() - this.#startTime;
|
|
95
|
-
return { ...this.#metrics };
|
|
96
|
-
}
|
|
97
|
-
/**
|
|
98
|
-
* Reset metrics
|
|
99
|
-
*/
|
|
100
|
-
reset() {
|
|
101
|
-
this.#metrics = this.emptyMetrics();
|
|
102
|
-
this.#taskStartTimes.clear();
|
|
103
|
-
this.#startTime = Date.now();
|
|
104
|
-
}
|
|
105
|
-
/**
|
|
106
|
-
* Update success rate
|
|
107
|
-
*/
|
|
108
|
-
updateSuccessRate() {
|
|
109
|
-
const total = this.#metrics.tasksCompleted + this.#metrics.tasksFailed;
|
|
110
|
-
this.#metrics.successRate = total > 0 ? (this.#metrics.tasksCompleted / total) * 100 : 0;
|
|
111
|
-
}
|
|
112
|
-
/**
|
|
113
|
-
* Update average task time
|
|
114
|
-
*/
|
|
115
|
-
updateAverageTaskTime() {
|
|
116
|
-
const total = this.#metrics.tasksCompleted + this.#metrics.tasksFailed;
|
|
117
|
-
if (total === 0) {
|
|
118
|
-
this.#metrics.averageTaskTime = 0;
|
|
119
|
-
return;
|
|
120
|
-
}
|
|
121
|
-
this.#metrics.averageTaskTime = this.#metrics.totalExecutionTime / 60000 / total; // Convert ms to minutes
|
|
122
|
-
}
|
|
123
|
-
/**
|
|
124
|
-
* Create empty metrics object
|
|
125
|
-
*/
|
|
126
|
-
emptyMetrics() {
|
|
127
|
-
return {
|
|
128
|
-
tasksCompleted: 0,
|
|
129
|
-
tasksFailed: 0,
|
|
130
|
-
totalTasks: 0,
|
|
131
|
-
totalExecutionTime: 0,
|
|
132
|
-
averageTaskTime: 0,
|
|
133
|
-
successRate: 0,
|
|
134
|
-
git: {
|
|
135
|
-
totalCommits: 0,
|
|
136
|
-
totalFilesChanged: 0,
|
|
137
|
-
totalInsertions: 0,
|
|
138
|
-
totalDeletions: 0,
|
|
139
|
-
branchesCreated: 0,
|
|
140
|
-
},
|
|
141
|
-
tests: {
|
|
142
|
-
totalTestsRun: 0,
|
|
143
|
-
testsPassed: 0,
|
|
144
|
-
testsFailed: 0,
|
|
145
|
-
currentCoverage: 0,
|
|
146
|
-
testsAdded: 0,
|
|
147
|
-
},
|
|
148
|
-
improvements: {
|
|
149
|
-
bugsFixed: 0,
|
|
150
|
-
testsAdded: 0,
|
|
151
|
-
refactoringsCompleted: 0,
|
|
152
|
-
documentationAdded: 0,
|
|
153
|
-
qualityImprovements: 0,
|
|
154
|
-
},
|
|
155
|
-
};
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
//# sourceMappingURL=metrics.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../src/agent/metrics.ts"],"names":[],"mappings":"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"}
|