@n-dx/core 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +96 -0
- package/README.md +214 -0
- package/ci.js +1243 -0
- package/claude-integration.js +331 -0
- package/cli.js +975 -0
- package/config.js +1054 -0
- package/export.js +509 -0
- package/help.js +1051 -0
- package/package.json +93 -0
- package/packages/hench/dist/agent/analysis/adaptive.d.ts +101 -0
- package/packages/hench/dist/agent/analysis/adaptive.js +353 -0
- package/packages/hench/dist/agent/analysis/adaptive.js.map +1 -0
- package/packages/hench/dist/agent/analysis/index.d.ts +26 -0
- package/packages/hench/dist/agent/analysis/index.js +30 -0
- package/packages/hench/dist/agent/analysis/index.js.map +1 -0
- package/packages/hench/dist/agent/analysis/review.d.ts +40 -0
- package/packages/hench/dist/agent/analysis/review.js +66 -0
- package/packages/hench/dist/agent/analysis/review.js.map +1 -0
- package/packages/hench/dist/agent/analysis/spin.d.ts +27 -0
- package/packages/hench/dist/agent/analysis/spin.js +32 -0
- package/packages/hench/dist/agent/analysis/spin.js.map +1 -0
- package/packages/hench/dist/agent/analysis/stuck.d.ts +22 -0
- package/packages/hench/dist/agent/analysis/stuck.js +56 -0
- package/packages/hench/dist/agent/analysis/stuck.js.map +1 -0
- package/packages/hench/dist/agent/analysis/summary.d.ts +9 -0
- package/packages/hench/dist/agent/analysis/summary.js +106 -0
- package/packages/hench/dist/agent/analysis/summary.js.map +1 -0
- package/packages/hench/dist/agent/analysis/workflow.d.ts +60 -0
- package/packages/hench/dist/agent/analysis/workflow.js +359 -0
- package/packages/hench/dist/agent/analysis/workflow.js.map +1 -0
- package/packages/hench/dist/agent/brief.d.ts +33 -0
- package/packages/hench/dist/agent/brief.js +235 -0
- package/packages/hench/dist/agent/brief.js.map +1 -0
- package/packages/hench/dist/agent/cli-loop.d.ts +43 -0
- package/packages/hench/dist/agent/cli-loop.js +469 -0
- package/packages/hench/dist/agent/cli-loop.js.map +1 -0
- package/packages/hench/dist/agent/completion.d.ts +8 -0
- package/packages/hench/dist/agent/completion.js +8 -0
- package/packages/hench/dist/agent/completion.js.map +1 -0
- package/packages/hench/dist/agent/index.d.ts +35 -0
- package/packages/hench/dist/agent/index.js +40 -0
- package/packages/hench/dist/agent/index.js.map +1 -0
- package/packages/hench/dist/agent/lifecycle/cli-loop.d.ts +65 -0
- package/packages/hench/dist/agent/lifecycle/cli-loop.js +882 -0
- package/packages/hench/dist/agent/lifecycle/cli-loop.js.map +1 -0
- package/packages/hench/dist/agent/lifecycle/heartbeat.d.ts +38 -0
- package/packages/hench/dist/agent/lifecycle/heartbeat.js +72 -0
- package/packages/hench/dist/agent/lifecycle/heartbeat.js.map +1 -0
- package/packages/hench/dist/agent/lifecycle/loop.d.ts +11 -0
- package/packages/hench/dist/agent/lifecycle/loop.js +300 -0
- package/packages/hench/dist/agent/lifecycle/loop.js.map +1 -0
- package/packages/hench/dist/agent/lifecycle/shared.d.ts +138 -0
- package/packages/hench/dist/agent/lifecycle/shared.js +241 -0
- package/packages/hench/dist/agent/lifecycle/shared.js.map +1 -0
- package/packages/hench/dist/agent/lifecycle/task-display.d.ts +7 -0
- package/packages/hench/dist/agent/lifecycle/task-display.js +22 -0
- package/packages/hench/dist/agent/lifecycle/task-display.js.map +1 -0
- package/packages/hench/dist/agent/lifecycle/token-budget.d.ts +18 -0
- package/packages/hench/dist/agent/lifecycle/token-budget.js +16 -0
- package/packages/hench/dist/agent/lifecycle/token-budget.js.map +1 -0
- package/packages/hench/dist/agent/lifecycle/token-usage.d.ts +44 -0
- package/packages/hench/dist/agent/lifecycle/token-usage.js +102 -0
- package/packages/hench/dist/agent/lifecycle/token-usage.js.map +1 -0
- package/packages/hench/dist/agent/loop.d.ts +24 -0
- package/packages/hench/dist/agent/loop.js +312 -0
- package/packages/hench/dist/agent/loop.js.map +1 -0
- package/packages/hench/dist/agent/planning/brief.d.ts +40 -0
- package/packages/hench/dist/agent/planning/brief.js +267 -0
- package/packages/hench/dist/agent/planning/brief.js.map +1 -0
- package/packages/hench/dist/agent/planning/prompt.d.ts +2 -0
- package/packages/hench/dist/agent/planning/prompt.js +73 -0
- package/packages/hench/dist/agent/planning/prompt.js.map +1 -0
- package/packages/hench/dist/agent/prompt.d.ts +2 -0
- package/packages/hench/dist/agent/prompt.js +65 -0
- package/packages/hench/dist/agent/prompt.js.map +1 -0
- package/packages/hench/dist/agent/review.d.ts +40 -0
- package/packages/hench/dist/agent/review.js +76 -0
- package/packages/hench/dist/agent/review.js.map +1 -0
- package/packages/hench/dist/agent/stuck.d.ts +22 -0
- package/packages/hench/dist/agent/stuck.js +56 -0
- package/packages/hench/dist/agent/stuck.js.map +1 -0
- package/packages/hench/dist/agent/summary.d.ts +9 -0
- package/packages/hench/dist/agent/summary.js +106 -0
- package/packages/hench/dist/agent/summary.js.map +1 -0
- package/packages/hench/dist/agent/test-runner.d.ts +81 -0
- package/packages/hench/dist/agent/test-runner.js +245 -0
- package/packages/hench/dist/agent/test-runner.js.map +1 -0
- package/packages/hench/dist/agent/token-budget.d.ts +18 -0
- package/packages/hench/dist/agent/token-budget.js +16 -0
- package/packages/hench/dist/agent/token-budget.js.map +1 -0
- package/packages/hench/dist/agent/token-usage.d.ts +27 -0
- package/packages/hench/dist/agent/token-usage.js +52 -0
- package/packages/hench/dist/agent/token-usage.js.map +1 -0
- package/packages/hench/dist/agent/tools.d.ts +8 -0
- package/packages/hench/dist/agent/tools.js +8 -0
- package/packages/hench/dist/agent/tools.js.map +1 -0
- package/packages/hench/dist/cli/commands/config.d.ts +40 -0
- package/packages/hench/dist/cli/commands/config.js +463 -0
- package/packages/hench/dist/cli/commands/config.js.map +1 -0
- package/packages/hench/dist/cli/commands/constants.d.ts +5 -0
- package/packages/hench/dist/cli/commands/constants.js +46 -0
- package/packages/hench/dist/cli/commands/constants.js.map +1 -0
- package/packages/hench/dist/cli/commands/init.d.ts +1 -0
- package/packages/hench/dist/cli/commands/init.js +22 -0
- package/packages/hench/dist/cli/commands/init.js.map +1 -0
- package/packages/hench/dist/cli/commands/run.d.ts +108 -0
- package/packages/hench/dist/cli/commands/run.js +847 -0
- package/packages/hench/dist/cli/commands/run.js.map +1 -0
- package/packages/hench/dist/cli/commands/show.d.ts +1 -0
- package/packages/hench/dist/cli/commands/show.js +101 -0
- package/packages/hench/dist/cli/commands/show.js.map +1 -0
- package/packages/hench/dist/cli/commands/status.d.ts +1 -0
- package/packages/hench/dist/cli/commands/status.js +63 -0
- package/packages/hench/dist/cli/commands/status.js.map +1 -0
- package/packages/hench/dist/cli/commands/task-lookup.d.ts +24 -0
- package/packages/hench/dist/cli/commands/task-lookup.js +69 -0
- package/packages/hench/dist/cli/commands/task-lookup.js.map +1 -0
- package/packages/hench/dist/cli/commands/template.d.ts +12 -0
- package/packages/hench/dist/cli/commands/template.js +217 -0
- package/packages/hench/dist/cli/commands/template.js.map +1 -0
- package/packages/hench/dist/cli/errors.d.ts +55 -0
- package/packages/hench/dist/cli/errors.js +185 -0
- package/packages/hench/dist/cli/errors.js.map +1 -0
- package/packages/hench/dist/cli/help.d.ts +23 -0
- package/packages/hench/dist/cli/help.js +186 -0
- package/packages/hench/dist/cli/help.js.map +1 -0
- package/packages/hench/dist/cli/index.d.ts +21 -0
- package/packages/hench/dist/cli/index.js +131 -0
- package/packages/hench/dist/cli/index.js.map +1 -0
- package/packages/hench/dist/cli/output.d.ts +9 -0
- package/packages/hench/dist/cli/output.js +10 -0
- package/packages/hench/dist/cli/output.js.map +1 -0
- package/packages/hench/dist/guard/commands.d.ts +27 -0
- package/packages/hench/dist/guard/commands.js +69 -0
- package/packages/hench/dist/guard/commands.js.map +1 -0
- package/packages/hench/dist/guard/contracts.d.ts +31 -0
- package/packages/hench/dist/guard/contracts.js +8 -0
- package/packages/hench/dist/guard/contracts.js.map +1 -0
- package/packages/hench/dist/guard/index.d.ts +107 -0
- package/packages/hench/dist/guard/index.js +139 -0
- package/packages/hench/dist/guard/index.js.map +1 -0
- package/packages/hench/dist/guard/paths.d.ts +43 -0
- package/packages/hench/dist/guard/paths.js +112 -0
- package/packages/hench/dist/guard/paths.js.map +1 -0
- package/packages/hench/dist/guard/policy.d.ts +108 -0
- package/packages/hench/dist/guard/policy.js +156 -0
- package/packages/hench/dist/guard/policy.js.map +1 -0
- package/packages/hench/dist/prd/llm-gateway.d.ts +47 -0
- package/packages/hench/dist/prd/llm-gateway.js +57 -0
- package/packages/hench/dist/prd/llm-gateway.js.map +1 -0
- package/packages/hench/dist/prd/ops.d.ts +5 -0
- package/packages/hench/dist/prd/ops.js +6 -0
- package/packages/hench/dist/prd/ops.js.map +1 -0
- package/packages/hench/dist/prd/rex-gateway.d.ts +95 -0
- package/packages/hench/dist/prd/rex-gateway.js +104 -0
- package/packages/hench/dist/prd/rex-gateway.js.map +1 -0
- package/packages/hench/dist/process/concurrent-execution-metrics.d.ts +243 -0
- package/packages/hench/dist/process/concurrent-execution-metrics.js +352 -0
- package/packages/hench/dist/process/concurrent-execution-metrics.js.map +1 -0
- package/packages/hench/dist/process/exec-shell.d.ts +8 -0
- package/packages/hench/dist/process/exec-shell.js +8 -0
- package/packages/hench/dist/process/exec-shell.js.map +1 -0
- package/packages/hench/dist/process/exec.d.ts +12 -0
- package/packages/hench/dist/process/exec.js +12 -0
- package/packages/hench/dist/process/exec.js.map +1 -0
- package/packages/hench/dist/process/index.d.ts +22 -0
- package/packages/hench/dist/process/index.js +15 -0
- package/packages/hench/dist/process/index.js.map +1 -0
- package/packages/hench/dist/process/lifecycle.d.ts +208 -0
- package/packages/hench/dist/process/lifecycle.js +387 -0
- package/packages/hench/dist/process/lifecycle.js.map +1 -0
- package/packages/hench/dist/process/limiter.d.ts +85 -0
- package/packages/hench/dist/process/limiter.js +215 -0
- package/packages/hench/dist/process/limiter.js.map +1 -0
- package/packages/hench/dist/process/memory-monitor.d.ts +162 -0
- package/packages/hench/dist/process/memory-monitor.js +268 -0
- package/packages/hench/dist/process/memory-monitor.js.map +1 -0
- package/packages/hench/dist/process/memory-throttle.d.ts +140 -0
- package/packages/hench/dist/process/memory-throttle.js +238 -0
- package/packages/hench/dist/process/memory-throttle.js.map +1 -0
- package/packages/hench/dist/process/pool.d.ts +231 -0
- package/packages/hench/dist/process/pool.js +344 -0
- package/packages/hench/dist/process/pool.js.map +1 -0
- package/packages/hench/dist/process/process-memory-tracker.d.ts +164 -0
- package/packages/hench/dist/process/process-memory-tracker.js +249 -0
- package/packages/hench/dist/process/process-memory-tracker.js.map +1 -0
- package/packages/hench/dist/public.d.ts +62 -0
- package/packages/hench/dist/public.js +58 -0
- package/packages/hench/dist/public.js.map +1 -0
- package/packages/hench/dist/queue/execution-queue.d.ts +128 -0
- package/packages/hench/dist/queue/execution-queue.js +206 -0
- package/packages/hench/dist/queue/execution-queue.js.map +1 -0
- package/packages/hench/dist/queue/format.d.ts +19 -0
- package/packages/hench/dist/queue/format.js +52 -0
- package/packages/hench/dist/queue/format.js.map +1 -0
- package/packages/hench/dist/queue/index.d.ts +5 -0
- package/packages/hench/dist/queue/index.js +4 -0
- package/packages/hench/dist/queue/index.js.map +1 -0
- package/packages/hench/dist/queue/priority-scheduler.d.ts +73 -0
- package/packages/hench/dist/queue/priority-scheduler.js +119 -0
- package/packages/hench/dist/queue/priority-scheduler.js.map +1 -0
- package/packages/hench/dist/schema/index.d.ts +6 -0
- package/packages/hench/dist/schema/index.js +4 -0
- package/packages/hench/dist/schema/index.js.map +1 -0
- package/packages/hench/dist/schema/templates.d.ts +34 -0
- package/packages/hench/dist/schema/templates.js +147 -0
- package/packages/hench/dist/schema/templates.js.map +1 -0
- package/packages/hench/dist/schema/v1.d.ts +235 -0
- package/packages/hench/dist/schema/v1.js +34 -0
- package/packages/hench/dist/schema/v1.js.map +1 -0
- package/packages/hench/dist/schema/validate.d.ts +601 -0
- package/packages/hench/dist/schema/validate.js +166 -0
- package/packages/hench/dist/schema/validate.js.map +1 -0
- package/packages/hench/dist/shared/glob.d.ts +11 -0
- package/packages/hench/dist/shared/glob.js +57 -0
- package/packages/hench/dist/shared/glob.js.map +1 -0
- package/packages/hench/dist/store/adjustments.d.ts +75 -0
- package/packages/hench/dist/store/adjustments.js +139 -0
- package/packages/hench/dist/store/adjustments.js.map +1 -0
- package/packages/hench/dist/store/config.d.ts +6 -0
- package/packages/hench/dist/store/config.js +41 -0
- package/packages/hench/dist/store/config.js.map +1 -0
- package/packages/hench/dist/store/index.d.ts +7 -0
- package/packages/hench/dist/store/index.js +6 -0
- package/packages/hench/dist/store/index.js.map +1 -0
- package/packages/hench/dist/store/json.d.ts +1 -0
- package/packages/hench/dist/store/json.js +3 -0
- package/packages/hench/dist/store/json.js.map +1 -0
- package/packages/hench/dist/store/project-config.d.ts +62 -0
- package/packages/hench/dist/store/project-config.js +100 -0
- package/packages/hench/dist/store/project-config.js.map +1 -0
- package/packages/hench/dist/store/run-archiver.d.ts +107 -0
- package/packages/hench/dist/store/run-archiver.js +204 -0
- package/packages/hench/dist/store/run-archiver.js.map +1 -0
- package/packages/hench/dist/store/run-change-detector.d.ts +99 -0
- package/packages/hench/dist/store/run-change-detector.js +170 -0
- package/packages/hench/dist/store/run-change-detector.js.map +1 -0
- package/packages/hench/dist/store/run-retention-scheduler.d.ts +80 -0
- package/packages/hench/dist/store/run-retention-scheduler.js +143 -0
- package/packages/hench/dist/store/run-retention-scheduler.js.map +1 -0
- package/packages/hench/dist/store/run-retention.d.ts +150 -0
- package/packages/hench/dist/store/run-retention.js +327 -0
- package/packages/hench/dist/store/run-retention.js.map +1 -0
- package/packages/hench/dist/store/runs.d.ts +4 -0
- package/packages/hench/dist/store/runs.js +80 -0
- package/packages/hench/dist/store/runs.js.map +1 -0
- package/packages/hench/dist/store/suggestions.d.ts +43 -0
- package/packages/hench/dist/store/suggestions.js +61 -0
- package/packages/hench/dist/store/suggestions.js.map +1 -0
- package/packages/hench/dist/store/templates.d.ts +34 -0
- package/packages/hench/dist/store/templates.js +119 -0
- package/packages/hench/dist/store/templates.js.map +1 -0
- package/packages/hench/dist/tools/contracts.d.ts +60 -0
- package/packages/hench/dist/tools/contracts.js +2 -0
- package/packages/hench/dist/tools/contracts.js.map +1 -0
- package/packages/hench/dist/tools/dispatch.d.ts +29 -0
- package/packages/hench/dist/tools/dispatch.js +213 -0
- package/packages/hench/dist/tools/dispatch.js.map +1 -0
- package/packages/hench/dist/tools/exec-shell.d.ts +23 -0
- package/packages/hench/dist/tools/exec-shell.js +29 -0
- package/packages/hench/dist/tools/exec-shell.js.map +1 -0
- package/packages/hench/dist/tools/files.d.ts +17 -0
- package/packages/hench/dist/tools/files.js +111 -0
- package/packages/hench/dist/tools/files.js.map +1 -0
- package/packages/hench/dist/tools/git.d.ts +5 -0
- package/packages/hench/dist/tools/git.js +48 -0
- package/packages/hench/dist/tools/git.js.map +1 -0
- package/packages/hench/dist/tools/index.d.ts +17 -0
- package/packages/hench/dist/tools/index.js +19 -0
- package/packages/hench/dist/tools/index.js.map +1 -0
- package/packages/hench/dist/tools/rex.d.ts +32 -0
- package/packages/hench/dist/tools/rex.js +185 -0
- package/packages/hench/dist/tools/rex.js.map +1 -0
- package/packages/hench/dist/tools/shell.d.ts +6 -0
- package/packages/hench/dist/tools/shell.js +10 -0
- package/packages/hench/dist/tools/shell.js.map +1 -0
- package/packages/hench/dist/tools/test-runner.d.ts +81 -0
- package/packages/hench/dist/tools/test-runner.js +229 -0
- package/packages/hench/dist/tools/test-runner.js.map +1 -0
- package/packages/hench/dist/types/index.d.ts +4 -0
- package/packages/hench/dist/types/index.js +6 -0
- package/packages/hench/dist/types/index.js.map +1 -0
- package/packages/hench/dist/types/output.d.ts +47 -0
- package/packages/hench/dist/types/output.js +74 -0
- package/packages/hench/dist/types/output.js.map +1 -0
- package/packages/hench/dist/validation/completion.d.ts +37 -0
- package/packages/hench/dist/validation/completion.js +83 -0
- package/packages/hench/dist/validation/completion.js.map +1 -0
- package/packages/hench/dist/validation/index.d.ts +9 -0
- package/packages/hench/dist/validation/index.js +9 -0
- package/packages/hench/dist/validation/index.js.map +1 -0
- package/packages/hench/package.json +40 -0
- package/packages/llm-client/dist/api-provider.d.ts +47 -0
- package/packages/llm-client/dist/api-provider.js +126 -0
- package/packages/llm-client/dist/api-provider.js.map +1 -0
- package/packages/llm-client/dist/auth.d.ts +85 -0
- package/packages/llm-client/dist/auth.js +165 -0
- package/packages/llm-client/dist/auth.js.map +1 -0
- package/packages/llm-client/dist/cli-provider.d.ts +49 -0
- package/packages/llm-client/dist/cli-provider.js +226 -0
- package/packages/llm-client/dist/cli-provider.js.map +1 -0
- package/packages/llm-client/dist/codex-cli-provider.d.ts +15 -0
- package/packages/llm-client/dist/codex-cli-provider.js +206 -0
- package/packages/llm-client/dist/codex-cli-provider.js.map +1 -0
- package/packages/llm-client/dist/config.d.ts +39 -0
- package/packages/llm-client/dist/config.js +85 -0
- package/packages/llm-client/dist/config.js.map +1 -0
- package/packages/llm-client/dist/create-client.d.ts +66 -0
- package/packages/llm-client/dist/create-client.js +73 -0
- package/packages/llm-client/dist/create-client.js.map +1 -0
- package/packages/llm-client/dist/exec.d.ts +231 -0
- package/packages/llm-client/dist/exec.js +440 -0
- package/packages/llm-client/dist/exec.js.map +1 -0
- package/packages/llm-client/dist/help-format.d.ts +143 -0
- package/packages/llm-client/dist/help-format.js +280 -0
- package/packages/llm-client/dist/help-format.js.map +1 -0
- package/packages/llm-client/dist/json.d.ts +15 -0
- package/packages/llm-client/dist/json.js +18 -0
- package/packages/llm-client/dist/json.js.map +1 -0
- package/packages/llm-client/dist/llm-client.d.ts +43 -0
- package/packages/llm-client/dist/llm-client.js +48 -0
- package/packages/llm-client/dist/llm-client.js.map +1 -0
- package/packages/llm-client/dist/llm-config.d.ts +16 -0
- package/packages/llm-client/dist/llm-config.js +81 -0
- package/packages/llm-client/dist/llm-config.js.map +1 -0
- package/packages/llm-client/dist/llm-types.d.ts +40 -0
- package/packages/llm-client/dist/llm-types.js +17 -0
- package/packages/llm-client/dist/llm-types.js.map +1 -0
- package/packages/llm-client/dist/output.d.ts +27 -0
- package/packages/llm-client/dist/output.js +38 -0
- package/packages/llm-client/dist/output.js.map +1 -0
- package/packages/llm-client/dist/project-config.d.ts +25 -0
- package/packages/llm-client/dist/project-config.js +66 -0
- package/packages/llm-client/dist/project-config.js.map +1 -0
- package/packages/llm-client/dist/project-dirs.d.ts +32 -0
- package/packages/llm-client/dist/project-dirs.js +31 -0
- package/packages/llm-client/dist/project-dirs.js.map +1 -0
- package/packages/llm-client/dist/provider-interface.d.ts +194 -0
- package/packages/llm-client/dist/provider-interface.js +50 -0
- package/packages/llm-client/dist/provider-interface.js.map +1 -0
- package/packages/llm-client/dist/provider-registry.d.ts +147 -0
- package/packages/llm-client/dist/provider-registry.js +175 -0
- package/packages/llm-client/dist/provider-registry.js.map +1 -0
- package/packages/llm-client/dist/provider-session.d.ts +141 -0
- package/packages/llm-client/dist/provider-session.js +174 -0
- package/packages/llm-client/dist/provider-session.js.map +1 -0
- package/packages/llm-client/dist/public.d.ts +120 -0
- package/packages/llm-client/dist/public.js +122 -0
- package/packages/llm-client/dist/public.js.map +1 -0
- package/packages/llm-client/dist/suggest.d.ts +27 -0
- package/packages/llm-client/dist/suggest.js +63 -0
- package/packages/llm-client/dist/suggest.js.map +1 -0
- package/packages/llm-client/dist/token-usage.d.ts +43 -0
- package/packages/llm-client/dist/token-usage.js +106 -0
- package/packages/llm-client/dist/token-usage.js.map +1 -0
- package/packages/llm-client/dist/types.d.ts +108 -0
- package/packages/llm-client/dist/types.js +49 -0
- package/packages/llm-client/dist/types.js.map +1 -0
- package/packages/llm-client/package.json +34 -0
- package/packages/rex/dist/analyze/acknowledge.d.ts +44 -0
- package/packages/rex/dist/analyze/acknowledge.js +100 -0
- package/packages/rex/dist/analyze/acknowledge.js.map +1 -0
- package/packages/rex/dist/analyze/analyze-shared.d.ts +51 -0
- package/packages/rex/dist/analyze/analyze-shared.js +356 -0
- package/packages/rex/dist/analyze/analyze-shared.js.map +1 -0
- package/packages/rex/dist/analyze/batch-types.d.ts +48 -0
- package/packages/rex/dist/analyze/batch-types.js +9 -0
- package/packages/rex/dist/analyze/batch-types.js.map +1 -0
- package/packages/rex/dist/analyze/consolidation-guard.d.ts +45 -0
- package/packages/rex/dist/analyze/consolidation-guard.js +125 -0
- package/packages/rex/dist/analyze/consolidation-guard.js.map +1 -0
- package/packages/rex/dist/analyze/decompose.d.ts +62 -0
- package/packages/rex/dist/analyze/decompose.js +212 -0
- package/packages/rex/dist/analyze/decompose.js.map +1 -0
- package/packages/rex/dist/analyze/dedupe.d.ts +30 -0
- package/packages/rex/dist/analyze/dedupe.js +339 -0
- package/packages/rex/dist/analyze/dedupe.js.map +1 -0
- package/packages/rex/dist/analyze/diff.d.ts +13 -0
- package/packages/rex/dist/analyze/diff.js +146 -0
- package/packages/rex/dist/analyze/diff.js.map +1 -0
- package/packages/rex/dist/analyze/extract.d.ts +152 -0
- package/packages/rex/dist/analyze/extract.js +1338 -0
- package/packages/rex/dist/analyze/extract.js.map +1 -0
- package/packages/rex/dist/analyze/file-validation.d.ts +122 -0
- package/packages/rex/dist/analyze/file-validation.js +427 -0
- package/packages/rex/dist/analyze/file-validation.js.map +1 -0
- package/packages/rex/dist/analyze/guided.d.ts +17 -0
- package/packages/rex/dist/analyze/guided.js +162 -0
- package/packages/rex/dist/analyze/guided.js.map +1 -0
- package/packages/rex/dist/analyze/index.d.ts +27 -0
- package/packages/rex/dist/analyze/index.js +15 -0
- package/packages/rex/dist/analyze/index.js.map +1 -0
- package/packages/rex/dist/analyze/llm-bridge.d.ts +49 -0
- package/packages/rex/dist/analyze/llm-bridge.js +133 -0
- package/packages/rex/dist/analyze/llm-bridge.js.map +1 -0
- package/packages/rex/dist/analyze/modify-reason.d.ts +68 -0
- package/packages/rex/dist/analyze/modify-reason.js +182 -0
- package/packages/rex/dist/analyze/modify-reason.js.map +1 -0
- package/packages/rex/dist/analyze/propose.d.ts +72 -0
- package/packages/rex/dist/analyze/propose.js +246 -0
- package/packages/rex/dist/analyze/propose.js.map +1 -0
- package/packages/rex/dist/analyze/reason.d.ts +277 -0
- package/packages/rex/dist/analyze/reason.js +1446 -0
- package/packages/rex/dist/analyze/reason.js.map +1 -0
- package/packages/rex/dist/analyze/reconcile.d.ts +25 -0
- package/packages/rex/dist/analyze/reconcile.js +82 -0
- package/packages/rex/dist/analyze/reconcile.js.map +1 -0
- package/packages/rex/dist/analyze/reshape-reason.d.ts +38 -0
- package/packages/rex/dist/analyze/reshape-reason.js +302 -0
- package/packages/rex/dist/analyze/reshape-reason.js.map +1 -0
- package/packages/rex/dist/analyze/scanners.d.ts +36 -0
- package/packages/rex/dist/analyze/scanners.js +805 -0
- package/packages/rex/dist/analyze/scanners.js.map +1 -0
- package/packages/rex/dist/analyze/validate-modification.d.ts +54 -0
- package/packages/rex/dist/analyze/validate-modification.js +166 -0
- package/packages/rex/dist/analyze/validate-modification.js.map +1 -0
- package/packages/rex/dist/cli/commands/adapter.d.ts +11 -0
- package/packages/rex/dist/cli/commands/adapter.js +211 -0
- package/packages/rex/dist/cli/commands/adapter.js.map +1 -0
- package/packages/rex/dist/cli/commands/add.d.ts +1 -0
- package/packages/rex/dist/cli/commands/add.js +111 -0
- package/packages/rex/dist/cli/commands/add.js.map +1 -0
- package/packages/rex/dist/cli/commands/analyze.d.ts +4 -0
- package/packages/rex/dist/cli/commands/analyze.js +672 -0
- package/packages/rex/dist/cli/commands/analyze.js.map +1 -0
- package/packages/rex/dist/cli/commands/chunked-review-state.d.ts +183 -0
- package/packages/rex/dist/cli/commands/chunked-review-state.js +637 -0
- package/packages/rex/dist/cli/commands/chunked-review-state.js.map +1 -0
- package/packages/rex/dist/cli/commands/chunked-review.d.ts +21 -0
- package/packages/rex/dist/cli/commands/chunked-review.js +147 -0
- package/packages/rex/dist/cli/commands/chunked-review.js.map +1 -0
- package/packages/rex/dist/cli/commands/constants.d.ts +3 -0
- package/packages/rex/dist/cli/commands/constants.js +50 -0
- package/packages/rex/dist/cli/commands/constants.js.map +1 -0
- package/packages/rex/dist/cli/commands/decomposition-review.d.ts +92 -0
- package/packages/rex/dist/cli/commands/decomposition-review.js +258 -0
- package/packages/rex/dist/cli/commands/decomposition-review.js.map +1 -0
- package/packages/rex/dist/cli/commands/fix.d.ts +8 -0
- package/packages/rex/dist/cli/commands/fix.js +101 -0
- package/packages/rex/dist/cli/commands/fix.js.map +1 -0
- package/packages/rex/dist/cli/commands/format-loe.d.ts +22 -0
- package/packages/rex/dist/cli/commands/format-loe.js +35 -0
- package/packages/rex/dist/cli/commands/format-loe.js.map +1 -0
- package/packages/rex/dist/cli/commands/health.d.ts +7 -0
- package/packages/rex/dist/cli/commands/health.js +24 -0
- package/packages/rex/dist/cli/commands/health.js.map +1 -0
- package/packages/rex/dist/cli/commands/init.d.ts +1 -0
- package/packages/rex/dist/cli/commands/init.js +64 -0
- package/packages/rex/dist/cli/commands/init.js.map +1 -0
- package/packages/rex/dist/cli/commands/move.d.ts +1 -0
- package/packages/rex/dist/cli/commands/move.js +45 -0
- package/packages/rex/dist/cli/commands/move.js.map +1 -0
- package/packages/rex/dist/cli/commands/next.d.ts +1 -0
- package/packages/rex/dist/cli/commands/next.js +64 -0
- package/packages/rex/dist/cli/commands/next.js.map +1 -0
- package/packages/rex/dist/cli/commands/prune.d.ts +1 -0
- package/packages/rex/dist/cli/commands/prune.js +561 -0
- package/packages/rex/dist/cli/commands/prune.js.map +1 -0
- package/packages/rex/dist/cli/commands/recommend.d.ts +2 -0
- package/packages/rex/dist/cli/commands/recommend.js +517 -0
- package/packages/rex/dist/cli/commands/recommend.js.map +1 -0
- package/packages/rex/dist/cli/commands/remove.d.ts +12 -0
- package/packages/rex/dist/cli/commands/remove.js +206 -0
- package/packages/rex/dist/cli/commands/remove.js.map +1 -0
- package/packages/rex/dist/cli/commands/reorganize.d.ts +16 -0
- package/packages/rex/dist/cli/commands/reorganize.js +288 -0
- package/packages/rex/dist/cli/commands/reorganize.js.map +1 -0
- package/packages/rex/dist/cli/commands/report.d.ts +49 -0
- package/packages/rex/dist/cli/commands/report.js +218 -0
- package/packages/rex/dist/cli/commands/report.js.map +1 -0
- package/packages/rex/dist/cli/commands/reshape.d.ts +1 -0
- package/packages/rex/dist/cli/commands/reshape.js +182 -0
- package/packages/rex/dist/cli/commands/reshape.js.map +1 -0
- package/packages/rex/dist/cli/commands/smart-add-duplicates.d.ts +45 -0
- package/packages/rex/dist/cli/commands/smart-add-duplicates.js +252 -0
- package/packages/rex/dist/cli/commands/smart-add-duplicates.js.map +1 -0
- package/packages/rex/dist/cli/commands/smart-add.d.ts +80 -0
- package/packages/rex/dist/cli/commands/smart-add.js +1343 -0
- package/packages/rex/dist/cli/commands/smart-add.js.map +1 -0
- package/packages/rex/dist/cli/commands/status-sections.d.ts +70 -0
- package/packages/rex/dist/cli/commands/status-sections.js +201 -0
- package/packages/rex/dist/cli/commands/status-sections.js.map +1 -0
- package/packages/rex/dist/cli/commands/status-shared.d.ts +44 -0
- package/packages/rex/dist/cli/commands/status-shared.js +191 -0
- package/packages/rex/dist/cli/commands/status-shared.js.map +1 -0
- package/packages/rex/dist/cli/commands/status.d.ts +3 -0
- package/packages/rex/dist/cli/commands/status.js +118 -0
- package/packages/rex/dist/cli/commands/status.js.map +1 -0
- package/packages/rex/dist/cli/commands/sync.d.ts +11 -0
- package/packages/rex/dist/cli/commands/sync.js +131 -0
- package/packages/rex/dist/cli/commands/sync.js.map +1 -0
- package/packages/rex/dist/cli/commands/token-format.d.ts +31 -0
- package/packages/rex/dist/cli/commands/token-format.js +86 -0
- package/packages/rex/dist/cli/commands/token-format.js.map +1 -0
- package/packages/rex/dist/cli/commands/update.d.ts +1 -0
- package/packages/rex/dist/cli/commands/update.js +146 -0
- package/packages/rex/dist/cli/commands/update.js.map +1 -0
- package/packages/rex/dist/cli/commands/usage.d.ts +1 -0
- package/packages/rex/dist/cli/commands/usage.js +192 -0
- package/packages/rex/dist/cli/commands/usage.js.map +1 -0
- package/packages/rex/dist/cli/commands/validate-interactive.d.ts +46 -0
- package/packages/rex/dist/cli/commands/validate-interactive.js +236 -0
- package/packages/rex/dist/cli/commands/validate-interactive.js.map +1 -0
- package/packages/rex/dist/cli/commands/validate.d.ts +10 -0
- package/packages/rex/dist/cli/commands/validate.js +212 -0
- package/packages/rex/dist/cli/commands/validate.js.map +1 -0
- package/packages/rex/dist/cli/commands/verify.d.ts +1 -0
- package/packages/rex/dist/cli/commands/verify.js +90 -0
- package/packages/rex/dist/cli/commands/verify.js.map +1 -0
- package/packages/rex/dist/cli/errors.d.ts +40 -0
- package/packages/rex/dist/cli/errors.js +125 -0
- package/packages/rex/dist/cli/errors.js.map +1 -0
- package/packages/rex/dist/cli/help.d.ts +23 -0
- package/packages/rex/dist/cli/help.js +584 -0
- package/packages/rex/dist/cli/help.js.map +1 -0
- package/packages/rex/dist/cli/index.d.ts +2 -0
- package/packages/rex/dist/cli/index.js +405 -0
- package/packages/rex/dist/cli/index.js.map +1 -0
- package/packages/rex/dist/cli/mcp-tools.d.ts +86 -0
- package/packages/rex/dist/cli/mcp-tools.js +555 -0
- package/packages/rex/dist/cli/mcp-tools.js.map +1 -0
- package/packages/rex/dist/cli/mcp.d.ts +26 -0
- package/packages/rex/dist/cli/mcp.js +144 -0
- package/packages/rex/dist/cli/mcp.js.map +1 -0
- package/packages/rex/dist/cli/output.d.ts +36 -0
- package/packages/rex/dist/cli/output.js +70 -0
- package/packages/rex/dist/cli/output.js.map +1 -0
- package/packages/rex/dist/cli/validate-input.d.ts +45 -0
- package/packages/rex/dist/cli/validate-input.js +87 -0
- package/packages/rex/dist/cli/validate-input.js.map +1 -0
- package/packages/rex/dist/core/analytics.d.ts +38 -0
- package/packages/rex/dist/core/analytics.js +87 -0
- package/packages/rex/dist/core/analytics.js.map +1 -0
- package/packages/rex/dist/core/canonical.d.ts +3 -0
- package/packages/rex/dist/core/canonical.js +21 -0
- package/packages/rex/dist/core/canonical.js.map +1 -0
- package/packages/rex/dist/core/cascade-reset.d.ts +31 -0
- package/packages/rex/dist/core/cascade-reset.js +47 -0
- package/packages/rex/dist/core/cascade-reset.js.map +1 -0
- package/packages/rex/dist/core/code-coverage.d.ts +38 -0
- package/packages/rex/dist/core/code-coverage.js +85 -0
- package/packages/rex/dist/core/code-coverage.js.map +1 -0
- package/packages/rex/dist/core/dag.d.ts +6 -0
- package/packages/rex/dist/core/dag.js +67 -0
- package/packages/rex/dist/core/dag.js.map +1 -0
- package/packages/rex/dist/core/delete.d.ts +10 -0
- package/packages/rex/dist/core/delete.js +38 -0
- package/packages/rex/dist/core/delete.js.map +1 -0
- package/packages/rex/dist/core/epic-correlation.d.ts +94 -0
- package/packages/rex/dist/core/epic-correlation.js +179 -0
- package/packages/rex/dist/core/epic-correlation.js.map +1 -0
- package/packages/rex/dist/core/facets.d.ts +54 -0
- package/packages/rex/dist/core/facets.js +176 -0
- package/packages/rex/dist/core/facets.js.map +1 -0
- package/packages/rex/dist/core/fix.d.ts +59 -0
- package/packages/rex/dist/core/fix.js +190 -0
- package/packages/rex/dist/core/fix.js.map +1 -0
- package/packages/rex/dist/core/health.d.ts +43 -0
- package/packages/rex/dist/core/health.js +331 -0
- package/packages/rex/dist/core/health.js.map +1 -0
- package/packages/rex/dist/core/keywords.d.ts +20 -0
- package/packages/rex/dist/core/keywords.js +47 -0
- package/packages/rex/dist/core/keywords.js.map +1 -0
- package/packages/rex/dist/core/merge.d.ts +87 -0
- package/packages/rex/dist/core/merge.js +289 -0
- package/packages/rex/dist/core/merge.js.map +1 -0
- package/packages/rex/dist/core/move.d.ts +48 -0
- package/packages/rex/dist/core/move.js +163 -0
- package/packages/rex/dist/core/move.js.map +1 -0
- package/packages/rex/dist/core/next-task.d.ts +121 -0
- package/packages/rex/dist/core/next-task.js +443 -0
- package/packages/rex/dist/core/next-task.js.map +1 -0
- package/packages/rex/dist/core/notion-map.d.ts +207 -0
- package/packages/rex/dist/core/notion-map.js +535 -0
- package/packages/rex/dist/core/notion-map.js.map +1 -0
- package/packages/rex/dist/core/override-escalation.d.ts +28 -0
- package/packages/rex/dist/core/override-escalation.js +69 -0
- package/packages/rex/dist/core/override-escalation.js.map +1 -0
- package/packages/rex/dist/core/parent-completion.d.ts +41 -0
- package/packages/rex/dist/core/parent-completion.js +75 -0
- package/packages/rex/dist/core/parent-completion.js.map +1 -0
- package/packages/rex/dist/core/parent-reset.d.ts +45 -0
- package/packages/rex/dist/core/parent-reset.js +59 -0
- package/packages/rex/dist/core/parent-reset.js.map +1 -0
- package/packages/rex/dist/core/pending-cache.d.ts +27 -0
- package/packages/rex/dist/core/pending-cache.js +55 -0
- package/packages/rex/dist/core/pending-cache.js.map +1 -0
- package/packages/rex/dist/core/prune.d.ts +50 -0
- package/packages/rex/dist/core/prune.js +89 -0
- package/packages/rex/dist/core/prune.js.map +1 -0
- package/packages/rex/dist/core/remove-epic.d.ts +35 -0
- package/packages/rex/dist/core/remove-epic.js +51 -0
- package/packages/rex/dist/core/remove-epic.js.map +1 -0
- package/packages/rex/dist/core/remove-feature.d.ts +100 -0
- package/packages/rex/dist/core/remove-feature.js +189 -0
- package/packages/rex/dist/core/remove-feature.js.map +1 -0
- package/packages/rex/dist/core/remove-task.d.ts +66 -0
- package/packages/rex/dist/core/remove-task.js +93 -0
- package/packages/rex/dist/core/remove-task.js.map +1 -0
- package/packages/rex/dist/core/reorganize-executor.d.ts +43 -0
- package/packages/rex/dist/core/reorganize-executor.js +153 -0
- package/packages/rex/dist/core/reorganize-executor.js.map +1 -0
- package/packages/rex/dist/core/reorganize.d.ts +109 -0
- package/packages/rex/dist/core/reorganize.js +453 -0
- package/packages/rex/dist/core/reorganize.js.map +1 -0
- package/packages/rex/dist/core/requirements.d.ts +131 -0
- package/packages/rex/dist/core/requirements.js +263 -0
- package/packages/rex/dist/core/requirements.js.map +1 -0
- package/packages/rex/dist/core/reshape.d.ts +88 -0
- package/packages/rex/dist/core/reshape.js +168 -0
- package/packages/rex/dist/core/reshape.js.map +1 -0
- package/packages/rex/dist/core/scope-creep.d.ts +31 -0
- package/packages/rex/dist/core/scope-creep.js +53 -0
- package/packages/rex/dist/core/scope-creep.js.map +1 -0
- package/packages/rex/dist/core/stats.d.ts +12 -0
- package/packages/rex/dist/core/stats.js +47 -0
- package/packages/rex/dist/core/stats.js.map +1 -0
- package/packages/rex/dist/core/structural.d.ts +63 -0
- package/packages/rex/dist/core/structural.js +267 -0
- package/packages/rex/dist/core/structural.js.map +1 -0
- package/packages/rex/dist/core/sync-engine.d.ts +63 -0
- package/packages/rex/dist/core/sync-engine.js +429 -0
- package/packages/rex/dist/core/sync-engine.js.map +1 -0
- package/packages/rex/dist/core/sync.d.ts +82 -0
- package/packages/rex/dist/core/sync.js +204 -0
- package/packages/rex/dist/core/sync.js.map +1 -0
- package/packages/rex/dist/core/timestamps.d.ts +34 -0
- package/packages/rex/dist/core/timestamps.js +50 -0
- package/packages/rex/dist/core/timestamps.js.map +1 -0
- package/packages/rex/dist/core/token-usage.d.ts +196 -0
- package/packages/rex/dist/core/token-usage.js +468 -0
- package/packages/rex/dist/core/token-usage.js.map +1 -0
- package/packages/rex/dist/core/transitions.d.ts +28 -0
- package/packages/rex/dist/core/transitions.js +74 -0
- package/packages/rex/dist/core/transitions.js.map +1 -0
- package/packages/rex/dist/core/tree.d.ts +12 -0
- package/packages/rex/dist/core/tree.js +76 -0
- package/packages/rex/dist/core/tree.js.map +1 -0
- package/packages/rex/dist/core/verify.d.ts +92 -0
- package/packages/rex/dist/core/verify.js +201 -0
- package/packages/rex/dist/core/verify.js.map +1 -0
- package/packages/rex/dist/public.d.ts +115 -0
- package/packages/rex/dist/public.js +114 -0
- package/packages/rex/dist/public.js.map +1 -0
- package/packages/rex/dist/recommend/conflict-detection.d.ts +102 -0
- package/packages/rex/dist/recommend/conflict-detection.js +238 -0
- package/packages/rex/dist/recommend/conflict-detection.js.map +1 -0
- package/packages/rex/dist/recommend/create-from-recommendations.d.ts +109 -0
- package/packages/rex/dist/recommend/create-from-recommendations.js +287 -0
- package/packages/rex/dist/recommend/create-from-recommendations.js.map +1 -0
- package/packages/rex/dist/recommend/types.d.ts +59 -0
- package/packages/rex/dist/recommend/types.js +11 -0
- package/packages/rex/dist/recommend/types.js.map +1 -0
- package/packages/rex/dist/schema/index.d.ts +23 -0
- package/packages/rex/dist/schema/index.js +22 -0
- package/packages/rex/dist/schema/index.js.map +1 -0
- package/packages/rex/dist/schema/levels.d.ts +82 -0
- package/packages/rex/dist/schema/levels.js +152 -0
- package/packages/rex/dist/schema/levels.js.map +1 -0
- package/packages/rex/dist/schema/v1.d.ts +341 -0
- package/packages/rex/dist/schema/v1.js +179 -0
- package/packages/rex/dist/schema/v1.js.map +1 -0
- package/packages/rex/dist/schema/validate.d.ts +194 -0
- package/packages/rex/dist/schema/validate.js +136 -0
- package/packages/rex/dist/schema/validate.js.map +1 -0
- package/packages/rex/dist/store/adapter-registry.d.ts +143 -0
- package/packages/rex/dist/store/adapter-registry.js +304 -0
- package/packages/rex/dist/store/adapter-registry.js.map +1 -0
- package/packages/rex/dist/store/atomic-write.d.ts +22 -0
- package/packages/rex/dist/store/atomic-write.js +30 -0
- package/packages/rex/dist/store/atomic-write.js.map +1 -0
- package/packages/rex/dist/store/contracts.d.ts +142 -0
- package/packages/rex/dist/store/contracts.js +19 -0
- package/packages/rex/dist/store/contracts.js.map +1 -0
- package/packages/rex/dist/store/file-adapter.d.ts +23 -0
- package/packages/rex/dist/store/file-adapter.js +150 -0
- package/packages/rex/dist/store/file-adapter.js.map +1 -0
- package/packages/rex/dist/store/index.d.ts +67 -0
- package/packages/rex/dist/store/index.js +78 -0
- package/packages/rex/dist/store/index.js.map +1 -0
- package/packages/rex/dist/store/integration-schema.d.ts +205 -0
- package/packages/rex/dist/store/integration-schema.js +136 -0
- package/packages/rex/dist/store/integration-schema.js.map +1 -0
- package/packages/rex/dist/store/integration-schemas/index.d.ts +28 -0
- package/packages/rex/dist/store/integration-schemas/index.js +45 -0
- package/packages/rex/dist/store/integration-schemas/index.js.map +1 -0
- package/packages/rex/dist/store/integration-schemas/jira.d.ts +11 -0
- package/packages/rex/dist/store/integration-schemas/jira.js +147 -0
- package/packages/rex/dist/store/integration-schemas/jira.js.map +1 -0
- package/packages/rex/dist/store/integration-schemas/notion.d.ts +11 -0
- package/packages/rex/dist/store/integration-schemas/notion.js +80 -0
- package/packages/rex/dist/store/integration-schemas/notion.js.map +1 -0
- package/packages/rex/dist/store/notion-adapter.d.ts +42 -0
- package/packages/rex/dist/store/notion-adapter.js +247 -0
- package/packages/rex/dist/store/notion-adapter.js.map +1 -0
- package/packages/rex/dist/store/notion-client.d.ts +56 -0
- package/packages/rex/dist/store/notion-client.js +82 -0
- package/packages/rex/dist/store/notion-client.js.map +1 -0
- package/packages/rex/dist/store/notion-map.d.ts +207 -0
- package/packages/rex/dist/store/notion-map.js +535 -0
- package/packages/rex/dist/store/notion-map.js.map +1 -0
- package/packages/rex/dist/store/project-config.d.ts +44 -0
- package/packages/rex/dist/store/project-config.js +56 -0
- package/packages/rex/dist/store/project-config.js.map +1 -0
- package/packages/rex/dist/store/types.d.ts +142 -0
- package/packages/rex/dist/store/types.js +19 -0
- package/packages/rex/dist/store/types.js.map +1 -0
- package/packages/rex/dist/workflow/default.d.ts +1 -0
- package/packages/rex/dist/workflow/default.js +21 -0
- package/packages/rex/dist/workflow/default.js.map +1 -0
- package/packages/rex/package.json +40 -0
- package/packages/sourcevision/dist/analyzers/__tests__/components.test.d.ts +1 -0
- package/packages/sourcevision/dist/analyzers/__tests__/components.test.js +370 -0
- package/packages/sourcevision/dist/analyzers/__tests__/components.test.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/__tests__/imports.test.d.ts +1 -0
- package/packages/sourcevision/dist/analyzers/__tests__/imports.test.js +101 -0
- package/packages/sourcevision/dist/analyzers/__tests__/imports.test.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/__tests__/inventory.test.d.ts +1 -0
- package/packages/sourcevision/dist/analyzers/__tests__/inventory.test.js +118 -0
- package/packages/sourcevision/dist/analyzers/__tests__/inventory.test.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/__tests__/manifest.test.d.ts +1 -0
- package/packages/sourcevision/dist/analyzers/__tests__/manifest.test.js +61 -0
- package/packages/sourcevision/dist/analyzers/__tests__/manifest.test.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/__tests__/zones.test.d.ts +1 -0
- package/packages/sourcevision/dist/analyzers/__tests__/zones.test.js +836 -0
- package/packages/sourcevision/dist/analyzers/__tests__/zones.test.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/archetypes.d.ts +18 -0
- package/packages/sourcevision/dist/analyzers/archetypes.js +272 -0
- package/packages/sourcevision/dist/analyzers/archetypes.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/branch-work-classifier.d.ts +67 -0
- package/packages/sourcevision/dist/analyzers/branch-work-classifier.js +202 -0
- package/packages/sourcevision/dist/analyzers/branch-work-classifier.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/branch-work-collector.d.ts +121 -0
- package/packages/sourcevision/dist/analyzers/branch-work-collector.js +301 -0
- package/packages/sourcevision/dist/analyzers/branch-work-collector.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/branch-work-filter.d.ts +112 -0
- package/packages/sourcevision/dist/analyzers/branch-work-filter.js +285 -0
- package/packages/sourcevision/dist/analyzers/branch-work-filter.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/branch-work-store.d.ts +65 -0
- package/packages/sourcevision/dist/analyzers/branch-work-store.js +127 -0
- package/packages/sourcevision/dist/analyzers/branch-work-store.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/callgraph-findings.d.ts +26 -0
- package/packages/sourcevision/dist/analyzers/callgraph-findings.js +581 -0
- package/packages/sourcevision/dist/analyzers/callgraph-findings.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/callgraph.d.ts +64 -0
- package/packages/sourcevision/dist/analyzers/callgraph.js +659 -0
- package/packages/sourcevision/dist/analyzers/callgraph.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/classify.d.ts +45 -0
- package/packages/sourcevision/dist/analyzers/classify.js +431 -0
- package/packages/sourcevision/dist/analyzers/classify.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/claude-cli.d.ts +29 -0
- package/packages/sourcevision/dist/analyzers/claude-cli.js +137 -0
- package/packages/sourcevision/dist/analyzers/claude-cli.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/claude-client.d.ts +47 -0
- package/packages/sourcevision/dist/analyzers/claude-client.js +112 -0
- package/packages/sourcevision/dist/analyzers/claude-client.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/completion-reader.d.ts +218 -0
- package/packages/sourcevision/dist/analyzers/completion-reader.js +355 -0
- package/packages/sourcevision/dist/analyzers/completion-reader.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/components.d.ts +18 -0
- package/packages/sourcevision/dist/analyzers/components.js +598 -0
- package/packages/sourcevision/dist/analyzers/components.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/context.d.ts +6 -0
- package/packages/sourcevision/dist/analyzers/context.js +175 -0
- package/packages/sourcevision/dist/analyzers/context.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/convergence.d.ts +74 -0
- package/packages/sourcevision/dist/analyzers/convergence.js +144 -0
- package/packages/sourcevision/dist/analyzers/convergence.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/enrich-batch.d.ts +47 -0
- package/packages/sourcevision/dist/analyzers/enrich-batch.js +340 -0
- package/packages/sourcevision/dist/analyzers/enrich-batch.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/enrich-config.d.ts +41 -0
- package/packages/sourcevision/dist/analyzers/enrich-config.js +215 -0
- package/packages/sourcevision/dist/analyzers/enrich-config.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/enrich-parsing.d.ts +58 -0
- package/packages/sourcevision/dist/analyzers/enrich-parsing.js +401 -0
- package/packages/sourcevision/dist/analyzers/enrich-parsing.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/enrich-per-zone.d.ts +27 -0
- package/packages/sourcevision/dist/analyzers/enrich-per-zone.js +287 -0
- package/packages/sourcevision/dist/analyzers/enrich-per-zone.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/enrich.d.ts +25 -0
- package/packages/sourcevision/dist/analyzers/enrich.js +255 -0
- package/packages/sourcevision/dist/analyzers/enrich.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/imports.d.ts +18 -0
- package/packages/sourcevision/dist/analyzers/imports.js +448 -0
- package/packages/sourcevision/dist/analyzers/imports.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/index.d.ts +12 -0
- package/packages/sourcevision/dist/analyzers/index.js +10 -0
- package/packages/sourcevision/dist/analyzers/index.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/inventory.d.ts +33 -0
- package/packages/sourcevision/dist/analyzers/inventory.js +594 -0
- package/packages/sourcevision/dist/analyzers/inventory.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/llms-txt.d.ts +6 -0
- package/packages/sourcevision/dist/analyzers/llms-txt.js +268 -0
- package/packages/sourcevision/dist/analyzers/llms-txt.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/louvain.d.ts +123 -0
- package/packages/sourcevision/dist/analyzers/louvain.js +669 -0
- package/packages/sourcevision/dist/analyzers/louvain.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/manifest.d.ts +8 -0
- package/packages/sourcevision/dist/analyzers/manifest.js +72 -0
- package/packages/sourcevision/dist/analyzers/manifest.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/move-recommendations.d.ts +41 -0
- package/packages/sourcevision/dist/analyzers/move-recommendations.js +193 -0
- package/packages/sourcevision/dist/analyzers/move-recommendations.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/next-steps.d.ts +10 -0
- package/packages/sourcevision/dist/analyzers/next-steps.js +228 -0
- package/packages/sourcevision/dist/analyzers/next-steps.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/risk-scoring.d.ts +120 -0
- package/packages/sourcevision/dist/analyzers/risk-scoring.js +266 -0
- package/packages/sourcevision/dist/analyzers/risk-scoring.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/route-detection.d.ts +29 -0
- package/packages/sourcevision/dist/analyzers/route-detection.js +316 -0
- package/packages/sourcevision/dist/analyzers/route-detection.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/server-route-detection.d.ts +35 -0
- package/packages/sourcevision/dist/analyzers/server-route-detection.js +210 -0
- package/packages/sourcevision/dist/analyzers/server-route-detection.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/token-usage.d.ts +11 -0
- package/packages/sourcevision/dist/analyzers/token-usage.js +41 -0
- package/packages/sourcevision/dist/analyzers/token-usage.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/workspace-aggregate.d.ts +80 -0
- package/packages/sourcevision/dist/analyzers/workspace-aggregate.js +386 -0
- package/packages/sourcevision/dist/analyzers/workspace-aggregate.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/workspace-crossings.d.ts +63 -0
- package/packages/sourcevision/dist/analyzers/workspace-crossings.js +239 -0
- package/packages/sourcevision/dist/analyzers/workspace-crossings.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/workspace.d.ts +65 -0
- package/packages/sourcevision/dist/analyzers/workspace.js +243 -0
- package/packages/sourcevision/dist/analyzers/workspace.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/zone-hash.d.ts +15 -0
- package/packages/sourcevision/dist/analyzers/zone-hash.js +23 -0
- package/packages/sourcevision/dist/analyzers/zone-hash.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/zone-output.d.ts +20 -0
- package/packages/sourcevision/dist/analyzers/zone-output.js +252 -0
- package/packages/sourcevision/dist/analyzers/zone-output.js.map +1 -0
- package/packages/sourcevision/dist/analyzers/zones.d.ts +224 -0
- package/packages/sourcevision/dist/analyzers/zones.js +1538 -0
- package/packages/sourcevision/dist/analyzers/zones.js.map +1 -0
- package/packages/sourcevision/dist/cli/commands/analyze-phases.d.ts +48 -0
- package/packages/sourcevision/dist/cli/commands/analyze-phases.js +496 -0
- package/packages/sourcevision/dist/cli/commands/analyze-phases.js.map +1 -0
- package/packages/sourcevision/dist/cli/commands/analyze.d.ts +13 -0
- package/packages/sourcevision/dist/cli/commands/analyze.js +332 -0
- package/packages/sourcevision/dist/cli/commands/analyze.js.map +1 -0
- package/packages/sourcevision/dist/cli/commands/constants.d.ts +2 -0
- package/packages/sourcevision/dist/cli/commands/constants.js +34 -0
- package/packages/sourcevision/dist/cli/commands/constants.js.map +1 -0
- package/packages/sourcevision/dist/cli/commands/export-pdf.d.ts +19 -0
- package/packages/sourcevision/dist/cli/commands/export-pdf.js +73 -0
- package/packages/sourcevision/dist/cli/commands/export-pdf.js.map +1 -0
- package/packages/sourcevision/dist/cli/commands/git-credential-helper.d.ts +2 -0
- package/packages/sourcevision/dist/cli/commands/git-credential-helper.js +59 -0
- package/packages/sourcevision/dist/cli/commands/git-credential-helper.js.map +1 -0
- package/packages/sourcevision/dist/cli/commands/init.d.ts +2 -0
- package/packages/sourcevision/dist/cli/commands/init.js +55 -0
- package/packages/sourcevision/dist/cli/commands/init.js.map +1 -0
- package/packages/sourcevision/dist/cli/commands/pr-markdown.d.ts +72 -0
- package/packages/sourcevision/dist/cli/commands/pr-markdown.js +121 -0
- package/packages/sourcevision/dist/cli/commands/pr-markdown.js.map +1 -0
- package/packages/sourcevision/dist/cli/commands/prd-epic-resolver.d.ts +45 -0
- package/packages/sourcevision/dist/cli/commands/prd-epic-resolver.js +220 -0
- package/packages/sourcevision/dist/cli/commands/prd-epic-resolver.js.map +1 -0
- package/packages/sourcevision/dist/cli/commands/reset.d.ts +1 -0
- package/packages/sourcevision/dist/cli/commands/reset.js +54 -0
- package/packages/sourcevision/dist/cli/commands/reset.js.map +1 -0
- package/packages/sourcevision/dist/cli/commands/validate.d.ts +1 -0
- package/packages/sourcevision/dist/cli/commands/validate.js +53 -0
- package/packages/sourcevision/dist/cli/commands/validate.js.map +1 -0
- package/packages/sourcevision/dist/cli/commands/workspace.d.ts +19 -0
- package/packages/sourcevision/dist/cli/commands/workspace.js +139 -0
- package/packages/sourcevision/dist/cli/commands/workspace.js.map +1 -0
- package/packages/sourcevision/dist/cli/errors.d.ts +31 -0
- package/packages/sourcevision/dist/cli/errors.js +100 -0
- package/packages/sourcevision/dist/cli/errors.js.map +1 -0
- package/packages/sourcevision/dist/cli/help.d.ts +23 -0
- package/packages/sourcevision/dist/cli/help.js +241 -0
- package/packages/sourcevision/dist/cli/help.js.map +1 -0
- package/packages/sourcevision/dist/cli/index.d.ts +15 -0
- package/packages/sourcevision/dist/cli/index.js +127 -0
- package/packages/sourcevision/dist/cli/index.js.map +1 -0
- package/packages/sourcevision/dist/cli/mcp.d.ts +13 -0
- package/packages/sourcevision/dist/cli/mcp.js +433 -0
- package/packages/sourcevision/dist/cli/mcp.js.map +1 -0
- package/packages/sourcevision/dist/cli/output.d.ts +19 -0
- package/packages/sourcevision/dist/cli/output.js +48 -0
- package/packages/sourcevision/dist/cli/output.js.map +1 -0
- package/packages/sourcevision/dist/cli/serve.d.ts +11 -0
- package/packages/sourcevision/dist/cli/serve.js +41 -0
- package/packages/sourcevision/dist/cli/serve.js.map +1 -0
- package/packages/sourcevision/dist/cli/server/index.d.ts +19 -0
- package/packages/sourcevision/dist/cli/server/index.js +17 -0
- package/packages/sourcevision/dist/cli/server/index.js.map +1 -0
- package/packages/sourcevision/dist/cli/server/routes-data.d.ts +14 -0
- package/packages/sourcevision/dist/cli/server/routes-data.js +122 -0
- package/packages/sourcevision/dist/cli/server/routes-data.js.map +1 -0
- package/packages/sourcevision/dist/cli/server/routes-hench.d.ts +12 -0
- package/packages/sourcevision/dist/cli/server/routes-hench.js +100 -0
- package/packages/sourcevision/dist/cli/server/routes-hench.js.map +1 -0
- package/packages/sourcevision/dist/cli/server/routes-rex.d.ts +23 -0
- package/packages/sourcevision/dist/cli/server/routes-rex.js +817 -0
- package/packages/sourcevision/dist/cli/server/routes-rex.js.map +1 -0
- package/packages/sourcevision/dist/cli/server/routes-sourcevision.d.ts +17 -0
- package/packages/sourcevision/dist/cli/server/routes-sourcevision.js +145 -0
- package/packages/sourcevision/dist/cli/server/routes-sourcevision.js.map +1 -0
- package/packages/sourcevision/dist/cli/server/routes-static.d.ts +17 -0
- package/packages/sourcevision/dist/cli/server/routes-static.js +88 -0
- package/packages/sourcevision/dist/cli/server/routes-static.js.map +1 -0
- package/packages/sourcevision/dist/cli/server/routes-token-usage.d.ts +18 -0
- package/packages/sourcevision/dist/cli/server/routes-token-usage.js +349 -0
- package/packages/sourcevision/dist/cli/server/routes-token-usage.js.map +1 -0
- package/packages/sourcevision/dist/cli/server/routes-validation.d.ts +10 -0
- package/packages/sourcevision/dist/cli/server/routes-validation.js +395 -0
- package/packages/sourcevision/dist/cli/server/routes-validation.js.map +1 -0
- package/packages/sourcevision/dist/cli/server/start.d.ts +7 -0
- package/packages/sourcevision/dist/cli/server/start.js +166 -0
- package/packages/sourcevision/dist/cli/server/start.js.map +1 -0
- package/packages/sourcevision/dist/cli/server/types.d.ts +23 -0
- package/packages/sourcevision/dist/cli/server/types.js +26 -0
- package/packages/sourcevision/dist/cli/server/types.js.map +1 -0
- package/packages/sourcevision/dist/cli/server/websocket.d.ts +31 -0
- package/packages/sourcevision/dist/cli/server/websocket.js +247 -0
- package/packages/sourcevision/dist/cli/server/websocket.js.map +1 -0
- package/packages/sourcevision/dist/constants.d.ts +4 -0
- package/packages/sourcevision/dist/constants.js +6 -0
- package/packages/sourcevision/dist/constants.js.map +1 -0
- package/packages/sourcevision/dist/export/pdf-report.d.ts +27 -0
- package/packages/sourcevision/dist/export/pdf-report.js +447 -0
- package/packages/sourcevision/dist/export/pdf-report.js.map +1 -0
- package/packages/sourcevision/dist/generators/pr-markdown-template.d.ts +56 -0
- package/packages/sourcevision/dist/generators/pr-markdown-template.js +264 -0
- package/packages/sourcevision/dist/generators/pr-markdown-template.js.map +1 -0
- package/packages/sourcevision/dist/public.d.ts +41 -0
- package/packages/sourcevision/dist/public.js +43 -0
- package/packages/sourcevision/dist/public.js.map +1 -0
- package/packages/sourcevision/dist/schema/data-files.d.ts +11 -0
- package/packages/sourcevision/dist/schema/data-files.js +12 -0
- package/packages/sourcevision/dist/schema/data-files.js.map +1 -0
- package/packages/sourcevision/dist/schema/index.d.ts +3 -0
- package/packages/sourcevision/dist/schema/index.js +3 -0
- package/packages/sourcevision/dist/schema/index.js.map +1 -0
- package/packages/sourcevision/dist/schema/v1.d.ts +550 -0
- package/packages/sourcevision/dist/schema/v1.js +3 -0
- package/packages/sourcevision/dist/schema/v1.js.map +1 -0
- package/packages/sourcevision/dist/schema/validate.d.ts +1243 -0
- package/packages/sourcevision/dist/schema/validate.js +411 -0
- package/packages/sourcevision/dist/schema/validate.js.map +1 -0
- package/packages/sourcevision/dist/util/__tests__/merge.test.d.ts +1 -0
- package/packages/sourcevision/dist/util/__tests__/merge.test.js +122 -0
- package/packages/sourcevision/dist/util/__tests__/merge.test.js.map +1 -0
- package/packages/sourcevision/dist/util/__tests__/sort.test.d.ts +1 -0
- package/packages/sourcevision/dist/util/__tests__/sort.test.js +151 -0
- package/packages/sourcevision/dist/util/__tests__/sort.test.js.map +1 -0
- package/packages/sourcevision/dist/util/merge.d.ts +18 -0
- package/packages/sourcevision/dist/util/merge.js +152 -0
- package/packages/sourcevision/dist/util/merge.js.map +1 -0
- package/packages/sourcevision/dist/util/paths.d.ts +2 -0
- package/packages/sourcevision/dist/util/paths.js +5 -0
- package/packages/sourcevision/dist/util/paths.js.map +1 -0
- package/packages/sourcevision/dist/util/project-config.d.ts +29 -0
- package/packages/sourcevision/dist/util/project-config.js +49 -0
- package/packages/sourcevision/dist/util/project-config.js.map +1 -0
- package/packages/sourcevision/dist/util/sort.d.ts +31 -0
- package/packages/sourcevision/dist/util/sort.js +149 -0
- package/packages/sourcevision/dist/util/sort.js.map +1 -0
- package/packages/sourcevision/dist/viewer/Hench-F.png +0 -0
- package/packages/sourcevision/dist/viewer/Rex-F.png +0 -0
- package/packages/sourcevision/dist/viewer/SourceVision-F.png +0 -0
- package/packages/sourcevision/dist/viewer/SourceVision.png +0 -0
- package/packages/sourcevision/dist/viewer/components/collapsible-section.d.ts +12 -0
- package/packages/sourcevision/dist/viewer/components/collapsible-section.js +40 -0
- package/packages/sourcevision/dist/viewer/components/collapsible-section.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/constants.d.ts +6 -0
- package/packages/sourcevision/dist/viewer/components/constants.js +16 -0
- package/packages/sourcevision/dist/viewer/components/constants.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/data-display/collapsible-section.d.ts +12 -0
- package/packages/sourcevision/dist/viewer/components/data-display/collapsible-section.js +40 -0
- package/packages/sourcevision/dist/viewer/components/data-display/collapsible-section.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/data-display/findings-list.d.ts +13 -0
- package/packages/sourcevision/dist/viewer/components/data-display/findings-list.js +136 -0
- package/packages/sourcevision/dist/viewer/components/data-display/findings-list.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/data-display/health-gauge.d.ts +47 -0
- package/packages/sourcevision/dist/viewer/components/data-display/health-gauge.js +70 -0
- package/packages/sourcevision/dist/viewer/components/data-display/health-gauge.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/data-display/mini-charts.d.ts +36 -0
- package/packages/sourcevision/dist/viewer/components/data-display/mini-charts.js +124 -0
- package/packages/sourcevision/dist/viewer/components/data-display/mini-charts.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/data-display/tree-view.d.ts +18 -0
- package/packages/sourcevision/dist/viewer/components/data-display/tree-view.js +107 -0
- package/packages/sourcevision/dist/viewer/components/data-display/tree-view.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/data-display/zone-map.d.ts +28 -0
- package/packages/sourcevision/dist/viewer/components/data-display/zone-map.js +195 -0
- package/packages/sourcevision/dist/viewer/components/data-display/zone-map.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/detail-panel.d.ts +12 -0
- package/packages/sourcevision/dist/viewer/components/detail-panel.js +166 -0
- package/packages/sourcevision/dist/viewer/components/detail-panel.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/faq.d.ts +1 -0
- package/packages/sourcevision/dist/viewer/components/faq.js +162 -0
- package/packages/sourcevision/dist/viewer/components/faq.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/findings-list.d.ts +13 -0
- package/packages/sourcevision/dist/viewer/components/findings-list.js +136 -0
- package/packages/sourcevision/dist/viewer/components/findings-list.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/guide.d.ts +5 -0
- package/packages/sourcevision/dist/viewer/components/guide.js +77 -0
- package/packages/sourcevision/dist/viewer/components/guide.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/health-gauge.d.ts +47 -0
- package/packages/sourcevision/dist/viewer/components/health-gauge.js +70 -0
- package/packages/sourcevision/dist/viewer/components/health-gauge.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/logos.d.ts +103 -0
- package/packages/sourcevision/dist/viewer/components/logos.js +148 -0
- package/packages/sourcevision/dist/viewer/components/logos.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/mini-charts.d.ts +36 -0
- package/packages/sourcevision/dist/viewer/components/mini-charts.js +124 -0
- package/packages/sourcevision/dist/viewer/components/mini-charts.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/add-item-form.d.ts +31 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/add-item-form.js +209 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/add-item-form.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/analyze-panel.d.ts +13 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/analyze-panel.js +225 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/analyze-panel.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/bulk-actions.d.ts +17 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/bulk-actions.js +80 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/bulk-actions.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/compute.d.ts +28 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/compute.js +116 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/compute.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/index.d.ts +14 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/index.js +8 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/index.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/prd-tree.d.ts +21 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/prd-tree.js +293 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/prd-tree.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/status-filter.d.ts +40 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/status-filter.js +129 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/status-filter.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/task-detail.d.ts +18 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/task-detail.js +221 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/task-detail.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/types.d.ts +45 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/types.js +15 -0
- package/packages/sourcevision/dist/viewer/components/prd-tree/types.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/rex-task-link.d.ts +48 -0
- package/packages/sourcevision/dist/viewer/components/rex-task-link.js +191 -0
- package/packages/sourcevision/dist/viewer/components/rex-task-link.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/search-filter.d.ts +20 -0
- package/packages/sourcevision/dist/viewer/components/search-filter.js +28 -0
- package/packages/sourcevision/dist/viewer/components/search-filter.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/sidebar.d.ts +16 -0
- package/packages/sourcevision/dist/viewer/components/sidebar.js +296 -0
- package/packages/sourcevision/dist/viewer/components/sidebar.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/theme-toggle.d.ts +14 -0
- package/packages/sourcevision/dist/viewer/components/theme-toggle.js +37 -0
- package/packages/sourcevision/dist/viewer/components/theme-toggle.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/tree-view.d.ts +18 -0
- package/packages/sourcevision/dist/viewer/components/tree-view.js +107 -0
- package/packages/sourcevision/dist/viewer/components/tree-view.js.map +1 -0
- package/packages/sourcevision/dist/viewer/components/zone-map.d.ts +28 -0
- package/packages/sourcevision/dist/viewer/components/zone-map.js +195 -0
- package/packages/sourcevision/dist/viewer/components/zone-map.js.map +1 -0
- package/packages/sourcevision/dist/viewer/graph/physics.d.ts +70 -0
- package/packages/sourcevision/dist/viewer/graph/physics.js +260 -0
- package/packages/sourcevision/dist/viewer/graph/physics.js.map +1 -0
- package/packages/sourcevision/dist/viewer/graph/renderer.d.ts +69 -0
- package/packages/sourcevision/dist/viewer/graph/renderer.js +423 -0
- package/packages/sourcevision/dist/viewer/graph/renderer.js.map +1 -0
- package/packages/sourcevision/dist/viewer/index.html +27 -0
- package/packages/sourcevision/dist/viewer/loader.d.ts +20 -0
- package/packages/sourcevision/dist/viewer/loader.js +142 -0
- package/packages/sourcevision/dist/viewer/loader.js.map +1 -0
- package/packages/sourcevision/dist/viewer/main.d.ts +1 -0
- package/packages/sourcevision/dist/viewer/main.js +234 -0
- package/packages/sourcevision/dist/viewer/main.js.map +1 -0
- package/packages/sourcevision/dist/viewer/n-dx.png +0 -0
- package/packages/sourcevision/dist/viewer/schema-compat.d.ts +17 -0
- package/packages/sourcevision/dist/viewer/schema-compat.js +47 -0
- package/packages/sourcevision/dist/viewer/schema-compat.js.map +1 -0
- package/packages/sourcevision/dist/viewer/styles.css +2052 -0
- package/packages/sourcevision/dist/viewer/types.d.ts +63 -0
- package/packages/sourcevision/dist/viewer/types.js +2 -0
- package/packages/sourcevision/dist/viewer/types.js.map +1 -0
- package/packages/sourcevision/dist/viewer/utils.d.ts +23 -0
- package/packages/sourcevision/dist/viewer/utils.js +49 -0
- package/packages/sourcevision/dist/viewer/utils.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/analysis.d.ts +10 -0
- package/packages/sourcevision/dist/viewer/views/analysis.js +87 -0
- package/packages/sourcevision/dist/viewer/views/analysis.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/architecture.d.ts +10 -0
- package/packages/sourcevision/dist/viewer/views/architecture.js +75 -0
- package/packages/sourcevision/dist/viewer/views/architecture.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/files.d.ts +13 -0
- package/packages/sourcevision/dist/viewer/views/files.js +162 -0
- package/packages/sourcevision/dist/viewer/views/files.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/graph.d.ts +11 -0
- package/packages/sourcevision/dist/viewer/views/graph.js +130 -0
- package/packages/sourcevision/dist/viewer/views/graph.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/hench-runs.d.ts +17 -0
- package/packages/sourcevision/dist/viewer/views/hench-runs.js +336 -0
- package/packages/sourcevision/dist/viewer/views/hench-runs.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/overview.d.ts +10 -0
- package/packages/sourcevision/dist/viewer/views/overview.js +230 -0
- package/packages/sourcevision/dist/viewer/views/overview.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/prd.d.ts +21 -0
- package/packages/sourcevision/dist/viewer/views/prd.js +201 -0
- package/packages/sourcevision/dist/viewer/views/prd.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/problems.d.ts +8 -0
- package/packages/sourcevision/dist/viewer/views/problems.js +51 -0
- package/packages/sourcevision/dist/viewer/views/problems.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/rex-dashboard.d.ts +14 -0
- package/packages/sourcevision/dist/viewer/views/rex-dashboard.js +229 -0
- package/packages/sourcevision/dist/viewer/views/rex-dashboard.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/routes.d.ts +8 -0
- package/packages/sourcevision/dist/viewer/views/routes.js +218 -0
- package/packages/sourcevision/dist/viewer/views/routes.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/suggestions.d.ts +8 -0
- package/packages/sourcevision/dist/viewer/views/suggestions.js +36 -0
- package/packages/sourcevision/dist/viewer/views/suggestions.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/token-usage.d.ts +10 -0
- package/packages/sourcevision/dist/viewer/views/token-usage.js +384 -0
- package/packages/sourcevision/dist/viewer/views/token-usage.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/validation.d.ts +8 -0
- package/packages/sourcevision/dist/viewer/views/validation.js +470 -0
- package/packages/sourcevision/dist/viewer/views/validation.js.map +1 -0
- package/packages/sourcevision/dist/viewer/views/zones.d.ts +11 -0
- package/packages/sourcevision/dist/viewer/views/zones.js +146 -0
- package/packages/sourcevision/dist/viewer/views/zones.js.map +1 -0
- package/packages/sourcevision/package.json +43 -0
- package/packages/web/build.js +243 -0
- package/packages/web/dist/cli/index.d.ts +8 -0
- package/packages/web/dist/cli/index.js +50 -0
- package/packages/web/dist/cli/index.js.map +1 -0
- package/packages/web/dist/landing/color-inversion.d.ts +7 -0
- package/packages/web/dist/landing/color-inversion.js +24 -0
- package/packages/web/dist/landing/color-inversion.js.map +1 -0
- package/packages/web/dist/landing/index.html +325 -0
- package/packages/web/dist/landing/landing.d.ts +38 -0
- package/packages/web/dist/landing/landing.js +299 -0
- package/packages/web/dist/landing/landing.js.map +1 -0
- package/packages/web/dist/public.d.ts +55 -0
- package/packages/web/dist/public.js +51 -0
- package/packages/web/dist/public.js.map +1 -0
- package/packages/web/dist/schema/data-files.d.ts +10 -0
- package/packages/web/dist/schema/data-files.js +11 -0
- package/packages/web/dist/schema/data-files.js.map +1 -0
- package/packages/web/dist/schema/features.d.ts +28 -0
- package/packages/web/dist/schema/features.js +9 -0
- package/packages/web/dist/schema/features.js.map +1 -0
- package/packages/web/dist/schema/v1.d.ts +317 -0
- package/packages/web/dist/schema/v1.js +3 -0
- package/packages/web/dist/schema/v1.js.map +1 -0
- package/packages/web/dist/schema/validate.d.ts +15 -0
- package/packages/web/dist/schema/validate.js +260 -0
- package/packages/web/dist/schema/validate.js.map +1 -0
- package/packages/web/dist/server/aggregation-cache.d.ts +105 -0
- package/packages/web/dist/server/aggregation-cache.js +163 -0
- package/packages/web/dist/server/aggregation-cache.js.map +1 -0
- package/packages/web/dist/server/concurrent-execution-metrics.d.ts +103 -0
- package/packages/web/dist/server/concurrent-execution-metrics.js +253 -0
- package/packages/web/dist/server/concurrent-execution-metrics.js.map +1 -0
- package/packages/web/dist/server/domain-gateway.d.ts +18 -0
- package/packages/web/dist/server/domain-gateway.js +19 -0
- package/packages/web/dist/server/domain-gateway.js.map +1 -0
- package/packages/web/dist/server/incremental-task-usage.d.ts +92 -0
- package/packages/web/dist/server/incremental-task-usage.js +251 -0
- package/packages/web/dist/server/incremental-task-usage.js.map +1 -0
- package/packages/web/dist/server/index.d.ts +39 -0
- package/packages/web/dist/server/index.js +36 -0
- package/packages/web/dist/server/index.js.map +1 -0
- package/packages/web/dist/server/mcp-deps.d.ts +6 -0
- package/packages/web/dist/server/mcp-deps.js +7 -0
- package/packages/web/dist/server/mcp-deps.js.map +1 -0
- package/packages/web/dist/server/port.d.ts +96 -0
- package/packages/web/dist/server/port.js +134 -0
- package/packages/web/dist/server/port.js.map +1 -0
- package/packages/web/dist/server/pr-markdown-refresh-diagnostics.d.ts +59 -0
- package/packages/web/dist/server/pr-markdown-refresh-diagnostics.js +429 -0
- package/packages/web/dist/server/pr-markdown-refresh-diagnostics.js.map +1 -0
- package/packages/web/dist/server/prd-io.d.ts +40 -0
- package/packages/web/dist/server/prd-io.js +66 -0
- package/packages/web/dist/server/prd-io.js.map +1 -0
- package/packages/web/dist/server/process-memory-tracker.d.ts +79 -0
- package/packages/web/dist/server/process-memory-tracker.js +194 -0
- package/packages/web/dist/server/process-memory-tracker.js.map +1 -0
- package/packages/web/dist/server/register-scheduler.d.ts +53 -0
- package/packages/web/dist/server/register-scheduler.js +36 -0
- package/packages/web/dist/server/register-scheduler.js.map +1 -0
- package/packages/web/dist/server/rex-domain.d.ts +55 -0
- package/packages/web/dist/server/rex-domain.js +84 -0
- package/packages/web/dist/server/rex-domain.js.map +1 -0
- package/packages/web/dist/server/rex-gateway.d.ts +39 -0
- package/packages/web/dist/server/rex-gateway.js +47 -0
- package/packages/web/dist/server/rex-gateway.js.map +1 -0
- package/packages/web/dist/server/routes-adaptive.d.ts +21 -0
- package/packages/web/dist/server/routes-adaptive.js +659 -0
- package/packages/web/dist/server/routes-adaptive.js.map +1 -0
- package/packages/web/dist/server/routes-config.d.ts +47 -0
- package/packages/web/dist/server/routes-config.js +222 -0
- package/packages/web/dist/server/routes-config.js.map +1 -0
- package/packages/web/dist/server/routes-data.d.ts +14 -0
- package/packages/web/dist/server/routes-data.js +129 -0
- package/packages/web/dist/server/routes-data.js.map +1 -0
- package/packages/web/dist/server/routes-features.d.ts +14 -0
- package/packages/web/dist/server/routes-features.js +245 -0
- package/packages/web/dist/server/routes-features.js.map +1 -0
- package/packages/web/dist/server/routes-hench.d.ts +116 -0
- package/packages/web/dist/server/routes-hench.js +2016 -0
- package/packages/web/dist/server/routes-hench.js.map +1 -0
- package/packages/web/dist/server/routes-integrations.d.ts +23 -0
- package/packages/web/dist/server/routes-integrations.js +277 -0
- package/packages/web/dist/server/routes-integrations.js.map +1 -0
- package/packages/web/dist/server/routes-mcp.d.ts +31 -0
- package/packages/web/dist/server/routes-mcp.js +175 -0
- package/packages/web/dist/server/routes-mcp.js.map +1 -0
- package/packages/web/dist/server/routes-notion.d.ts +23 -0
- package/packages/web/dist/server/routes-notion.js +723 -0
- package/packages/web/dist/server/routes-notion.js.map +1 -0
- package/packages/web/dist/server/routes-project.d.ts +47 -0
- package/packages/web/dist/server/routes-project.js +128 -0
- package/packages/web/dist/server/routes-project.js.map +1 -0
- package/packages/web/dist/server/routes-rex/analysis.d.ts +11 -0
- package/packages/web/dist/server/routes-rex/analysis.js +583 -0
- package/packages/web/dist/server/routes-rex/analysis.js.map +1 -0
- package/packages/web/dist/server/routes-rex/execution.d.ts +37 -0
- package/packages/web/dist/server/routes-rex/execution.js +355 -0
- package/packages/web/dist/server/routes-rex/execution.js.map +1 -0
- package/packages/web/dist/server/routes-rex/health.d.ts +8 -0
- package/packages/web/dist/server/routes-rex/health.js +136 -0
- package/packages/web/dist/server/routes-rex/health.js.map +1 -0
- package/packages/web/dist/server/routes-rex/index.d.ts +35 -0
- package/packages/web/dist/server/routes-rex/index.js +72 -0
- package/packages/web/dist/server/routes-rex/index.js.map +1 -0
- package/packages/web/dist/server/routes-rex/items.d.ts +8 -0
- package/packages/web/dist/server/routes-rex/items.js +359 -0
- package/packages/web/dist/server/routes-rex/items.js.map +1 -0
- package/packages/web/dist/server/routes-rex/prune.d.ts +11 -0
- package/packages/web/dist/server/routes-rex/prune.js +379 -0
- package/packages/web/dist/server/routes-rex/prune.js.map +1 -0
- package/packages/web/dist/server/routes-rex/reads.d.ts +9 -0
- package/packages/web/dist/server/routes-rex/reads.js +119 -0
- package/packages/web/dist/server/routes-rex/reads.js.map +1 -0
- package/packages/web/dist/server/routes-rex/requirements.d.ts +10 -0
- package/packages/web/dist/server/routes-rex/requirements.js +408 -0
- package/packages/web/dist/server/routes-rex/requirements.js.map +1 -0
- package/packages/web/dist/server/routes-rex/shared.d.ts +37 -0
- package/packages/web/dist/server/routes-rex/shared.js +73 -0
- package/packages/web/dist/server/routes-rex/shared.js.map +1 -0
- package/packages/web/dist/server/routes-rex.d.ts +77 -0
- package/packages/web/dist/server/routes-rex.js +2403 -0
- package/packages/web/dist/server/routes-rex.js.map +1 -0
- package/packages/web/dist/server/routes-search.d.ts +26 -0
- package/packages/web/dist/server/routes-search.js +82 -0
- package/packages/web/dist/server/routes-search.js.map +1 -0
- package/packages/web/dist/server/routes-sourcevision.d.ts +18 -0
- package/packages/web/dist/server/routes-sourcevision.js +444 -0
- package/packages/web/dist/server/routes-sourcevision.js.map +1 -0
- package/packages/web/dist/server/routes-static.d.ts +20 -0
- package/packages/web/dist/server/routes-static.js +168 -0
- package/packages/web/dist/server/routes-static.js.map +1 -0
- package/packages/web/dist/server/routes-status.d.ts +58 -0
- package/packages/web/dist/server/routes-status.js +191 -0
- package/packages/web/dist/server/routes-status.js.map +1 -0
- package/packages/web/dist/server/routes-token-usage.d.ts +63 -0
- package/packages/web/dist/server/routes-token-usage.js +720 -0
- package/packages/web/dist/server/routes-token-usage.js.map +1 -0
- package/packages/web/dist/server/routes-validation.d.ts +10 -0
- package/packages/web/dist/server/routes-validation.js +365 -0
- package/packages/web/dist/server/routes-validation.js.map +1 -0
- package/packages/web/dist/server/routes-workflow.d.ts +15 -0
- package/packages/web/dist/server/routes-workflow.js +498 -0
- package/packages/web/dist/server/routes-workflow.js.map +1 -0
- package/packages/web/dist/server/search-index.d.ts +111 -0
- package/packages/web/dist/server/search-index.js +348 -0
- package/packages/web/dist/server/search-index.js.map +1 -0
- package/packages/web/dist/server/shared-types.d.ts +65 -0
- package/packages/web/dist/server/shared-types.js +31 -0
- package/packages/web/dist/server/shared-types.js.map +1 -0
- package/packages/web/dist/server/start.d.ts +68 -0
- package/packages/web/dist/server/start.js +568 -0
- package/packages/web/dist/server/start.js.map +1 -0
- package/packages/web/dist/server/task-usage.d.ts +17 -0
- package/packages/web/dist/server/task-usage.js +20 -0
- package/packages/web/dist/server/task-usage.js.map +1 -0
- package/packages/web/dist/server/types.d.ts +27 -0
- package/packages/web/dist/server/types.js +26 -0
- package/packages/web/dist/server/types.js.map +1 -0
- package/packages/web/dist/server/usage-cleanup-scheduler.d.ts +107 -0
- package/packages/web/dist/server/usage-cleanup-scheduler.js +232 -0
- package/packages/web/dist/server/usage-cleanup-scheduler.js.map +1 -0
- package/packages/web/dist/server/websocket.d.ts +131 -0
- package/packages/web/dist/server/websocket.js +512 -0
- package/packages/web/dist/server/websocket.js.map +1 -0
- package/packages/web/dist/server/ws-health-tracker.d.ts +86 -0
- package/packages/web/dist/server/ws-health-tracker.js +186 -0
- package/packages/web/dist/server/ws-health-tracker.js.map +1 -0
- package/packages/web/dist/shared/data-files.d.ts +17 -0
- package/packages/web/dist/shared/data-files.js +18 -0
- package/packages/web/dist/shared/data-files.js.map +1 -0
- package/packages/web/dist/shared/index.d.ts +9 -0
- package/packages/web/dist/shared/index.js +9 -0
- package/packages/web/dist/shared/index.js.map +1 -0
- package/packages/web/dist/shared/node-culler.d.ts +94 -0
- package/packages/web/dist/shared/node-culler.js +133 -0
- package/packages/web/dist/shared/node-culler.js.map +1 -0
- package/packages/web/dist/shared/request-dedup.d.ts +43 -0
- package/packages/web/dist/shared/request-dedup.js +55 -0
- package/packages/web/dist/shared/request-dedup.js.map +1 -0
- package/packages/web/dist/shared/view-id.d.ts +8 -0
- package/packages/web/dist/shared/view-id.js +9 -0
- package/packages/web/dist/shared/view-id.js.map +1 -0
- package/packages/web/dist/viewer/Hench-F.png +0 -0
- package/packages/web/dist/viewer/Rex-F.png +0 -0
- package/packages/web/dist/viewer/SourceVision-F.png +0 -0
- package/packages/web/dist/viewer/SourceVision.png +0 -0
- package/packages/web/dist/viewer/api.d.ts +19 -0
- package/packages/web/dist/viewer/api.js +17 -0
- package/packages/web/dist/viewer/api.js.map +1 -0
- package/packages/web/dist/viewer/batched-tick-dispatcher.d.ts +83 -0
- package/packages/web/dist/viewer/batched-tick-dispatcher.js +183 -0
- package/packages/web/dist/viewer/batched-tick-dispatcher.js.map +1 -0
- package/packages/web/dist/viewer/bootstrap.d.ts +13 -0
- package/packages/web/dist/viewer/bootstrap.js +40 -0
- package/packages/web/dist/viewer/bootstrap.js.map +1 -0
- package/packages/web/dist/viewer/call-rate-limiter.d.ts +50 -0
- package/packages/web/dist/viewer/call-rate-limiter.js +103 -0
- package/packages/web/dist/viewer/call-rate-limiter.js.map +1 -0
- package/packages/web/dist/viewer/components/active-tasks-panel.d.ts +36 -0
- package/packages/web/dist/viewer/components/active-tasks-panel.js +183 -0
- package/packages/web/dist/viewer/components/active-tasks-panel.js.map +1 -0
- package/packages/web/dist/viewer/components/breadcrumb.d.ts +21 -0
- package/packages/web/dist/viewer/components/breadcrumb.js +117 -0
- package/packages/web/dist/viewer/components/breadcrumb.js.map +1 -0
- package/packages/web/dist/viewer/components/concurrency-panel.d.ts +18 -0
- package/packages/web/dist/viewer/components/concurrency-panel.js +175 -0
- package/packages/web/dist/viewer/components/concurrency-panel.js.map +1 -0
- package/packages/web/dist/viewer/components/config-footer.d.ts +11 -0
- package/packages/web/dist/viewer/components/config-footer.js +132 -0
- package/packages/web/dist/viewer/components/config-footer.js.map +1 -0
- package/packages/web/dist/viewer/components/constants.d.ts +10 -0
- package/packages/web/dist/viewer/components/constants.js +11 -0
- package/packages/web/dist/viewer/components/constants.js.map +1 -0
- package/packages/web/dist/viewer/components/copy-link-button.d.ts +30 -0
- package/packages/web/dist/viewer/components/copy-link-button.js +74 -0
- package/packages/web/dist/viewer/components/copy-link-button.js.map +1 -0
- package/packages/web/dist/viewer/components/crash-recovery-banner.d.ts +28 -0
- package/packages/web/dist/viewer/components/crash-recovery-banner.js +47 -0
- package/packages/web/dist/viewer/components/crash-recovery-banner.js.map +1 -0
- package/packages/web/dist/viewer/components/data-display/collapsible-section.d.ts +14 -0
- package/packages/web/dist/viewer/components/data-display/collapsible-section.js +66 -0
- package/packages/web/dist/viewer/components/data-display/collapsible-section.js.map +1 -0
- package/packages/web/dist/viewer/components/data-display/findings-list.d.ts +13 -0
- package/packages/web/dist/viewer/components/data-display/findings-list.js +136 -0
- package/packages/web/dist/viewer/components/data-display/findings-list.js.map +1 -0
- package/packages/web/dist/viewer/components/data-display/health-gauge.d.ts +37 -0
- package/packages/web/dist/viewer/components/data-display/health-gauge.js +62 -0
- package/packages/web/dist/viewer/components/data-display/health-gauge.js.map +1 -0
- package/packages/web/dist/viewer/components/data-display/mini-charts.d.ts +36 -0
- package/packages/web/dist/viewer/components/data-display/mini-charts.js +124 -0
- package/packages/web/dist/viewer/components/data-display/mini-charts.js.map +1 -0
- package/packages/web/dist/viewer/components/data-display/tree-view.d.ts +18 -0
- package/packages/web/dist/viewer/components/data-display/tree-view.js +107 -0
- package/packages/web/dist/viewer/components/data-display/tree-view.js.map +1 -0
- package/packages/web/dist/viewer/components/data-display/zone-map.d.ts +28 -0
- package/packages/web/dist/viewer/components/data-display/zone-map.js +197 -0
- package/packages/web/dist/viewer/components/data-display/zone-map.js.map +1 -0
- package/packages/web/dist/viewer/components/degradation-banner.d.ts +28 -0
- package/packages/web/dist/viewer/components/degradation-banner.js +47 -0
- package/packages/web/dist/viewer/components/degradation-banner.js.map +1 -0
- package/packages/web/dist/viewer/components/detail-panel.d.ts +12 -0
- package/packages/web/dist/viewer/components/detail-panel.js +166 -0
- package/packages/web/dist/viewer/components/detail-panel.js.map +1 -0
- package/packages/web/dist/viewer/components/elapsed-time.d.ts +38 -0
- package/packages/web/dist/viewer/components/elapsed-time.js +35 -0
- package/packages/web/dist/viewer/components/elapsed-time.js.map +1 -0
- package/packages/web/dist/viewer/components/faq.d.ts +12 -0
- package/packages/web/dist/viewer/components/faq.js +237 -0
- package/packages/web/dist/viewer/components/faq.js.map +1 -0
- package/packages/web/dist/viewer/components/favicon.d.ts +30 -0
- package/packages/web/dist/viewer/components/favicon.js +90 -0
- package/packages/web/dist/viewer/components/favicon.js.map +1 -0
- package/packages/web/dist/viewer/components/guide.d.ts +5 -0
- package/packages/web/dist/viewer/components/guide.js +116 -0
- package/packages/web/dist/viewer/components/guide.js.map +1 -0
- package/packages/web/dist/viewer/components/index.d.ts +37 -0
- package/packages/web/dist/viewer/components/index.js +46 -0
- package/packages/web/dist/viewer/components/index.js.map +1 -0
- package/packages/web/dist/viewer/components/logos.d.ts +42 -0
- package/packages/web/dist/viewer/components/logos.js +46 -0
- package/packages/web/dist/viewer/components/logos.js.map +1 -0
- package/packages/web/dist/viewer/components/memory-panel.d.ts +19 -0
- package/packages/web/dist/viewer/components/memory-panel.js +181 -0
- package/packages/web/dist/viewer/components/memory-panel.js.map +1 -0
- package/packages/web/dist/viewer/components/memory-warning.d.ts +23 -0
- package/packages/web/dist/viewer/components/memory-warning.js +42 -0
- package/packages/web/dist/viewer/components/memory-warning.js.map +1 -0
- package/packages/web/dist/viewer/components/notion-schema-wizard.d.ts +16 -0
- package/packages/web/dist/viewer/components/notion-schema-wizard.js +263 -0
- package/packages/web/dist/viewer/components/notion-schema-wizard.js.map +1 -0
- package/packages/web/dist/viewer/components/polling-suspension-indicator.d.ts +24 -0
- package/packages/web/dist/viewer/components/polling-suspension-indicator.js +31 -0
- package/packages/web/dist/viewer/components/polling-suspension-indicator.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/add-item-form.d.ts +31 -0
- package/packages/web/dist/viewer/components/prd-tree/add-item-form.js +231 -0
- package/packages/web/dist/viewer/components/prd-tree/add-item-form.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/analyze-panel.d.ts +13 -0
- package/packages/web/dist/viewer/components/prd-tree/analyze-panel.js +245 -0
- package/packages/web/dist/viewer/components/prd-tree/analyze-panel.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/batch-import-panel.d.ts +34 -0
- package/packages/web/dist/viewer/components/prd-tree/batch-import-panel.js +415 -0
- package/packages/web/dist/viewer/components/prd-tree/batch-import-panel.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/bulk-actions.d.ts +19 -0
- package/packages/web/dist/viewer/components/prd-tree/bulk-actions.js +90 -0
- package/packages/web/dist/viewer/components/prd-tree/bulk-actions.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/compute.d.ts +32 -0
- package/packages/web/dist/viewer/components/prd-tree/compute.js +129 -0
- package/packages/web/dist/viewer/components/prd-tree/compute.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/delete-confirmation.d.ts +23 -0
- package/packages/web/dist/viewer/components/prd-tree/delete-confirmation.js +83 -0
- package/packages/web/dist/viewer/components/prd-tree/delete-confirmation.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/execution-panel.d.ts +14 -0
- package/packages/web/dist/viewer/components/prd-tree/execution-panel.js +291 -0
- package/packages/web/dist/viewer/components/prd-tree/execution-panel.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/facet-filter.d.ts +40 -0
- package/packages/web/dist/viewer/components/prd-tree/facet-filter.js +188 -0
- package/packages/web/dist/viewer/components/prd-tree/facet-filter.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/index.d.ts +24 -0
- package/packages/web/dist/viewer/components/prd-tree/index.js +16 -0
- package/packages/web/dist/viewer/components/prd-tree/index.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/inline-add-form.d.ts +32 -0
- package/packages/web/dist/viewer/components/prd-tree/inline-add-form.js +175 -0
- package/packages/web/dist/viewer/components/prd-tree/inline-add-form.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/inline-status-picker.d.ts +31 -0
- package/packages/web/dist/viewer/components/prd-tree/inline-status-picker.js +110 -0
- package/packages/web/dist/viewer/components/prd-tree/inline-status-picker.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/lazy-children.d.ts +40 -0
- package/packages/web/dist/viewer/components/prd-tree/lazy-children.js +73 -0
- package/packages/web/dist/viewer/components/prd-tree/lazy-children.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/levels.d.ts +31 -0
- package/packages/web/dist/viewer/components/prd-tree/levels.js +72 -0
- package/packages/web/dist/viewer/components/prd-tree/levels.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/listener-lifecycle.d.ts +105 -0
- package/packages/web/dist/viewer/components/prd-tree/listener-lifecycle.js +173 -0
- package/packages/web/dist/viewer/components/prd-tree/listener-lifecycle.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/merge-preview.d.ts +25 -0
- package/packages/web/dist/viewer/components/prd-tree/merge-preview.js +181 -0
- package/packages/web/dist/viewer/components/prd-tree/merge-preview.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/node-culler.d.ts +96 -0
- package/packages/web/dist/viewer/components/prd-tree/node-culler.js +135 -0
- package/packages/web/dist/viewer/components/prd-tree/node-culler.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/prd-tree.d.ts +91 -0
- package/packages/web/dist/viewer/components/prd-tree/prd-tree.js +565 -0
- package/packages/web/dist/viewer/components/prd-tree/prd-tree.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/progressive-loader.d.ts +114 -0
- package/packages/web/dist/viewer/components/prd-tree/progressive-loader.js +225 -0
- package/packages/web/dist/viewer/components/prd-tree/progressive-loader.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/proposal-editor.d.ts +44 -0
- package/packages/web/dist/viewer/components/prd-tree/proposal-editor.js +438 -0
- package/packages/web/dist/viewer/components/prd-tree/proposal-editor.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/prune-confirmation.d.ts +25 -0
- package/packages/web/dist/viewer/components/prd-tree/prune-confirmation.js +336 -0
- package/packages/web/dist/viewer/components/prd-tree/prune-confirmation.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/prune-diff-tree.d.ts +39 -0
- package/packages/web/dist/viewer/components/prd-tree/prune-diff-tree.js +319 -0
- package/packages/web/dist/viewer/components/prd-tree/prune-diff-tree.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/reorganize-panel.d.ts +16 -0
- package/packages/web/dist/viewer/components/prd-tree/reorganize-panel.js +213 -0
- package/packages/web/dist/viewer/components/prd-tree/reorganize-panel.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/shared-imports.d.ts +18 -0
- package/packages/web/dist/viewer/components/prd-tree/shared-imports.js +18 -0
- package/packages/web/dist/viewer/components/prd-tree/shared-imports.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/smart-add-input.d.ts +19 -0
- package/packages/web/dist/viewer/components/prd-tree/smart-add-input.js +383 -0
- package/packages/web/dist/viewer/components/prd-tree/smart-add-input.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/status-filter.d.ts +40 -0
- package/packages/web/dist/viewer/components/prd-tree/status-filter.js +131 -0
- package/packages/web/dist/viewer/components/prd-tree/status-filter.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/task-detail.d.ts +41 -0
- package/packages/web/dist/viewer/components/prd-tree/task-detail.js +1205 -0
- package/packages/web/dist/viewer/components/prd-tree/task-detail.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/task-utilization.d.ts +7 -0
- package/packages/web/dist/viewer/components/prd-tree/task-utilization.js +25 -0
- package/packages/web/dist/viewer/components/prd-tree/task-utilization.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-differ.d.ts +59 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-differ.js +200 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-differ.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-event-delegate.d.ts +70 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-event-delegate.js +176 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-event-delegate.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-search.d.ts +65 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-search.js +178 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-search.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-utils.d.ts +38 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-utils.js +107 -0
- package/packages/web/dist/viewer/components/prd-tree/tree-utils.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/types.d.ts +93 -0
- package/packages/web/dist/viewer/components/prd-tree/types.js +16 -0
- package/packages/web/dist/viewer/components/prd-tree/types.js.map +1 -0
- package/packages/web/dist/viewer/components/prd-tree/virtual-scroll.d.ts +119 -0
- package/packages/web/dist/viewer/components/prd-tree/virtual-scroll.js +169 -0
- package/packages/web/dist/viewer/components/prd-tree/virtual-scroll.js.map +1 -0
- package/packages/web/dist/viewer/components/progressive-loader.d.ts +114 -0
- package/packages/web/dist/viewer/components/progressive-loader.js +225 -0
- package/packages/web/dist/viewer/components/progressive-loader.js.map +1 -0
- package/packages/web/dist/viewer/components/refresh-queue-status.d.ts +20 -0
- package/packages/web/dist/viewer/components/refresh-queue-status.js +65 -0
- package/packages/web/dist/viewer/components/refresh-queue-status.js.map +1 -0
- package/packages/web/dist/viewer/components/rex-task-link.d.ts +50 -0
- package/packages/web/dist/viewer/components/rex-task-link.js +218 -0
- package/packages/web/dist/viewer/components/rex-task-link.js.map +1 -0
- package/packages/web/dist/viewer/components/search-filter.d.ts +20 -0
- package/packages/web/dist/viewer/components/search-filter.js +28 -0
- package/packages/web/dist/viewer/components/search-filter.js.map +1 -0
- package/packages/web/dist/viewer/components/search-overlay.d.ts +31 -0
- package/packages/web/dist/viewer/components/search-overlay.js +472 -0
- package/packages/web/dist/viewer/components/search-overlay.js.map +1 -0
- package/packages/web/dist/viewer/components/sidebar.d.ts +18 -0
- package/packages/web/dist/viewer/components/sidebar.js +357 -0
- package/packages/web/dist/viewer/components/sidebar.js.map +1 -0
- package/packages/web/dist/viewer/components/status-indicators.d.ts +63 -0
- package/packages/web/dist/viewer/components/status-indicators.js +136 -0
- package/packages/web/dist/viewer/components/status-indicators.js.map +1 -0
- package/packages/web/dist/viewer/components/theme-toggle.d.ts +8 -0
- package/packages/web/dist/viewer/components/theme-toggle.js +28 -0
- package/packages/web/dist/viewer/components/theme-toggle.js.map +1 -0
- package/packages/web/dist/viewer/components/throttle-controls.d.ts +18 -0
- package/packages/web/dist/viewer/components/throttle-controls.js +304 -0
- package/packages/web/dist/viewer/components/throttle-controls.js.map +1 -0
- package/packages/web/dist/viewer/components/ws-health-panel.d.ts +18 -0
- package/packages/web/dist/viewer/components/ws-health-panel.js +250 -0
- package/packages/web/dist/viewer/components/ws-health-panel.js.map +1 -0
- package/packages/web/dist/viewer/components/zone-slideout.d.ts +17 -0
- package/packages/web/dist/viewer/components/zone-slideout.js +162 -0
- package/packages/web/dist/viewer/components/zone-slideout.js.map +1 -0
- package/packages/web/dist/viewer/crash/crash-detector.d.ts +69 -0
- package/packages/web/dist/viewer/crash/crash-detector.js +239 -0
- package/packages/web/dist/viewer/crash/crash-detector.js.map +1 -0
- package/packages/web/dist/viewer/crash/index.d.ts +7 -0
- package/packages/web/dist/viewer/crash/index.js +8 -0
- package/packages/web/dist/viewer/crash/index.js.map +1 -0
- package/packages/web/dist/viewer/crash-detector.d.ts +105 -0
- package/packages/web/dist/viewer/crash-detector.js +257 -0
- package/packages/web/dist/viewer/crash-detector.js.map +1 -0
- package/packages/web/dist/viewer/deployed-mode.d.ts +37 -0
- package/packages/web/dist/viewer/deployed-mode.js +94 -0
- package/packages/web/dist/viewer/deployed-mode.js.map +1 -0
- package/packages/web/dist/viewer/dom-performance-monitor.d.ts +158 -0
- package/packages/web/dist/viewer/dom-performance-monitor.js +342 -0
- package/packages/web/dist/viewer/dom-performance-monitor.js.map +1 -0
- package/packages/web/dist/viewer/dom-update-gate.d.ts +122 -0
- package/packages/web/dist/viewer/dom-update-gate.js +229 -0
- package/packages/web/dist/viewer/dom-update-gate.js.map +1 -0
- package/packages/web/dist/viewer/external.d.ts +17 -0
- package/packages/web/dist/viewer/external.js +17 -0
- package/packages/web/dist/viewer/external.js.map +1 -0
- package/packages/web/dist/viewer/graceful-degradation.d.ts +73 -0
- package/packages/web/dist/viewer/graceful-degradation.js +152 -0
- package/packages/web/dist/viewer/graceful-degradation.js.map +1 -0
- package/packages/web/dist/viewer/graph/index.d.ts +9 -0
- package/packages/web/dist/viewer/graph/index.js +12 -0
- package/packages/web/dist/viewer/graph/index.js.map +1 -0
- package/packages/web/dist/viewer/graph/physics.d.ts +96 -0
- package/packages/web/dist/viewer/graph/physics.js +366 -0
- package/packages/web/dist/viewer/graph/physics.js.map +1 -0
- package/packages/web/dist/viewer/graph/renderer.d.ts +184 -0
- package/packages/web/dist/viewer/graph/renderer.js +1438 -0
- package/packages/web/dist/viewer/graph/renderer.js.map +1 -0
- package/packages/web/dist/viewer/hooks/index.d.ts +27 -0
- package/packages/web/dist/viewer/hooks/index.js +28 -0
- package/packages/web/dist/viewer/hooks/index.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-app-data.d.ts +31 -0
- package/packages/web/dist/viewer/hooks/use-app-data.js +152 -0
- package/packages/web/dist/viewer/hooks/use-app-data.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-crash-recovery.d.ts +50 -0
- package/packages/web/dist/viewer/hooks/use-crash-recovery.js +76 -0
- package/packages/web/dist/viewer/hooks/use-crash-recovery.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-delete-actions.d.ts +48 -0
- package/packages/web/dist/viewer/hooks/use-delete-actions.js +103 -0
- package/packages/web/dist/viewer/hooks/use-delete-actions.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-dom-performance-monitor.d.ts +68 -0
- package/packages/web/dist/viewer/hooks/use-dom-performance-monitor.js +71 -0
- package/packages/web/dist/viewer/hooks/use-dom-performance-monitor.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-facet-state.d.ts +32 -0
- package/packages/web/dist/viewer/hooks/use-facet-state.js +119 -0
- package/packages/web/dist/viewer/hooks/use-facet-state.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-feature-toggle.d.ts +18 -0
- package/packages/web/dist/viewer/hooks/use-feature-toggle.js +57 -0
- package/packages/web/dist/viewer/hooks/use-feature-toggle.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-file-edges.d.ts +23 -0
- package/packages/web/dist/viewer/hooks/use-file-edges.js +221 -0
- package/packages/web/dist/viewer/hooks/use-file-edges.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-graceful-degradation.d.ts +30 -0
- package/packages/web/dist/viewer/hooks/use-graceful-degradation.js +45 -0
- package/packages/web/dist/viewer/hooks/use-graceful-degradation.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-item-selection.d.ts +49 -0
- package/packages/web/dist/viewer/hooks/use-item-selection.js +117 -0
- package/packages/web/dist/viewer/hooks/use-item-selection.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-memory-monitor.d.ts +39 -0
- package/packages/web/dist/viewer/hooks/use-memory-monitor.js +73 -0
- package/packages/web/dist/viewer/hooks/use-memory-monitor.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-pan-zoom.d.ts +33 -0
- package/packages/web/dist/viewer/hooks/use-pan-zoom.js +110 -0
- package/packages/web/dist/viewer/hooks/use-pan-zoom.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-persistent-filter.d.ts +24 -0
- package/packages/web/dist/viewer/hooks/use-persistent-filter.js +37 -0
- package/packages/web/dist/viewer/hooks/use-persistent-filter.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-polling-suspension.d.ts +32 -0
- package/packages/web/dist/viewer/hooks/use-polling-suspension.js +41 -0
- package/packages/web/dist/viewer/hooks/use-polling-suspension.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-polling.d.ts +39 -0
- package/packages/web/dist/viewer/hooks/use-polling.js +55 -0
- package/packages/web/dist/viewer/hooks/use-polling.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-prd-actions.d.ts +126 -0
- package/packages/web/dist/viewer/hooks/use-prd-actions.js +250 -0
- package/packages/web/dist/viewer/hooks/use-prd-actions.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-prd-data.d.ts +45 -0
- package/packages/web/dist/viewer/hooks/use-prd-data.js +159 -0
- package/packages/web/dist/viewer/hooks/use-prd-data.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-prd-deep-link.d.ts +45 -0
- package/packages/web/dist/viewer/hooks/use-prd-deep-link.js +60 -0
- package/packages/web/dist/viewer/hooks/use-prd-deep-link.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-prd-websocket.d.ts +47 -0
- package/packages/web/dist/viewer/hooks/use-prd-websocket.js +139 -0
- package/packages/web/dist/viewer/hooks/use-prd-websocket.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-project-metadata.d.ts +25 -0
- package/packages/web/dist/viewer/hooks/use-project-metadata.js +55 -0
- package/packages/web/dist/viewer/hooks/use-project-metadata.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-project-status.d.ts +60 -0
- package/packages/web/dist/viewer/hooks/use-project-status.js +133 -0
- package/packages/web/dist/viewer/hooks/use-project-status.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-refresh-throttle.d.ts +45 -0
- package/packages/web/dist/viewer/hooks/use-refresh-throttle.js +52 -0
- package/packages/web/dist/viewer/hooks/use-refresh-throttle.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-route-state.d.ts +18 -0
- package/packages/web/dist/viewer/hooks/use-route-state.js +115 -0
- package/packages/web/dist/viewer/hooks/use-route-state.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-subzone-edges.d.ts +21 -0
- package/packages/web/dist/viewer/hooks/use-subzone-edges.js +147 -0
- package/packages/web/dist/viewer/hooks/use-subzone-edges.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-tab-visibility.d.ts +31 -0
- package/packages/web/dist/viewer/hooks/use-tab-visibility.js +43 -0
- package/packages/web/dist/viewer/hooks/use-tab-visibility.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-tick.d.ts +43 -0
- package/packages/web/dist/viewer/hooks/use-tick.js +76 -0
- package/packages/web/dist/viewer/hooks/use-tick.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-toast.d.ts +24 -0
- package/packages/web/dist/viewer/hooks/use-toast.js +26 -0
- package/packages/web/dist/viewer/hooks/use-toast.js.map +1 -0
- package/packages/web/dist/viewer/hooks/use-zone-drag.d.ts +30 -0
- package/packages/web/dist/viewer/hooks/use-zone-drag.js +60 -0
- package/packages/web/dist/viewer/hooks/use-zone-drag.js.map +1 -0
- package/packages/web/dist/viewer/index.html +36 -0
- package/packages/web/dist/viewer/loader.d.ts +33 -0
- package/packages/web/dist/viewer/loader.js +195 -0
- package/packages/web/dist/viewer/loader.js.map +1 -0
- package/packages/web/dist/viewer/main.d.ts +1 -0
- package/packages/web/dist/viewer/main.js +121 -0
- package/packages/web/dist/viewer/main.js.map +1 -0
- package/packages/web/dist/viewer/memory-monitor.d.ts +78 -0
- package/packages/web/dist/viewer/memory-monitor.js +218 -0
- package/packages/web/dist/viewer/memory-monitor.js.map +1 -0
- package/packages/web/dist/viewer/message-coalescer.d.ts +96 -0
- package/packages/web/dist/viewer/message-coalescer.js +121 -0
- package/packages/web/dist/viewer/message-coalescer.js.map +1 -0
- package/packages/web/dist/viewer/message-throttle.d.ts +95 -0
- package/packages/web/dist/viewer/message-throttle.js +147 -0
- package/packages/web/dist/viewer/message-throttle.js.map +1 -0
- package/packages/web/dist/viewer/messaging/call-rate-limiter.d.ts +50 -0
- package/packages/web/dist/viewer/messaging/call-rate-limiter.js +103 -0
- package/packages/web/dist/viewer/messaging/call-rate-limiter.js.map +1 -0
- package/packages/web/dist/viewer/messaging/fetch-pipeline.d.ts +58 -0
- package/packages/web/dist/viewer/messaging/fetch-pipeline.js +58 -0
- package/packages/web/dist/viewer/messaging/fetch-pipeline.js.map +1 -0
- package/packages/web/dist/viewer/messaging/index.d.ts +43 -0
- package/packages/web/dist/viewer/messaging/index.js +46 -0
- package/packages/web/dist/viewer/messaging/index.js.map +1 -0
- package/packages/web/dist/viewer/messaging/message-coalescer.d.ts +96 -0
- package/packages/web/dist/viewer/messaging/message-coalescer.js +121 -0
- package/packages/web/dist/viewer/messaging/message-coalescer.js.map +1 -0
- package/packages/web/dist/viewer/messaging/message-throttle.d.ts +95 -0
- package/packages/web/dist/viewer/messaging/message-throttle.js +147 -0
- package/packages/web/dist/viewer/messaging/message-throttle.js.map +1 -0
- package/packages/web/dist/viewer/messaging/request-dedup.d.ts +43 -0
- package/packages/web/dist/viewer/messaging/request-dedup.js +55 -0
- package/packages/web/dist/viewer/messaging/request-dedup.js.map +1 -0
- package/packages/web/dist/viewer/messaging/ws-pipeline.d.ts +85 -0
- package/packages/web/dist/viewer/messaging/ws-pipeline.js +68 -0
- package/packages/web/dist/viewer/messaging/ws-pipeline.js.map +1 -0
- package/packages/web/dist/viewer/n-dx.png +0 -0
- package/packages/web/dist/viewer/performance/crash-detector-test-support.d.ts +15 -0
- package/packages/web/dist/viewer/performance/crash-detector-test-support.js +19 -0
- package/packages/web/dist/viewer/performance/crash-detector-test-support.js.map +1 -0
- package/packages/web/dist/viewer/performance/crash-detector.d.ts +105 -0
- package/packages/web/dist/viewer/performance/crash-detector.js +257 -0
- package/packages/web/dist/viewer/performance/crash-detector.js.map +1 -0
- package/packages/web/dist/viewer/performance/dom-performance-monitor.d.ts +157 -0
- package/packages/web/dist/viewer/performance/dom-performance-monitor.js +341 -0
- package/packages/web/dist/viewer/performance/dom-performance-monitor.js.map +1 -0
- package/packages/web/dist/viewer/performance/dom-update-gate.d.ts +122 -0
- package/packages/web/dist/viewer/performance/dom-update-gate.js +229 -0
- package/packages/web/dist/viewer/performance/dom-update-gate.js.map +1 -0
- package/packages/web/dist/viewer/performance/graceful-degradation.d.ts +73 -0
- package/packages/web/dist/viewer/performance/graceful-degradation.js +152 -0
- package/packages/web/dist/viewer/performance/graceful-degradation.js.map +1 -0
- package/packages/web/dist/viewer/performance/index.d.ts +14 -0
- package/packages/web/dist/viewer/performance/index.js +20 -0
- package/packages/web/dist/viewer/performance/index.js.map +1 -0
- package/packages/web/dist/viewer/performance/memory-monitor.d.ts +78 -0
- package/packages/web/dist/viewer/performance/memory-monitor.js +218 -0
- package/packages/web/dist/viewer/performance/memory-monitor.js.map +1 -0
- package/packages/web/dist/viewer/performance/refresh-throttle.d.ts +90 -0
- package/packages/web/dist/viewer/performance/refresh-throttle.js +266 -0
- package/packages/web/dist/viewer/performance/refresh-throttle.js.map +1 -0
- package/packages/web/dist/viewer/performance/response-buffer-gate.d.ts +108 -0
- package/packages/web/dist/viewer/performance/response-buffer-gate.js +170 -0
- package/packages/web/dist/viewer/performance/response-buffer-gate.js.map +1 -0
- package/packages/web/dist/viewer/performance/update-batcher.d.ts +79 -0
- package/packages/web/dist/viewer/performance/update-batcher.js +119 -0
- package/packages/web/dist/viewer/performance/update-batcher.js.map +1 -0
- package/packages/web/dist/viewer/polling/batched-tick-dispatcher.d.ts +83 -0
- package/packages/web/dist/viewer/polling/batched-tick-dispatcher.js +183 -0
- package/packages/web/dist/viewer/polling/batched-tick-dispatcher.js.map +1 -0
- package/packages/web/dist/viewer/polling/index.d.ts +13 -0
- package/packages/web/dist/viewer/polling/index.js +16 -0
- package/packages/web/dist/viewer/polling/index.js.map +1 -0
- package/packages/web/dist/viewer/polling/polling-manager.d.ts +82 -0
- package/packages/web/dist/viewer/polling/polling-manager.js +254 -0
- package/packages/web/dist/viewer/polling/polling-manager.js.map +1 -0
- package/packages/web/dist/viewer/polling/polling-restart.d.ts +45 -0
- package/packages/web/dist/viewer/polling/polling-restart.js +98 -0
- package/packages/web/dist/viewer/polling/polling-restart.js.map +1 -0
- package/packages/web/dist/viewer/polling/polling-state.d.ts +182 -0
- package/packages/web/dist/viewer/polling/polling-state.js +306 -0
- package/packages/web/dist/viewer/polling/polling-state.js.map +1 -0
- package/packages/web/dist/viewer/polling/tab-visibility.d.ts +112 -0
- package/packages/web/dist/viewer/polling/tab-visibility.js +276 -0
- package/packages/web/dist/viewer/polling/tab-visibility.js.map +1 -0
- package/packages/web/dist/viewer/polling/tick-timer.d.ts +70 -0
- package/packages/web/dist/viewer/polling/tick-timer.js +168 -0
- package/packages/web/dist/viewer/polling/tick-timer.js.map +1 -0
- package/packages/web/dist/viewer/polling/tick-visibility-gate.d.ts +92 -0
- package/packages/web/dist/viewer/polling/tick-visibility-gate.js +146 -0
- package/packages/web/dist/viewer/polling/tick-visibility-gate.js.map +1 -0
- package/packages/web/dist/viewer/polling-manager.d.ts +82 -0
- package/packages/web/dist/viewer/polling-manager.js +254 -0
- package/packages/web/dist/viewer/polling-manager.js.map +1 -0
- package/packages/web/dist/viewer/polling-restart.d.ts +57 -0
- package/packages/web/dist/viewer/polling-restart.js +118 -0
- package/packages/web/dist/viewer/polling-restart.js.map +1 -0
- package/packages/web/dist/viewer/polling-state.d.ts +182 -0
- package/packages/web/dist/viewer/polling-state.js +306 -0
- package/packages/web/dist/viewer/polling-state.js.map +1 -0
- package/packages/web/dist/viewer/refresh-throttle.d.ts +90 -0
- package/packages/web/dist/viewer/refresh-throttle.js +266 -0
- package/packages/web/dist/viewer/refresh-throttle.js.map +1 -0
- package/packages/web/dist/viewer/request-dedup.d.ts +43 -0
- package/packages/web/dist/viewer/request-dedup.js +55 -0
- package/packages/web/dist/viewer/request-dedup.js.map +1 -0
- package/packages/web/dist/viewer/response-buffer-gate.d.ts +108 -0
- package/packages/web/dist/viewer/response-buffer-gate.js +170 -0
- package/packages/web/dist/viewer/response-buffer-gate.js.map +1 -0
- package/packages/web/dist/viewer/route-state.d.ts +8 -0
- package/packages/web/dist/viewer/route-state.js +77 -0
- package/packages/web/dist/viewer/route-state.js.map +1 -0
- package/packages/web/dist/viewer/schema-compat.d.ts +17 -0
- package/packages/web/dist/viewer/schema-compat.js +49 -0
- package/packages/web/dist/viewer/schema-compat.js.map +1 -0
- package/packages/web/dist/viewer/sourcevision-tabs.d.ts +10 -0
- package/packages/web/dist/viewer/sourcevision-tabs.js +14 -0
- package/packages/web/dist/viewer/sourcevision-tabs.js.map +1 -0
- package/packages/web/dist/viewer/tab-visibility.d.ts +112 -0
- package/packages/web/dist/viewer/tab-visibility.js +276 -0
- package/packages/web/dist/viewer/tab-visibility.js.map +1 -0
- package/packages/web/dist/viewer/tick-timer.d.ts +70 -0
- package/packages/web/dist/viewer/tick-timer.js +168 -0
- package/packages/web/dist/viewer/tick-timer.js.map +1 -0
- package/packages/web/dist/viewer/tick-visibility-gate.d.ts +92 -0
- package/packages/web/dist/viewer/tick-visibility-gate.js +146 -0
- package/packages/web/dist/viewer/tick-visibility-gate.js.map +1 -0
- package/packages/web/dist/viewer/types.d.ts +66 -0
- package/packages/web/dist/viewer/types.js +2 -0
- package/packages/web/dist/viewer/types.js.map +1 -0
- package/packages/web/dist/viewer/update-batcher.d.ts +79 -0
- package/packages/web/dist/viewer/update-batcher.js +119 -0
- package/packages/web/dist/viewer/update-batcher.js.map +1 -0
- package/packages/web/dist/viewer/usage/constants.d.ts +14 -0
- package/packages/web/dist/viewer/usage/constants.js +14 -0
- package/packages/web/dist/viewer/usage/constants.js.map +1 -0
- package/packages/web/dist/viewer/usage/index.d.ts +7 -0
- package/packages/web/dist/viewer/usage/index.js +8 -0
- package/packages/web/dist/viewer/usage/index.js.map +1 -0
- package/packages/web/dist/viewer/utils.d.ts +25 -0
- package/packages/web/dist/viewer/utils.js +48 -0
- package/packages/web/dist/viewer/utils.js.map +1 -0
- package/packages/web/dist/viewer/validate.d.ts +23 -0
- package/packages/web/dist/viewer/validate.js +275 -0
- package/packages/web/dist/viewer/validate.js.map +1 -0
- package/packages/web/dist/viewer/views/analysis.d.ts +10 -0
- package/packages/web/dist/viewer/views/analysis.js +109 -0
- package/packages/web/dist/viewer/views/analysis.js.map +1 -0
- package/packages/web/dist/viewer/views/architecture.d.ts +10 -0
- package/packages/web/dist/viewer/views/architecture.js +44 -0
- package/packages/web/dist/viewer/views/architecture.js.map +1 -0
- package/packages/web/dist/viewer/views/call-graph.d.ts +20 -0
- package/packages/web/dist/viewer/views/call-graph.js +1266 -0
- package/packages/web/dist/viewer/views/call-graph.js.map +1 -0
- package/packages/web/dist/viewer/views/domain-hench.d.ts +13 -0
- package/packages/web/dist/viewer/views/domain-hench.js +14 -0
- package/packages/web/dist/viewer/views/domain-hench.js.map +1 -0
- package/packages/web/dist/viewer/views/domain-rex.d.ts +17 -0
- package/packages/web/dist/viewer/views/domain-rex.js +18 -0
- package/packages/web/dist/viewer/views/domain-rex.js.map +1 -0
- package/packages/web/dist/viewer/views/domain-settings.d.ts +12 -0
- package/packages/web/dist/viewer/views/domain-settings.js +13 -0
- package/packages/web/dist/viewer/views/domain-settings.js.map +1 -0
- package/packages/web/dist/viewer/views/domain-sourcevision.d.ts +20 -0
- package/packages/web/dist/viewer/views/domain-sourcevision.js +21 -0
- package/packages/web/dist/viewer/views/domain-sourcevision.js.map +1 -0
- package/packages/web/dist/viewer/views/enrichment-thresholds.d.ts +11 -0
- package/packages/web/dist/viewer/views/enrichment-thresholds.js +12 -0
- package/packages/web/dist/viewer/views/enrichment-thresholds.js.map +1 -0
- package/packages/web/dist/viewer/views/feature-toggles.d.ts +13 -0
- package/packages/web/dist/viewer/views/feature-toggles.js +185 -0
- package/packages/web/dist/viewer/views/feature-toggles.js.map +1 -0
- package/packages/web/dist/viewer/views/files.d.ts +13 -0
- package/packages/web/dist/viewer/views/files.js +174 -0
- package/packages/web/dist/viewer/views/files.js.map +1 -0
- package/packages/web/dist/viewer/views/graph.d.ts +12 -0
- package/packages/web/dist/viewer/views/graph.js +316 -0
- package/packages/web/dist/viewer/views/graph.js.map +1 -0
- package/packages/web/dist/viewer/views/hench-config.d.ts +39 -0
- package/packages/web/dist/viewer/views/hench-config.js +473 -0
- package/packages/web/dist/viewer/views/hench-config.js.map +1 -0
- package/packages/web/dist/viewer/views/hench-runs.d.ts +19 -0
- package/packages/web/dist/viewer/views/hench-runs.js +460 -0
- package/packages/web/dist/viewer/views/hench-runs.js.map +1 -0
- package/packages/web/dist/viewer/views/hench-templates.d.ts +17 -0
- package/packages/web/dist/viewer/views/hench-templates.js +262 -0
- package/packages/web/dist/viewer/views/hench-templates.js.map +1 -0
- package/packages/web/dist/viewer/views/integration-config.d.ts +73 -0
- package/packages/web/dist/viewer/views/integration-config.js +524 -0
- package/packages/web/dist/viewer/views/integration-config.js.map +1 -0
- package/packages/web/dist/viewer/views/notion-config.d.ts +16 -0
- package/packages/web/dist/viewer/views/notion-config.js +357 -0
- package/packages/web/dist/viewer/views/notion-config.js.map +1 -0
- package/packages/web/dist/viewer/views/overview.d.ts +10 -0
- package/packages/web/dist/viewer/views/overview.js +187 -0
- package/packages/web/dist/viewer/views/overview.js.map +1 -0
- package/packages/web/dist/viewer/views/pr-markdown.d.ts +3 -0
- package/packages/web/dist/viewer/views/pr-markdown.js +350 -0
- package/packages/web/dist/viewer/views/pr-markdown.js.map +1 -0
- package/packages/web/dist/viewer/views/prd.d.ts +34 -0
- package/packages/web/dist/viewer/views/prd.js +257 -0
- package/packages/web/dist/viewer/views/prd.js.map +1 -0
- package/packages/web/dist/viewer/views/problems.d.ts +8 -0
- package/packages/web/dist/viewer/views/problems.js +50 -0
- package/packages/web/dist/viewer/views/problems.js.map +1 -0
- package/packages/web/dist/viewer/views/rex-dashboard.d.ts +14 -0
- package/packages/web/dist/viewer/views/rex-dashboard.js +334 -0
- package/packages/web/dist/viewer/views/rex-dashboard.js.map +1 -0
- package/packages/web/dist/viewer/views/routes.d.ts +8 -0
- package/packages/web/dist/viewer/views/routes.js +216 -0
- package/packages/web/dist/viewer/views/routes.js.map +1 -0
- package/packages/web/dist/viewer/views/sourcevision-tabs.d.ts +18 -0
- package/packages/web/dist/viewer/views/sourcevision-tabs.js +14 -0
- package/packages/web/dist/viewer/views/sourcevision-tabs.js.map +1 -0
- package/packages/web/dist/viewer/views/suggestions.d.ts +8 -0
- package/packages/web/dist/viewer/views/suggestions.js +36 -0
- package/packages/web/dist/viewer/views/suggestions.js.map +1 -0
- package/packages/web/dist/viewer/views/task-audit.d.ts +18 -0
- package/packages/web/dist/viewer/views/task-audit.js +413 -0
- package/packages/web/dist/viewer/views/task-audit.js.map +1 -0
- package/packages/web/dist/viewer/views/token-usage.d.ts +10 -0
- package/packages/web/dist/viewer/views/token-usage.js +410 -0
- package/packages/web/dist/viewer/views/token-usage.js.map +1 -0
- package/packages/web/dist/viewer/views/validation.d.ts +11 -0
- package/packages/web/dist/viewer/views/validation.js +475 -0
- package/packages/web/dist/viewer/views/validation.js.map +1 -0
- package/packages/web/dist/viewer/views/view-registry.d.ts +27 -0
- package/packages/web/dist/viewer/views/view-registry.js +70 -0
- package/packages/web/dist/viewer/views/view-registry.js.map +1 -0
- package/packages/web/dist/viewer/views/workflow-optimization.d.ts +12 -0
- package/packages/web/dist/viewer/views/workflow-optimization.js +311 -0
- package/packages/web/dist/viewer/views/workflow-optimization.js.map +1 -0
- package/packages/web/dist/viewer/views/zone-types.d.ts +69 -0
- package/packages/web/dist/viewer/views/zone-types.js +5 -0
- package/packages/web/dist/viewer/views/zone-types.js.map +1 -0
- package/packages/web/dist/viewer/views/zones.d.ts +50 -0
- package/packages/web/dist/viewer/views/zones.js +1438 -0
- package/packages/web/dist/viewer/views/zones.js.map +1 -0
- package/packages/web/dist/viewer/visualization/colors.d.ts +16 -0
- package/packages/web/dist/viewer/visualization/colors.js +31 -0
- package/packages/web/dist/viewer/visualization/colors.js.map +1 -0
- package/packages/web/dist/viewer/visualization/flow.d.ts +54 -0
- package/packages/web/dist/viewer/visualization/flow.js +123 -0
- package/packages/web/dist/viewer/visualization/flow.js.map +1 -0
- package/packages/web/dist/viewer/visualization/index.d.ts +34 -0
- package/packages/web/dist/viewer/visualization/index.js +40 -0
- package/packages/web/dist/viewer/visualization/index.js.map +1 -0
- package/packages/web/dist/viewer/visualization/metrics.d.ts +8 -0
- package/packages/web/dist/viewer/visualization/metrics.js +16 -0
- package/packages/web/dist/viewer/visualization/metrics.js.map +1 -0
- package/packages/web/package.json +53 -0
- package/refresh-artifacts.js +54 -0
- package/refresh-plan.js +79 -0
- package/refresh-validate.js +175 -0
- package/web.js +458 -0
|
@@ -0,0 +1,847 @@
|
|
|
1
|
+
import { join } from "node:path";
|
|
2
|
+
import { createInterface } from "node:readline";
|
|
3
|
+
import { resolveStore, findNextTask, findActionableTasks as findActionable, findItem, collectCompletedIds, isRootLevel, isWorkItem, SCHEMA_VERSION } from "../../prd/rex-gateway.js";
|
|
4
|
+
import { loadConfig, listRuns } from "../../store/index.js";
|
|
5
|
+
import { agentLoop } from "../../agent/lifecycle/loop.js";
|
|
6
|
+
import { cliLoop } from "../../agent/lifecycle/cli-loop.js";
|
|
7
|
+
import { getActionableTasks, collectEpicTaskIds } from "../../agent/planning/brief.js";
|
|
8
|
+
import { getStuckTaskIds } from "../../agent/analysis/stuck.js";
|
|
9
|
+
import { HENCH_DIR, safeParseInt, safeParseNonNegInt } from "./constants.js";
|
|
10
|
+
import { CLIError, EpicNotFoundError, requireLLMCLI } from "../errors.js";
|
|
11
|
+
import { info, result as output } from "../output.js";
|
|
12
|
+
import { loadLLMConfig, resolveLLMVendor, resolveVendorCliPath } from "../../store/project-config.js";
|
|
13
|
+
import { ExecutionQueue, formatQueueStatus, resolveSchedulingPriority } from "../../queue/index.js";
|
|
14
|
+
import { ProcessLimiter } from "../../process/limiter.js";
|
|
15
|
+
import { MemoryThrottle } from "../../process/memory-throttle.js";
|
|
16
|
+
// ---------------------------------------------------------------------------
|
|
17
|
+
// Schema compatibility
|
|
18
|
+
// ---------------------------------------------------------------------------
|
|
19
|
+
/**
|
|
20
|
+
* Verify the loaded PRD document uses a schema version compatible with this
|
|
21
|
+
* build of hench. Catches mismatches early (at startup) rather than letting
|
|
22
|
+
* them surface as mysterious runtime failures deep in the agent loop.
|
|
23
|
+
*/
|
|
24
|
+
async function assertSchemaCompatibility(store) {
|
|
25
|
+
const doc = await store.loadDocument();
|
|
26
|
+
if (doc.schema !== SCHEMA_VERSION) {
|
|
27
|
+
throw new CLIError(`PRD schema mismatch: document uses "${doc.schema}" but this version ` +
|
|
28
|
+
`of hench expects "${SCHEMA_VERSION}". Rebuild packages or run ` +
|
|
29
|
+
`"ndx init" to upgrade.`);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
// ---------------------------------------------------------------------------
|
|
33
|
+
// Formatting helpers
|
|
34
|
+
// ---------------------------------------------------------------------------
|
|
35
|
+
function formatDuration(ms) {
|
|
36
|
+
const seconds = Math.floor(ms / 1000);
|
|
37
|
+
if (seconds < 60)
|
|
38
|
+
return `${seconds}s`;
|
|
39
|
+
const minutes = Math.floor(seconds / 60);
|
|
40
|
+
const remaining = seconds % 60;
|
|
41
|
+
return `${minutes}m ${remaining}s`;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* List all epics in the PRD (root-level container items).
|
|
45
|
+
*/
|
|
46
|
+
export function listEpics(items) {
|
|
47
|
+
const epics = [];
|
|
48
|
+
for (const item of items) {
|
|
49
|
+
if (isRootLevel(item.level)) {
|
|
50
|
+
epics.push({ id: item.id, title: item.title });
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
return epics;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Find an epic by ID or title (case-insensitive title match).
|
|
57
|
+
* Returns the matched epic or null if not found.
|
|
58
|
+
*/
|
|
59
|
+
export function findEpicByIdOrTitle(items, search) {
|
|
60
|
+
const searchLower = search.toLowerCase();
|
|
61
|
+
for (const item of items) {
|
|
62
|
+
if (isRootLevel(item.level)) {
|
|
63
|
+
if (item.id === search || item.title.toLowerCase() === searchLower) {
|
|
64
|
+
return { id: item.id, title: item.title };
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return null;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Validate and resolve the --epic flag value.
|
|
72
|
+
* Throws EpicNotFoundError with available epics if not found.
|
|
73
|
+
*/
|
|
74
|
+
export async function resolveEpicFlag(store, epicFlag) {
|
|
75
|
+
const doc = await store.loadDocument();
|
|
76
|
+
const epic = findEpicByIdOrTitle(doc.items, epicFlag);
|
|
77
|
+
if (!epic) {
|
|
78
|
+
const available = listEpics(doc.items);
|
|
79
|
+
throw new EpicNotFoundError(epicFlag, available);
|
|
80
|
+
}
|
|
81
|
+
return epic;
|
|
82
|
+
}
|
|
83
|
+
// Re-export collectEpicTaskIds from brief.ts for backward compatibility with tests
|
|
84
|
+
export { collectEpicTaskIds } from "../../agent/planning/brief.js";
|
|
85
|
+
/**
|
|
86
|
+
* Get detailed scope information about an epic.
|
|
87
|
+
* Counts tasks/subtasks and their completion status.
|
|
88
|
+
*/
|
|
89
|
+
export async function getEpicScopeInfo(store, epicId) {
|
|
90
|
+
const doc = await store.loadDocument();
|
|
91
|
+
const epic = findEpicByIdOrTitle(doc.items, epicId);
|
|
92
|
+
if (!epic) {
|
|
93
|
+
throw new EpicNotFoundError(epicId, listEpics(doc.items));
|
|
94
|
+
}
|
|
95
|
+
const resolvedEpicId = epic.id;
|
|
96
|
+
// Walk the tree and count tasks belonging to this epic
|
|
97
|
+
const { walkTree } = await import("../../prd/rex-gateway.js");
|
|
98
|
+
let totalTasks = 0;
|
|
99
|
+
let completedTasks = 0;
|
|
100
|
+
let actionableTasks = 0;
|
|
101
|
+
for (const { item, parents } of walkTree(doc.items)) {
|
|
102
|
+
// Check if this item is inside the target epic
|
|
103
|
+
const isInEpic = item.id === resolvedEpicId ||
|
|
104
|
+
parents.some((p) => p.id === resolvedEpicId);
|
|
105
|
+
if (isInEpic && isWorkItem(item.level)) {
|
|
106
|
+
// Deleted items are excluded from all counts
|
|
107
|
+
if (item.status === "deleted")
|
|
108
|
+
continue;
|
|
109
|
+
totalTasks++;
|
|
110
|
+
if (item.status === "completed") {
|
|
111
|
+
completedTasks++;
|
|
112
|
+
}
|
|
113
|
+
else if (item.status === "pending" || item.status === "in_progress") {
|
|
114
|
+
actionableTasks++;
|
|
115
|
+
}
|
|
116
|
+
// deferred and blocked are neither completed nor actionable
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
const isComplete = totalTasks === 0 || completedTasks === totalTasks;
|
|
120
|
+
const hasActionableTasks = actionableTasks > 0;
|
|
121
|
+
return {
|
|
122
|
+
id: epic.id,
|
|
123
|
+
title: epic.title,
|
|
124
|
+
totalTasks,
|
|
125
|
+
completedTasks,
|
|
126
|
+
actionableTasks,
|
|
127
|
+
isComplete,
|
|
128
|
+
hasActionableTasks,
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
// ---------------------------------------------------------------------------
|
|
132
|
+
// Loop helpers (exported for testing)
|
|
133
|
+
// ---------------------------------------------------------------------------
|
|
134
|
+
/**
|
|
135
|
+
* Determine whether the loop should continue after a task run.
|
|
136
|
+
* Continues on success and transient errors; stops on hard failures
|
|
137
|
+
* only when stuck detection is disabled (threshold 0).
|
|
138
|
+
*
|
|
139
|
+
* With stuck detection enabled, the loop always continues — stuck tasks
|
|
140
|
+
* are simply skipped on the next iteration.
|
|
141
|
+
*/
|
|
142
|
+
export function shouldContinueLoop(status) {
|
|
143
|
+
return status !== "failed" && status !== "timeout" && status !== "budget_exceeded";
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Pause between loop iterations. Respects an optional AbortSignal so
|
|
147
|
+
* that a Ctrl-C handler can interrupt the wait immediately.
|
|
148
|
+
*/
|
|
149
|
+
export function loopPause(ms, signal) {
|
|
150
|
+
if (ms <= 0)
|
|
151
|
+
return Promise.resolve();
|
|
152
|
+
return new Promise((resolve) => {
|
|
153
|
+
const timer = setTimeout(resolve, ms);
|
|
154
|
+
if (signal) {
|
|
155
|
+
const onAbort = () => {
|
|
156
|
+
clearTimeout(timer);
|
|
157
|
+
resolve();
|
|
158
|
+
};
|
|
159
|
+
if (signal.aborted) {
|
|
160
|
+
clearTimeout(timer);
|
|
161
|
+
resolve();
|
|
162
|
+
return;
|
|
163
|
+
}
|
|
164
|
+
signal.addEventListener("abort", onAbort, { once: true });
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
// ---------------------------------------------------------------------------
|
|
169
|
+
// Stuck task helpers (exported for testing)
|
|
170
|
+
// ---------------------------------------------------------------------------
|
|
171
|
+
/**
|
|
172
|
+
* Load recent runs and compute which tasks are stuck (≥ threshold
|
|
173
|
+
* consecutive hard failures). Returns an empty set when threshold
|
|
174
|
+
* is 0 (disabled).
|
|
175
|
+
*/
|
|
176
|
+
export async function loadStuckTaskIds(henchDir, threshold) {
|
|
177
|
+
if (threshold <= 0)
|
|
178
|
+
return new Set();
|
|
179
|
+
const runs = await listRuns(henchDir);
|
|
180
|
+
const stuck = getStuckTaskIds(runs, threshold);
|
|
181
|
+
if (stuck.size > 0) {
|
|
182
|
+
info(`Stuck tasks detected (${stuck.size}): ${[...stuck].join(", ")}`);
|
|
183
|
+
}
|
|
184
|
+
return stuck;
|
|
185
|
+
}
|
|
186
|
+
// ---------------------------------------------------------------------------
|
|
187
|
+
// Execution queue factory (exported for testing and external consumers)
|
|
188
|
+
// ---------------------------------------------------------------------------
|
|
189
|
+
/**
|
|
190
|
+
* Create an ExecutionQueue sized from the hench guard config.
|
|
191
|
+
*
|
|
192
|
+
* The queue limits concurrent task executions to
|
|
193
|
+
* `guard.maxConcurrentProcesses` (default 3). This is the same
|
|
194
|
+
* limit used for cross-process concurrency, applied here at the
|
|
195
|
+
* in-process task-run level.
|
|
196
|
+
*/
|
|
197
|
+
export function createExecutionQueue(maxConcurrent) {
|
|
198
|
+
return new ExecutionQueue(maxConcurrent);
|
|
199
|
+
}
|
|
200
|
+
// ---------------------------------------------------------------------------
|
|
201
|
+
// Priority resolution helpers (exported for testing)
|
|
202
|
+
// ---------------------------------------------------------------------------
|
|
203
|
+
/**
|
|
204
|
+
* Peek at the next task's scheduling priority without consuming it.
|
|
205
|
+
*
|
|
206
|
+
* Looks up the task (by explicit ID or auto-selection) and resolves
|
|
207
|
+
* its effective scheduling priority from PRD metadata and optional
|
|
208
|
+
* CLI override. This priority is used for {@link ExecutionQueue}
|
|
209
|
+
* insertion ordering so that high-priority tasks bypass normal queue
|
|
210
|
+
* position under resource constraints.
|
|
211
|
+
*
|
|
212
|
+
* @param store PRD store
|
|
213
|
+
* @param taskId Explicit task ID (from --task flag), or undefined for auto-select
|
|
214
|
+
* @param cliOverride Priority override from --priority flag
|
|
215
|
+
* @param excludeTaskIds Task IDs to skip during auto-selection
|
|
216
|
+
* @param epicId Restrict selection to this epic
|
|
217
|
+
*/
|
|
218
|
+
export async function peekNextTaskPriority(store, taskId, cliOverride, excludeTaskIds, epicId) {
|
|
219
|
+
const doc = await store.loadDocument();
|
|
220
|
+
// If explicit task ID, look it up directly
|
|
221
|
+
if (taskId) {
|
|
222
|
+
const entry = findItem(doc.items, taskId);
|
|
223
|
+
if (entry) {
|
|
224
|
+
return resolveSchedulingPriority({
|
|
225
|
+
taskPriority: entry.item.priority,
|
|
226
|
+
tags: entry.item.tags,
|
|
227
|
+
cliOverride,
|
|
228
|
+
});
|
|
229
|
+
}
|
|
230
|
+
// Task not found — defer to default; runOne will throw later
|
|
231
|
+
return resolveSchedulingPriority({ cliOverride });
|
|
232
|
+
}
|
|
233
|
+
// Auto-select: peek at what findNextTask would pick
|
|
234
|
+
const completedIds = collectCompletedIds(doc.items);
|
|
235
|
+
const skipIds = excludeTaskIds
|
|
236
|
+
? new Set([...completedIds, ...excludeTaskIds])
|
|
237
|
+
: completedIds;
|
|
238
|
+
if (epicId) {
|
|
239
|
+
// Use the same logic as assembleTaskBrief for epic-scoped selection
|
|
240
|
+
const epicTaskIds = collectEpicTaskIds(doc.items, epicId);
|
|
241
|
+
const allActionable = findActionable(doc.items, skipIds, Infinity);
|
|
242
|
+
const epicActionable = allActionable.filter((e) => epicTaskIds.has(e.item.id) && !excludeTaskIds?.has(e.item.id));
|
|
243
|
+
if (epicActionable.length > 0) {
|
|
244
|
+
const next = epicActionable[0];
|
|
245
|
+
return resolveSchedulingPriority({
|
|
246
|
+
taskPriority: next.item.priority,
|
|
247
|
+
tags: next.item.tags,
|
|
248
|
+
cliOverride,
|
|
249
|
+
});
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
else {
|
|
253
|
+
const next = findNextTask(doc.items, skipIds);
|
|
254
|
+
if (next) {
|
|
255
|
+
return resolveSchedulingPriority({
|
|
256
|
+
taskPriority: next.item.priority,
|
|
257
|
+
tags: next.item.tags,
|
|
258
|
+
cliOverride,
|
|
259
|
+
});
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
// No actionable tasks — default priority (runOne will handle the error)
|
|
263
|
+
return resolveSchedulingPriority({ cliOverride });
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* Log queue status if there are any queued tasks.
|
|
267
|
+
* Suppressed when the queue is idle.
|
|
268
|
+
*/
|
|
269
|
+
function logQueueStatus(queue) {
|
|
270
|
+
const lines = formatQueueStatus(queue.status());
|
|
271
|
+
for (const line of lines) {
|
|
272
|
+
info(line);
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
// ---------------------------------------------------------------------------
|
|
276
|
+
// Interactive task selection
|
|
277
|
+
// ---------------------------------------------------------------------------
|
|
278
|
+
function promptUser(question) {
|
|
279
|
+
const rl = createInterface({ input: process.stdin, output: process.stdout });
|
|
280
|
+
return new Promise((resolve) => {
|
|
281
|
+
rl.question(question, (answer) => {
|
|
282
|
+
rl.close();
|
|
283
|
+
resolve(answer.trim());
|
|
284
|
+
});
|
|
285
|
+
});
|
|
286
|
+
}
|
|
287
|
+
async function selectTask(dir, rexDir, epicId) {
|
|
288
|
+
const store = await resolveStore(rexDir);
|
|
289
|
+
let tasks = await getActionableTasks(store);
|
|
290
|
+
// Filter to tasks within the specified epic if provided
|
|
291
|
+
if (epicId) {
|
|
292
|
+
const doc = await store.loadDocument();
|
|
293
|
+
const epicTaskIds = collectEpicTaskIds(doc.items, epicId);
|
|
294
|
+
tasks = tasks.filter((t) => epicTaskIds.has(t.id));
|
|
295
|
+
}
|
|
296
|
+
if (tasks.length === 0) {
|
|
297
|
+
const scope = epicId ? "within the specified epic" : "in PRD";
|
|
298
|
+
output(`No actionable tasks found ${scope}.`);
|
|
299
|
+
process.exit(0);
|
|
300
|
+
}
|
|
301
|
+
info("\nActionable tasks (by priority):\n");
|
|
302
|
+
for (let i = 0; i < tasks.length; i++) {
|
|
303
|
+
const t = tasks[i];
|
|
304
|
+
const pri = `[${t.priority}]`.padEnd(10);
|
|
305
|
+
const chain = t.parentChain ? ` (${t.parentChain})` : "";
|
|
306
|
+
info(` ${String(i + 1).padStart(2)}. ${pri} ${t.title}${chain}`);
|
|
307
|
+
}
|
|
308
|
+
info("");
|
|
309
|
+
const answer = await promptUser(`Select task [1]: `);
|
|
310
|
+
const idx = answer === "" ? 0 : parseInt(answer, 10) - 1;
|
|
311
|
+
if (isNaN(idx) || idx < 0 || idx >= tasks.length) {
|
|
312
|
+
throw new CLIError("Invalid selection.", `Enter a number between 1 and ${tasks.length}.`);
|
|
313
|
+
}
|
|
314
|
+
return tasks[idx].id;
|
|
315
|
+
}
|
|
316
|
+
// ---------------------------------------------------------------------------
|
|
317
|
+
// Single task execution
|
|
318
|
+
// ---------------------------------------------------------------------------
|
|
319
|
+
async function runOne(dir, henchDir, rexDir, provider, taskId, dryRun, model, maxTurns, tokenBudget, review, excludeTaskIds, epicId) {
|
|
320
|
+
const config = await loadConfig(henchDir);
|
|
321
|
+
const store = await resolveStore(rexDir);
|
|
322
|
+
await assertSchemaCompatibility(store);
|
|
323
|
+
// Apply CLI token budget override to config for CLI provider
|
|
324
|
+
const effectiveConfig = tokenBudget != null
|
|
325
|
+
? { ...config, provider, tokenBudget }
|
|
326
|
+
: { ...config, provider };
|
|
327
|
+
const result = provider === "cli"
|
|
328
|
+
? await cliLoop({
|
|
329
|
+
config: effectiveConfig,
|
|
330
|
+
store,
|
|
331
|
+
projectDir: dir,
|
|
332
|
+
henchDir,
|
|
333
|
+
taskId,
|
|
334
|
+
dryRun,
|
|
335
|
+
model,
|
|
336
|
+
review,
|
|
337
|
+
excludeTaskIds,
|
|
338
|
+
epicId,
|
|
339
|
+
})
|
|
340
|
+
: await agentLoop({
|
|
341
|
+
config: effectiveConfig,
|
|
342
|
+
store,
|
|
343
|
+
projectDir: dir,
|
|
344
|
+
henchDir,
|
|
345
|
+
taskId,
|
|
346
|
+
dryRun,
|
|
347
|
+
maxTurns,
|
|
348
|
+
tokenBudget,
|
|
349
|
+
model,
|
|
350
|
+
review,
|
|
351
|
+
excludeTaskIds,
|
|
352
|
+
epicId,
|
|
353
|
+
});
|
|
354
|
+
const { run } = result;
|
|
355
|
+
info("\n=== Run Complete ===");
|
|
356
|
+
output(`Run ID: ${run.id}`);
|
|
357
|
+
output(`Task: ${run.taskTitle}`);
|
|
358
|
+
output(`Status: ${run.status}`);
|
|
359
|
+
// Duration
|
|
360
|
+
if (run.startedAt && run.finishedAt) {
|
|
361
|
+
const durationMs = new Date(run.finishedAt).getTime() - new Date(run.startedAt).getTime();
|
|
362
|
+
info(`Duration: ${formatDuration(durationMs)}`);
|
|
363
|
+
}
|
|
364
|
+
info(`Turns: ${run.turns}`);
|
|
365
|
+
info(`Tokens: ${run.tokenUsage.input} in / ${run.tokenUsage.output} out`);
|
|
366
|
+
info(`Tool calls: ${run.toolCalls.length}`);
|
|
367
|
+
// Memory stats
|
|
368
|
+
if (run.memoryStats) {
|
|
369
|
+
const peakMB = Math.round(run.memoryStats.peakRssBytes / 1024 / 1024);
|
|
370
|
+
const availGB = run.memoryStats.systemAvailableAtEndBytes >= 0
|
|
371
|
+
? (run.memoryStats.systemAvailableAtEndBytes / 1024 / 1024 / 1024).toFixed(1)
|
|
372
|
+
: "?";
|
|
373
|
+
const totalGB = run.memoryStats.systemTotalBytes >= 0
|
|
374
|
+
? (run.memoryStats.systemTotalBytes / 1024 / 1024 / 1024).toFixed(1)
|
|
375
|
+
: "?";
|
|
376
|
+
info(`Memory: ${peakMB} MB peak RSS (system: ${availGB} / ${totalGB} GB available)`);
|
|
377
|
+
}
|
|
378
|
+
// Post-task test results
|
|
379
|
+
const postTests = run.structuredSummary?.postRunTests;
|
|
380
|
+
if (postTests?.ran) {
|
|
381
|
+
const scope = postTests.targetedFiles.length > 0
|
|
382
|
+
? `${postTests.targetedFiles.length} targeted file(s)`
|
|
383
|
+
: "full suite";
|
|
384
|
+
info(`Post-task tests: ${postTests.passed ? "passed" : "FAILED"} (${scope}, ${postTests.durationMs ?? 0}ms)`);
|
|
385
|
+
}
|
|
386
|
+
if (run.summary) {
|
|
387
|
+
info(`\nSummary: ${run.summary}`);
|
|
388
|
+
}
|
|
389
|
+
if (run.error) {
|
|
390
|
+
output(`\nError: ${run.error}`);
|
|
391
|
+
}
|
|
392
|
+
return { status: run.status };
|
|
393
|
+
}
|
|
394
|
+
// ---------------------------------------------------------------------------
|
|
395
|
+
// No-more-tasks sentinel
|
|
396
|
+
// ---------------------------------------------------------------------------
|
|
397
|
+
const NO_TASKS_MSG = "No actionable tasks found in PRD";
|
|
398
|
+
function isNoTasksError(err) {
|
|
399
|
+
return err instanceof Error && err.message.includes(NO_TASKS_MSG);
|
|
400
|
+
}
|
|
401
|
+
// ---------------------------------------------------------------------------
|
|
402
|
+
// cmdRun — main entry point
|
|
403
|
+
// ---------------------------------------------------------------------------
|
|
404
|
+
export async function cmdRun(dir, flags) {
|
|
405
|
+
const henchDir = join(dir, HENCH_DIR);
|
|
406
|
+
const config = await loadConfig(henchDir);
|
|
407
|
+
const rexDir = join(dir, config.rexDir);
|
|
408
|
+
const llmConfig = await loadLLMConfig(henchDir);
|
|
409
|
+
const llmVendor = resolveLLMVendor(llmConfig);
|
|
410
|
+
const provider = flags.provider ?? config.provider;
|
|
411
|
+
const dryRun = flags["dry-run"] === "true";
|
|
412
|
+
const review = flags.review === "true";
|
|
413
|
+
const model = flags.model;
|
|
414
|
+
const auto = flags.auto === "true";
|
|
415
|
+
const loop = flags.loop === "true";
|
|
416
|
+
const selfHeal = flags["self-heal"] === "true";
|
|
417
|
+
// Apply self-heal mode to config so it flows through to prompt building
|
|
418
|
+
if (selfHeal) {
|
|
419
|
+
config.selfHeal = true;
|
|
420
|
+
}
|
|
421
|
+
if (llmVendor === "codex" && provider === "api" && !dryRun) {
|
|
422
|
+
throw new CLIError("Hench API provider is only supported for vendor=claude.", "Set 'n-dx config hench.provider cli' or switch vendor: 'n-dx config llm.vendor claude'.");
|
|
423
|
+
}
|
|
424
|
+
// Fail fast if CLI provider selected but vendor CLI binary not available
|
|
425
|
+
if (provider === "cli" && !dryRun) {
|
|
426
|
+
const customPath = resolveVendorCliPath(llmConfig);
|
|
427
|
+
requireLLMCLI(llmVendor, customPath);
|
|
428
|
+
}
|
|
429
|
+
const iterations = flags.iterations ? safeParseInt(flags.iterations, "iterations") : 1;
|
|
430
|
+
const maxTurns = flags["max-turns"] ? safeParseInt(flags["max-turns"], "max-turns") : undefined;
|
|
431
|
+
const tokenBudget = flags["token-budget"] != null ? safeParseNonNegInt(flags["token-budget"], "token-budget") : undefined;
|
|
432
|
+
const pauseMs = flags["loop-pause"]
|
|
433
|
+
? safeParseInt(flags["loop-pause"], "loop-pause")
|
|
434
|
+
: config.loopPauseMs;
|
|
435
|
+
// Validate epic flag if provided (validates existence before starting work)
|
|
436
|
+
let epicId;
|
|
437
|
+
if (flags.epic) {
|
|
438
|
+
const store = await resolveStore(rexDir);
|
|
439
|
+
const scopeInfo = await getEpicScopeInfo(store, flags.epic);
|
|
440
|
+
epicId = scopeInfo.id;
|
|
441
|
+
// Show epic scope with completion status
|
|
442
|
+
const progress = scopeInfo.totalTasks > 0
|
|
443
|
+
? `${scopeInfo.completedTasks}/${scopeInfo.totalTasks} tasks complete`
|
|
444
|
+
: "no tasks";
|
|
445
|
+
info(`Epic scope: ${scopeInfo.title} (${scopeInfo.id}) — ${progress}`);
|
|
446
|
+
// Check for completion or no actionable tasks
|
|
447
|
+
if (scopeInfo.isComplete) {
|
|
448
|
+
output(`\n✓ All tasks in epic "${scopeInfo.title}" are complete.`);
|
|
449
|
+
process.exit(0);
|
|
450
|
+
}
|
|
451
|
+
if (!scopeInfo.hasActionableTasks) {
|
|
452
|
+
output(`\n⚠ Epic "${scopeInfo.title}" has no actionable tasks.`);
|
|
453
|
+
output(` ${scopeInfo.totalTasks - scopeInfo.completedTasks} task(s) are blocked or deferred.`);
|
|
454
|
+
output(` Use 'rex status' to see task statuses, or update tasks with 'rex update <id> --status=pending'.`);
|
|
455
|
+
process.exit(0);
|
|
456
|
+
}
|
|
457
|
+
}
|
|
458
|
+
const epicByEpic = flags["epic-by-epic"] === "true";
|
|
459
|
+
// --priority flag: override task scheduling priority.
|
|
460
|
+
// Valid values: critical, high, medium, low.
|
|
461
|
+
const priorityOverride = flags.priority;
|
|
462
|
+
// --epic-by-epic and --epic are mutually exclusive
|
|
463
|
+
if (epicByEpic && flags.epic) {
|
|
464
|
+
throw new CLIError("Cannot use --epic-by-epic with --epic.", "Use --epic to scope to a single epic, or --epic-by-epic to process all epics sequentially.");
|
|
465
|
+
}
|
|
466
|
+
// Memory-based execution throttling.
|
|
467
|
+
// Delays or rejects runs when system memory is under pressure.
|
|
468
|
+
const throttle = new MemoryThrottle(config.guard.memoryThrottle);
|
|
469
|
+
await throttle.gate(({ decision, memoryUsagePercent, delayMs, attempt, maxRetries }) => {
|
|
470
|
+
if (decision === "delay") {
|
|
471
|
+
info(`⏳ Memory usage high (${memoryUsagePercent.toFixed(1)}%) — ` +
|
|
472
|
+
`delaying execution ${delayMs}ms (attempt ${attempt + 1}/${maxRetries})`);
|
|
473
|
+
}
|
|
474
|
+
else if (decision === "reject") {
|
|
475
|
+
info(`🚫 Memory usage critical (${memoryUsagePercent.toFixed(1)}%) — rejecting execution`);
|
|
476
|
+
}
|
|
477
|
+
else if (attempt > 0) {
|
|
478
|
+
info(`✓ Memory usage recovered (${memoryUsagePercent.toFixed(1)}%) — proceeding`);
|
|
479
|
+
}
|
|
480
|
+
});
|
|
481
|
+
// Enforce cross-process concurrency limit.
|
|
482
|
+
// Prevents multiple `hench run` invocations from exhausting memory.
|
|
483
|
+
const limiter = new ProcessLimiter(henchDir, config.guard.maxConcurrentProcesses);
|
|
484
|
+
await limiter.acquire(flags.task);
|
|
485
|
+
try {
|
|
486
|
+
// Create execution queue for in-process concurrency control.
|
|
487
|
+
// The queue limits concurrent task runs within this process
|
|
488
|
+
// (loop mode, epic-by-epic).
|
|
489
|
+
const queue = createExecutionQueue(config.guard.maxConcurrentProcesses);
|
|
490
|
+
if (epicByEpic) {
|
|
491
|
+
await runEpicByEpic(dir, henchDir, rexDir, provider, dryRun, model, maxTurns, tokenBudget, pauseMs, config.maxFailedAttempts, review, queue, priorityOverride);
|
|
492
|
+
return;
|
|
493
|
+
}
|
|
494
|
+
let taskId = flags.task;
|
|
495
|
+
// Task selection: --task > interactive (TTY) > autoselect
|
|
496
|
+
// In loop mode, always autoselect (skip interactive)
|
|
497
|
+
if (!taskId && !auto && !loop && process.stdin.isTTY && !dryRun) {
|
|
498
|
+
taskId = await selectTask(dir, rexDir, epicId);
|
|
499
|
+
}
|
|
500
|
+
// If --auto, --loop, or non-TTY, taskId stays undefined → assembleTaskBrief autoselects
|
|
501
|
+
if (loop) {
|
|
502
|
+
await runLoop(dir, henchDir, rexDir, provider, taskId, dryRun, model, maxTurns, tokenBudget, pauseMs, config.maxFailedAttempts, review, epicId, queue, priorityOverride);
|
|
503
|
+
}
|
|
504
|
+
else {
|
|
505
|
+
await runIterations(dir, henchDir, rexDir, provider, taskId, dryRun, model, maxTurns, tokenBudget, iterations, config.maxFailedAttempts, review, epicId);
|
|
506
|
+
}
|
|
507
|
+
}
|
|
508
|
+
finally {
|
|
509
|
+
await limiter.release();
|
|
510
|
+
}
|
|
511
|
+
}
|
|
512
|
+
// ---------------------------------------------------------------------------
|
|
513
|
+
// Fixed iteration mode (existing behaviour)
|
|
514
|
+
// ---------------------------------------------------------------------------
|
|
515
|
+
async function runIterations(dir, henchDir, rexDir, provider, taskId, dryRun, model, maxTurns, tokenBudget, iterations, maxFailedAttempts, review, epicId) {
|
|
516
|
+
for (let i = 0; i < iterations; i++) {
|
|
517
|
+
if (iterations > 1) {
|
|
518
|
+
info(`\n=== Iteration ${i + 1}/${iterations} ===`);
|
|
519
|
+
}
|
|
520
|
+
// For autoselected iterations, skip stuck tasks
|
|
521
|
+
const isAutoselect = i > 0 || !taskId;
|
|
522
|
+
const stuckIds = isAutoselect
|
|
523
|
+
? await loadStuckTaskIds(henchDir, maxFailedAttempts)
|
|
524
|
+
: undefined;
|
|
525
|
+
const { status } = await runOne(dir, henchDir, rexDir, provider,
|
|
526
|
+
// Only use the explicit taskId for the first iteration;
|
|
527
|
+
// subsequent iterations autoselect the next task
|
|
528
|
+
i === 0 ? taskId : undefined, dryRun, model, maxTurns, tokenBudget, review, stuckIds, epicId);
|
|
529
|
+
if (status === "error_transient") {
|
|
530
|
+
info(`\nTransient error on iteration ${i + 1}, continuing to next task...`);
|
|
531
|
+
continue;
|
|
532
|
+
}
|
|
533
|
+
if (status === "failed" || status === "timeout" || status === "budget_exceeded") {
|
|
534
|
+
info(`\nStopping after ${i + 1} iteration(s) due to ${status} status.`);
|
|
535
|
+
break;
|
|
536
|
+
}
|
|
537
|
+
if (dryRun)
|
|
538
|
+
break;
|
|
539
|
+
}
|
|
540
|
+
}
|
|
541
|
+
// ---------------------------------------------------------------------------
|
|
542
|
+
// Continuous loop mode (--loop)
|
|
543
|
+
// ---------------------------------------------------------------------------
|
|
544
|
+
async function runLoop(dir, henchDir, rexDir, provider, taskId, dryRun, model, maxTurns, tokenBudget, pauseMs, maxFailedAttempts, review, epicId, queue, priorityOverride) {
|
|
545
|
+
// Graceful shutdown via SIGINT (Ctrl-C)
|
|
546
|
+
const ac = new AbortController();
|
|
547
|
+
let stopping = false;
|
|
548
|
+
const onSignal = () => {
|
|
549
|
+
if (stopping) {
|
|
550
|
+
// Second Ctrl-C: force exit
|
|
551
|
+
process.exit(1);
|
|
552
|
+
}
|
|
553
|
+
stopping = true;
|
|
554
|
+
ac.abort();
|
|
555
|
+
if (queue)
|
|
556
|
+
queue.drain();
|
|
557
|
+
info("\nReceived interrupt — finishing current task then stopping…");
|
|
558
|
+
};
|
|
559
|
+
process.on("SIGINT", onSignal);
|
|
560
|
+
let completed = 0;
|
|
561
|
+
try {
|
|
562
|
+
const scope = epicId ? "epic tasks" : "all tasks";
|
|
563
|
+
info(`Loop mode: running continuously until ${scope} complete or interrupted (Ctrl+C to stop)`);
|
|
564
|
+
// eslint-disable-next-line no-constant-condition
|
|
565
|
+
while (true) {
|
|
566
|
+
if (stopping) {
|
|
567
|
+
info(`\nLoop stopped by user after ${completed} task(s).`);
|
|
568
|
+
break;
|
|
569
|
+
}
|
|
570
|
+
completed++;
|
|
571
|
+
info(`\n=== Loop iteration ${completed} ===`);
|
|
572
|
+
// Show queue status if there are pending tasks
|
|
573
|
+
if (queue)
|
|
574
|
+
logQueueStatus(queue);
|
|
575
|
+
// Compute stuck tasks before each iteration so that
|
|
576
|
+
// recently-stuck tasks are automatically skipped
|
|
577
|
+
const isAutoselect = completed > 1 || !taskId;
|
|
578
|
+
const stuckIds = isAutoselect
|
|
579
|
+
? await loadStuckTaskIds(henchDir, maxFailedAttempts)
|
|
580
|
+
: undefined;
|
|
581
|
+
let status;
|
|
582
|
+
try {
|
|
583
|
+
// Resolve scheduling priority from task metadata before enqueuing.
|
|
584
|
+
// This lets high-priority tasks bypass normal queue position.
|
|
585
|
+
const effectiveTaskId = completed === 1 ? taskId : undefined;
|
|
586
|
+
let schedulingPriority = "medium";
|
|
587
|
+
if (queue) {
|
|
588
|
+
const store = await resolveStore(rexDir);
|
|
589
|
+
schedulingPriority = await peekNextTaskPriority(store, effectiveTaskId, priorityOverride, stuckIds, epicId);
|
|
590
|
+
await queue.acquire(effectiveTaskId ?? "auto", schedulingPriority);
|
|
591
|
+
}
|
|
592
|
+
try {
|
|
593
|
+
const result = await runOne(dir, henchDir, rexDir, provider,
|
|
594
|
+
// Only use explicit taskId on the very first iteration
|
|
595
|
+
effectiveTaskId, dryRun, model, maxTurns, tokenBudget, review, stuckIds, epicId);
|
|
596
|
+
status = result.status;
|
|
597
|
+
}
|
|
598
|
+
finally {
|
|
599
|
+
// Release the queue slot after the task completes
|
|
600
|
+
if (queue)
|
|
601
|
+
queue.release();
|
|
602
|
+
}
|
|
603
|
+
}
|
|
604
|
+
catch (err) {
|
|
605
|
+
if (isNoTasksError(err)) {
|
|
606
|
+
const scope = epicId ? " in epic" : "";
|
|
607
|
+
info(`\nAll tasks${scope} complete — loop finished after ${completed - 1} task(s).`);
|
|
608
|
+
break;
|
|
609
|
+
}
|
|
610
|
+
throw err;
|
|
611
|
+
}
|
|
612
|
+
if (!shouldContinueLoop(status)) {
|
|
613
|
+
// In loop mode, hard failures don't stop the loop — the stuck
|
|
614
|
+
// task will be detected and skipped on the next iteration.
|
|
615
|
+
info(`\nTask failed (${status}), will skip if stuck on next iteration...`);
|
|
616
|
+
}
|
|
617
|
+
if (dryRun) {
|
|
618
|
+
info("\nDry run — stopping after one iteration.");
|
|
619
|
+
break;
|
|
620
|
+
}
|
|
621
|
+
if (status === "error_transient") {
|
|
622
|
+
info("\nTransient error, continuing to next task...");
|
|
623
|
+
}
|
|
624
|
+
// Pause between tasks (interruptible)
|
|
625
|
+
if (!stopping && pauseMs > 0) {
|
|
626
|
+
info(`\nPausing ${pauseMs}ms before next task...`);
|
|
627
|
+
await loopPause(pauseMs, ac.signal);
|
|
628
|
+
}
|
|
629
|
+
}
|
|
630
|
+
}
|
|
631
|
+
finally {
|
|
632
|
+
process.removeListener("SIGINT", onSignal);
|
|
633
|
+
}
|
|
634
|
+
}
|
|
635
|
+
/**
|
|
636
|
+
* Collect ordered list of epics that have actionable tasks.
|
|
637
|
+
* Returns all epics in PRD order, including those that are fully complete
|
|
638
|
+
* (so the caller can decide what to process).
|
|
639
|
+
*/
|
|
640
|
+
export async function getOrderedEpics(store) {
|
|
641
|
+
const doc = await store.loadDocument();
|
|
642
|
+
const epics = listEpics(doc.items);
|
|
643
|
+
const result = [];
|
|
644
|
+
for (const epic of epics) {
|
|
645
|
+
const scopeInfo = await getEpicScopeInfo(store, epic.id);
|
|
646
|
+
result.push(scopeInfo);
|
|
647
|
+
}
|
|
648
|
+
return result;
|
|
649
|
+
}
|
|
650
|
+
/**
|
|
651
|
+
* Run tasks across all epics sequentially. For each epic that has
|
|
652
|
+
* actionable tasks, runs tasks in a loop until the epic is complete,
|
|
653
|
+
* blocked, or interrupted, then advances to the next epic.
|
|
654
|
+
*/
|
|
655
|
+
async function runEpicByEpic(dir, henchDir, rexDir, provider, dryRun, model, maxTurns, tokenBudget, pauseMs, maxFailedAttempts, review, queue, priorityOverride) {
|
|
656
|
+
// Graceful shutdown via SIGINT (Ctrl-C)
|
|
657
|
+
const ac = new AbortController();
|
|
658
|
+
let stopping = false;
|
|
659
|
+
const onSignal = () => {
|
|
660
|
+
if (stopping) {
|
|
661
|
+
process.exit(1);
|
|
662
|
+
}
|
|
663
|
+
stopping = true;
|
|
664
|
+
ac.abort();
|
|
665
|
+
if (queue)
|
|
666
|
+
queue.drain();
|
|
667
|
+
info("\nReceived interrupt — finishing current task then stopping…");
|
|
668
|
+
};
|
|
669
|
+
process.on("SIGINT", onSignal);
|
|
670
|
+
const summaries = [];
|
|
671
|
+
try {
|
|
672
|
+
const store = await resolveStore(rexDir);
|
|
673
|
+
await assertSchemaCompatibility(store);
|
|
674
|
+
const allEpics = await getOrderedEpics(store);
|
|
675
|
+
if (allEpics.length === 0) {
|
|
676
|
+
output("No epics found in PRD.");
|
|
677
|
+
return;
|
|
678
|
+
}
|
|
679
|
+
// Filter to epics that need work
|
|
680
|
+
const actionableEpics = allEpics.filter((e) => !e.isComplete);
|
|
681
|
+
if (actionableEpics.length === 0) {
|
|
682
|
+
output("✓ All epics are complete.");
|
|
683
|
+
return;
|
|
684
|
+
}
|
|
685
|
+
info(`Epic-by-epic mode: ${actionableEpics.length} epic(s) to process\n`);
|
|
686
|
+
for (const epic of actionableEpics) {
|
|
687
|
+
const progress = `${epic.completedTasks}/${epic.totalTasks} tasks complete`;
|
|
688
|
+
info(` • ${epic.title} — ${progress}`);
|
|
689
|
+
}
|
|
690
|
+
for (let epicIdx = 0; epicIdx < actionableEpics.length; epicIdx++) {
|
|
691
|
+
if (stopping) {
|
|
692
|
+
// Mark remaining epics as interrupted
|
|
693
|
+
for (let j = epicIdx; j < actionableEpics.length; j++) {
|
|
694
|
+
summaries.push({
|
|
695
|
+
id: actionableEpics[j].id,
|
|
696
|
+
title: actionableEpics[j].title,
|
|
697
|
+
tasksCompleted: 0,
|
|
698
|
+
tasksFailed: 0,
|
|
699
|
+
outcome: "interrupted",
|
|
700
|
+
});
|
|
701
|
+
}
|
|
702
|
+
break;
|
|
703
|
+
}
|
|
704
|
+
const epic = actionableEpics[epicIdx];
|
|
705
|
+
info(`\n${"═".repeat(60)}`);
|
|
706
|
+
info(`Epic ${epicIdx + 1}/${actionableEpics.length}: ${epic.title}`);
|
|
707
|
+
info(`${"═".repeat(60)}`);
|
|
708
|
+
// Re-check epic scope (tasks may have changed from prior epic's work)
|
|
709
|
+
const freshScope = await getEpicScopeInfo(store, epic.id);
|
|
710
|
+
if (freshScope.isComplete) {
|
|
711
|
+
info(`✓ Epic "${epic.title}" is already complete.`);
|
|
712
|
+
summaries.push({
|
|
713
|
+
id: epic.id,
|
|
714
|
+
title: epic.title,
|
|
715
|
+
tasksCompleted: 0,
|
|
716
|
+
tasksFailed: 0,
|
|
717
|
+
outcome: "completed",
|
|
718
|
+
});
|
|
719
|
+
continue;
|
|
720
|
+
}
|
|
721
|
+
if (!freshScope.hasActionableTasks) {
|
|
722
|
+
info(`⚠ Epic "${epic.title}" has no actionable tasks (${freshScope.totalTasks - freshScope.completedTasks} blocked/deferred).`);
|
|
723
|
+
summaries.push({
|
|
724
|
+
id: epic.id,
|
|
725
|
+
title: epic.title,
|
|
726
|
+
tasksCompleted: 0,
|
|
727
|
+
tasksFailed: 0,
|
|
728
|
+
outcome: "no_actionable_tasks",
|
|
729
|
+
});
|
|
730
|
+
continue;
|
|
731
|
+
}
|
|
732
|
+
const progress = `${freshScope.completedTasks}/${freshScope.totalTasks} tasks complete`;
|
|
733
|
+
info(`Starting: ${freshScope.actionableTasks} actionable task(s), ${progress}`);
|
|
734
|
+
let tasksCompleted = 0;
|
|
735
|
+
let tasksFailed = 0;
|
|
736
|
+
// Inner loop: run tasks within this epic
|
|
737
|
+
// eslint-disable-next-line no-constant-condition
|
|
738
|
+
while (true) {
|
|
739
|
+
if (stopping)
|
|
740
|
+
break;
|
|
741
|
+
// Show queue status if there are pending tasks
|
|
742
|
+
if (queue)
|
|
743
|
+
logQueueStatus(queue);
|
|
744
|
+
const stuckIds = await loadStuckTaskIds(henchDir, maxFailedAttempts);
|
|
745
|
+
let status;
|
|
746
|
+
try {
|
|
747
|
+
// Resolve scheduling priority from task metadata before enqueuing.
|
|
748
|
+
// This lets high-priority tasks bypass normal queue position.
|
|
749
|
+
if (queue) {
|
|
750
|
+
const schedulingPriority = await peekNextTaskPriority(store, undefined, priorityOverride, stuckIds, epic.id);
|
|
751
|
+
await queue.acquire(epic.id, schedulingPriority);
|
|
752
|
+
}
|
|
753
|
+
try {
|
|
754
|
+
const result = await runOne(dir, henchDir, rexDir, provider, undefined, // autoselect within epic
|
|
755
|
+
dryRun, model, maxTurns, tokenBudget, review, stuckIds, epic.id);
|
|
756
|
+
status = result.status;
|
|
757
|
+
}
|
|
758
|
+
finally {
|
|
759
|
+
// Release the queue slot after the task completes
|
|
760
|
+
if (queue)
|
|
761
|
+
queue.release();
|
|
762
|
+
}
|
|
763
|
+
}
|
|
764
|
+
catch (err) {
|
|
765
|
+
if (isNoTasksError(err)) {
|
|
766
|
+
// All tasks in this epic are done
|
|
767
|
+
break;
|
|
768
|
+
}
|
|
769
|
+
throw err;
|
|
770
|
+
}
|
|
771
|
+
if (status === "completed") {
|
|
772
|
+
tasksCompleted++;
|
|
773
|
+
}
|
|
774
|
+
else if (status === "failed" || status === "timeout" || status === "budget_exceeded") {
|
|
775
|
+
tasksFailed++;
|
|
776
|
+
}
|
|
777
|
+
if (dryRun) {
|
|
778
|
+
info("\nDry run — stopping after one task.");
|
|
779
|
+
break;
|
|
780
|
+
}
|
|
781
|
+
// Re-check epic scope after each task
|
|
782
|
+
const updated = await getEpicScopeInfo(store, epic.id);
|
|
783
|
+
if (updated.isComplete) {
|
|
784
|
+
info(`\n✓ Epic "${epic.title}" is now complete!`);
|
|
785
|
+
break;
|
|
786
|
+
}
|
|
787
|
+
if (!updated.hasActionableTasks) {
|
|
788
|
+
info(`\n⚠ Epic "${epic.title}" has no more actionable tasks.`);
|
|
789
|
+
break;
|
|
790
|
+
}
|
|
791
|
+
// Pause between tasks (interruptible)
|
|
792
|
+
if (!stopping && pauseMs > 0) {
|
|
793
|
+
info(`\nPausing ${pauseMs}ms before next task...`);
|
|
794
|
+
await loopPause(pauseMs, ac.signal);
|
|
795
|
+
}
|
|
796
|
+
}
|
|
797
|
+
const epicOutcome = stopping ? "interrupted" : ((await getEpicScopeInfo(store, epic.id)).isComplete
|
|
798
|
+
? "completed"
|
|
799
|
+
: "no_actionable_tasks");
|
|
800
|
+
summaries.push({
|
|
801
|
+
id: epic.id,
|
|
802
|
+
title: epic.title,
|
|
803
|
+
tasksCompleted,
|
|
804
|
+
tasksFailed,
|
|
805
|
+
outcome: epicOutcome,
|
|
806
|
+
});
|
|
807
|
+
if (dryRun)
|
|
808
|
+
break;
|
|
809
|
+
// Pause between epics (interruptible)
|
|
810
|
+
if (!stopping && epicIdx < actionableEpics.length - 1 && pauseMs > 0) {
|
|
811
|
+
info(`\nPausing ${pauseMs}ms before next epic...`);
|
|
812
|
+
await loopPause(pauseMs, ac.signal);
|
|
813
|
+
}
|
|
814
|
+
}
|
|
815
|
+
// Print final summary
|
|
816
|
+
printEpicByEpicSummary(summaries);
|
|
817
|
+
}
|
|
818
|
+
finally {
|
|
819
|
+
process.removeListener("SIGINT", onSignal);
|
|
820
|
+
}
|
|
821
|
+
}
|
|
822
|
+
/**
|
|
823
|
+
* Print a summary table of epic-by-epic execution results.
|
|
824
|
+
*/
|
|
825
|
+
export function printEpicByEpicSummary(summaries) {
|
|
826
|
+
info(`\n${"═".repeat(60)}`);
|
|
827
|
+
info("Epic-by-Epic Execution Summary");
|
|
828
|
+
info(`${"═".repeat(60)}`);
|
|
829
|
+
let totalCompleted = 0;
|
|
830
|
+
let totalFailed = 0;
|
|
831
|
+
for (const s of summaries) {
|
|
832
|
+
const icon = s.outcome === "completed" ? "✓" :
|
|
833
|
+
s.outcome === "interrupted" ? "⊘" :
|
|
834
|
+
s.outcome === "no_actionable_tasks" ? "⚠" :
|
|
835
|
+
s.outcome === "skipped" ? "–" :
|
|
836
|
+
"?";
|
|
837
|
+
const stats = s.tasksCompleted > 0 || s.tasksFailed > 0
|
|
838
|
+
? ` (${s.tasksCompleted} done, ${s.tasksFailed} failed)`
|
|
839
|
+
: "";
|
|
840
|
+
output(` ${icon} ${s.title} — ${s.outcome}${stats}`);
|
|
841
|
+
totalCompleted += s.tasksCompleted;
|
|
842
|
+
totalFailed += s.tasksFailed;
|
|
843
|
+
}
|
|
844
|
+
const epicsDone = summaries.filter((s) => s.outcome === "completed").length;
|
|
845
|
+
output(`\nEpics: ${epicsDone}/${summaries.length} completed | Tasks: ${totalCompleted} done, ${totalFailed} failed`);
|
|
846
|
+
}
|
|
847
|
+
//# sourceMappingURL=run.js.map
|