@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
package/dist/commands/plan.js
DELETED
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { readFileSync } from 'node:fs';
|
|
2
|
-
import { Command } from 'commander';
|
|
3
|
-
import { plan } from '../api';
|
|
4
|
-
import { getBaseWorkflowOptions } from '../utils/command';
|
|
5
|
-
import { getUserInput } from '../utils/userInput';
|
|
6
|
-
export const planCommand = new Command('plan')
|
|
7
|
-
.description('Create or update a plan for a task.')
|
|
8
|
-
.argument('[task]', 'The task to plan.')
|
|
9
|
-
.option('-p, --plan-file <path>', 'The path to the plan file.')
|
|
10
|
-
.action(async (task, options, command) => {
|
|
11
|
-
const workflowOpts = getBaseWorkflowOptions(command);
|
|
12
|
-
let taskInput = task;
|
|
13
|
-
let fileContent;
|
|
14
|
-
if (options.planFile) {
|
|
15
|
-
try {
|
|
16
|
-
fileContent = readFileSync(options.planFile, 'utf-8').trim();
|
|
17
|
-
}
|
|
18
|
-
catch {
|
|
19
|
-
// we can't read the file, maybe it doesn't exist, that's fine
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
if (!taskInput) {
|
|
23
|
-
taskInput = await getUserInput('What is the task you want to plan?');
|
|
24
|
-
if (taskInput === undefined) {
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
if (!taskInput.trim()) {
|
|
28
|
-
workflowOpts.logger.info('No task provided. Exiting...');
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
await plan({
|
|
33
|
-
task: taskInput,
|
|
34
|
-
fileContent,
|
|
35
|
-
planFile: options.planFile,
|
|
36
|
-
...workflowOpts,
|
|
37
|
-
});
|
|
38
|
-
});
|
|
39
|
-
//# sourceMappingURL=plan.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"plan.js","sourceRoot":"","sources":["../../src/commands/plan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAA;AAC7B,OAAO,EAAE,sBAAsB,EAAE,MAAM,kBAAkB,CAAA;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AAEjD,MAAM,CAAC,MAAM,WAAW,GAAG,IAAI,OAAO,CAAC,MAAM,CAAC;KAC3C,WAAW,CAAC,qCAAqC,CAAC;KAClD,QAAQ,CAAC,QAAQ,EAAE,mBAAmB,CAAC;KACvC,MAAM,CAAC,wBAAwB,EAAE,4BAA4B,CAAC;KAC9D,MAAM,CAAC,KAAK,EAAE,IAAwB,EAAE,OAA8B,EAAE,OAAgB,EAAE,EAAE;IAC3F,MAAM,YAAY,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAA;IAEpD,IAAI,SAAS,GAAG,IAAI,CAAA;IACpB,IAAI,WAA+B,CAAA;IACnC,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;QACrB,IAAI,CAAC;YACH,WAAW,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,CAAA;QAC9D,CAAC;QAAC,MAAM,CAAC;YACP,8DAA8D;QAChE,CAAC;IACH,CAAC;IAED,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,SAAS,GAAG,MAAM,YAAY,CAAC,oCAAoC,CAAC,CAAA;QACpE,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;YAC5B,OAAM;QACR,CAAC;QAED,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC;YACtB,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAA;YACxD,OAAM;QACR,CAAC;IACH,CAAC;IAED,MAAM,IAAI,CAAC;QACT,IAAI,EAAE,SAAS;QACf,WAAW;QACX,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,GAAG,YAAY;KAChB,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
package/dist/commands/pr.js
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import { createPr } from '../api';
|
|
3
|
-
import { getBaseWorkflowOptions } from '../utils/command';
|
|
4
|
-
export const prCommand = new Command('pr')
|
|
5
|
-
.description('Create a GitHub pull request')
|
|
6
|
-
.argument('[message]', 'Optional context for the pull request generation')
|
|
7
|
-
.action(async (message, _options, command) => {
|
|
8
|
-
const workflowOpts = getBaseWorkflowOptions(command);
|
|
9
|
-
await createPr({
|
|
10
|
-
context: message,
|
|
11
|
-
...workflowOpts,
|
|
12
|
-
});
|
|
13
|
-
});
|
|
14
|
-
//# sourceMappingURL=pr.js.map
|
package/dist/commands/pr.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"pr.js","sourceRoot":"","sources":["../../src/commands/pr.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AACjC,OAAO,EAAE,sBAAsB,EAAE,MAAM,kBAAkB,CAAA;AAEzD,MAAM,CAAC,MAAM,SAAS,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;KACvC,WAAW,CAAC,8BAA8B,CAAC;KAC3C,QAAQ,CAAC,WAAW,EAAE,kDAAkD,CAAC;KACzE,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAgB,EAAE,EAAE;IACpD,MAAM,YAAY,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAA;IACpD,MAAM,QAAQ,CAAC;QACb,OAAO,EAAE,OAAO;QAChB,GAAG,YAAY;KAChB,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
// Integration test to verify review --json outputs valid JSON without extra logging
|
|
2
|
-
// generated by polka.codes
|
|
3
|
-
import { describe, expect, mock, test } from 'bun:test';
|
|
4
|
-
import { createLogger } from '../logger';
|
|
5
|
-
describe('Review command JSON output integrity', () => {
|
|
6
|
-
test('silent logger (verbose: -1) should not write to stderr', () => {
|
|
7
|
-
// This test verifies the fix for the bug where --json flag emitted non-JSON output.
|
|
8
|
-
// The root cause was that logger calls in the workflow were not silenced.
|
|
9
|
-
// When verbose is -1, all logger methods should be no-ops.
|
|
10
|
-
const silentLogger = createLogger({ verbose: -1 });
|
|
11
|
-
const normalLogger = createLogger({ verbose: 0 });
|
|
12
|
-
// Mock process.stderr.write to track calls
|
|
13
|
-
const writeMock = mock(() => true);
|
|
14
|
-
const originalWrite = process.stderr.write;
|
|
15
|
-
process.stderr.write = writeMock;
|
|
16
|
-
try {
|
|
17
|
-
// Silent logger - no writes should occur
|
|
18
|
-
silentLogger.debug('debug message');
|
|
19
|
-
silentLogger.info('info message');
|
|
20
|
-
silentLogger.warn('warning message');
|
|
21
|
-
silentLogger.error('error message');
|
|
22
|
-
expect(writeMock).toHaveBeenCalledTimes(0);
|
|
23
|
-
// Normal logger - writes should occur
|
|
24
|
-
normalLogger.info('normal message');
|
|
25
|
-
normalLogger.warn('normal warning');
|
|
26
|
-
expect(writeMock).toHaveBeenCalled();
|
|
27
|
-
}
|
|
28
|
-
finally {
|
|
29
|
-
process.stderr.write = originalWrite;
|
|
30
|
-
}
|
|
31
|
-
});
|
|
32
|
-
});
|
|
33
|
-
//# sourceMappingURL=review-json.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"review-json.test.js","sourceRoot":"","sources":["../../src/commands/review-json.test.ts"],"names":[],"mappings":"AAAA,oFAAoF;AACpF,2BAA2B;AAE3B,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,UAAU,CAAA;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAA;AAExC,QAAQ,CAAC,sCAAsC,EAAE,GAAG,EAAE;IACpD,IAAI,CAAC,wDAAwD,EAAE,GAAG,EAAE;QAClE,oFAAoF;QACpF,0EAA0E;QAC1E,2DAA2D;QAE3D,MAAM,YAAY,GAAG,YAAY,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAA;QAClD,MAAM,YAAY,GAAG,YAAY,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;QAEjD,2CAA2C;QAC3C,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAA;QAClC,MAAM,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAA;QAE1C,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,SAAS,CAAA;QAEhC,IAAI,CAAC;YACH,yCAAyC;YACzC,YAAY,CAAC,KAAK,CAAC,eAAe,CAAC,CAAA;YACnC,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;YACjC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAA;YACpC,YAAY,CAAC,KAAK,CAAC,eAAe,CAAC,CAAA;YACnC,MAAM,CAAC,SAAS,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAA;YAE1C,sCAAsC;YACtC,YAAY,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;YACnC,YAAY,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;YACnC,MAAM,CAAC,SAAS,CAAC,CAAC,gBAAgB,EAAE,CAAA;QACtC,CAAC;gBAAS,CAAC;YACT,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,aAAa,CAAA;QACtC,CAAC;IACH,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
package/dist/commands/review.js
DELETED
|
@@ -1,137 +0,0 @@
|
|
|
1
|
-
// generated by polka.codes
|
|
2
|
-
import { existsSync } from 'node:fs';
|
|
3
|
-
import { checkbox, select } from '@inquirer/prompts';
|
|
4
|
-
import { Command, InvalidOptionArgumentError } from 'commander';
|
|
5
|
-
import { code, reviewCode } from '../api';
|
|
6
|
-
import { createLogger } from '../logger';
|
|
7
|
-
import { getBaseWorkflowOptions } from '../utils/command';
|
|
8
|
-
import { formatReviewForConsole } from '../workflows/workflow.utils';
|
|
9
|
-
export const reviewCommand = new Command('review')
|
|
10
|
-
.description('Review a GitHub pull request or local changes')
|
|
11
|
-
.argument('[files...]', 'Specific files to review (use --context for review instructions)')
|
|
12
|
-
.option('--pr <pr>', 'The pull request number to review', (value) => {
|
|
13
|
-
const parsedValue = parseInt(value, 10);
|
|
14
|
-
if (Number.isNaN(parsedValue) || parsedValue < 1) {
|
|
15
|
-
throw new InvalidOptionArgumentError('Must be a positive number.');
|
|
16
|
-
}
|
|
17
|
-
return parsedValue;
|
|
18
|
-
})
|
|
19
|
-
.option('--range <range>', 'Git range to review (e.g., HEAD~3..HEAD, origin/main..HEAD)')
|
|
20
|
-
.option('--context <context>', 'Additional context for the review')
|
|
21
|
-
.option('--json', 'Output the review in JSON format', false)
|
|
22
|
-
.option('-y, --yes', 'Automatically apply review feedback', false)
|
|
23
|
-
.option('--loop [count]', 'Re-review after changes are applied.', (value) => {
|
|
24
|
-
if (value === undefined || value === null) {
|
|
25
|
-
return 1;
|
|
26
|
-
}
|
|
27
|
-
const parsedValue = parseInt(value, 10);
|
|
28
|
-
if (Number.isNaN(parsedValue) || parsedValue < 1) {
|
|
29
|
-
throw new InvalidOptionArgumentError('Must be a positive number.');
|
|
30
|
-
}
|
|
31
|
-
return parsedValue;
|
|
32
|
-
}, 1)
|
|
33
|
-
.action(async (files, options, command) => {
|
|
34
|
-
const { json, pr, range, context: contextOption, loop: maxIterations, yes: yesOption } = options;
|
|
35
|
-
const yes = maxIterations > 1 || yesOption;
|
|
36
|
-
let changesAppliedInThisIteration = false;
|
|
37
|
-
const workflowOpts = getBaseWorkflowOptions(command);
|
|
38
|
-
// Override interactive mode: disable in JSON mode
|
|
39
|
-
if (json) {
|
|
40
|
-
workflowOpts.interactive = false;
|
|
41
|
-
}
|
|
42
|
-
const { verbose } = workflowOpts;
|
|
43
|
-
// In JSON mode, force silent mode to suppress all non-JSON output
|
|
44
|
-
const logger = createLogger({
|
|
45
|
-
verbose,
|
|
46
|
-
});
|
|
47
|
-
let context = contextOption;
|
|
48
|
-
let filesToReview = files;
|
|
49
|
-
// Heuristic to detect if the positional argument is intended as context
|
|
50
|
-
if (files.length === 1 && !existsSync(files[0]) && files[0].includes(' ') && !context) {
|
|
51
|
-
logger.warn('Warning: The argument looks like context but was passed as a file. Treating it as context. Please use --context for review instructions in the future.');
|
|
52
|
-
context = files[0];
|
|
53
|
-
filesToReview = [];
|
|
54
|
-
}
|
|
55
|
-
for (let i = 0; i < maxIterations; i++) {
|
|
56
|
-
changesAppliedInThisIteration = false;
|
|
57
|
-
if (i > 0) {
|
|
58
|
-
logger.debug(`Re-running review (iteration ${i + 1} of ${maxIterations})...`);
|
|
59
|
-
}
|
|
60
|
-
const reviewResult = await reviewCode({
|
|
61
|
-
pr,
|
|
62
|
-
range,
|
|
63
|
-
files: filesToReview.length > 0 ? filesToReview : undefined,
|
|
64
|
-
context,
|
|
65
|
-
...workflowOpts,
|
|
66
|
-
});
|
|
67
|
-
if (reviewResult) {
|
|
68
|
-
let formattedReview = formatReviewForConsole(reviewResult);
|
|
69
|
-
if (json) {
|
|
70
|
-
console.log(JSON.stringify(reviewResult, null, 2));
|
|
71
|
-
}
|
|
72
|
-
else if (formattedReview) {
|
|
73
|
-
logger.info(formattedReview);
|
|
74
|
-
}
|
|
75
|
-
let shouldRunTask = false;
|
|
76
|
-
if (reviewResult.specificReviews && reviewResult.specificReviews.length > 0) {
|
|
77
|
-
if (yes) {
|
|
78
|
-
shouldRunTask = true;
|
|
79
|
-
}
|
|
80
|
-
else if (process.stdin.isTTY && !json) {
|
|
81
|
-
await new Promise((resolve) => setTimeout(resolve, 50)); // wait for ora to finish
|
|
82
|
-
try {
|
|
83
|
-
const answer = await select({
|
|
84
|
-
message: 'Do you wish polka-codes to address the review results?',
|
|
85
|
-
choices: [
|
|
86
|
-
{ name: 'No', value: 'no' },
|
|
87
|
-
{ name: 'Yes', value: 'yes' },
|
|
88
|
-
{ name: 'Select findings', value: 'select' },
|
|
89
|
-
],
|
|
90
|
-
default: 'no',
|
|
91
|
-
});
|
|
92
|
-
if (answer === 'yes') {
|
|
93
|
-
shouldRunTask = true;
|
|
94
|
-
}
|
|
95
|
-
else if (answer === 'select') {
|
|
96
|
-
const selectedIndices = await checkbox({
|
|
97
|
-
message: 'Select findings to address',
|
|
98
|
-
choices: reviewResult.specificReviews.map((review, index) => ({
|
|
99
|
-
name: `${review.file}:${review.lines} - ${review.review.split('\n')[0]}`,
|
|
100
|
-
value: index,
|
|
101
|
-
checked: true,
|
|
102
|
-
})),
|
|
103
|
-
});
|
|
104
|
-
if (selectedIndices.length > 0) {
|
|
105
|
-
shouldRunTask = true;
|
|
106
|
-
reviewResult.specificReviews = reviewResult.specificReviews.filter((_, index) => selectedIndices.includes(index));
|
|
107
|
-
formattedReview = formatReviewForConsole(reviewResult);
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
catch (error) {
|
|
112
|
-
if (error instanceof Error && error.name === 'ExitPromptError') {
|
|
113
|
-
return;
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
// In JSON mode, exit after first iteration (no auto-apply)
|
|
119
|
-
if (json) {
|
|
120
|
-
break;
|
|
121
|
-
}
|
|
122
|
-
if (shouldRunTask && formattedReview) {
|
|
123
|
-
changesAppliedInThisIteration = true;
|
|
124
|
-
const taskInstruction = `please address the review result:\n\n${formattedReview}`;
|
|
125
|
-
await code({
|
|
126
|
-
task: taskInstruction,
|
|
127
|
-
...workflowOpts,
|
|
128
|
-
});
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
if (maxIterations > 1 && !changesAppliedInThisIteration) {
|
|
132
|
-
logger.debug('No more review feedback to apply. Exiting loop.');
|
|
133
|
-
break;
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
});
|
|
137
|
-
//# sourceMappingURL=review.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"review.js","sourceRoot":"","sources":["../../src/commands/review.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
// Unit test to verify review command usage consolidation behavior
|
|
2
|
-
// generated by polka.codes
|
|
3
|
-
import { describe, expect, test } from 'bun:test';
|
|
4
|
-
import { UsageMeter } from '@polka-codes/core';
|
|
5
|
-
describe('Review command usage consolidation', () => {
|
|
6
|
-
test('should consolidate usage tracking across review workflow and task execution', () => {
|
|
7
|
-
// Simulate the usage meter being shared between review workflow and task execution
|
|
8
|
-
const sharedUsageMeter = new UsageMeter({
|
|
9
|
-
anthropic: {
|
|
10
|
-
'claude-3-5-sonnet-20241022': {
|
|
11
|
-
inputPrice: 3,
|
|
12
|
-
outputPrice: 15,
|
|
13
|
-
cacheWritesPrice: 3.75,
|
|
14
|
-
cacheReadsPrice: 0.3,
|
|
15
|
-
},
|
|
16
|
-
},
|
|
17
|
-
});
|
|
18
|
-
// Simulate review workflow usage
|
|
19
|
-
sharedUsageMeter.incrementMessageCount(1);
|
|
20
|
-
const reviewUsage = sharedUsageMeter.usage;
|
|
21
|
-
// Simulate task execution using the same usage meter
|
|
22
|
-
sharedUsageMeter.incrementMessageCount(2);
|
|
23
|
-
const finalUsage = sharedUsageMeter.usage;
|
|
24
|
-
// Verify that the usage is cumulative
|
|
25
|
-
expect(finalUsage.messageCount).toBe(3); // 1 from review + 2 from task
|
|
26
|
-
expect(finalUsage.messageCount).toBeGreaterThan(reviewUsage.messageCount);
|
|
27
|
-
// Verify usage structure
|
|
28
|
-
expect(finalUsage).toHaveProperty('messageCount', 3);
|
|
29
|
-
expect(finalUsage).toHaveProperty('cost');
|
|
30
|
-
expect(typeof finalUsage.cost).toBe('number');
|
|
31
|
-
});
|
|
32
|
-
test('should handle case where no task runs after review', () => {
|
|
33
|
-
const usageMeter = new UsageMeter();
|
|
34
|
-
// Simulate review workflow only
|
|
35
|
-
usageMeter.incrementMessageCount(1);
|
|
36
|
-
const usage = usageMeter.usage;
|
|
37
|
-
expect(usage.messageCount).toBe(1);
|
|
38
|
-
expect(usage.cost).toBe(0);
|
|
39
|
-
});
|
|
40
|
-
});
|
|
41
|
-
//# sourceMappingURL=review.usage.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"review.usage.test.js","sourceRoot":"","sources":["../../src/commands/review.usage.test.ts"],"names":[],"mappings":"AAAA,kEAAkE;AAClE,2BAA2B;AAE3B,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,UAAU,CAAA;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAE9C,QAAQ,CAAC,oCAAoC,EAAE,GAAG,EAAE;IAClD,IAAI,CAAC,6EAA6E,EAAE,GAAG,EAAE;QACvF,mFAAmF;QACnF,MAAM,gBAAgB,GAAG,IAAI,UAAU,CAAC;YACtC,SAAS,EAAE;gBACT,4BAA4B,EAAE;oBAC5B,UAAU,EAAE,CAAC;oBACb,WAAW,EAAE,EAAE;oBACf,gBAAgB,EAAE,IAAI;oBACtB,eAAe,EAAE,GAAG;iBACrB;aACF;SACF,CAAC,CAAA;QAEF,iCAAiC;QACjC,gBAAgB,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAA;QACzC,MAAM,WAAW,GAAG,gBAAgB,CAAC,KAAK,CAAA;QAE1C,qDAAqD;QACrD,gBAAgB,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAA;QACzC,MAAM,UAAU,GAAG,gBAAgB,CAAC,KAAK,CAAA;QAEzC,sCAAsC;QACtC,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA,CAAC,8BAA8B;QACtE,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,eAAe,CAAC,WAAW,CAAC,YAAY,CAAC,CAAA;QAEzE,yBAAyB;QACzB,MAAM,CAAC,UAAU,CAAC,CAAC,cAAc,CAAC,cAAc,EAAE,CAAC,CAAC,CAAA;QACpD,MAAM,CAAC,UAAU,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC,CAAA;QACzC,MAAM,CAAC,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IAC/C,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC9D,MAAM,UAAU,GAAG,IAAI,UAAU,EAAE,CAAA;QAEnC,gCAAgC;QAChC,UAAU,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAA;QACnC,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAA;QAE9B,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAClC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IAC5B,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
package/dist/commands/run.js
DELETED
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Run custom scripts command
|
|
3
|
-
*
|
|
4
|
-
* Provides explicit script execution with:
|
|
5
|
-
* - List all available scripts
|
|
6
|
-
* - Execute specific scripts by name
|
|
7
|
-
* - Pass arguments to scripts
|
|
8
|
-
* Generated by polka.codes
|
|
9
|
-
*/
|
|
10
|
-
import { loadConfig } from '@polka-codes/cli-shared';
|
|
11
|
-
import { Command } from 'commander';
|
|
12
|
-
import { createLogger } from '../logger';
|
|
13
|
-
import { executeScript, ScriptExecutionFailedError } from '../script/executor';
|
|
14
|
-
export const runCommand = new Command('run')
|
|
15
|
-
.description('Run custom scripts')
|
|
16
|
-
.argument('[script-name]', 'Name of the script to run')
|
|
17
|
-
.option('--list', 'List all available scripts')
|
|
18
|
-
.option('--args <args...>', 'Arguments to pass to the script')
|
|
19
|
-
.action(async (scriptName, options, command) => {
|
|
20
|
-
const globalOpts = (command.parent ?? command).opts();
|
|
21
|
-
const { verbose } = globalOpts;
|
|
22
|
-
const logger = createLogger({
|
|
23
|
-
verbose,
|
|
24
|
-
});
|
|
25
|
-
const config = await loadConfig();
|
|
26
|
-
// Handle --list flag
|
|
27
|
-
if (options.list) {
|
|
28
|
-
listAvailableScripts(config, logger);
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
// Validate script name provided
|
|
32
|
-
if (!scriptName) {
|
|
33
|
-
logger.error('Error: No script name provided');
|
|
34
|
-
logger.info('Usage: polka run <script-name>');
|
|
35
|
-
logger.info(' Use --list to see available scripts');
|
|
36
|
-
process.exit(1);
|
|
37
|
-
}
|
|
38
|
-
// Find script in config
|
|
39
|
-
const script = config?.scripts?.[scriptName];
|
|
40
|
-
if (!script) {
|
|
41
|
-
logger.error(`Error: Script '${scriptName}' not found`);
|
|
42
|
-
logger.info('Available scripts:');
|
|
43
|
-
listAvailableScripts(config, logger);
|
|
44
|
-
process.exit(1);
|
|
45
|
-
}
|
|
46
|
-
// Execute the script
|
|
47
|
-
try {
|
|
48
|
-
await executeScript(script, scriptName, logger, options.args || []);
|
|
49
|
-
}
|
|
50
|
-
catch (error) {
|
|
51
|
-
if (error instanceof ScriptExecutionFailedError) {
|
|
52
|
-
// Script failed, exit with code 1
|
|
53
|
-
process.exit(1);
|
|
54
|
-
}
|
|
55
|
-
throw error;
|
|
56
|
-
}
|
|
57
|
-
});
|
|
58
|
-
/**
|
|
59
|
-
* List all available scripts from config
|
|
60
|
-
*/
|
|
61
|
-
function listAvailableScripts(config, logger) {
|
|
62
|
-
const scripts = config?.scripts;
|
|
63
|
-
if (!scripts || Object.keys(scripts).length === 0) {
|
|
64
|
-
logger.info('No custom scripts configured.');
|
|
65
|
-
logger.info('Add scripts to your .polkacodes.yml:');
|
|
66
|
-
logger.info(' scripts:');
|
|
67
|
-
logger.info(' my-script:');
|
|
68
|
-
logger.info(' script: ./scripts/my-script.ts');
|
|
69
|
-
logger.info(' description: My custom automation');
|
|
70
|
-
return;
|
|
71
|
-
}
|
|
72
|
-
logger.info('Available scripts:');
|
|
73
|
-
for (const [name, scriptConfig] of Object.entries(scripts)) {
|
|
74
|
-
const type = getScriptType(scriptConfig);
|
|
75
|
-
const icon = type === 'ts' ? '⚡' : type === 'workflow' ? '🔄' : type === 'command' ? '💻' : '📜';
|
|
76
|
-
const desc = getScriptDescription(scriptConfig);
|
|
77
|
-
logger.info(` ${icon} ${name}${desc ? ` - ${desc}` : ''}`);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
/**
|
|
81
|
-
* Get the type of a script for display purposes
|
|
82
|
-
*/
|
|
83
|
-
function getScriptType(script) {
|
|
84
|
-
if (typeof script === 'string') {
|
|
85
|
-
return 'shell';
|
|
86
|
-
}
|
|
87
|
-
if ('command' in script) {
|
|
88
|
-
return 'command';
|
|
89
|
-
}
|
|
90
|
-
if ('script' in script) {
|
|
91
|
-
return 'ts';
|
|
92
|
-
}
|
|
93
|
-
if ('workflow' in script) {
|
|
94
|
-
return 'workflow';
|
|
95
|
-
}
|
|
96
|
-
return 'unknown';
|
|
97
|
-
}
|
|
98
|
-
/**
|
|
99
|
-
* Get description from a script configuration
|
|
100
|
-
*/
|
|
101
|
-
function getScriptDescription(script) {
|
|
102
|
-
if (typeof script === 'string') {
|
|
103
|
-
return undefined;
|
|
104
|
-
}
|
|
105
|
-
return script.description;
|
|
106
|
-
}
|
|
107
|
-
//# sourceMappingURL=run.js.map
|
package/dist/commands/run.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"run.js","sourceRoot":"","sources":["../../src/commands/run.ts"],"names":[],"mappings":"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"}
|
package/dist/commands/skills.js
DELETED
|
@@ -1,175 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Skills management command
|
|
3
|
-
*
|
|
4
|
-
* Provides commands for managing Agent Skills:
|
|
5
|
-
* - List all available skills
|
|
6
|
-
* - Show skill details
|
|
7
|
-
* - Validate skill format
|
|
8
|
-
* Generated by polka.codes
|
|
9
|
-
*/
|
|
10
|
-
import { SkillDiscoveryService, SOURCE_ICONS, validateSkillMetadata, validateSkillReferences, validateSkillSecurity, } from '@polka-codes/core';
|
|
11
|
-
import { Command } from 'commander';
|
|
12
|
-
import { createLogger } from '../logger';
|
|
13
|
-
export const skillsCommand = new Command('skills').description('Manage Agent Skills');
|
|
14
|
-
// List available skills
|
|
15
|
-
skillsCommand
|
|
16
|
-
.command('list')
|
|
17
|
-
.description('List all available skills')
|
|
18
|
-
.action(async () => {
|
|
19
|
-
const logger = createLogger({ verbose: 0 });
|
|
20
|
-
const service = new SkillDiscoveryService({ cwd: process.cwd() });
|
|
21
|
-
const skills = await service.discoverAll();
|
|
22
|
-
if (skills.length === 0) {
|
|
23
|
-
logger.info('No skills found.');
|
|
24
|
-
logger.info('Create a skill with: polka init skill <name>');
|
|
25
|
-
logger.info('Or create one manually at .claude/skills/<skill-name>/SKILL.md');
|
|
26
|
-
return;
|
|
27
|
-
}
|
|
28
|
-
logger.info(`Found ${skills.length} skill${skills.length !== 1 ? 's' : ''}:`);
|
|
29
|
-
logger.info('');
|
|
30
|
-
for (const skill of skills) {
|
|
31
|
-
const sourceIcon = SOURCE_ICONS[skill.source];
|
|
32
|
-
logger.info(`${sourceIcon} ${skill.metadata.name}`);
|
|
33
|
-
logger.info(` ${skill.metadata.description}`);
|
|
34
|
-
logger.info('');
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
// Show skill details
|
|
38
|
-
skillsCommand
|
|
39
|
-
.command('show')
|
|
40
|
-
.description('Show details for a specific skill')
|
|
41
|
-
.argument('<skill-name>', 'Name of the skill')
|
|
42
|
-
.option('--full', 'Show full content including supporting files')
|
|
43
|
-
.action(async (skillName, options) => {
|
|
44
|
-
const logger = createLogger({ verbose: 0 });
|
|
45
|
-
const service = new SkillDiscoveryService({ cwd: process.cwd() });
|
|
46
|
-
const skills = await service.discoverAll();
|
|
47
|
-
const skillRef = skills.find((s) => s.metadata.name === skillName);
|
|
48
|
-
if (!skillRef) {
|
|
49
|
-
logger.error(`Skill '${skillName}' not found`);
|
|
50
|
-
logger.info('Run "polka skills list" to see available skills');
|
|
51
|
-
process.exit(1);
|
|
52
|
-
}
|
|
53
|
-
let skill;
|
|
54
|
-
try {
|
|
55
|
-
skill = await service.loadSkill(skillRef.path, skillRef.source);
|
|
56
|
-
}
|
|
57
|
-
catch (error) {
|
|
58
|
-
logger.error(`Failed to load skill '${skillName}': ${error instanceof Error ? error.message : String(error)}`);
|
|
59
|
-
logger.info(`Please check the skill file at: ${skillRef.path}`);
|
|
60
|
-
process.exit(1);
|
|
61
|
-
}
|
|
62
|
-
logger.info(`#${skill.metadata.name}`);
|
|
63
|
-
logger.info('');
|
|
64
|
-
logger.info(`Source: ${skill.source}`);
|
|
65
|
-
logger.info(`Path: ${skill.path}`);
|
|
66
|
-
logger.info('');
|
|
67
|
-
logger.info(`Description:`);
|
|
68
|
-
logger.info(` ${skill.metadata.description}`);
|
|
69
|
-
if (skill.metadata.allowedTools && skill.metadata.allowedTools.length > 0) {
|
|
70
|
-
logger.info('');
|
|
71
|
-
logger.info(`Allowed Tools: ${skill.metadata.allowedTools.join(', ')}`);
|
|
72
|
-
}
|
|
73
|
-
logger.info('');
|
|
74
|
-
logger.info(`Content:`);
|
|
75
|
-
if (options.full) {
|
|
76
|
-
logger.info(skill.content);
|
|
77
|
-
if (skill.files.size > 0) {
|
|
78
|
-
logger.info('');
|
|
79
|
-
logger.info(`Supporting Files (${skill.files.size}):`);
|
|
80
|
-
for (const [name, content] of skill.files) {
|
|
81
|
-
logger.info('');
|
|
82
|
-
logger.info(`### ${name}`);
|
|
83
|
-
logger.info(content);
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
else {
|
|
88
|
-
// Show preview (first 10 lines)
|
|
89
|
-
const lines = skill.content.split('\n');
|
|
90
|
-
const preview = lines.slice(0, 10).join('\n');
|
|
91
|
-
logger.info(preview);
|
|
92
|
-
if (lines.length > 10) {
|
|
93
|
-
logger.info('');
|
|
94
|
-
logger.info('...');
|
|
95
|
-
logger.info(`(Use --full to see complete content)`);
|
|
96
|
-
}
|
|
97
|
-
// List supporting files without showing content
|
|
98
|
-
if (skill.files.size > 0) {
|
|
99
|
-
logger.info('');
|
|
100
|
-
logger.info(`Supporting Files (${skill.files.size}):`);
|
|
101
|
-
for (const [name] of skill.files.keys()) {
|
|
102
|
-
logger.info(` - ${name}`);
|
|
103
|
-
}
|
|
104
|
-
logger.info('');
|
|
105
|
-
logger.info('(Use --full to see file contents)');
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
});
|
|
109
|
-
// Validate skill
|
|
110
|
-
skillsCommand
|
|
111
|
-
.command('validate')
|
|
112
|
-
.description("Validate a skill's structure and content")
|
|
113
|
-
.argument('[skill-name]', 'Name of the skill (validates all if not provided)')
|
|
114
|
-
.action(async (skillName) => {
|
|
115
|
-
const logger = createLogger({ verbose: 0 });
|
|
116
|
-
const service = new SkillDiscoveryService({ cwd: process.cwd() });
|
|
117
|
-
const skills = await service.discoverAll();
|
|
118
|
-
const skillRefsToValidate = skillName ? skills.filter((s) => s.metadata.name === skillName) : skills;
|
|
119
|
-
if (skillRefsToValidate.length === 0) {
|
|
120
|
-
logger.error(`No skill${skillName ? ` '${skillName}'` : 's'} found`);
|
|
121
|
-
process.exit(1);
|
|
122
|
-
}
|
|
123
|
-
let hasErrors = false;
|
|
124
|
-
let totalWarnings = 0;
|
|
125
|
-
for (const skillRef of skillRefsToValidate) {
|
|
126
|
-
logger.info(`Validating ${skillRef.metadata.name}...`);
|
|
127
|
-
let skillHasErrors = false;
|
|
128
|
-
try {
|
|
129
|
-
const skill = await service.loadSkill(skillRef.path, skillRef.source);
|
|
130
|
-
// Check metadata
|
|
131
|
-
const errors = validateSkillMetadata(skill);
|
|
132
|
-
for (const error of errors) {
|
|
133
|
-
logger.error(` ❌ ${error}`);
|
|
134
|
-
hasErrors = true;
|
|
135
|
-
skillHasErrors = true;
|
|
136
|
-
}
|
|
137
|
-
// Check security
|
|
138
|
-
try {
|
|
139
|
-
validateSkillSecurity(skill);
|
|
140
|
-
logger.info(` ✅ Security validation passed`);
|
|
141
|
-
}
|
|
142
|
-
catch (error) {
|
|
143
|
-
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
144
|
-
logger.error(` ❌ Security: ${errorMessage}`);
|
|
145
|
-
hasErrors = true;
|
|
146
|
-
skillHasErrors = true;
|
|
147
|
-
}
|
|
148
|
-
// Check references
|
|
149
|
-
const warnings = validateSkillReferences(skill);
|
|
150
|
-
for (const warning of warnings) {
|
|
151
|
-
logger.warn(` ⚠️ ${warning}`);
|
|
152
|
-
totalWarnings++;
|
|
153
|
-
}
|
|
154
|
-
// No errors for this skill means valid
|
|
155
|
-
if (!skillHasErrors) {
|
|
156
|
-
logger.info(` ✅ Valid`);
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
catch (error) {
|
|
160
|
-
logger.error(` ❌ Failed to load skill: ${error instanceof Error ? error.message : String(error)}`);
|
|
161
|
-
hasErrors = true;
|
|
162
|
-
}
|
|
163
|
-
logger.info('');
|
|
164
|
-
}
|
|
165
|
-
if (hasErrors) {
|
|
166
|
-
process.exit(1);
|
|
167
|
-
}
|
|
168
|
-
if (totalWarnings > 0) {
|
|
169
|
-
logger.info(`Validation complete with ${totalWarnings} warning${totalWarnings !== 1 ? 's' : ''}`);
|
|
170
|
-
}
|
|
171
|
-
else {
|
|
172
|
-
logger.info('All validations passed!');
|
|
173
|
-
}
|
|
174
|
-
});
|
|
175
|
-
//# sourceMappingURL=skills.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"skills.js","sourceRoot":"","sources":["../../src/commands/skills.ts"],"names":[],"mappings":"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"}
|
package/dist/commands/task.js
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
import { task } from '../api';
|
|
3
|
-
import { getBaseWorkflowOptions } from '../utils/command';
|
|
4
|
-
export async function runTask(taskInput, options, command) {
|
|
5
|
-
const workflowOpts = getBaseWorkflowOptions(command);
|
|
6
|
-
// Handle JSON output mode
|
|
7
|
-
if (options.json) {
|
|
8
|
-
workflowOpts.silent = true;
|
|
9
|
-
}
|
|
10
|
-
const result = await task({
|
|
11
|
-
task: taskInput ?? '',
|
|
12
|
-
jsonMode: options.json === true,
|
|
13
|
-
...workflowOpts,
|
|
14
|
-
});
|
|
15
|
-
// Output JSON if requested
|
|
16
|
-
if (options.json) {
|
|
17
|
-
if (result) {
|
|
18
|
-
// If the agent returned an object (structured JSON), output that
|
|
19
|
-
if (result.type === 'Exit' && result.object) {
|
|
20
|
-
console.log(JSON.stringify(result.object, null, 2));
|
|
21
|
-
}
|
|
22
|
-
else {
|
|
23
|
-
// Otherwise output the ExitReason structure
|
|
24
|
-
console.log(JSON.stringify(result, null, 2));
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
export const taskCommand = new Command('task')
|
|
30
|
-
.description('Run a generic task using an AI agent.')
|
|
31
|
-
.argument('[task]', 'The task to perform')
|
|
32
|
-
.option('--json', 'Output result as JSON')
|
|
33
|
-
.action(runTask);
|
|
34
|
-
//# sourceMappingURL=task.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"task.js","sourceRoot":"","sources":["../../src/commands/task.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAA;AAC7B,OAAO,EAAE,sBAAsB,EAAE,MAAM,kBAAkB,CAAA;AAEzD,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,SAA6B,EAAE,OAA2B,EAAE,OAAgB;IACxG,MAAM,YAAY,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAA;IAEpD,0BAA0B;IAC1B,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,YAAY,CAAC,MAAM,GAAG,IAAI,CAAA;IAC5B,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC;QACxB,IAAI,EAAE,SAAS,IAAI,EAAE;QACrB,QAAQ,EAAE,OAAO,CAAC,IAAI,KAAK,IAAI;QAC/B,GAAG,YAAY;KAChB,CAAC,CAAA;IAEF,2BAA2B;IAC3B,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,IAAI,MAAM,EAAE,CAAC;YACX,iEAAiE;YACjE,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;gBAC5C,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;YACrD,CAAC;iBAAM,CAAC;gBACN,4CAA4C;gBAC5C,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;YAC9C,CAAC;QACH,CAAC;IACH,CAAC;AACH,CAAC;AAED,MAAM,CAAC,MAAM,WAAW,GAAG,IAAI,OAAO,CAAC,MAAM,CAAC;KAC3C,WAAW,CAAC,uCAAuC,CAAC;KACpD,QAAQ,CAAC,QAAQ,EAAE,qBAAqB,CAAC;KACzC,MAAM,CAAC,QAAQ,EAAE,uBAAuB,CAAC;KACzC,MAAM,CAAC,OAAO,CAAC,CAAA"}
|