@manehorizons/cadence-core 1.1.1
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 +21 -0
- package/README.md +5 -0
- package/bin/cadence.cjs +4 -0
- package/dist/build/record.d.ts +16 -0
- package/dist/build/record.d.ts.map +1 -0
- package/dist/build/record.js +33 -0
- package/dist/build/record.js.map +1 -0
- package/dist/checks/boundary.d.ts +35 -0
- package/dist/checks/boundary.d.ts.map +1 -0
- package/dist/checks/boundary.js +29 -0
- package/dist/checks/boundary.js.map +1 -0
- package/dist/checks/skill-audit.d.ts +29 -0
- package/dist/checks/skill-audit.d.ts.map +1 -0
- package/dist/checks/skill-audit.js +57 -0
- package/dist/checks/skill-audit.js.map +1 -0
- package/dist/classify/tier.d.ts +9 -0
- package/dist/classify/tier.d.ts.map +1 -0
- package/dist/classify/tier.js +15 -0
- package/dist/classify/tier.js.map +1 -0
- package/dist/cli/commands/assumption.d.ts +3 -0
- package/dist/cli/commands/assumption.d.ts.map +1 -0
- package/dist/cli/commands/assumption.js +313 -0
- package/dist/cli/commands/assumption.js.map +1 -0
- package/dist/cli/commands/block.d.ts +3 -0
- package/dist/cli/commands/block.d.ts.map +1 -0
- package/dist/cli/commands/block.js +23 -0
- package/dist/cli/commands/block.js.map +1 -0
- package/dist/cli/commands/build.d.ts +3 -0
- package/dist/cli/commands/build.d.ts.map +1 -0
- package/dist/cli/commands/build.js +89 -0
- package/dist/cli/commands/build.js.map +1 -0
- package/dist/cli/commands/config.d.ts +3 -0
- package/dist/cli/commands/config.d.ts.map +1 -0
- package/dist/cli/commands/config.js +91 -0
- package/dist/cli/commands/config.js.map +1 -0
- package/dist/cli/commands/context.d.ts +3 -0
- package/dist/cli/commands/context.d.ts.map +1 -0
- package/dist/cli/commands/context.js +31 -0
- package/dist/cli/commands/context.js.map +1 -0
- package/dist/cli/commands/decision.d.ts +3 -0
- package/dist/cli/commands/decision.d.ts.map +1 -0
- package/dist/cli/commands/decision.js +390 -0
- package/dist/cli/commands/decision.js.map +1 -0
- package/dist/cli/commands/done.d.ts +3 -0
- package/dist/cli/commands/done.d.ts.map +1 -0
- package/dist/cli/commands/done.js +23 -0
- package/dist/cli/commands/done.js.map +1 -0
- package/dist/cli/commands/draft-new.d.ts +4 -0
- package/dist/cli/commands/draft-new.d.ts.map +1 -0
- package/dist/cli/commands/draft-new.js +108 -0
- package/dist/cli/commands/draft-new.js.map +1 -0
- package/dist/cli/commands/draft.d.ts +4 -0
- package/dist/cli/commands/draft.d.ts.map +1 -0
- package/dist/cli/commands/draft.js +125 -0
- package/dist/cli/commands/draft.js.map +1 -0
- package/dist/cli/commands/hook.d.ts +3 -0
- package/dist/cli/commands/hook.d.ts.map +1 -0
- package/dist/cli/commands/hook.js +50 -0
- package/dist/cli/commands/hook.js.map +1 -0
- package/dist/cli/commands/init.d.ts +21 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +255 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/inspect.d.ts +3 -0
- package/dist/cli/commands/inspect.d.ts.map +1 -0
- package/dist/cli/commands/inspect.js +24 -0
- package/dist/cli/commands/inspect.js.map +1 -0
- package/dist/cli/commands/intelligence.d.ts +3 -0
- package/dist/cli/commands/intelligence.d.ts.map +1 -0
- package/dist/cli/commands/intelligence.js +173 -0
- package/dist/cli/commands/intelligence.js.map +1 -0
- package/dist/cli/commands/milestone.d.ts +3 -0
- package/dist/cli/commands/milestone.d.ts.map +1 -0
- package/dist/cli/commands/milestone.js +119 -0
- package/dist/cli/commands/milestone.js.map +1 -0
- package/dist/cli/commands/needs-context.d.ts +3 -0
- package/dist/cli/commands/needs-context.d.ts.map +1 -0
- package/dist/cli/commands/needs-context.js +23 -0
- package/dist/cli/commands/needs-context.js.map +1 -0
- package/dist/cli/commands/progress.d.ts +3 -0
- package/dist/cli/commands/progress.d.ts.map +1 -0
- package/dist/cli/commands/progress.js +21 -0
- package/dist/cli/commands/progress.js.map +1 -0
- package/dist/cli/commands/recommend.d.ts +3 -0
- package/dist/cli/commands/recommend.d.ts.map +1 -0
- package/dist/cli/commands/recommend.js +24 -0
- package/dist/cli/commands/recommend.js.map +1 -0
- package/dist/cli/commands/recommendation.d.ts +3 -0
- package/dist/cli/commands/recommendation.d.ts.map +1 -0
- package/dist/cli/commands/recommendation.js +360 -0
- package/dist/cli/commands/recommendation.js.map +1 -0
- package/dist/cli/commands/settle.d.ts +3 -0
- package/dist/cli/commands/settle.d.ts.map +1 -0
- package/dist/cli/commands/settle.js +453 -0
- package/dist/cli/commands/settle.js.map +1 -0
- package/dist/cli/commands/spec.d.ts +10 -0
- package/dist/cli/commands/spec.d.ts.map +1 -0
- package/dist/cli/commands/spec.js +246 -0
- package/dist/cli/commands/spec.js.map +1 -0
- package/dist/cli/commands/status.d.ts +11 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/status.js +211 -0
- package/dist/cli/commands/status.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +21 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/register.d.ts +3 -0
- package/dist/cli/register.d.ts.map +1 -0
- package/dist/cli/register.js +43 -0
- package/dist/cli/register.js.map +1 -0
- package/dist/coherence/check.d.ts +11 -0
- package/dist/coherence/check.d.ts.map +1 -0
- package/dist/coherence/check.js +34 -0
- package/dist/coherence/check.js.map +1 -0
- package/dist/config/loader.d.ts +4 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +40 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/errors.d.ts +23 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +31 -0
- package/dist/errors.js.map +1 -0
- package/dist/gates/approve.d.ts +20 -0
- package/dist/gates/approve.d.ts.map +1 -0
- package/dist/gates/approve.js +55 -0
- package/dist/gates/approve.js.map +1 -0
- package/dist/gates/build-context.d.ts +17 -0
- package/dist/gates/build-context.d.ts.map +1 -0
- package/dist/gates/build-context.js +81 -0
- package/dist/gates/build-context.js.map +1 -0
- package/dist/gates/build-test-must-pass.d.ts +12 -0
- package/dist/gates/build-test-must-pass.d.ts.map +1 -0
- package/dist/gates/build-test-must-pass.js +23 -0
- package/dist/gates/build-test-must-pass.js.map +1 -0
- package/dist/gates/build-types.d.ts +54 -0
- package/dist/gates/build-types.d.ts.map +1 -0
- package/dist/gates/build-types.js +2 -0
- package/dist/gates/build-types.js.map +1 -0
- package/dist/gates/code-review.d.ts +20 -0
- package/dist/gates/code-review.d.ts.map +1 -0
- package/dist/gates/code-review.js +137 -0
- package/dist/gates/code-review.js.map +1 -0
- package/dist/gates/coherence.d.ts +26 -0
- package/dist/gates/coherence.d.ts.map +1 -0
- package/dist/gates/coherence.js +59 -0
- package/dist/gates/coherence.js.map +1 -0
- package/dist/gates/coverage.d.ts +8 -0
- package/dist/gates/coverage.d.ts.map +1 -0
- package/dist/gates/coverage.js +26 -0
- package/dist/gates/coverage.js.map +1 -0
- package/dist/gates/deep-verify.d.ts +7 -0
- package/dist/gates/deep-verify.d.ts.map +1 -0
- package/dist/gates/deep-verify.js +77 -0
- package/dist/gates/deep-verify.js.map +1 -0
- package/dist/gates/draft-context.d.ts +20 -0
- package/dist/gates/draft-context.d.ts.map +1 -0
- package/dist/gates/draft-context.js +87 -0
- package/dist/gates/draft-context.js.map +1 -0
- package/dist/gates/draft-read.d.ts +10 -0
- package/dist/gates/draft-read.d.ts.map +1 -0
- package/dist/gates/draft-read.js +24 -0
- package/dist/gates/draft-read.js.map +1 -0
- package/dist/gates/draft-types.d.ts +75 -0
- package/dist/gates/draft-types.d.ts.map +1 -0
- package/dist/gates/draft-types.js +2 -0
- package/dist/gates/draft-types.js.map +1 -0
- package/dist/gates/engine.d.ts +21 -0
- package/dist/gates/engine.d.ts.map +1 -0
- package/dist/gates/engine.js +98 -0
- package/dist/gates/engine.js.map +1 -0
- package/dist/gates/interactive.d.ts +11 -0
- package/dist/gates/interactive.d.ts.map +1 -0
- package/dist/gates/interactive.js +55 -0
- package/dist/gates/interactive.js.map +1 -0
- package/dist/gates/per-task-verify.d.ts +12 -0
- package/dist/gates/per-task-verify.d.ts.map +1 -0
- package/dist/gates/per-task-verify.js +52 -0
- package/dist/gates/per-task-verify.js.map +1 -0
- package/dist/gates/plan-review.d.ts +13 -0
- package/dist/gates/plan-review.d.ts.map +1 -0
- package/dist/gates/plan-review.js +98 -0
- package/dist/gates/plan-review.js.map +1 -0
- package/dist/gates/registry.d.ts +53 -0
- package/dist/gates/registry.d.ts.map +1 -0
- package/dist/gates/registry.js +66 -0
- package/dist/gates/registry.js.map +1 -0
- package/dist/gates/security-audit.d.ts +11 -0
- package/dist/gates/security-audit.d.ts.map +1 -0
- package/dist/gates/security-audit.js +40 -0
- package/dist/gates/security-audit.js.map +1 -0
- package/dist/gates/structural-verifier.d.ts +8 -0
- package/dist/gates/structural-verifier.d.ts.map +1 -0
- package/dist/gates/structural-verifier.js +25 -0
- package/dist/gates/structural-verifier.js.map +1 -0
- package/dist/gates/types.d.ts +202 -0
- package/dist/gates/types.d.ts.map +1 -0
- package/dist/gates/types.js +12 -0
- package/dist/gates/types.js.map +1 -0
- package/dist/hooks/dispatcher.d.ts +8 -0
- package/dist/hooks/dispatcher.d.ts.map +1 -0
- package/dist/hooks/dispatcher.js +31 -0
- package/dist/hooks/dispatcher.js.map +1 -0
- package/dist/hooks/handlers.d.ts +21 -0
- package/dist/hooks/handlers.d.ts.map +1 -0
- package/dist/hooks/handlers.js +121 -0
- package/dist/hooks/handlers.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/dist/init/claude-md-template.d.ts +34 -0
- package/dist/init/claude-md-template.d.ts.map +1 -0
- package/dist/init/claude-md-template.js +72 -0
- package/dist/init/claude-md-template.js.map +1 -0
- package/dist/intelligence/backend/cadence.d.ts +21 -0
- package/dist/intelligence/backend/cadence.d.ts.map +1 -0
- package/dist/intelligence/backend/cadence.js +127 -0
- package/dist/intelligence/backend/cadence.js.map +1 -0
- package/dist/intelligence/context.d.ts +11 -0
- package/dist/intelligence/context.d.ts.map +1 -0
- package/dist/intelligence/context.js +197 -0
- package/dist/intelligence/context.js.map +1 -0
- package/dist/intelligence/graph-decision.d.ts +9 -0
- package/dist/intelligence/graph-decision.d.ts.map +1 -0
- package/dist/intelligence/graph-decision.js +55 -0
- package/dist/intelligence/graph-decision.js.map +1 -0
- package/dist/intelligence/inspect.d.ts +9 -0
- package/dist/intelligence/inspect.d.ts.map +1 -0
- package/dist/intelligence/inspect.js +93 -0
- package/dist/intelligence/inspect.js.map +1 -0
- package/dist/intelligence/milestone.d.ts +40 -0
- package/dist/intelligence/milestone.d.ts.map +1 -0
- package/dist/intelligence/milestone.js +312 -0
- package/dist/intelligence/milestone.js.map +1 -0
- package/dist/intelligence/recommend.d.ts +20 -0
- package/dist/intelligence/recommend.d.ts.map +1 -0
- package/dist/intelligence/recommend.js +185 -0
- package/dist/intelligence/recommend.js.map +1 -0
- package/dist/intelligence/render-assumption-detail.d.ts +3 -0
- package/dist/intelligence/render-assumption-detail.d.ts.map +1 -0
- package/dist/intelligence/render-assumption-detail.js +16 -0
- package/dist/intelligence/render-assumption-detail.js.map +1 -0
- package/dist/intelligence/render-assumption.d.ts +3 -0
- package/dist/intelligence/render-assumption.d.ts.map +1 -0
- package/dist/intelligence/render-assumption.js +37 -0
- package/dist/intelligence/render-assumption.js.map +1 -0
- package/dist/intelligence/render-context.d.ts +3 -0
- package/dist/intelligence/render-context.d.ts.map +1 -0
- package/dist/intelligence/render-context.js +92 -0
- package/dist/intelligence/render-context.js.map +1 -0
- package/dist/intelligence/render-decision-detail.d.ts +3 -0
- package/dist/intelligence/render-decision-detail.d.ts.map +1 -0
- package/dist/intelligence/render-decision-detail.js +30 -0
- package/dist/intelligence/render-decision-detail.js.map +1 -0
- package/dist/intelligence/render-decision-graph.d.ts +3 -0
- package/dist/intelligence/render-decision-graph.d.ts.map +1 -0
- package/dist/intelligence/render-decision-graph.js +49 -0
- package/dist/intelligence/render-decision-graph.js.map +1 -0
- package/dist/intelligence/render-decision.d.ts +3 -0
- package/dist/intelligence/render-decision.d.ts.map +1 -0
- package/dist/intelligence/render-decision.js +45 -0
- package/dist/intelligence/render-decision.js.map +1 -0
- package/dist/intelligence/render-inspection.d.ts +3 -0
- package/dist/intelligence/render-inspection.d.ts.map +1 -0
- package/dist/intelligence/render-inspection.js +69 -0
- package/dist/intelligence/render-inspection.js.map +1 -0
- package/dist/intelligence/render-intelligence-audit.d.ts +5 -0
- package/dist/intelligence/render-intelligence-audit.d.ts.map +1 -0
- package/dist/intelligence/render-intelligence-audit.js +93 -0
- package/dist/intelligence/render-intelligence-audit.js.map +1 -0
- package/dist/intelligence/render-intelligence-stats.d.ts +6 -0
- package/dist/intelligence/render-intelligence-stats.d.ts.map +1 -0
- package/dist/intelligence/render-intelligence-stats.js +76 -0
- package/dist/intelligence/render-intelligence-stats.js.map +1 -0
- package/dist/intelligence/render-milestone.d.ts +3 -0
- package/dist/intelligence/render-milestone.d.ts.map +1 -0
- package/dist/intelligence/render-milestone.js +80 -0
- package/dist/intelligence/render-milestone.js.map +1 -0
- package/dist/intelligence/render-recommend.d.ts +3 -0
- package/dist/intelligence/render-recommend.d.ts.map +1 -0
- package/dist/intelligence/render-recommend.js +62 -0
- package/dist/intelligence/render-recommend.js.map +1 -0
- package/dist/intelligence/render-recommendation-detail.d.ts +7 -0
- package/dist/intelligence/render-recommendation-detail.d.ts.map +1 -0
- package/dist/intelligence/render-recommendation-detail.js +93 -0
- package/dist/intelligence/render-recommendation-detail.js.map +1 -0
- package/dist/intelligence/render.d.ts +3 -0
- package/dist/intelligence/render.d.ts.map +1 -0
- package/dist/intelligence/render.js +57 -0
- package/dist/intelligence/render.js.map +1 -0
- package/dist/intelligence/scan.d.ts +3 -0
- package/dist/intelligence/scan.d.ts.map +1 -0
- package/dist/intelligence/scan.js +103 -0
- package/dist/intelligence/scan.js.map +1 -0
- package/dist/intelligence/store.d.ts +143 -0
- package/dist/intelligence/store.d.ts.map +1 -0
- package/dist/intelligence/store.js +701 -0
- package/dist/intelligence/store.js.map +1 -0
- package/dist/notify/code-review.d.ts +34 -0
- package/dist/notify/code-review.d.ts.map +1 -0
- package/dist/notify/code-review.js +56 -0
- package/dist/notify/code-review.js.map +1 -0
- package/dist/notify/collect.d.ts +31 -0
- package/dist/notify/collect.d.ts.map +1 -0
- package/dist/notify/collect.js +127 -0
- package/dist/notify/collect.js.map +1 -0
- package/dist/notify/emit-unconverged.d.ts +26 -0
- package/dist/notify/emit-unconverged.d.ts.map +1 -0
- package/dist/notify/emit-unconverged.js +31 -0
- package/dist/notify/emit-unconverged.js.map +1 -0
- package/dist/notify/factory.d.ts +12 -0
- package/dist/notify/factory.d.ts.map +1 -0
- package/dist/notify/factory.js +29 -0
- package/dist/notify/factory.js.map +1 -0
- package/dist/notify/file.d.ts +13 -0
- package/dist/notify/file.d.ts.map +1 -0
- package/dist/notify/file.js +21 -0
- package/dist/notify/file.js.map +1 -0
- package/dist/notify/loop-violation.d.ts +10 -0
- package/dist/notify/loop-violation.d.ts.map +1 -0
- package/dist/notify/loop-violation.js +46 -0
- package/dist/notify/loop-violation.js.map +1 -0
- package/dist/notify/notifier.d.ts +13 -0
- package/dist/notify/notifier.d.ts.map +1 -0
- package/dist/notify/notifier.js +2 -0
- package/dist/notify/notifier.js.map +1 -0
- package/dist/notify/null.d.ts +11 -0
- package/dist/notify/null.d.ts.map +1 -0
- package/dist/notify/null.js +11 -0
- package/dist/notify/null.js.map +1 -0
- package/dist/notify/plan-review.d.ts +20 -0
- package/dist/notify/plan-review.d.ts.map +1 -0
- package/dist/notify/plan-review.js +15 -0
- package/dist/notify/plan-review.js.map +1 -0
- package/dist/notify/skill-audit.d.ts +18 -0
- package/dist/notify/skill-audit.d.ts.map +1 -0
- package/dist/notify/skill-audit.js +33 -0
- package/dist/notify/skill-audit.js.map +1 -0
- package/dist/notify/spec-review.d.ts +20 -0
- package/dist/notify/spec-review.d.ts.map +1 -0
- package/dist/notify/spec-review.js +15 -0
- package/dist/notify/spec-review.js.map +1 -0
- package/dist/notify/stderr.d.ts +17 -0
- package/dist/notify/stderr.d.ts.map +1 -0
- package/dist/notify/stderr.js +17 -0
- package/dist/notify/stderr.js.map +1 -0
- package/dist/notify/webhook.d.ts +33 -0
- package/dist/notify/webhook.d.ts.map +1 -0
- package/dist/notify/webhook.js +55 -0
- package/dist/notify/webhook.js.map +1 -0
- package/dist/parse/draft-parser.d.ts +3 -0
- package/dist/parse/draft-parser.d.ts.map +1 -0
- package/dist/parse/draft-parser.js +99 -0
- package/dist/parse/draft-parser.js.map +1 -0
- package/dist/parse/draft-scaffold.d.ts +14 -0
- package/dist/parse/draft-scaffold.d.ts.map +1 -0
- package/dist/parse/draft-scaffold.js +31 -0
- package/dist/parse/draft-scaffold.js.map +1 -0
- package/dist/parse/spec-parser.d.ts +3 -0
- package/dist/parse/spec-parser.d.ts.map +1 -0
- package/dist/parse/spec-parser.js +68 -0
- package/dist/parse/spec-parser.js.map +1 -0
- package/dist/parse/summary-writer.d.ts +3 -0
- package/dist/parse/summary-writer.d.ts.map +1 -0
- package/dist/parse/summary-writer.js +41 -0
- package/dist/parse/summary-writer.js.map +1 -0
- package/dist/progress.d.ts +7 -0
- package/dist/progress.d.ts.map +1 -0
- package/dist/progress.js +37 -0
- package/dist/progress.js.map +1 -0
- package/dist/render/state-md.d.ts +3 -0
- package/dist/render/state-md.d.ts.map +1 -0
- package/dist/render/state-md.js +33 -0
- package/dist/render/state-md.js.map +1 -0
- package/dist/state/atomic-write.d.ts +3 -0
- package/dist/state/atomic-write.d.ts.map +1 -0
- package/dist/state/atomic-write.js +52 -0
- package/dist/state/atomic-write.js.map +1 -0
- package/dist/state/backend.d.ts +13 -0
- package/dist/state/backend.d.ts.map +1 -0
- package/dist/state/backend.js +2 -0
- package/dist/state/backend.js.map +1 -0
- package/dist/state/simple.d.ts +18 -0
- package/dist/state/simple.d.ts.map +1 -0
- package/dist/state/simple.js +67 -0
- package/dist/state/simple.js.map +1 -0
- package/dist/status.d.ts +47 -0
- package/dist/status.d.ts.map +1 -0
- package/dist/status.js +209 -0
- package/dist/status.js.map +1 -0
- package/dist/verify/anthropic-verifier.d.ts +28 -0
- package/dist/verify/anthropic-verifier.d.ts.map +1 -0
- package/dist/verify/anthropic-verifier.js +109 -0
- package/dist/verify/anthropic-verifier.js.map +1 -0
- package/dist/verify/code-review-factory.d.ts +103 -0
- package/dist/verify/code-review-factory.d.ts.map +1 -0
- package/dist/verify/code-review-factory.js +11 -0
- package/dist/verify/code-review-factory.js.map +1 -0
- package/dist/verify/code-review.d.ts +65 -0
- package/dist/verify/code-review.d.ts.map +1 -0
- package/dist/verify/code-review.js +189 -0
- package/dist/verify/code-review.js.map +1 -0
- package/dist/verify/converge.d.ts +14 -0
- package/dist/verify/converge.d.ts.map +1 -0
- package/dist/verify/converge.js +17 -0
- package/dist/verify/converge.js.map +1 -0
- package/dist/verify/coverage.d.ts +31 -0
- package/dist/verify/coverage.d.ts.map +1 -0
- package/dist/verify/coverage.js +125 -0
- package/dist/verify/coverage.js.map +1 -0
- package/dist/verify/factory.d.ts +107 -0
- package/dist/verify/factory.d.ts.map +1 -0
- package/dist/verify/factory.js +17 -0
- package/dist/verify/factory.js.map +1 -0
- package/dist/verify/interactive.d.ts +22 -0
- package/dist/verify/interactive.d.ts.map +1 -0
- package/dist/verify/interactive.js +61 -0
- package/dist/verify/interactive.js.map +1 -0
- package/dist/verify/local-client.d.ts +13 -0
- package/dist/verify/local-client.d.ts.map +1 -0
- package/dist/verify/local-client.js +73 -0
- package/dist/verify/local-client.js.map +1 -0
- package/dist/verify/mock-verifier.d.ts +16 -0
- package/dist/verify/mock-verifier.d.ts.map +1 -0
- package/dist/verify/mock-verifier.js +30 -0
- package/dist/verify/mock-verifier.js.map +1 -0
- package/dist/verify/per-task-factory.d.ts +103 -0
- package/dist/verify/per-task-factory.d.ts.map +1 -0
- package/dist/verify/per-task-factory.js +11 -0
- package/dist/verify/per-task-factory.js.map +1 -0
- package/dist/verify/per-task.d.ts +69 -0
- package/dist/verify/per-task.d.ts.map +1 -0
- package/dist/verify/per-task.js +154 -0
- package/dist/verify/per-task.js.map +1 -0
- package/dist/verify/plan-review-factory.d.ts +103 -0
- package/dist/verify/plan-review-factory.d.ts.map +1 -0
- package/dist/verify/plan-review-factory.js +11 -0
- package/dist/verify/plan-review-factory.js.map +1 -0
- package/dist/verify/plan-review.d.ts +67 -0
- package/dist/verify/plan-review.d.ts.map +1 -0
- package/dist/verify/plan-review.js +196 -0
- package/dist/verify/plan-review.js.map +1 -0
- package/dist/verify/prompter.d.ts +40 -0
- package/dist/verify/prompter.d.ts.map +1 -0
- package/dist/verify/prompter.js +48 -0
- package/dist/verify/prompter.js.map +1 -0
- package/dist/verify/security-audit-factory.d.ts +103 -0
- package/dist/verify/security-audit-factory.d.ts.map +1 -0
- package/dist/verify/security-audit-factory.js +11 -0
- package/dist/verify/security-audit-factory.js.map +1 -0
- package/dist/verify/security-audit.d.ts +63 -0
- package/dist/verify/security-audit.d.ts.map +1 -0
- package/dist/verify/security-audit.js +196 -0
- package/dist/verify/security-audit.js.map +1 -0
- package/dist/verify/skill-match.d.ts +10 -0
- package/dist/verify/skill-match.d.ts.map +1 -0
- package/dist/verify/skill-match.js +15 -0
- package/dist/verify/skill-match.js.map +1 -0
- package/dist/verify/spec-review-factory.d.ts +103 -0
- package/dist/verify/spec-review-factory.d.ts.map +1 -0
- package/dist/verify/spec-review-factory.js +11 -0
- package/dist/verify/spec-review-factory.js.map +1 -0
- package/dist/verify/spec-review.d.ts +63 -0
- package/dist/verify/spec-review.d.ts.map +1 -0
- package/dist/verify/spec-review.js +182 -0
- package/dist/verify/spec-review.js.map +1 -0
- package/dist/verify/verifier-factory.d.ts +45 -0
- package/dist/verify/verifier-factory.d.ts.map +1 -0
- package/dist/verify/verifier-factory.js +38 -0
- package/dist/verify/verifier-factory.js.map +1 -0
- package/dist/verify/verifier.d.ts +63 -0
- package/dist/verify/verifier.d.ts.map +1 -0
- package/dist/verify/verifier.js +32 -0
- package/dist/verify/verifier.js.map +1 -0
- package/package.json +62 -0
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { readdir, readFile } from 'node:fs/promises';
|
|
2
|
+
import { existsSync } from 'node:fs';
|
|
3
|
+
import { join, relative, sep } from 'node:path';
|
|
4
|
+
const DEFAULT_GLOBS = ['packages/**/*.test.ts', 'packages/**/*.test.tsx'];
|
|
5
|
+
const AC_TOKEN_RE = /\bAC-\d+\b/g;
|
|
6
|
+
/**
|
|
7
|
+
* Walk the repo and collect a map of AC ids → tests that reference them.
|
|
8
|
+
* The convention is whole-file text search: any occurrence of `AC-N` inside
|
|
9
|
+
* a file matched by `globs` counts as one linked test. Comment refs count
|
|
10
|
+
* too, by design — the gate is binary per AC, not coverage-percentage.
|
|
11
|
+
*/
|
|
12
|
+
export async function scanTestCoverage(repoRoot, opts = {}) {
|
|
13
|
+
const out = new Map();
|
|
14
|
+
const globs = (opts.globs ?? DEFAULT_GLOBS).map(toMatcher);
|
|
15
|
+
const files = await listAllFiles(repoRoot);
|
|
16
|
+
for (const abs of files) {
|
|
17
|
+
const relPath = relative(repoRoot, abs).split(sep).join('/');
|
|
18
|
+
if (!globs.some((m) => m(relPath)))
|
|
19
|
+
continue;
|
|
20
|
+
let raw;
|
|
21
|
+
try {
|
|
22
|
+
raw = await readFile(abs, 'utf8');
|
|
23
|
+
}
|
|
24
|
+
catch {
|
|
25
|
+
continue;
|
|
26
|
+
}
|
|
27
|
+
const lines = raw.split(/\r?\n/);
|
|
28
|
+
const seenInFile = new Set();
|
|
29
|
+
for (let i = 0; i < lines.length; i++) {
|
|
30
|
+
const line = lines[i] ?? '';
|
|
31
|
+
const matches = line.matchAll(AC_TOKEN_RE);
|
|
32
|
+
for (const m of matches) {
|
|
33
|
+
const id = m[0];
|
|
34
|
+
const key = `${id}@${relPath}`;
|
|
35
|
+
if (seenInFile.has(key))
|
|
36
|
+
continue;
|
|
37
|
+
seenInFile.add(key);
|
|
38
|
+
const arr = out.get(id) ?? [];
|
|
39
|
+
arr.push({ file: relPath, line: i + 1, snippet: line.trim().slice(0, 120) });
|
|
40
|
+
out.set(id, arr);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
return out;
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Returns the list of AC ids that have zero linked tests. Useful for the
|
|
48
|
+
* settle gate's refusal message.
|
|
49
|
+
*/
|
|
50
|
+
export function uncoveredAcs(acIds, coverage) {
|
|
51
|
+
return acIds.filter((id) => (coverage.get(id) ?? []).length === 0);
|
|
52
|
+
}
|
|
53
|
+
/** Best-effort recursive listing, skipping node_modules / dist / .git. */
|
|
54
|
+
async function listAllFiles(root) {
|
|
55
|
+
if (!existsSync(root))
|
|
56
|
+
return [];
|
|
57
|
+
const out = [];
|
|
58
|
+
const stack = [root];
|
|
59
|
+
while (stack.length > 0) {
|
|
60
|
+
const dir = stack.pop();
|
|
61
|
+
let entries;
|
|
62
|
+
try {
|
|
63
|
+
entries = await readdir(dir, { withFileTypes: true });
|
|
64
|
+
}
|
|
65
|
+
catch {
|
|
66
|
+
continue;
|
|
67
|
+
}
|
|
68
|
+
for (const e of entries) {
|
|
69
|
+
if (e.name === 'node_modules' ||
|
|
70
|
+
e.name === 'dist' ||
|
|
71
|
+
e.name === '.git' ||
|
|
72
|
+
e.name === '.turbo') {
|
|
73
|
+
continue;
|
|
74
|
+
}
|
|
75
|
+
const abs = join(dir, e.name);
|
|
76
|
+
if (e.isDirectory()) {
|
|
77
|
+
stack.push(abs);
|
|
78
|
+
}
|
|
79
|
+
else if (e.isFile()) {
|
|
80
|
+
out.push(abs);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return out;
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Compile a glob pattern (subset: `**`, `*`, literal segments) into a
|
|
88
|
+
* predicate over forward-slashed relative paths. Examples:
|
|
89
|
+
* `packages/**\/*.test.ts` → matches `packages/core/tests/foo.test.ts`
|
|
90
|
+
* `**\/*.test.ts` → matches `apps/api/__tests__/bar.test.ts`
|
|
91
|
+
*/
|
|
92
|
+
function toMatcher(pattern) {
|
|
93
|
+
const re = globToRegExp(pattern);
|
|
94
|
+
return (p) => re.test(p);
|
|
95
|
+
}
|
|
96
|
+
function globToRegExp(pattern) {
|
|
97
|
+
// Tokenize: split on '/', then handle '**' specially.
|
|
98
|
+
const parts = pattern.split('/');
|
|
99
|
+
const reParts = [];
|
|
100
|
+
for (let i = 0; i < parts.length; i++) {
|
|
101
|
+
const part = parts[i];
|
|
102
|
+
if (part === '**') {
|
|
103
|
+
// Match zero-or-more path segments.
|
|
104
|
+
// If there is a following part, allow `**/x` to match `x` too (zero segments).
|
|
105
|
+
const next = parts[i + 1];
|
|
106
|
+
if (next !== undefined) {
|
|
107
|
+
reParts.push('(?:[^/]+/)*');
|
|
108
|
+
// Consume the trailing slash semantics; let the next iteration add `next` literally.
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
reParts.push('.*');
|
|
112
|
+
}
|
|
113
|
+
continue;
|
|
114
|
+
}
|
|
115
|
+
// Escape regex specials except `*`.
|
|
116
|
+
const seg = part
|
|
117
|
+
.replace(/[.+?^${}()|[\]\\]/g, '\\$&')
|
|
118
|
+
.replace(/\*/g, '[^/]*');
|
|
119
|
+
reParts.push(seg);
|
|
120
|
+
if (i < parts.length - 1)
|
|
121
|
+
reParts.push('/');
|
|
122
|
+
}
|
|
123
|
+
return new RegExp('^' + reParts.join('') + '$');
|
|
124
|
+
}
|
|
125
|
+
//# sourceMappingURL=coverage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coverage.js","sourceRoot":"","sources":["../../src/verify/coverage.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import { type Verifier } from './verifier.js';
|
|
2
|
+
import { type VerifierSelectOptions } from './verifier-factory.js';
|
|
3
|
+
/** @deprecated alias of `VerifierSelectOptions` (kept for API stability). */
|
|
4
|
+
export type SelectVerifierOptions = VerifierSelectOptions;
|
|
5
|
+
/**
|
|
6
|
+
* Picks the right verifier given config + env (Phase 15). Falls back to mock
|
|
7
|
+
* when a provider's prerequisites are missing — with a stderr warning so the
|
|
8
|
+
* caller knows downgrading happened.
|
|
9
|
+
*/
|
|
10
|
+
export declare const selectVerifier: (config: Pick<{
|
|
11
|
+
schemaVersion: 1;
|
|
12
|
+
profile: "strict" | "standard" | "auto";
|
|
13
|
+
loopEnforcement: "strict" | "soft" | "reminder";
|
|
14
|
+
acDiscipline: "strict" | "tier-scaled" | "optional";
|
|
15
|
+
workstreamBackend: string;
|
|
16
|
+
ruleProvider: string;
|
|
17
|
+
subagentPolicy: {
|
|
18
|
+
contextBudgetThreshold: number;
|
|
19
|
+
largeTaskTokens: number;
|
|
20
|
+
mechanicalBatchMin: number;
|
|
21
|
+
};
|
|
22
|
+
modelPerClass: {
|
|
23
|
+
standard: string;
|
|
24
|
+
mechanical: string;
|
|
25
|
+
complex: string;
|
|
26
|
+
drafting: string;
|
|
27
|
+
};
|
|
28
|
+
commitCadence: "task" | "draft" | "manual";
|
|
29
|
+
templates: {
|
|
30
|
+
dir: string;
|
|
31
|
+
overrides: string[];
|
|
32
|
+
};
|
|
33
|
+
hooks: {
|
|
34
|
+
sessionStart: boolean;
|
|
35
|
+
stopReminder: boolean;
|
|
36
|
+
preToolUseBuildGate: boolean;
|
|
37
|
+
userPromptSubmit: boolean;
|
|
38
|
+
};
|
|
39
|
+
packs: {
|
|
40
|
+
enabled: string[];
|
|
41
|
+
disabled: string[];
|
|
42
|
+
};
|
|
43
|
+
telemetry: {
|
|
44
|
+
tokenUtilization: boolean;
|
|
45
|
+
skillInvocations: boolean;
|
|
46
|
+
remoteOptIn: boolean;
|
|
47
|
+
};
|
|
48
|
+
skillAudit: {
|
|
49
|
+
required: string[];
|
|
50
|
+
};
|
|
51
|
+
convergence: {
|
|
52
|
+
maxAttempts: number;
|
|
53
|
+
};
|
|
54
|
+
specReview: {
|
|
55
|
+
provider: "mock" | "anthropic" | "local";
|
|
56
|
+
model?: string | undefined;
|
|
57
|
+
};
|
|
58
|
+
tier: {
|
|
59
|
+
standard: {
|
|
60
|
+
maxTasks: number;
|
|
61
|
+
maxFiles: number;
|
|
62
|
+
};
|
|
63
|
+
complex: {
|
|
64
|
+
maxTasks: number;
|
|
65
|
+
minTasks: number;
|
|
66
|
+
};
|
|
67
|
+
quickFix: {
|
|
68
|
+
maxTasks: number;
|
|
69
|
+
maxFiles: number;
|
|
70
|
+
};
|
|
71
|
+
};
|
|
72
|
+
verification: {
|
|
73
|
+
testGlobs: string[];
|
|
74
|
+
testCommand?: string | undefined;
|
|
75
|
+
};
|
|
76
|
+
verifier: {
|
|
77
|
+
provider: "mock" | "anthropic" | "local";
|
|
78
|
+
model?: string | undefined;
|
|
79
|
+
};
|
|
80
|
+
perTaskVerifier: {
|
|
81
|
+
provider: "mock" | "anthropic" | "local";
|
|
82
|
+
model?: string | undefined;
|
|
83
|
+
};
|
|
84
|
+
codeReview: {
|
|
85
|
+
provider: "mock" | "anthropic" | "local";
|
|
86
|
+
model?: string | undefined;
|
|
87
|
+
};
|
|
88
|
+
planReview: {
|
|
89
|
+
provider: "mock" | "anthropic" | "local";
|
|
90
|
+
model?: string | undefined;
|
|
91
|
+
};
|
|
92
|
+
securityAudit: {
|
|
93
|
+
provider: "mock" | "anthropic" | "local";
|
|
94
|
+
model?: string | undefined;
|
|
95
|
+
};
|
|
96
|
+
notify: {
|
|
97
|
+
transport: "stderr" | "file" | "none" | "webhook";
|
|
98
|
+
file?: string | undefined;
|
|
99
|
+
webhook?: {
|
|
100
|
+
url: string;
|
|
101
|
+
headers?: Record<string, string> | undefined;
|
|
102
|
+
timeoutMs?: number | undefined;
|
|
103
|
+
} | undefined;
|
|
104
|
+
};
|
|
105
|
+
$schema?: string | undefined;
|
|
106
|
+
}, "verifier"> | null, opts?: VerifierSelectOptions) => Verifier;
|
|
107
|
+
//# sourceMappingURL=factory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../src/verify/factory.ts"],"names":[],"mappings":"AAGA,OAAO,EAAiB,KAAK,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC7D,OAAO,EAEL,KAAK,qBAAqB,EAC3B,MAAM,uBAAuB,CAAC;AAE/B,6EAA6E;AAC7E,MAAM,MAAM,qBAAqB,GAAG,qBAAqB,CAAC;AAE1D;;;;GAIG;AACH,eAAO,MAAM,cAAc;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;aAUyvY,CAAC;;;;;;;;;;;;;;;;;;mBAAoY,CAAC;;;;aAA4G,CAAC;;;;aAAmH,CAAC;;;;aAA8G,CAAC;;;;aAA8G,CAAC;;;;aAAiH,CAAC;;;;YAAkH,CAAC;eAAqC,CAAC;;mBAAgD,CAAC;qBAA2D,CAAC;;;;gEAD/8a,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { AnthropicVerifier } from './anthropic-verifier.js';
|
|
2
|
+
import { MockVerifier } from './mock-verifier.js';
|
|
3
|
+
import { LocalVerifier } from './verifier.js';
|
|
4
|
+
import { createVerifierFactory, } from './verifier-factory.js';
|
|
5
|
+
/**
|
|
6
|
+
* Picks the right verifier given config + env (Phase 15). Falls back to mock
|
|
7
|
+
* when a provider's prerequisites are missing — with a stderr warning so the
|
|
8
|
+
* caller knows downgrading happened.
|
|
9
|
+
*/
|
|
10
|
+
export const selectVerifier = createVerifierFactory({
|
|
11
|
+
label: 'verifier',
|
|
12
|
+
read: (c) => c?.verifier,
|
|
13
|
+
mock: () => new MockVerifier(),
|
|
14
|
+
anthropic: (o) => new AnthropicVerifier(o),
|
|
15
|
+
local: (o) => new LocalVerifier(o),
|
|
16
|
+
});
|
|
17
|
+
//# sourceMappingURL=factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"factory.js","sourceRoot":"","sources":["../../src/verify/factory.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAiB,MAAM,eAAe,CAAC;AAC7D,OAAO,EACL,qBAAqB,GAEtB,MAAM,uBAAuB,CAAC;AAK/B;;;;GAIG;AACH,MAAM,CAAC,MAAM,cAAc,GAAG,qBAAqB,CAGjD;IACA,KAAK,EAAE,UAAU;IACjB,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,QAAQ;IACxB,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI,YAAY,EAAE;IAC9B,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,iBAAiB,CAAC,CAAC,CAAC;IAC1C,KAAK,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,aAAa,CAAC,CAAC,CAAC;CACnC,CAAC,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { Prompter } from './prompter.js';
|
|
2
|
+
import type { VerifyAc, VerifyTestRef } from './verifier.js';
|
|
3
|
+
export interface InteractiveVerdict {
|
|
4
|
+
verdict: 'pass' | 'fail';
|
|
5
|
+
note?: string;
|
|
6
|
+
}
|
|
7
|
+
export interface InteractiveInput {
|
|
8
|
+
acs: VerifyAc[];
|
|
9
|
+
tests: Record<string, VerifyTestRef[]>;
|
|
10
|
+
files: string[];
|
|
11
|
+
}
|
|
12
|
+
export interface WalkOptions {
|
|
13
|
+
/** Test seam — defaults to `process.stdout.write`. */
|
|
14
|
+
write?: (chunk: string) => void;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Walk each AC in order, render its context, and prompt the user for a verdict.
|
|
18
|
+
* Returns one entry per AC the user verdicted on (`pass` or `fail`). Skipped
|
|
19
|
+
* ACs are omitted from the result so they can fall through to other gates.
|
|
20
|
+
*/
|
|
21
|
+
export declare function walkAcsInteractively(input: InteractiveInput, prompter: Prompter, opts?: WalkOptions): Promise<Record<string, InteractiveVerdict>>;
|
|
22
|
+
//# sourceMappingURL=interactive.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interactive.d.ts","sourceRoot":"","sources":["../../src/verify/interactive.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,KAAK,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAE7D,MAAM,WAAW,kBAAkB;IACjC,OAAO,EAAE,MAAM,GAAG,MAAM,CAAC;IACzB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,gBAAgB;IAC/B,GAAG,EAAE,QAAQ,EAAE,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,EAAE,CAAC,CAAC;IACvC,KAAK,EAAE,MAAM,EAAE,CAAC;CACjB;AAED,MAAM,WAAW,WAAW;IAC1B,sDAAsD;IACtD,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACjC;AAED;;;;GAIG;AACH,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,gBAAgB,EACvB,QAAQ,EAAE,QAAQ,EAClB,IAAI,GAAE,WAAgB,GACrB,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,kBAAkB,CAAC,CAAC,CA0C7C"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Walk each AC in order, render its context, and prompt the user for a verdict.
|
|
3
|
+
* Returns one entry per AC the user verdicted on (`pass` or `fail`). Skipped
|
|
4
|
+
* ACs are omitted from the result so they can fall through to other gates.
|
|
5
|
+
*/
|
|
6
|
+
export async function walkAcsInteractively(input, prompter, opts = {}) {
|
|
7
|
+
const write = opts.write ?? ((c) => process.stdout.write(c));
|
|
8
|
+
const out = {};
|
|
9
|
+
write(`\nCADENCE — interactive verdict (${input.acs.length} AC${input.acs.length === 1 ? '' : 's'})\n`);
|
|
10
|
+
write('Answer per AC: pass | fail | skip. Skip falls through to other gates.\n');
|
|
11
|
+
for (const ac of input.acs) {
|
|
12
|
+
write(`\n──── ${ac.id} ────────────────────────────────────────────────\n`);
|
|
13
|
+
write(`Given: ${ac.given}\n`);
|
|
14
|
+
write(`When: ${ac.when}\n`);
|
|
15
|
+
write(`Then: ${ac.then}\n`);
|
|
16
|
+
const linked = input.tests[ac.id] ?? [];
|
|
17
|
+
if (linked.length > 0) {
|
|
18
|
+
write(`Linked tests (${linked.length}):\n`);
|
|
19
|
+
for (const t of linked.slice(0, 5)) {
|
|
20
|
+
write(` - ${t.file}:${t.line}\n`);
|
|
21
|
+
}
|
|
22
|
+
if (linked.length > 5)
|
|
23
|
+
write(` … and ${linked.length - 5} more\n`);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
write('Linked tests: (none)\n');
|
|
27
|
+
}
|
|
28
|
+
if (input.files.length > 0) {
|
|
29
|
+
write(`Touched files: ${input.files.slice(0, 5).join(', ')}`);
|
|
30
|
+
if (input.files.length > 5)
|
|
31
|
+
write(` (+${input.files.length - 5} more)`);
|
|
32
|
+
write('\n');
|
|
33
|
+
}
|
|
34
|
+
const verdict = await askVerdict(prompter, ac.id);
|
|
35
|
+
if (verdict === 'skip') {
|
|
36
|
+
write(`→ ${ac.id}: skipped\n`);
|
|
37
|
+
continue;
|
|
38
|
+
}
|
|
39
|
+
const note = await askNote(prompter);
|
|
40
|
+
out[ac.id] = note ? { verdict, note } : { verdict };
|
|
41
|
+
write(`→ ${ac.id}: ${verdict}${note ? ` — ${note}` : ''}\n`);
|
|
42
|
+
}
|
|
43
|
+
return out;
|
|
44
|
+
}
|
|
45
|
+
async function askVerdict(prompter, acId) {
|
|
46
|
+
for (let attempt = 0; attempt < 3; attempt++) {
|
|
47
|
+
const raw = (await prompter.ask(`${acId} verdict [pass/fail/skip]: `)).trim().toLowerCase();
|
|
48
|
+
if (raw === 'pass' || raw === 'p')
|
|
49
|
+
return 'pass';
|
|
50
|
+
if (raw === 'fail' || raw === 'f')
|
|
51
|
+
return 'fail';
|
|
52
|
+
if (raw === 'skip' || raw === 's' || raw === '')
|
|
53
|
+
return 'skip';
|
|
54
|
+
}
|
|
55
|
+
throw new Error(`walker: failed to read a valid verdict for ${acId} after 3 attempts`);
|
|
56
|
+
}
|
|
57
|
+
async function askNote(prompter) {
|
|
58
|
+
const raw = (await prompter.ask('Note (optional, one line, blank to skip): ')).trim();
|
|
59
|
+
return raw.length > 0 ? raw : undefined;
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=interactive.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interactive.js","sourceRoot":"","sources":["../../src/verify/interactive.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { ZodType } from 'zod/v4';
|
|
2
|
+
export interface LocalChatJSONOptions<T> {
|
|
3
|
+
baseURL: string;
|
|
4
|
+
model: string;
|
|
5
|
+
system: string;
|
|
6
|
+
user: string;
|
|
7
|
+
schema: ZodType<T>;
|
|
8
|
+
/** Test seam; defaults to global fetch. */
|
|
9
|
+
transport?: typeof fetch;
|
|
10
|
+
maxTokens?: number;
|
|
11
|
+
}
|
|
12
|
+
export declare function localChatJSON<T>(o: LocalChatJSONOptions<T>): Promise<T>;
|
|
13
|
+
//# sourceMappingURL=local-client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-client.d.ts","sourceRoot":"","sources":["../../src/verify/local-client.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AAEtC,MAAM,WAAW,oBAAoB,CAAC,CAAC;IACrC,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACnB,2CAA2C;IAC3C,SAAS,CAAC,EAAE,OAAO,KAAK,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAsDD,wBAAsB,aAAa,CAAC,CAAC,EAAE,CAAC,EAAE,oBAAoB,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAgC7E"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
/** Extract a JSON object from model content: drop fences, slice first { … last }. */
|
|
2
|
+
function extractJson(content) {
|
|
3
|
+
const noFence = content.replace(/```(?:json)?/gi, '');
|
|
4
|
+
const start = noFence.indexOf('{');
|
|
5
|
+
const end = noFence.lastIndexOf('}');
|
|
6
|
+
if (start === -1 || end === -1 || end < start)
|
|
7
|
+
return noFence.trim();
|
|
8
|
+
return noFence.slice(start, end + 1);
|
|
9
|
+
}
|
|
10
|
+
async function callOnce(o, messages) {
|
|
11
|
+
const fetchImpl = o.transport ?? fetch;
|
|
12
|
+
let res;
|
|
13
|
+
try {
|
|
14
|
+
res = await fetchImpl(`${o.baseURL}/chat/completions`, {
|
|
15
|
+
method: 'POST',
|
|
16
|
+
headers: { 'content-type': 'application/json' },
|
|
17
|
+
body: JSON.stringify({
|
|
18
|
+
model: o.model,
|
|
19
|
+
messages,
|
|
20
|
+
response_format: { type: 'json_object' },
|
|
21
|
+
temperature: 0,
|
|
22
|
+
...(o.maxTokens ? { max_tokens: o.maxTokens } : {}),
|
|
23
|
+
}),
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
catch (err) {
|
|
27
|
+
throw new Error(`local provider: request to ${o.baseURL} failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
28
|
+
}
|
|
29
|
+
if (!res.ok) {
|
|
30
|
+
throw new Error(`local provider: ${o.baseURL} returned HTTP ${res.status}`);
|
|
31
|
+
}
|
|
32
|
+
const body = (await res.json());
|
|
33
|
+
return body.choices?.[0]?.message?.content ?? '';
|
|
34
|
+
}
|
|
35
|
+
function safeJson(s) {
|
|
36
|
+
try {
|
|
37
|
+
return JSON.parse(s);
|
|
38
|
+
}
|
|
39
|
+
catch {
|
|
40
|
+
return undefined; // schema.safeParse(undefined) fails → triggers repair/throw
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
/** Initial call + this many repair retries before throwing. */
|
|
44
|
+
const MAX_REPAIR_RETRIES = 2;
|
|
45
|
+
export async function localChatJSON(o) {
|
|
46
|
+
const messages = [
|
|
47
|
+
{ role: 'system', content: o.system },
|
|
48
|
+
{ role: 'user', content: o.user },
|
|
49
|
+
];
|
|
50
|
+
let raw = await callOnce(o, messages);
|
|
51
|
+
let parsed = o.schema.safeParse(safeJson(extractJson(raw)));
|
|
52
|
+
let lastError = parsed.success ? '' : parsed.error.message;
|
|
53
|
+
for (let retry = 0; !parsed.success && retry < MAX_REPAIR_RETRIES; retry++) {
|
|
54
|
+
// Repair retry: feed back the bad output + the validation error.
|
|
55
|
+
const repairMessages = [
|
|
56
|
+
...messages,
|
|
57
|
+
{ role: 'assistant', content: raw },
|
|
58
|
+
{
|
|
59
|
+
role: 'user',
|
|
60
|
+
content: 'That was not valid. Return ONLY strict JSON matching the required schema, no prose, no code fences. Error: ' +
|
|
61
|
+
lastError,
|
|
62
|
+
},
|
|
63
|
+
];
|
|
64
|
+
raw = await callOnce(o, repairMessages);
|
|
65
|
+
parsed = o.schema.safeParse(safeJson(extractJson(raw)));
|
|
66
|
+
if (!parsed.success)
|
|
67
|
+
lastError = parsed.error.message;
|
|
68
|
+
}
|
|
69
|
+
if (parsed.success)
|
|
70
|
+
return parsed.data;
|
|
71
|
+
throw new Error(`local provider: model output failed JSON/schema validation after ${MAX_REPAIR_RETRIES} repair retries (${o.baseURL}, model=${o.model}): ${lastError}`);
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=local-client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-client.js","sourceRoot":"","sources":["../../src/verify/local-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { Verifier, VerifyInput, VerifyResult } from './verifier.js';
|
|
2
|
+
/**
|
|
3
|
+
* Deterministic mock provider. Rule: an AC passes iff it has ≥1 linked test
|
|
4
|
+
* in `input.tests[ac.id]`; otherwise it fails with reason
|
|
5
|
+
* `"no linked test found"`. Pure function — no I/O — so the gate is testable
|
|
6
|
+
* offline and CI doesn't need an API key.
|
|
7
|
+
*
|
|
8
|
+
* The rule deliberately mirrors the Phase 14 coverage gate. Mock is a
|
|
9
|
+
* deterministic floor; real verifiers (Anthropic, etc.) read the diff + test
|
|
10
|
+
* bodies to give a richer behavioral verdict.
|
|
11
|
+
*/
|
|
12
|
+
export declare class MockVerifier implements Verifier {
|
|
13
|
+
readonly name = "mock";
|
|
14
|
+
verify(input: VerifyInput): Promise<VerifyResult>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=mock-verifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mock-verifier.d.ts","sourceRoot":"","sources":["../../src/verify/mock-verifier.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAEzE;;;;;;;;;GASG;AACH,qBAAa,YAAa,YAAW,QAAQ;IAC3C,QAAQ,CAAC,IAAI,UAAU;IAEjB,MAAM,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,YAAY,CAAC;CAexD"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Deterministic mock provider. Rule: an AC passes iff it has ≥1 linked test
|
|
3
|
+
* in `input.tests[ac.id]`; otherwise it fails with reason
|
|
4
|
+
* `"no linked test found"`. Pure function — no I/O — so the gate is testable
|
|
5
|
+
* offline and CI doesn't need an API key.
|
|
6
|
+
*
|
|
7
|
+
* The rule deliberately mirrors the Phase 14 coverage gate. Mock is a
|
|
8
|
+
* deterministic floor; real verifiers (Anthropic, etc.) read the diff + test
|
|
9
|
+
* bodies to give a richer behavioral verdict.
|
|
10
|
+
*/
|
|
11
|
+
export class MockVerifier {
|
|
12
|
+
name = 'mock';
|
|
13
|
+
async verify(input) {
|
|
14
|
+
const verdicts = {};
|
|
15
|
+
for (const ac of input.acs) {
|
|
16
|
+
const linkedTests = input.tests[ac.id] ?? [];
|
|
17
|
+
if (linkedTests.length > 0) {
|
|
18
|
+
verdicts[ac.id] = {
|
|
19
|
+
pass: true,
|
|
20
|
+
reason: `mock: ${linkedTests.length} linked test${linkedTests.length === 1 ? '' : 's'} (${linkedTests[0].file}:${linkedTests[0].line})`,
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
verdicts[ac.id] = { pass: false, reason: 'no linked test found' };
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
return { verdicts, provider: this.name };
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=mock-verifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mock-verifier.js","sourceRoot":"","sources":["../../src/verify/mock-verifier.ts"],"names":[],"mappings":"AAEA;;;;;;;;;GASG;AACH,MAAM,OAAO,YAAY;IACd,IAAI,GAAG,MAAM,CAAC;IAEvB,KAAK,CAAC,MAAM,CAAC,KAAkB;QAC7B,MAAM,QAAQ,GAA6B,EAAE,CAAC;QAC9C,KAAK,MAAM,EAAE,IAAI,KAAK,CAAC,GAAG,EAAE,CAAC;YAC3B,MAAM,WAAW,GAAG,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC;YAC7C,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC3B,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG;oBAChB,IAAI,EAAE,IAAI;oBACV,MAAM,EAAE,SAAS,WAAW,CAAC,MAAM,eAAe,WAAW,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,WAAW,CAAC,CAAC,CAAE,CAAC,IAAI,IAAI,WAAW,CAAC,CAAC,CAAE,CAAC,IAAI,GAAG;iBAC1I,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,sBAAsB,EAAE,CAAC;YACpE,CAAC;QACH,CAAC;QACD,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC;IAC3C,CAAC;CACF"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { type PerTaskVerifier } from './per-task.js';
|
|
2
|
+
import { type VerifierSelectOptions } from './verifier-factory.js';
|
|
3
|
+
/** @deprecated alias of `VerifierSelectOptions` (kept for API stability). */
|
|
4
|
+
export type SelectPerTaskVerifierOptions = VerifierSelectOptions;
|
|
5
|
+
/** Picks the per-task verifier given config + env (Phase 24.2). */
|
|
6
|
+
export declare const selectPerTaskVerifier: (config: Pick<{
|
|
7
|
+
schemaVersion: 1;
|
|
8
|
+
profile: "strict" | "standard" | "auto";
|
|
9
|
+
loopEnforcement: "strict" | "soft" | "reminder";
|
|
10
|
+
acDiscipline: "strict" | "tier-scaled" | "optional";
|
|
11
|
+
workstreamBackend: string;
|
|
12
|
+
ruleProvider: string;
|
|
13
|
+
subagentPolicy: {
|
|
14
|
+
contextBudgetThreshold: number;
|
|
15
|
+
largeTaskTokens: number;
|
|
16
|
+
mechanicalBatchMin: number;
|
|
17
|
+
};
|
|
18
|
+
modelPerClass: {
|
|
19
|
+
standard: string;
|
|
20
|
+
mechanical: string;
|
|
21
|
+
complex: string;
|
|
22
|
+
drafting: string;
|
|
23
|
+
};
|
|
24
|
+
commitCadence: "task" | "draft" | "manual";
|
|
25
|
+
templates: {
|
|
26
|
+
dir: string;
|
|
27
|
+
overrides: string[];
|
|
28
|
+
};
|
|
29
|
+
hooks: {
|
|
30
|
+
sessionStart: boolean;
|
|
31
|
+
stopReminder: boolean;
|
|
32
|
+
preToolUseBuildGate: boolean;
|
|
33
|
+
userPromptSubmit: boolean;
|
|
34
|
+
};
|
|
35
|
+
packs: {
|
|
36
|
+
enabled: string[];
|
|
37
|
+
disabled: string[];
|
|
38
|
+
};
|
|
39
|
+
telemetry: {
|
|
40
|
+
tokenUtilization: boolean;
|
|
41
|
+
skillInvocations: boolean;
|
|
42
|
+
remoteOptIn: boolean;
|
|
43
|
+
};
|
|
44
|
+
skillAudit: {
|
|
45
|
+
required: string[];
|
|
46
|
+
};
|
|
47
|
+
convergence: {
|
|
48
|
+
maxAttempts: number;
|
|
49
|
+
};
|
|
50
|
+
specReview: {
|
|
51
|
+
provider: "mock" | "anthropic" | "local";
|
|
52
|
+
model?: string | undefined;
|
|
53
|
+
};
|
|
54
|
+
tier: {
|
|
55
|
+
standard: {
|
|
56
|
+
maxTasks: number;
|
|
57
|
+
maxFiles: number;
|
|
58
|
+
};
|
|
59
|
+
complex: {
|
|
60
|
+
maxTasks: number;
|
|
61
|
+
minTasks: number;
|
|
62
|
+
};
|
|
63
|
+
quickFix: {
|
|
64
|
+
maxTasks: number;
|
|
65
|
+
maxFiles: number;
|
|
66
|
+
};
|
|
67
|
+
};
|
|
68
|
+
verification: {
|
|
69
|
+
testGlobs: string[];
|
|
70
|
+
testCommand?: string | undefined;
|
|
71
|
+
};
|
|
72
|
+
verifier: {
|
|
73
|
+
provider: "mock" | "anthropic" | "local";
|
|
74
|
+
model?: string | undefined;
|
|
75
|
+
};
|
|
76
|
+
perTaskVerifier: {
|
|
77
|
+
provider: "mock" | "anthropic" | "local";
|
|
78
|
+
model?: string | undefined;
|
|
79
|
+
};
|
|
80
|
+
codeReview: {
|
|
81
|
+
provider: "mock" | "anthropic" | "local";
|
|
82
|
+
model?: string | undefined;
|
|
83
|
+
};
|
|
84
|
+
planReview: {
|
|
85
|
+
provider: "mock" | "anthropic" | "local";
|
|
86
|
+
model?: string | undefined;
|
|
87
|
+
};
|
|
88
|
+
securityAudit: {
|
|
89
|
+
provider: "mock" | "anthropic" | "local";
|
|
90
|
+
model?: string | undefined;
|
|
91
|
+
};
|
|
92
|
+
notify: {
|
|
93
|
+
transport: "stderr" | "file" | "none" | "webhook";
|
|
94
|
+
file?: string | undefined;
|
|
95
|
+
webhook?: {
|
|
96
|
+
url: string;
|
|
97
|
+
headers?: Record<string, string> | undefined;
|
|
98
|
+
timeoutMs?: number | undefined;
|
|
99
|
+
} | undefined;
|
|
100
|
+
};
|
|
101
|
+
$schema?: string | undefined;
|
|
102
|
+
}, "perTaskVerifier"> | null, opts?: VerifierSelectOptions) => PerTaskVerifier;
|
|
103
|
+
//# sourceMappingURL=per-task-factory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"per-task-factory.d.ts","sourceRoot":"","sources":["../../src/verify/per-task-factory.ts"],"names":[],"mappings":"AACA,OAAO,EAIL,KAAK,eAAe,EACrB,MAAM,eAAe,CAAC;AACvB,OAAO,EAEL,KAAK,qBAAqB,EAC3B,MAAM,uBAAuB,CAAC;AAE/B,6EAA6E;AAC7E,MAAM,MAAM,4BAA4B,GAAG,qBAAqB,CAAC;AAEjE,mEAAmE;AACnE,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;aAUm2Y,CAAC;;;;;;;;;;;;;;;;;;mBAAoY,CAAC;;;;aAA4G,CAAC;;;;aAAmH,CAAC;;;;aAA8G,CAAC;;;;aAA8G,CAAC;;;;aAAiH,CAAC;;;;YAAkH,CAAC;eAAqC,CAAC;;mBAAgD,CAAC;qBAA2D,CAAC;;;;8EADhkb,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { AnthropicPerTaskVerifier, LocalPerTaskVerifier, MockPerTaskVerifier, } from './per-task.js';
|
|
2
|
+
import { createVerifierFactory, } from './verifier-factory.js';
|
|
3
|
+
/** Picks the per-task verifier given config + env (Phase 24.2). */
|
|
4
|
+
export const selectPerTaskVerifier = createVerifierFactory({
|
|
5
|
+
label: 'per-task-verify',
|
|
6
|
+
read: (c) => c?.perTaskVerifier,
|
|
7
|
+
mock: () => new MockPerTaskVerifier(),
|
|
8
|
+
anthropic: (o) => new AnthropicPerTaskVerifier(o),
|
|
9
|
+
local: (o) => new LocalPerTaskVerifier(o),
|
|
10
|
+
});
|
|
11
|
+
//# sourceMappingURL=per-task-factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"per-task-factory.js","sourceRoot":"","sources":["../../src/verify/per-task-factory.ts"],"names":[],"mappings":"AACA,OAAO,EACL,wBAAwB,EACxB,oBAAoB,EACpB,mBAAmB,GAEpB,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,qBAAqB,GAEtB,MAAM,uBAAuB,CAAC;AAK/B,mEAAmE;AACnE,MAAM,CAAC,MAAM,qBAAqB,GAAG,qBAAqB,CAGxD;IACA,KAAK,EAAE,iBAAiB;IACxB,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,eAAe;IAC/B,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI,mBAAmB,EAAE;IACrC,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,wBAAwB,CAAC,CAAC,CAAC;IACjD,KAAK,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,oBAAoB,CAAC,CAAC,CAAC;CAC1C,CAAC,CAAC"}
|