@nathapp/nax 0.50.3 → 0.51.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +30 -0
- package/README.md +177 -104
- package/dist/nax.js +417 -213
- package/package.json +1 -3
- package/bin/nax.ts +0 -1195
- package/src/acceptance/fix-generator.ts +0 -322
- package/src/acceptance/generator.ts +0 -415
- package/src/acceptance/index.ts +0 -42
- package/src/acceptance/refinement.ts +0 -224
- package/src/acceptance/templates/cli.ts +0 -47
- package/src/acceptance/templates/component.ts +0 -78
- package/src/acceptance/templates/e2e.ts +0 -43
- package/src/acceptance/templates/index.ts +0 -21
- package/src/acceptance/templates/snapshot.ts +0 -50
- package/src/acceptance/templates/unit.ts +0 -48
- package/src/acceptance/types.ts +0 -138
- package/src/agents/acp/adapter.ts +0 -888
- package/src/agents/acp/cost.ts +0 -9
- package/src/agents/acp/index.ts +0 -7
- package/src/agents/acp/interaction-bridge.ts +0 -126
- package/src/agents/acp/parser.ts +0 -119
- package/src/agents/acp/spawn-client.ts +0 -373
- package/src/agents/acp/types.ts +0 -22
- package/src/agents/aider/adapter.ts +0 -135
- package/src/agents/claude/adapter.ts +0 -258
- package/src/agents/claude/complete.ts +0 -80
- package/src/agents/claude/cost.ts +0 -16
- package/src/agents/claude/execution.ts +0 -215
- package/src/agents/claude/index.ts +0 -3
- package/src/agents/claude/interactive.ts +0 -77
- package/src/agents/claude/plan.ts +0 -179
- package/src/agents/codex/adapter.ts +0 -153
- package/src/agents/cost/calculate.ts +0 -154
- package/src/agents/cost/index.ts +0 -10
- package/src/agents/cost/parse.ts +0 -97
- package/src/agents/cost/pricing.ts +0 -59
- package/src/agents/cost/types.ts +0 -45
- package/src/agents/gemini/adapter.ts +0 -177
- package/src/agents/index.ts +0 -18
- package/src/agents/opencode/adapter.ts +0 -106
- package/src/agents/registry.ts +0 -136
- package/src/agents/shared/decompose.ts +0 -154
- package/src/agents/shared/model-resolution.ts +0 -43
- package/src/agents/shared/types-extended.ts +0 -164
- package/src/agents/shared/validation.ts +0 -69
- package/src/agents/shared/version-detection.ts +0 -109
- package/src/agents/types.ts +0 -205
- package/src/analyze/classifier.ts +0 -282
- package/src/analyze/index.ts +0 -16
- package/src/analyze/scanner.ts +0 -171
- package/src/analyze/types.ts +0 -51
- package/src/cli/accept.ts +0 -108
- package/src/cli/agents.ts +0 -87
- package/src/cli/analyze-parser.ts +0 -291
- package/src/cli/analyze.ts +0 -352
- package/src/cli/config-descriptions.ts +0 -219
- package/src/cli/config-diff.ts +0 -103
- package/src/cli/config-display.ts +0 -285
- package/src/cli/config-get.ts +0 -55
- package/src/cli/config.ts +0 -14
- package/src/cli/constitution.ts +0 -17
- package/src/cli/diagnose-analysis.ts +0 -159
- package/src/cli/diagnose-formatter.ts +0 -87
- package/src/cli/diagnose.ts +0 -203
- package/src/cli/generate.ts +0 -250
- package/src/cli/index.ts +0 -42
- package/src/cli/init-context.ts +0 -405
- package/src/cli/init-detect.ts +0 -303
- package/src/cli/init.ts +0 -296
- package/src/cli/interact.ts +0 -295
- package/src/cli/plan.ts +0 -509
- package/src/cli/plugins.ts +0 -122
- package/src/cli/prompts-export.ts +0 -58
- package/src/cli/prompts-init.ts +0 -200
- package/src/cli/prompts-main.ts +0 -183
- package/src/cli/prompts-shared.ts +0 -70
- package/src/cli/prompts-tdd.ts +0 -88
- package/src/cli/prompts.ts +0 -17
- package/src/cli/runs.ts +0 -174
- package/src/cli/status-cost.ts +0 -151
- package/src/cli/status-features.ts +0 -405
- package/src/cli/status.ts +0 -13
- package/src/commands/common.ts +0 -171
- package/src/commands/diagnose.ts +0 -17
- package/src/commands/index.ts +0 -9
- package/src/commands/logs-formatter.ts +0 -201
- package/src/commands/logs-reader.ts +0 -171
- package/src/commands/logs.ts +0 -103
- package/src/commands/precheck.ts +0 -86
- package/src/commands/runs.ts +0 -220
- package/src/commands/unlock.ts +0 -96
- package/src/config/defaults.ts +0 -218
- package/src/config/index.ts +0 -22
- package/src/config/loader.ts +0 -143
- package/src/config/merge.ts +0 -106
- package/src/config/merger.ts +0 -147
- package/src/config/path-security.ts +0 -121
- package/src/config/paths.ts +0 -27
- package/src/config/permissions.ts +0 -63
- package/src/config/runtime-types.ts +0 -522
- package/src/config/schema-types.ts +0 -53
- package/src/config/schema.ts +0 -60
- package/src/config/schemas.ts +0 -426
- package/src/config/test-strategy.ts +0 -71
- package/src/config/types.ts +0 -57
- package/src/config/validate.ts +0 -103
- package/src/constitution/generator.ts +0 -158
- package/src/constitution/generators/aider.ts +0 -41
- package/src/constitution/generators/claude.ts +0 -35
- package/src/constitution/generators/cursor.ts +0 -36
- package/src/constitution/generators/opencode.ts +0 -38
- package/src/constitution/generators/types.ts +0 -33
- package/src/constitution/generators/windsurf.ts +0 -36
- package/src/constitution/index.ts +0 -11
- package/src/constitution/loader.ts +0 -121
- package/src/constitution/types.ts +0 -31
- package/src/context/auto-detect.ts +0 -228
- package/src/context/builder.ts +0 -299
- package/src/context/elements.ts +0 -122
- package/src/context/formatter.ts +0 -107
- package/src/context/generator.ts +0 -343
- package/src/context/generators/aider.ts +0 -34
- package/src/context/generators/claude.ts +0 -28
- package/src/context/generators/codex.ts +0 -28
- package/src/context/generators/cursor.ts +0 -28
- package/src/context/generators/gemini.ts +0 -28
- package/src/context/generators/opencode.ts +0 -30
- package/src/context/generators/windsurf.ts +0 -28
- package/src/context/greenfield.ts +0 -114
- package/src/context/index.ts +0 -34
- package/src/context/injector.ts +0 -279
- package/src/context/parent-context.ts +0 -39
- package/src/context/test-scanner.ts +0 -370
- package/src/context/types.ts +0 -98
- package/src/decompose/apply.ts +0 -50
- package/src/decompose/builder.ts +0 -181
- package/src/decompose/index.ts +0 -8
- package/src/decompose/sections/codebase.ts +0 -26
- package/src/decompose/sections/constraints.ts +0 -32
- package/src/decompose/sections/index.ts +0 -4
- package/src/decompose/sections/sibling-stories.ts +0 -25
- package/src/decompose/sections/target-story.ts +0 -31
- package/src/decompose/types.ts +0 -55
- package/src/decompose/validators/complexity.ts +0 -45
- package/src/decompose/validators/coverage.ts +0 -134
- package/src/decompose/validators/dependency.ts +0 -91
- package/src/decompose/validators/index.ts +0 -35
- package/src/decompose/validators/overlap.ts +0 -128
- package/src/errors.ts +0 -67
- package/src/execution/batching.ts +0 -157
- package/src/execution/crash-heartbeat.ts +0 -77
- package/src/execution/crash-recovery.ts +0 -79
- package/src/execution/crash-signals.ts +0 -165
- package/src/execution/crash-writer.ts +0 -154
- package/src/execution/deferred-review.ts +0 -105
- package/src/execution/dry-run.ts +0 -81
- package/src/execution/escalation/escalation.ts +0 -46
- package/src/execution/escalation/index.ts +0 -13
- package/src/execution/escalation/tier-escalation.ts +0 -346
- package/src/execution/escalation/tier-outcome.ts +0 -143
- package/src/execution/executor-types.ts +0 -73
- package/src/execution/helpers.ts +0 -38
- package/src/execution/index.ts +0 -27
- package/src/execution/iteration-runner.ts +0 -160
- package/src/execution/lifecycle/acceptance-loop.ts +0 -309
- package/src/execution/lifecycle/headless-formatter.ts +0 -83
- package/src/execution/lifecycle/index.ts +0 -11
- package/src/execution/lifecycle/parallel-lifecycle.ts +0 -101
- package/src/execution/lifecycle/precheck-runner.ts +0 -140
- package/src/execution/lifecycle/run-cleanup.ts +0 -81
- package/src/execution/lifecycle/run-completion.ts +0 -247
- package/src/execution/lifecycle/run-initialization.ts +0 -187
- package/src/execution/lifecycle/run-regression.ts +0 -305
- package/src/execution/lifecycle/run-setup.ts +0 -240
- package/src/execution/lifecycle/story-size-prompts.ts +0 -123
- package/src/execution/lock.ts +0 -129
- package/src/execution/parallel-coordinator.ts +0 -281
- package/src/execution/parallel-executor-rectification-pass.ts +0 -117
- package/src/execution/parallel-executor-rectify.ts +0 -136
- package/src/execution/parallel-executor.ts +0 -330
- package/src/execution/parallel-worker.ts +0 -149
- package/src/execution/parallel.ts +0 -13
- package/src/execution/pid-registry.ts +0 -275
- package/src/execution/pipeline-result-handler.ts +0 -221
- package/src/execution/progress.ts +0 -27
- package/src/execution/queue-handler.ts +0 -109
- package/src/execution/runner-completion.ts +0 -171
- package/src/execution/runner-execution.ts +0 -243
- package/src/execution/runner-setup.ts +0 -86
- package/src/execution/runner.ts +0 -265
- package/src/execution/sequential-executor.ts +0 -219
- package/src/execution/status-file.ts +0 -264
- package/src/execution/status-writer.ts +0 -181
- package/src/execution/story-context.ts +0 -266
- package/src/execution/story-selector.ts +0 -76
- package/src/execution/test-output-parser.ts +0 -14
- package/src/execution/timeout-handler.ts +0 -100
- package/src/hooks/index.ts +0 -2
- package/src/hooks/runner.ts +0 -280
- package/src/hooks/types.ts +0 -79
- package/src/interaction/chain.ts +0 -170
- package/src/interaction/index.ts +0 -61
- package/src/interaction/init.ts +0 -84
- package/src/interaction/plugins/auto.ts +0 -243
- package/src/interaction/plugins/cli.ts +0 -300
- package/src/interaction/plugins/telegram.ts +0 -384
- package/src/interaction/plugins/webhook.ts +0 -286
- package/src/interaction/state.ts +0 -171
- package/src/interaction/triggers.ts +0 -250
- package/src/interaction/types.ts +0 -170
- package/src/logger/formatters.ts +0 -84
- package/src/logger/index.ts +0 -16
- package/src/logger/logger.ts +0 -296
- package/src/logger/types.ts +0 -48
- package/src/logging/formatter.ts +0 -355
- package/src/logging/index.ts +0 -22
- package/src/logging/types.ts +0 -93
- package/src/metrics/aggregator.ts +0 -191
- package/src/metrics/index.ts +0 -14
- package/src/metrics/tracker.ts +0 -200
- package/src/metrics/types.ts +0 -115
- package/src/optimizer/index.ts +0 -63
- package/src/optimizer/noop.optimizer.ts +0 -24
- package/src/optimizer/rule-based.optimizer.ts +0 -248
- package/src/optimizer/types.ts +0 -53
- package/src/pipeline/event-bus.ts +0 -297
- package/src/pipeline/events.ts +0 -130
- package/src/pipeline/index.ts +0 -19
- package/src/pipeline/runner.ts +0 -149
- package/src/pipeline/stages/acceptance-setup.ts +0 -144
- package/src/pipeline/stages/acceptance.ts +0 -215
- package/src/pipeline/stages/autofix.ts +0 -262
- package/src/pipeline/stages/completion.ts +0 -110
- package/src/pipeline/stages/constitution.ts +0 -63
- package/src/pipeline/stages/context.ts +0 -122
- package/src/pipeline/stages/execution.ts +0 -359
- package/src/pipeline/stages/index.ts +0 -86
- package/src/pipeline/stages/optimizer.ts +0 -74
- package/src/pipeline/stages/prompt.ts +0 -79
- package/src/pipeline/stages/queue-check.ts +0 -103
- package/src/pipeline/stages/rectify.ts +0 -101
- package/src/pipeline/stages/regression.ts +0 -99
- package/src/pipeline/stages/review.ts +0 -94
- package/src/pipeline/stages/routing.ts +0 -276
- package/src/pipeline/stages/verify.ts +0 -286
- package/src/pipeline/subscribers/events-writer.ts +0 -135
- package/src/pipeline/subscribers/hooks.ts +0 -179
- package/src/pipeline/subscribers/interaction.ts +0 -103
- package/src/pipeline/subscribers/registry.ts +0 -73
- package/src/pipeline/subscribers/reporters.ts +0 -174
- package/src/pipeline/types.ts +0 -220
- package/src/plugins/extensions.ts +0 -225
- package/src/plugins/index.ts +0 -33
- package/src/plugins/loader.ts +0 -352
- package/src/plugins/plugin-logger.ts +0 -41
- package/src/plugins/registry.ts +0 -168
- package/src/plugins/types.ts +0 -206
- package/src/plugins/validator.ts +0 -352
- package/src/prd/index.ts +0 -220
- package/src/prd/schema.ts +0 -268
- package/src/prd/types.ts +0 -273
- package/src/prd/validate.ts +0 -41
- package/src/precheck/checks-agents.ts +0 -63
- package/src/precheck/checks-blockers.ts +0 -23
- package/src/precheck/checks-cli.ts +0 -68
- package/src/precheck/checks-config.ts +0 -102
- package/src/precheck/checks-git.ts +0 -117
- package/src/precheck/checks-system.ts +0 -101
- package/src/precheck/checks-warnings.ts +0 -221
- package/src/precheck/checks.ts +0 -36
- package/src/precheck/index.ts +0 -374
- package/src/precheck/story-size-gate.ts +0 -144
- package/src/precheck/types.ts +0 -31
- package/src/prompts/builder.ts +0 -166
- package/src/prompts/index.ts +0 -2
- package/src/prompts/loader.ts +0 -43
- package/src/prompts/sections/conventions.ts +0 -19
- package/src/prompts/sections/hermetic.ts +0 -41
- package/src/prompts/sections/index.ts +0 -12
- package/src/prompts/sections/isolation.ts +0 -70
- package/src/prompts/sections/role-task.ts +0 -182
- package/src/prompts/sections/story.ts +0 -55
- package/src/prompts/sections/verdict.ts +0 -70
- package/src/prompts/types.ts +0 -21
- package/src/queue/index.ts +0 -2
- package/src/queue/manager.ts +0 -254
- package/src/queue/types.ts +0 -54
- package/src/review/index.ts +0 -8
- package/src/review/orchestrator.ts +0 -154
- package/src/review/runner.ts +0 -303
- package/src/review/types.ts +0 -70
- package/src/routing/batch-route.ts +0 -35
- package/src/routing/builder.ts +0 -81
- package/src/routing/chain.ts +0 -75
- package/src/routing/content-hash.ts +0 -25
- package/src/routing/index.ts +0 -20
- package/src/routing/loader.ts +0 -62
- package/src/routing/router.ts +0 -305
- package/src/routing/strategies/adaptive.ts +0 -215
- package/src/routing/strategies/index.ts +0 -8
- package/src/routing/strategies/keyword.ts +0 -180
- package/src/routing/strategies/llm-prompts.ts +0 -224
- package/src/routing/strategies/llm.ts +0 -320
- package/src/routing/strategies/manual.ts +0 -50
- package/src/routing/strategy.ts +0 -102
- package/src/tdd/cleanup.ts +0 -120
- package/src/tdd/index.ts +0 -22
- package/src/tdd/isolation.ts +0 -117
- package/src/tdd/orchestrator.ts +0 -406
- package/src/tdd/prompts.ts +0 -40
- package/src/tdd/rectification-gate.ts +0 -274
- package/src/tdd/session-runner.ts +0 -263
- package/src/tdd/types.ts +0 -84
- package/src/tdd/verdict-reader.ts +0 -266
- package/src/tdd/verdict.ts +0 -152
- package/src/tui/App.tsx +0 -265
- package/src/tui/components/AgentPanel.tsx +0 -75
- package/src/tui/components/CostOverlay.tsx +0 -118
- package/src/tui/components/HelpOverlay.tsx +0 -107
- package/src/tui/components/StatusBar.tsx +0 -63
- package/src/tui/components/StoriesPanel.tsx +0 -177
- package/src/tui/hooks/useKeyboard.ts +0 -142
- package/src/tui/hooks/useLayout.ts +0 -137
- package/src/tui/hooks/usePipelineEvents.ts +0 -183
- package/src/tui/hooks/usePty.ts +0 -189
- package/src/tui/index.tsx +0 -38
- package/src/tui/types.ts +0 -76
- package/src/utils/errors.ts +0 -12
- package/src/utils/git.ts +0 -245
- package/src/utils/json-file.ts +0 -72
- package/src/utils/log-test-output.ts +0 -25
- package/src/utils/path-security.ts +0 -73
- package/src/utils/queue-writer.ts +0 -54
- package/src/verification/crash-detector.ts +0 -34
- package/src/verification/executor.ts +0 -250
- package/src/verification/index.ts +0 -12
- package/src/verification/orchestrator-types.ts +0 -154
- package/src/verification/orchestrator.ts +0 -76
- package/src/verification/parser.ts +0 -220
- package/src/verification/rectification-loop.ts +0 -172
- package/src/verification/rectification.ts +0 -108
- package/src/verification/runners.ts +0 -129
- package/src/verification/smart-runner.ts +0 -307
- package/src/verification/strategies/acceptance.ts +0 -136
- package/src/verification/strategies/regression.ts +0 -90
- package/src/verification/strategies/scoped.ts +0 -154
- package/src/verification/types.ts +0 -117
- package/src/version.ts +0 -40
- package/src/worktree/dispatcher.ts +0 -6
- package/src/worktree/index.ts +0 -2
- package/src/worktree/manager.ts +0 -193
- package/src/worktree/merge.ts +0 -302
- package/src/worktree/types.ts +0 -4
package/src/prompts/types.ts
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* PromptBuilder Types
|
|
3
|
-
*
|
|
4
|
-
* Shared types for the unified prompt building system.
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
/** Role determining which default template body to use */
|
|
8
|
-
export type PromptRole = "test-writer" | "implementer" | "verifier" | "single-session" | "tdd-simple" | "batch";
|
|
9
|
-
|
|
10
|
-
/** A single section of a composed prompt */
|
|
11
|
-
export interface PromptSection {
|
|
12
|
-
/** Unique section identifier */
|
|
13
|
-
id: string;
|
|
14
|
-
/** Section content */
|
|
15
|
-
content: string;
|
|
16
|
-
/** Whether this section can be removed by user override */
|
|
17
|
-
overridable: boolean;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
/** Options passed to PromptBuilder.for() */
|
|
21
|
-
export type PromptOptions = Record<string, unknown>;
|
package/src/queue/index.ts
DELETED
package/src/queue/manager.ts
DELETED
|
@@ -1,254 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Queue Manager
|
|
3
|
-
*
|
|
4
|
-
* Manages priority queue for user stories.
|
|
5
|
-
* Supports dependency-based ordering and multi-agent execution.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import type { QueueCommand, QueueFileResult, QueueItem, QueueItemStatus, QueueStats } from "./types";
|
|
9
|
-
|
|
10
|
-
export class QueueManager {
|
|
11
|
-
private items: QueueItem[] = [];
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Add a story to the queue.
|
|
15
|
-
* Priority is used for ordering (higher = more urgent).
|
|
16
|
-
*/
|
|
17
|
-
enqueue(storyId: string, title: string, priority: number): void {
|
|
18
|
-
const existing = this.items.find((item) => item.storyId === storyId);
|
|
19
|
-
if (existing) {
|
|
20
|
-
throw new Error(`Story ${storyId} already in queue`);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const item: QueueItem = {
|
|
24
|
-
storyId,
|
|
25
|
-
title,
|
|
26
|
-
priority,
|
|
27
|
-
status: "pending",
|
|
28
|
-
attempts: 0,
|
|
29
|
-
addedAt: new Date(),
|
|
30
|
-
};
|
|
31
|
-
|
|
32
|
-
this.items.push(item);
|
|
33
|
-
// Sort by priority (descending) — higher priority first
|
|
34
|
-
this.items.sort((a, b) => b.priority - a.priority);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
/**
|
|
38
|
-
* Get the next pending item (highest priority).
|
|
39
|
-
* Returns null if no pending items.
|
|
40
|
-
*/
|
|
41
|
-
dequeue(): QueueItem | null {
|
|
42
|
-
const pending = this.items.find((item) => item.status === "pending");
|
|
43
|
-
return pending ?? null;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* Peek at the next pending item without removing it.
|
|
48
|
-
*/
|
|
49
|
-
peek(): QueueItem | null {
|
|
50
|
-
return this.dequeue();
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
/**
|
|
54
|
-
* Mark a story as in-progress and assign it to an agent.
|
|
55
|
-
*/
|
|
56
|
-
markInProgress(storyId: string, assignedAgent: string): void {
|
|
57
|
-
const item = this.items.find((i) => i.storyId === storyId);
|
|
58
|
-
if (!item) {
|
|
59
|
-
throw new Error(`Story ${storyId} not found in queue`);
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
item.status = "in-progress";
|
|
63
|
-
item.assignedAgent = assignedAgent;
|
|
64
|
-
item.startedAt = new Date();
|
|
65
|
-
item.attempts += 1;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* Mark a story as completed.
|
|
70
|
-
*/
|
|
71
|
-
markComplete(storyId: string): void {
|
|
72
|
-
const item = this.items.find((i) => i.storyId === storyId);
|
|
73
|
-
if (!item) {
|
|
74
|
-
throw new Error(`Story ${storyId} not found in queue`);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
item.status = "completed";
|
|
78
|
-
item.completedAt = new Date();
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
/**
|
|
82
|
-
* Mark a story as failed with an error message.
|
|
83
|
-
*/
|
|
84
|
-
markFailed(storyId: string, error: string): void {
|
|
85
|
-
const item = this.items.find((i) => i.storyId === storyId);
|
|
86
|
-
if (!item) {
|
|
87
|
-
throw new Error(`Story ${storyId} not found in queue`);
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
item.status = "failed";
|
|
91
|
-
item.error = error;
|
|
92
|
-
item.completedAt = new Date();
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* Reset a story back to pending (e.g., for retry).
|
|
97
|
-
*/
|
|
98
|
-
resetToPending(storyId: string): void {
|
|
99
|
-
const item = this.items.find((i) => i.storyId === storyId);
|
|
100
|
-
if (!item) {
|
|
101
|
-
throw new Error(`Story ${storyId} not found in queue`);
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
item.status = "pending";
|
|
105
|
-
item.assignedAgent = undefined;
|
|
106
|
-
item.startedAt = undefined;
|
|
107
|
-
item.completedAt = undefined;
|
|
108
|
-
item.error = undefined;
|
|
109
|
-
// Re-sort after status change
|
|
110
|
-
this.items.sort((a, b) => b.priority - a.priority);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
/**
|
|
114
|
-
* Get all items with a specific status.
|
|
115
|
-
*/
|
|
116
|
-
getByStatus(status: QueueItemStatus): QueueItem[] {
|
|
117
|
-
return this.items.filter((item) => item.status === status);
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
/**
|
|
121
|
-
* Get a specific item by story ID.
|
|
122
|
-
*/
|
|
123
|
-
getItem(storyId: string): QueueItem | null {
|
|
124
|
-
return this.items.find((i) => i.storyId === storyId) ?? null;
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
/**
|
|
128
|
-
* Get all items in the queue.
|
|
129
|
-
*/
|
|
130
|
-
getAllItems(): QueueItem[] {
|
|
131
|
-
return [...this.items];
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
/**
|
|
135
|
-
* Get queue statistics.
|
|
136
|
-
*/
|
|
137
|
-
getStats(): QueueStats {
|
|
138
|
-
return {
|
|
139
|
-
total: this.items.length,
|
|
140
|
-
pending: this.items.filter((i) => i.status === "pending").length,
|
|
141
|
-
inProgress: this.items.filter((i) => i.status === "in-progress").length,
|
|
142
|
-
completed: this.items.filter((i) => i.status === "completed").length,
|
|
143
|
-
failed: this.items.filter((i) => i.status === "failed").length,
|
|
144
|
-
skipped: this.items.filter((i) => i.status === "skipped").length,
|
|
145
|
-
};
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
/**
|
|
149
|
-
* Remove a story from the queue entirely.
|
|
150
|
-
*/
|
|
151
|
-
remove(storyId: string): void {
|
|
152
|
-
const index = this.items.findIndex((i) => i.storyId === storyId);
|
|
153
|
-
if (index === -1) {
|
|
154
|
-
throw new Error(`Story ${storyId} not found in queue`);
|
|
155
|
-
}
|
|
156
|
-
this.items.splice(index, 1);
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
/**
|
|
160
|
-
* Clear all items from the queue.
|
|
161
|
-
*/
|
|
162
|
-
clear(): void {
|
|
163
|
-
this.items = [];
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
/**
|
|
167
|
-
* Check if the queue is empty.
|
|
168
|
-
*/
|
|
169
|
-
isEmpty(): boolean {
|
|
170
|
-
return this.items.length === 0;
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
/**
|
|
174
|
-
* Check if there are any pending items.
|
|
175
|
-
*/
|
|
176
|
-
hasPending(): boolean {
|
|
177
|
-
return this.items.some((i) => i.status === "pending");
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
/**
|
|
181
|
-
* Mark a story as skipped.
|
|
182
|
-
*/
|
|
183
|
-
markSkipped(storyId: string): void {
|
|
184
|
-
const item = this.items.find((i) => i.storyId === storyId);
|
|
185
|
-
if (!item) {
|
|
186
|
-
throw new Error(`Story ${storyId} not found in queue`);
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
item.status = "skipped";
|
|
190
|
-
item.error = "Skipped by user command";
|
|
191
|
-
item.completedAt = new Date();
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
/**
|
|
196
|
-
* Parse queue file content into commands and guidance.
|
|
197
|
-
*
|
|
198
|
-
* Commands:
|
|
199
|
-
* - PAUSE: Pause execution after current story
|
|
200
|
-
* - ABORT: Mark all remaining stories as skipped and stop
|
|
201
|
-
* - SKIP US-XXX: Skip a specific story
|
|
202
|
-
*
|
|
203
|
-
* Everything else after "--- PENDING ---" is treated as guidance text.
|
|
204
|
-
*/
|
|
205
|
-
export function parseQueueFile(content: string): QueueFileResult {
|
|
206
|
-
const commands: QueueCommand[] = [];
|
|
207
|
-
const guidance: string[] = [];
|
|
208
|
-
|
|
209
|
-
const lines = content.split("\n");
|
|
210
|
-
let inPendingSection = false;
|
|
211
|
-
|
|
212
|
-
for (const line of lines) {
|
|
213
|
-
const trimmed = line.trim();
|
|
214
|
-
|
|
215
|
-
// Skip empty lines
|
|
216
|
-
if (!trimmed) {
|
|
217
|
-
continue;
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
// Check for pending section marker
|
|
221
|
-
if (trimmed === "--- PENDING ---") {
|
|
222
|
-
inPendingSection = true;
|
|
223
|
-
continue;
|
|
224
|
-
}
|
|
225
|
-
|
|
226
|
-
// Parse commands (case-insensitive)
|
|
227
|
-
const upper = trimmed.toUpperCase();
|
|
228
|
-
|
|
229
|
-
if (upper === "PAUSE") {
|
|
230
|
-
commands.push({ type: "PAUSE" });
|
|
231
|
-
} else if (upper === "ABORT") {
|
|
232
|
-
commands.push({ type: "ABORT" });
|
|
233
|
-
} else if (upper.startsWith("SKIP ")) {
|
|
234
|
-
// Extract story ID after "SKIP"
|
|
235
|
-
const storyId = trimmed.substring(5).trim();
|
|
236
|
-
if (storyId) {
|
|
237
|
-
commands.push({ type: "SKIP", storyId });
|
|
238
|
-
} else {
|
|
239
|
-
// No story ID, treat as guidance
|
|
240
|
-
guidance.push(trimmed);
|
|
241
|
-
}
|
|
242
|
-
} else if (upper === "SKIP") {
|
|
243
|
-
// SKIP with no story ID, treat as guidance
|
|
244
|
-
guidance.push(trimmed);
|
|
245
|
-
} else {
|
|
246
|
-
// Not a command, treat as guidance if in pending section
|
|
247
|
-
if (inPendingSection) {
|
|
248
|
-
guidance.push(trimmed);
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
return { commands, guidance };
|
|
254
|
-
}
|
package/src/queue/types.ts
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Queue Types
|
|
3
|
-
*
|
|
4
|
-
* Priority queue for scheduling user stories across agents.
|
|
5
|
-
* Enables future parallel agent execution.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
/** Queue item status */
|
|
9
|
-
export type QueueItemStatus = "pending" | "in-progress" | "completed" | "failed" | "skipped";
|
|
10
|
-
|
|
11
|
-
/** Queue item representing a user story to be executed */
|
|
12
|
-
export interface QueueItem {
|
|
13
|
-
/** Unique story ID */
|
|
14
|
-
storyId: string;
|
|
15
|
-
/** Display title */
|
|
16
|
-
title: string;
|
|
17
|
-
/** Priority score (higher = more urgent) */
|
|
18
|
-
priority: number;
|
|
19
|
-
/** Current status */
|
|
20
|
-
status: QueueItemStatus;
|
|
21
|
-
/** Assigned agent (if any) */
|
|
22
|
-
assignedAgent?: string;
|
|
23
|
-
/** Number of retry attempts */
|
|
24
|
-
attempts: number;
|
|
25
|
-
/** Timestamp when added to queue */
|
|
26
|
-
addedAt: Date;
|
|
27
|
-
/** Timestamp when started (if in-progress) */
|
|
28
|
-
startedAt?: Date;
|
|
29
|
-
/** Timestamp when completed/failed */
|
|
30
|
-
completedAt?: Date;
|
|
31
|
-
/** Error message (if failed) */
|
|
32
|
-
error?: string;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
/** Queue statistics */
|
|
36
|
-
export interface QueueStats {
|
|
37
|
-
total: number;
|
|
38
|
-
pending: number;
|
|
39
|
-
inProgress: number;
|
|
40
|
-
completed: number;
|
|
41
|
-
failed: number;
|
|
42
|
-
skipped: number;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
/** Queue command for mid-run control */
|
|
46
|
-
export type QueueCommand = { type: "PAUSE" } | { type: "ABORT" } | { type: "SKIP"; storyId: string };
|
|
47
|
-
|
|
48
|
-
/** Result of parsing a queue file */
|
|
49
|
-
export interface QueueFileResult {
|
|
50
|
-
/** Parsed commands from the queue file */
|
|
51
|
-
commands: QueueCommand[];
|
|
52
|
-
/** Non-command lines (existing guidance behavior) */
|
|
53
|
-
guidance: string[];
|
|
54
|
-
}
|
package/src/review/index.ts
DELETED
|
@@ -1,154 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Review Orchestrator (ADR-005, Phase 2)
|
|
3
|
-
*
|
|
4
|
-
* Single entry point for all post-implementation review. Delegates to the
|
|
5
|
-
* review runner and plugin reviewers. Provides a unified result.
|
|
6
|
-
*
|
|
7
|
-
* Usage:
|
|
8
|
-
* const result = await reviewOrchestrator.review(config, workdir, executionConfig, plugins);
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import { spawn } from "bun";
|
|
12
|
-
import type { NaxConfig } from "../config";
|
|
13
|
-
import { getSafeLogger } from "../logger";
|
|
14
|
-
import type { PluginRegistry } from "../plugins";
|
|
15
|
-
import { errorMessage } from "../utils/errors";
|
|
16
|
-
import { runReview } from "./runner";
|
|
17
|
-
import type { ReviewConfig, ReviewResult } from "./types";
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Injectable dependencies for getChangedFiles() — allows tests to intercept
|
|
21
|
-
* spawn calls without requiring the git binary.
|
|
22
|
-
*
|
|
23
|
-
* @internal
|
|
24
|
-
*/
|
|
25
|
-
export const _orchestratorDeps = { spawn };
|
|
26
|
-
|
|
27
|
-
async function getChangedFiles(workdir: string, baseRef?: string): Promise<string[]> {
|
|
28
|
-
try {
|
|
29
|
-
const diffArgs = ["diff", "--name-only"];
|
|
30
|
-
const [stagedProc, unstagedProc, baseProc] = [
|
|
31
|
-
_orchestratorDeps.spawn({ cmd: ["git", ...diffArgs, "--cached"], cwd: workdir, stdout: "pipe", stderr: "pipe" }),
|
|
32
|
-
_orchestratorDeps.spawn({ cmd: ["git", ...diffArgs], cwd: workdir, stdout: "pipe", stderr: "pipe" }),
|
|
33
|
-
baseRef
|
|
34
|
-
? _orchestratorDeps.spawn({
|
|
35
|
-
cmd: ["git", ...diffArgs, `${baseRef}...HEAD`],
|
|
36
|
-
cwd: workdir,
|
|
37
|
-
stdout: "pipe",
|
|
38
|
-
stderr: "pipe",
|
|
39
|
-
})
|
|
40
|
-
: null,
|
|
41
|
-
];
|
|
42
|
-
|
|
43
|
-
await Promise.all([stagedProc.exited, unstagedProc.exited, baseProc?.exited]);
|
|
44
|
-
|
|
45
|
-
const [staged, unstaged, based] = await Promise.all([
|
|
46
|
-
new Response(stagedProc.stdout).text().then((t) => t.trim().split("\n").filter(Boolean)),
|
|
47
|
-
new Response(unstagedProc.stdout).text().then((t) => t.trim().split("\n").filter(Boolean)),
|
|
48
|
-
baseProc
|
|
49
|
-
? new Response(baseProc.stdout).text().then((t) => t.trim().split("\n").filter(Boolean))
|
|
50
|
-
: Promise.resolve([]),
|
|
51
|
-
]);
|
|
52
|
-
|
|
53
|
-
return Array.from(new Set([...staged, ...unstaged, ...based]));
|
|
54
|
-
} catch {
|
|
55
|
-
return [];
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
export interface OrchestratorReviewResult {
|
|
60
|
-
/** Built-in review result (typecheck, lint, format) */
|
|
61
|
-
builtIn: ReviewResult;
|
|
62
|
-
/** Whether ALL checks passed (built-in + plugin reviewers) */
|
|
63
|
-
success: boolean;
|
|
64
|
-
/** Failure reason if success === false */
|
|
65
|
-
failureReason?: string;
|
|
66
|
-
/** Plugin reviewer hard-failure flag (determines escalate vs fail) */
|
|
67
|
-
pluginFailed: boolean;
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
export class ReviewOrchestrator {
|
|
71
|
-
/** Run built-in checks + plugin reviewers. Returns unified result. */
|
|
72
|
-
async review(
|
|
73
|
-
reviewConfig: ReviewConfig,
|
|
74
|
-
workdir: string,
|
|
75
|
-
executionConfig: NaxConfig["execution"],
|
|
76
|
-
plugins?: PluginRegistry,
|
|
77
|
-
storyGitRef?: string,
|
|
78
|
-
scopePrefix?: string,
|
|
79
|
-
): Promise<OrchestratorReviewResult> {
|
|
80
|
-
const logger = getSafeLogger();
|
|
81
|
-
|
|
82
|
-
const builtIn = await runReview(reviewConfig, workdir, executionConfig);
|
|
83
|
-
|
|
84
|
-
if (!builtIn.success) {
|
|
85
|
-
return { builtIn, success: false, failureReason: builtIn.failureReason, pluginFailed: false };
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
if (reviewConfig.pluginMode === "deferred") {
|
|
89
|
-
logger?.debug("review", "Plugin reviewers deferred — skipping per-story execution");
|
|
90
|
-
return { builtIn, success: true, pluginFailed: false };
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
if (plugins) {
|
|
94
|
-
const reviewers = plugins.getReviewers();
|
|
95
|
-
if (reviewers.length > 0) {
|
|
96
|
-
// Use the story's start ref if available to capture auto-committed changes
|
|
97
|
-
const baseRef = storyGitRef ?? executionConfig?.storyGitRef;
|
|
98
|
-
const changedFiles = await getChangedFiles(workdir, baseRef);
|
|
99
|
-
const scopedFiles = scopePrefix
|
|
100
|
-
? changedFiles.filter((f) => f === scopePrefix || f.startsWith(`${scopePrefix}/`))
|
|
101
|
-
: changedFiles;
|
|
102
|
-
const pluginResults: ReviewResult["pluginReviewers"] = [];
|
|
103
|
-
|
|
104
|
-
for (const reviewer of reviewers) {
|
|
105
|
-
logger?.info("review", `Running plugin reviewer: ${reviewer.name}`, {
|
|
106
|
-
changedFiles: scopedFiles.length,
|
|
107
|
-
});
|
|
108
|
-
try {
|
|
109
|
-
const result = await reviewer.check(workdir, scopedFiles);
|
|
110
|
-
// Always log the result so skips/passes are visible in the log
|
|
111
|
-
logger?.info("review", `Plugin reviewer result: ${reviewer.name}`, {
|
|
112
|
-
passed: result.passed,
|
|
113
|
-
exitCode: result.exitCode,
|
|
114
|
-
output: result.output?.slice(0, 500),
|
|
115
|
-
findings: result.findings?.length ?? 0,
|
|
116
|
-
});
|
|
117
|
-
pluginResults.push({
|
|
118
|
-
name: reviewer.name,
|
|
119
|
-
passed: result.passed,
|
|
120
|
-
output: result.output,
|
|
121
|
-
exitCode: result.exitCode,
|
|
122
|
-
findings: result.findings,
|
|
123
|
-
});
|
|
124
|
-
if (!result.passed) {
|
|
125
|
-
builtIn.pluginReviewers = pluginResults;
|
|
126
|
-
return {
|
|
127
|
-
builtIn,
|
|
128
|
-
success: false,
|
|
129
|
-
failureReason: `plugin reviewer '${reviewer.name}' failed`,
|
|
130
|
-
pluginFailed: true,
|
|
131
|
-
};
|
|
132
|
-
}
|
|
133
|
-
} catch (error) {
|
|
134
|
-
const errorMsg = errorMessage(error);
|
|
135
|
-
logger?.warn("review", `Plugin reviewer threw error: ${reviewer.name}`, { error: errorMsg });
|
|
136
|
-
pluginResults.push({ name: reviewer.name, passed: false, output: "", error: errorMsg });
|
|
137
|
-
builtIn.pluginReviewers = pluginResults;
|
|
138
|
-
return {
|
|
139
|
-
builtIn,
|
|
140
|
-
success: false,
|
|
141
|
-
failureReason: `plugin reviewer '${reviewer.name}' threw error`,
|
|
142
|
-
pluginFailed: true,
|
|
143
|
-
};
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
builtIn.pluginReviewers = pluginResults;
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
return { builtIn, success: true, pluginFailed: false };
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
export const reviewOrchestrator = new ReviewOrchestrator();
|