@paths.design/caws-cli 10.1.0 → 11.0.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/README.md +125 -374
- package/dist/index.js +43 -756
- package/dist/shell/binding/resolve-binding.d.ts +4 -0
- package/dist/shell/binding/resolve-binding.d.ts.map +1 -0
- package/dist/shell/binding/resolve-binding.js +228 -0
- package/dist/shell/binding/resolve-binding.js.map +1 -0
- package/dist/shell/binding/types.d.ts +42 -0
- package/dist/shell/binding/types.d.ts.map +1 -0
- package/dist/shell/binding/types.js +21 -0
- package/dist/shell/binding/types.js.map +1 -0
- package/dist/shell/commands/claim.d.ts +14 -0
- package/dist/shell/commands/claim.d.ts.map +1 -0
- package/dist/shell/commands/claim.js +197 -0
- package/dist/shell/commands/claim.js.map +1 -0
- package/dist/shell/commands/doctor.d.ts +13 -0
- package/dist/shell/commands/doctor.d.ts.map +1 -0
- package/dist/shell/commands/doctor.js +97 -0
- package/dist/shell/commands/doctor.js.map +1 -0
- package/dist/shell/commands/evidence.d.ts +28 -0
- package/dist/shell/commands/evidence.d.ts.map +1 -0
- package/dist/shell/commands/evidence.js +166 -0
- package/dist/shell/commands/evidence.js.map +1 -0
- package/dist/shell/commands/gates.d.ts +19 -0
- package/dist/shell/commands/gates.d.ts.map +1 -0
- package/dist/shell/commands/gates.js +181 -0
- package/dist/shell/commands/gates.js.map +1 -0
- package/dist/shell/commands/init.d.ts +8 -0
- package/dist/shell/commands/init.d.ts.map +1 -0
- package/dist/shell/commands/init.js +64 -0
- package/dist/shell/commands/init.js.map +1 -0
- package/dist/shell/commands/scope.d.ts +11 -0
- package/dist/shell/commands/scope.d.ts.map +1 -0
- package/dist/shell/commands/scope.js +92 -0
- package/dist/shell/commands/scope.js.map +1 -0
- package/dist/shell/commands/status.d.ts +15 -0
- package/dist/shell/commands/status.d.ts.map +1 -0
- package/dist/shell/commands/status.js +106 -0
- package/dist/shell/commands/status.js.map +1 -0
- package/dist/shell/commands/waiver.d.ts +38 -0
- package/dist/shell/commands/waiver.d.ts.map +1 -0
- package/dist/shell/commands/waiver.js +240 -0
- package/dist/shell/commands/waiver.js.map +1 -0
- package/dist/shell/gates/disposition.d.ts +23 -0
- package/dist/shell/gates/disposition.d.ts.map +1 -0
- package/dist/shell/gates/disposition.js +87 -0
- package/dist/shell/gates/disposition.js.map +1 -0
- package/dist/shell/gates/gate-result-contract.d.ts +39 -0
- package/dist/shell/gates/gate-result-contract.d.ts.map +1 -0
- package/dist/shell/gates/gate-result-contract.js +150 -0
- package/dist/shell/gates/gate-result-contract.js.map +1 -0
- package/dist/shell/gates/quality-gates-adapter.d.ts +55 -0
- package/dist/shell/gates/quality-gates-adapter.d.ts.map +1 -0
- package/dist/shell/gates/quality-gates-adapter.js +161 -0
- package/dist/shell/gates/quality-gates-adapter.js.map +1 -0
- package/dist/shell/gates/waiver-filter.d.ts +58 -0
- package/dist/shell/gates/waiver-filter.d.ts.map +1 -0
- package/dist/shell/gates/waiver-filter.js +119 -0
- package/dist/shell/gates/waiver-filter.js.map +1 -0
- package/dist/shell/index.d.ts +50 -0
- package/dist/shell/index.d.ts.map +1 -0
- package/dist/shell/index.js +73 -0
- package/dist/shell/index.js.map +1 -0
- package/dist/shell/register.d.ts +11 -0
- package/dist/shell/register.d.ts.map +1 -0
- package/dist/shell/register.js +274 -0
- package/dist/shell/register.js.map +1 -0
- package/dist/shell/render/claim.d.ts +22 -0
- package/dist/shell/render/claim.d.ts.map +1 -0
- package/dist/shell/render/claim.js +75 -0
- package/dist/shell/render/claim.js.map +1 -0
- package/dist/shell/render/decision.d.ts +15 -0
- package/dist/shell/render/decision.d.ts.map +1 -0
- package/dist/shell/render/decision.js +66 -0
- package/dist/shell/render/decision.js.map +1 -0
- package/dist/shell/render/diagnostic.d.ts +19 -0
- package/dist/shell/render/diagnostic.d.ts.map +1 -0
- package/dist/shell/render/diagnostic.js +76 -0
- package/dist/shell/render/diagnostic.js.map +1 -0
- package/dist/shell/render/finding.d.ts +15 -0
- package/dist/shell/render/finding.d.ts.map +1 -0
- package/dist/shell/render/finding.js +57 -0
- package/dist/shell/render/finding.js.map +1 -0
- package/dist/shell/render/gates.d.ts +3 -0
- package/dist/shell/render/gates.d.ts.map +1 -0
- package/dist/shell/render/gates.js +56 -0
- package/dist/shell/render/gates.js.map +1 -0
- package/dist/shell/render/init.d.ts +11 -0
- package/dist/shell/render/init.d.ts.map +1 -0
- package/dist/shell/render/init.js +32 -0
- package/dist/shell/render/init.js.map +1 -0
- package/dist/shell/render/status.d.ts +26 -0
- package/dist/shell/render/status.d.ts.map +1 -0
- package/dist/shell/render/status.js +143 -0
- package/dist/shell/render/status.js.map +1 -0
- package/dist/shell/render/waiver.d.ts +21 -0
- package/dist/shell/render/waiver.d.ts.map +1 -0
- package/dist/shell/render/waiver.js +94 -0
- package/dist/shell/render/waiver.js.map +1 -0
- package/dist/shell/rules.d.ts +37 -0
- package/dist/shell/rules.d.ts.map +1 -0
- package/dist/shell/rules.js +51 -0
- package/dist/shell/rules.js.map +1 -0
- package/dist/shell/session/actor.d.ts +14 -0
- package/dist/shell/session/actor.d.ts.map +1 -0
- package/dist/shell/session/actor.js +34 -0
- package/dist/shell/session/actor.js.map +1 -0
- package/dist/shell/session/resolve-session.d.ts +5 -0
- package/dist/shell/session/resolve-session.d.ts.map +1 -0
- package/dist/shell/session/resolve-session.js +239 -0
- package/dist/shell/session/resolve-session.js.map +1 -0
- package/dist/shell/session/types.d.ts +56 -0
- package/dist/shell/session/types.d.ts.map +1 -0
- package/dist/shell/session/types.js +15 -0
- package/dist/shell/session/types.js.map +1 -0
- package/dist/store/agents-store.d.ts +3 -0
- package/dist/store/agents-store.d.ts.map +1 -0
- package/dist/store/agents-store.js +63 -0
- package/dist/store/agents-store.js.map +1 -0
- package/dist/store/apply-patch.d.ts +16 -0
- package/dist/store/apply-patch.d.ts.map +1 -0
- package/dist/store/apply-patch.js +191 -0
- package/dist/store/apply-patch.js.map +1 -0
- package/dist/store/atomic-write.d.ts +16 -0
- package/dist/store/atomic-write.d.ts.map +1 -0
- package/dist/store/atomic-write.js +132 -0
- package/dist/store/atomic-write.js.map +1 -0
- package/dist/store/doctor-snapshot.d.ts +20 -0
- package/dist/store/doctor-snapshot.d.ts.map +1 -0
- package/dist/store/doctor-snapshot.js +176 -0
- package/dist/store/doctor-snapshot.js.map +1 -0
- package/dist/store/events-store.d.ts +33 -0
- package/dist/store/events-store.d.ts.map +1 -0
- package/dist/store/events-store.js +297 -0
- package/dist/store/events-store.js.map +1 -0
- package/dist/store/index.d.ts +21 -0
- package/dist/store/index.d.ts.map +1 -0
- package/dist/store/index.js +47 -0
- package/dist/store/index.js.map +1 -0
- package/dist/store/init-store.d.ts +21 -0
- package/dist/store/init-store.d.ts.map +1 -0
- package/dist/store/init-store.js +295 -0
- package/dist/store/init-store.js.map +1 -0
- package/dist/store/json-store.d.ts +3 -0
- package/dist/store/json-store.d.ts.map +1 -0
- package/dist/store/json-store.js +65 -0
- package/dist/store/json-store.js.map +1 -0
- package/dist/store/policy-store.d.ts +3 -0
- package/dist/store/policy-store.d.ts.map +1 -0
- package/dist/store/policy-store.js +65 -0
- package/dist/store/policy-store.js.map +1 -0
- package/dist/store/repo-root.d.ts +46 -0
- package/dist/store/repo-root.d.ts.map +1 -0
- package/dist/store/repo-root.js +145 -0
- package/dist/store/repo-root.js.map +1 -0
- package/dist/store/rules.d.ts +53 -0
- package/dist/store/rules.d.ts.map +1 -0
- package/dist/store/rules.js +78 -0
- package/dist/store/rules.js.map +1 -0
- package/dist/store/specs-store.d.ts +3 -0
- package/dist/store/specs-store.d.ts.map +1 -0
- package/dist/store/specs-store.js +131 -0
- package/dist/store/specs-store.js.map +1 -0
- package/dist/store/types.d.ts +84 -0
- package/dist/store/types.d.ts.map +1 -0
- package/dist/store/types.js +14 -0
- package/dist/store/types.js.map +1 -0
- package/dist/store/waivers-store.d.ts +25 -0
- package/dist/store/waivers-store.d.ts.map +1 -0
- package/dist/store/waivers-store.js +232 -0
- package/dist/store/waivers-store.js.map +1 -0
- package/dist/store/worktrees-store.d.ts +3 -0
- package/dist/store/worktrees-store.d.ts.map +1 -0
- package/dist/store/worktrees-store.js +62 -0
- package/dist/store/worktrees-store.js.map +1 -0
- package/dist/store/yaml-store.d.ts +9 -0
- package/dist/store/yaml-store.d.ts.map +1 -0
- package/dist/store/yaml-store.js +121 -0
- package/dist/store/yaml-store.js.map +1 -0
- package/package.json +15 -13
- package/dist/budget-derivation.js +0 -751
- package/dist/cicd-optimizer.js +0 -504
- package/dist/commands/archive.js +0 -500
- package/dist/commands/burnup.js +0 -198
- package/dist/commands/diagnose.js +0 -525
- package/dist/commands/evaluate.js +0 -314
- package/dist/commands/gates.js +0 -149
- package/dist/commands/init.js +0 -857
- package/dist/commands/iterate.js +0 -417
- package/dist/commands/mode.js +0 -269
- package/dist/commands/parallel.js +0 -242
- package/dist/commands/plan.js +0 -438
- package/dist/commands/provenance.js +0 -1143
- package/dist/commands/quality-monitor.js +0 -284
- package/dist/commands/scope.js +0 -264
- package/dist/commands/session.js +0 -312
- package/dist/commands/sidecar.js +0 -74
- package/dist/commands/specs.js +0 -1448
- package/dist/commands/status.js +0 -1151
- package/dist/commands/templates.js +0 -237
- package/dist/commands/tool.js +0 -136
- package/dist/commands/tutorial.js +0 -480
- package/dist/commands/validate.js +0 -357
- package/dist/commands/verify-acs.js +0 -443
- package/dist/commands/waivers.js +0 -599
- package/dist/commands/workflow.js +0 -243
- package/dist/commands/worktree.js +0 -386
- package/dist/config/lite-scope.js +0 -158
- package/dist/config/modes.js +0 -347
- package/dist/constants/spec-types.js +0 -65
- package/dist/gates/budget-limit.js +0 -121
- package/dist/gates/feedback.js +0 -260
- package/dist/gates/format.js +0 -179
- package/dist/gates/god-object.js +0 -117
- package/dist/gates/pipeline.js +0 -167
- package/dist/gates/scope-boundary.js +0 -93
- package/dist/gates/spec-completeness.js +0 -109
- package/dist/gates/todo-detection.js +0 -205
- package/dist/generators/jest-config-generator.js +0 -242
- package/dist/generators/working-spec.js +0 -237
- package/dist/minimal-cli.js +0 -88
- package/dist/parallel/parallel-manager.js +0 -433
- package/dist/policy/PolicyManager.js +0 -465
- package/dist/scaffold/claude-hooks.js +0 -443
- package/dist/scaffold/cursor-hooks.js +0 -177
- package/dist/scaffold/git-hooks.js +0 -928
- package/dist/scaffold/index.js +0 -794
- package/dist/session/session-manager.js +0 -653
- package/dist/sidecars/index.js +0 -33
- package/dist/sidecars/listeners.js +0 -40
- package/dist/sidecars/provenance-summary.js +0 -238
- package/dist/sidecars/quality-gaps.js +0 -258
- package/dist/sidecars/schema.js +0 -149
- package/dist/sidecars/spec-drift.js +0 -151
- package/dist/sidecars/waiver-draft.js +0 -176
- package/dist/spec/SpecFileManager.js +0 -419
- package/dist/templates/.caws/schemas/policy.schema.json +0 -112
- package/dist/templates/.caws/schemas/scope.schema.json +0 -52
- package/dist/templates/.caws/schemas/waivers.schema.json +0 -106
- package/dist/templates/.caws/schemas/working-spec.schema.json +0 -340
- package/dist/templates/.caws/schemas/worktrees.schema.json +0 -38
- package/dist/templates/.caws/templates/working-spec.template.yml +0 -80
- package/dist/templates/.caws/tools/README.md +0 -18
- package/dist/templates/.caws/tools/scope-guard.js +0 -203
- package/dist/templates/.caws/tools-allow.json +0 -331
- package/dist/templates/.caws/waivers.yml +0 -19
- package/dist/templates/.claude/README.md +0 -190
- package/dist/templates/.claude/hooks/audit.sh +0 -121
- package/dist/templates/.claude/hooks/block-dangerous.sh +0 -203
- package/dist/templates/.claude/hooks/classify_command.py +0 -592
- package/dist/templates/.claude/hooks/doc-frontmatter-check.sh +0 -173
- package/dist/templates/.claude/hooks/lite-sprawl-check.sh +0 -145
- package/dist/templates/.claude/hooks/naming-check.sh +0 -100
- package/dist/templates/.claude/hooks/protected-paths.sh +0 -39
- package/dist/templates/.claude/hooks/quality-check.sh +0 -81
- package/dist/templates/.claude/hooks/scan-secrets.sh +0 -85
- package/dist/templates/.claude/hooks/scope-guard.sh +0 -381
- package/dist/templates/.claude/hooks/session-caws-status.sh +0 -117
- package/dist/templates/.claude/hooks/session-log.sh +0 -634
- package/dist/templates/.claude/hooks/simplification-guard.sh +0 -92
- package/dist/templates/.claude/hooks/stop-worktree-check.sh +0 -46
- package/dist/templates/.claude/hooks/test_classify_command.py +0 -370
- package/dist/templates/.claude/hooks/test_wrapper_smoke.sh +0 -96
- package/dist/templates/.claude/hooks/validate-spec.sh +0 -76
- package/dist/templates/.claude/hooks/worktree-guard.sh +0 -220
- package/dist/templates/.claude/hooks/worktree-write-guard.sh +0 -190
- package/dist/templates/.claude/rules/git-safety.md +0 -26
- package/dist/templates/.claude/rules/worktree-isolation.md +0 -83
- package/dist/templates/.claude/settings.json +0 -141
- package/dist/templates/.cursor/README.md +0 -299
- package/dist/templates/.cursor/hooks/audit.sh +0 -55
- package/dist/templates/.cursor/hooks/block-dangerous.sh +0 -84
- package/dist/templates/.cursor/hooks/caws-quality-check.sh +0 -52
- package/dist/templates/.cursor/hooks/caws-scope-guard.sh +0 -130
- package/dist/templates/.cursor/hooks/format.sh +0 -38
- package/dist/templates/.cursor/hooks/naming-check.sh +0 -64
- package/dist/templates/.cursor/hooks/scan-secrets.sh +0 -51
- package/dist/templates/.cursor/hooks/scope-guard.sh +0 -52
- package/dist/templates/.cursor/hooks/session-log.sh +0 -924
- package/dist/templates/.cursor/hooks/validate-spec.sh +0 -83
- package/dist/templates/.cursor/hooks.json +0 -76
- package/dist/templates/.cursor/rules/00-claims-verification.mdc +0 -144
- package/dist/templates/.cursor/rules/01-working-style.mdc +0 -50
- package/dist/templates/.cursor/rules/02-quality-gates.mdc +0 -368
- package/dist/templates/.cursor/rules/03-naming-and-refactor.mdc +0 -33
- package/dist/templates/.cursor/rules/04-logging-language-style.mdc +0 -23
- package/dist/templates/.cursor/rules/05-safe-defaults-guards.mdc +0 -23
- package/dist/templates/.cursor/rules/06-typescript-conventions.mdc +0 -36
- package/dist/templates/.cursor/rules/07-process-ops.mdc +0 -20
- package/dist/templates/.cursor/rules/08-solid-and-architecture.mdc +0 -16
- package/dist/templates/.cursor/rules/09-docstrings.mdc +0 -89
- package/dist/templates/.cursor/rules/10-documentation-quality-standards.mdc +0 -385
- package/dist/templates/.cursor/rules/11-scope-management-waivers.mdc +0 -381
- package/dist/templates/.cursor/rules/12-implementation-completeness.mdc +0 -516
- package/dist/templates/.cursor/rules/13-language-agnostic-standards.mdc +0 -578
- package/dist/templates/.cursor/rules/README.md +0 -148
- package/dist/templates/.github/copilot-instructions.md +0 -82
- package/dist/templates/.idea/runConfigurations/CAWS_Evaluate.xml +0 -5
- package/dist/templates/.idea/runConfigurations/CAWS_Validate.xml +0 -5
- package/dist/templates/.junie/guidelines.md +0 -73
- package/dist/templates/.vscode/launch.json +0 -17
- package/dist/templates/.vscode/settings.json +0 -95
- package/dist/templates/.windsurf/rules/caws-quality-standards.md +0 -54
- package/dist/templates/.windsurf/workflows/caws-guided-development.md +0 -92
- package/dist/templates/CLAUDE.md +0 -174
- package/dist/templates/COMMIT_CONVENTIONS.md +0 -86
- package/dist/templates/OIDC_SETUP.md +0 -300
- package/dist/templates/agents.md +0 -145
- package/dist/templates/codemod/README.md +0 -1
- package/dist/templates/codemod/test.js +0 -93
- package/dist/templates/docs/README.md +0 -151
- package/dist/templates/scripts/new_feature.sh +0 -80
- package/dist/templates/scripts/quality-gates/check-god-objects.js +0 -146
- package/dist/templates/scripts/quality-gates/run-quality-gates.js +0 -50
- package/dist/templates/scripts/v3/analysis/todo_analyzer.py +0 -1997
- package/dist/test-analysis.js +0 -786
- package/dist/tool-interface.js +0 -314
- package/dist/tool-loader.js +0 -303
- package/dist/tool-validator.js +0 -393
- package/dist/utils/agent-session.js +0 -202
- package/dist/utils/async-utils.js +0 -188
- package/dist/utils/command-wrapper.js +0 -200
- package/dist/utils/event-log.js +0 -584
- package/dist/utils/event-renderer.js +0 -521
- package/dist/utils/finalization.js +0 -230
- package/dist/utils/git-lock.js +0 -119
- package/dist/utils/gitignore-updater.js +0 -158
- package/dist/utils/ide-detection.js +0 -133
- package/dist/utils/lifecycle-events.js +0 -94
- package/dist/utils/project-analysis.js +0 -367
- package/dist/utils/promise-utils.js +0 -72
- package/dist/utils/quality-gates-errors.js +0 -520
- package/dist/utils/quality-gates-utils.js +0 -387
- package/dist/utils/schema-validator.js +0 -50
- package/dist/utils/spec-resolver.js +0 -711
- package/dist/utils/typescript-detector.js +0 -369
- package/dist/utils/working-state.js +0 -530
- package/dist/utils/yaml-validation.js +0 -156
- package/dist/validation/spec-validation.js +0 -921
- package/dist/waivers-manager.js +0 -732
- package/dist/worktree/worktree-manager.js +0 -1374
- package/templates/.caws/schemas/policy.schema.json +0 -112
- package/templates/.caws/schemas/scope.schema.json +0 -52
- package/templates/.caws/schemas/waivers.schema.json +0 -106
- package/templates/.caws/schemas/working-spec.schema.json +0 -340
- package/templates/.caws/schemas/worktrees.schema.json +0 -38
- package/templates/.caws/templates/working-spec.template.yml +0 -80
- package/templates/.caws/tools/README.md +0 -18
- package/templates/.caws/tools/scope-guard.js +0 -203
- package/templates/.caws/tools-allow.json +0 -331
- package/templates/.caws/waivers.yml +0 -19
- package/templates/.claude/README.md +0 -190
- package/templates/.claude/hooks/audit.sh +0 -121
- package/templates/.claude/hooks/block-dangerous.sh +0 -203
- package/templates/.claude/hooks/classify_command.py +0 -592
- package/templates/.claude/hooks/doc-frontmatter-check.sh +0 -173
- package/templates/.claude/hooks/lite-sprawl-check.sh +0 -145
- package/templates/.claude/hooks/naming-check.sh +0 -100
- package/templates/.claude/hooks/protected-paths.sh +0 -39
- package/templates/.claude/hooks/quality-check.sh +0 -81
- package/templates/.claude/hooks/scan-secrets.sh +0 -85
- package/templates/.claude/hooks/scope-guard.sh +0 -381
- package/templates/.claude/hooks/session-caws-status.sh +0 -117
- package/templates/.claude/hooks/session-log.sh +0 -634
- package/templates/.claude/hooks/simplification-guard.sh +0 -92
- package/templates/.claude/hooks/stop-worktree-check.sh +0 -46
- package/templates/.claude/hooks/test_classify_command.py +0 -370
- package/templates/.claude/hooks/test_wrapper_smoke.sh +0 -96
- package/templates/.claude/hooks/validate-spec.sh +0 -76
- package/templates/.claude/hooks/worktree-guard.sh +0 -220
- package/templates/.claude/hooks/worktree-write-guard.sh +0 -190
- package/templates/.claude/rules/git-safety.md +0 -26
- package/templates/.claude/rules/worktree-isolation.md +0 -83
- package/templates/.claude/settings.json +0 -141
- package/templates/.cursor/README.md +0 -299
- package/templates/.cursor/hooks/audit.sh +0 -55
- package/templates/.cursor/hooks/block-dangerous.sh +0 -84
- package/templates/.cursor/hooks/caws-quality-check.sh +0 -52
- package/templates/.cursor/hooks/caws-scope-guard.sh +0 -130
- package/templates/.cursor/hooks/format.sh +0 -38
- package/templates/.cursor/hooks/naming-check.sh +0 -64
- package/templates/.cursor/hooks/scan-secrets.sh +0 -51
- package/templates/.cursor/hooks/scope-guard.sh +0 -52
- package/templates/.cursor/hooks/session-log.sh +0 -924
- package/templates/.cursor/hooks/validate-spec.sh +0 -83
- package/templates/.cursor/hooks.json +0 -76
- package/templates/.cursor/rules/00-claims-verification.mdc +0 -144
- package/templates/.cursor/rules/01-working-style.mdc +0 -50
- package/templates/.cursor/rules/02-quality-gates.mdc +0 -368
- package/templates/.cursor/rules/03-naming-and-refactor.mdc +0 -33
- package/templates/.cursor/rules/04-logging-language-style.mdc +0 -23
- package/templates/.cursor/rules/05-safe-defaults-guards.mdc +0 -23
- package/templates/.cursor/rules/06-typescript-conventions.mdc +0 -36
- package/templates/.cursor/rules/07-process-ops.mdc +0 -20
- package/templates/.cursor/rules/08-solid-and-architecture.mdc +0 -16
- package/templates/.cursor/rules/09-docstrings.mdc +0 -89
- package/templates/.cursor/rules/10-documentation-quality-standards.mdc +0 -385
- package/templates/.cursor/rules/11-scope-management-waivers.mdc +0 -381
- package/templates/.cursor/rules/12-implementation-completeness.mdc +0 -516
- package/templates/.cursor/rules/13-language-agnostic-standards.mdc +0 -578
- package/templates/.cursor/rules/README.md +0 -148
- package/templates/.github/copilot-instructions.md +0 -82
- package/templates/.idea/runConfigurations/CAWS_Evaluate.xml +0 -5
- package/templates/.idea/runConfigurations/CAWS_Validate.xml +0 -5
- package/templates/.junie/guidelines.md +0 -73
- package/templates/.vscode/launch.json +0 -17
- package/templates/.vscode/settings.json +0 -95
- package/templates/.windsurf/rules/caws-quality-standards.md +0 -54
- package/templates/.windsurf/workflows/caws-guided-development.md +0 -92
- package/templates/CLAUDE.md +0 -174
- package/templates/COMMIT_CONVENTIONS.md +0 -86
- package/templates/OIDC_SETUP.md +0 -300
- package/templates/agents.md +0 -145
- package/templates/codemod/README.md +0 -1
- package/templates/codemod/test.js +0 -93
- package/templates/docs/README.md +0 -151
- package/templates/scripts/new_feature.sh +0 -80
- package/templates/scripts/quality-gates/check-god-objects.js +0 -146
- package/templates/scripts/quality-gates/run-quality-gates.js +0 -50
- package/templates/scripts/v3/analysis/todo_analyzer.py +0 -1997
|
@@ -1,158 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview CAWS Lite-Mode Scope Configuration Loader
|
|
3
|
-
* Reads and validates .caws/scope.json for guardrails-only mode
|
|
4
|
-
* @author @darianrosebrook
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
const fs = require('fs-extra');
|
|
8
|
-
const path = require('path');
|
|
9
|
-
const micromatch = require('micromatch');
|
|
10
|
-
|
|
11
|
-
const SCOPE_FILE = '.caws/scope.json';
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Default scope configuration for lite mode
|
|
15
|
-
* @returns {Object} Default scope.json contents
|
|
16
|
-
*/
|
|
17
|
-
function getLiteScopeDefaults() {
|
|
18
|
-
return {
|
|
19
|
-
version: 1,
|
|
20
|
-
allowedDirectories: ['src/', 'tests/', 'docs/'],
|
|
21
|
-
bannedPatterns: {
|
|
22
|
-
files: ['*-enhanced.*', '*-final.*', '*-v2.*', '*-copy.*'],
|
|
23
|
-
directories: ['*venv*', '.venv', 'm-venv', 'env/'],
|
|
24
|
-
docs: ['*-summary.md', '*-recap.md', '*-plan.md', 'sprint-*'],
|
|
25
|
-
},
|
|
26
|
-
maxNewFilesPerCommit: 10,
|
|
27
|
-
designatedVenvPath: '.venv',
|
|
28
|
-
};
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* Load lite scope configuration from .caws/scope.json
|
|
33
|
-
* @param {string} [projectRoot] - Project root directory (defaults to cwd)
|
|
34
|
-
* @returns {Object} Scope configuration (defaults if file not found)
|
|
35
|
-
*/
|
|
36
|
-
function loadLiteScope(projectRoot) {
|
|
37
|
-
const root = projectRoot || process.cwd();
|
|
38
|
-
const scopePath = path.join(root, SCOPE_FILE);
|
|
39
|
-
|
|
40
|
-
try {
|
|
41
|
-
if (!fs.existsSync(scopePath)) {
|
|
42
|
-
return getLiteScopeDefaults();
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
const raw = fs.readFileSync(scopePath, 'utf8');
|
|
46
|
-
const config = JSON.parse(raw);
|
|
47
|
-
|
|
48
|
-
// Merge with defaults for any missing fields
|
|
49
|
-
const defaults = getLiteScopeDefaults();
|
|
50
|
-
return {
|
|
51
|
-
version: config.version || defaults.version,
|
|
52
|
-
allowedDirectories: config.allowedDirectories || defaults.allowedDirectories,
|
|
53
|
-
bannedPatterns: {
|
|
54
|
-
files: config.bannedPatterns?.files || defaults.bannedPatterns.files,
|
|
55
|
-
directories: config.bannedPatterns?.directories || defaults.bannedPatterns.directories,
|
|
56
|
-
docs: config.bannedPatterns?.docs || defaults.bannedPatterns.docs,
|
|
57
|
-
},
|
|
58
|
-
maxNewFilesPerCommit: config.maxNewFilesPerCommit ?? defaults.maxNewFilesPerCommit,
|
|
59
|
-
designatedVenvPath: config.designatedVenvPath || defaults.designatedVenvPath,
|
|
60
|
-
};
|
|
61
|
-
} catch (error) {
|
|
62
|
-
// If file is malformed, return defaults
|
|
63
|
-
return getLiteScopeDefaults();
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
/**
|
|
68
|
-
* Check if a file path is allowed by the scope configuration
|
|
69
|
-
* @param {string} filePath - Relative file path to check
|
|
70
|
-
* @param {Object} [scope] - Scope configuration (loads from disk if not provided)
|
|
71
|
-
* @param {string} [projectRoot] - Project root directory
|
|
72
|
-
* @returns {boolean} Whether the path is allowed
|
|
73
|
-
*/
|
|
74
|
-
function isPathAllowed(filePath, scope, projectRoot) {
|
|
75
|
-
const config = scope || loadLiteScope(projectRoot);
|
|
76
|
-
const dirs = config.allowedDirectories;
|
|
77
|
-
|
|
78
|
-
// If no allowed directories specified, everything is allowed
|
|
79
|
-
if (!dirs || dirs.length === 0) {
|
|
80
|
-
return true;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
// Normalize the file path
|
|
84
|
-
const normalized = filePath.replace(/\\/g, '/');
|
|
85
|
-
|
|
86
|
-
// Check if file is within any allowed directory
|
|
87
|
-
for (const dir of dirs) {
|
|
88
|
-
const normalizedDir = dir.replace(/\\/g, '/').replace(/\/$/, '');
|
|
89
|
-
if (normalized.startsWith(normalizedDir + '/') || normalized === normalizedDir) {
|
|
90
|
-
return true;
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
// Also allow root-level config files (package.json, etc.)
|
|
95
|
-
if (!normalized.includes('/')) {
|
|
96
|
-
return true;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
// Allow .caws/ directory itself
|
|
100
|
-
if (normalized.startsWith('.caws/')) {
|
|
101
|
-
return true;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
return false;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
/**
|
|
108
|
-
* Check if a filename or path matches any banned pattern
|
|
109
|
-
* @param {string} filePath - File path to check
|
|
110
|
-
* @param {Object} [scope] - Scope configuration (loads from disk if not provided)
|
|
111
|
-
* @param {string} [projectRoot] - Project root directory
|
|
112
|
-
* @returns {{ matched: boolean, pattern: string|null, category: string|null }} Match result
|
|
113
|
-
*/
|
|
114
|
-
function matchesBannedPattern(filePath, scope, projectRoot) {
|
|
115
|
-
const config = scope || loadLiteScope(projectRoot);
|
|
116
|
-
const banned = config.bannedPatterns;
|
|
117
|
-
const basename = path.basename(filePath);
|
|
118
|
-
const normalized = filePath.replace(/\\/g, '/');
|
|
119
|
-
|
|
120
|
-
// Check file patterns
|
|
121
|
-
if (banned.files && banned.files.length > 0) {
|
|
122
|
-
if (micromatch.isMatch(basename, banned.files, { dot: true })) {
|
|
123
|
-
const matched = banned.files.find((p) => micromatch.isMatch(basename, p, { dot: true }));
|
|
124
|
-
return { matched: true, pattern: matched, category: 'files' };
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
// Check directory patterns
|
|
129
|
-
if (banned.directories && banned.directories.length > 0) {
|
|
130
|
-
const parts = normalized.split('/');
|
|
131
|
-
for (const part of parts) {
|
|
132
|
-
if (micromatch.isMatch(part, banned.directories, { dot: true })) {
|
|
133
|
-
const matched = banned.directories.find((p) =>
|
|
134
|
-
micromatch.isMatch(part, p, { dot: true })
|
|
135
|
-
);
|
|
136
|
-
return { matched: true, pattern: matched, category: 'directories' };
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
// Check doc patterns
|
|
142
|
-
if (banned.docs && banned.docs.length > 0) {
|
|
143
|
-
if (micromatch.isMatch(basename, banned.docs, { dot: true })) {
|
|
144
|
-
const matched = banned.docs.find((p) => micromatch.isMatch(basename, p, { dot: true }));
|
|
145
|
-
return { matched: true, pattern: matched, category: 'docs' };
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
return { matched: false, pattern: null, category: null };
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
module.exports = {
|
|
153
|
-
loadLiteScope,
|
|
154
|
-
isPathAllowed,
|
|
155
|
-
matchesBannedPattern,
|
|
156
|
-
getLiteScopeDefaults,
|
|
157
|
-
SCOPE_FILE,
|
|
158
|
-
};
|
package/dist/config/modes.js
DELETED
|
@@ -1,347 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview CAWS Complexity Modes Configuration
|
|
3
|
-
* Defines different tiers of CAWS complexity for different project needs
|
|
4
|
-
* @author @darianrosebrook
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
const chalk = require('chalk');
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* CAWS Complexity Tiers
|
|
11
|
-
*/
|
|
12
|
-
const COMPLEXITY_TIERS = {
|
|
13
|
-
lite: {
|
|
14
|
-
name: 'Lite',
|
|
15
|
-
description: 'Guardrails-only mode — no YAML specs required',
|
|
16
|
-
color: chalk.magenta,
|
|
17
|
-
icon: '',
|
|
18
|
-
features: {
|
|
19
|
-
workingSpec: false,
|
|
20
|
-
destructiveCommandBlocking: true,
|
|
21
|
-
fileSprawlDetection: true,
|
|
22
|
-
scopeFence: true,
|
|
23
|
-
simplificationGuard: true,
|
|
24
|
-
worktreeIsolation: true,
|
|
25
|
-
},
|
|
26
|
-
qualityRequirements: {
|
|
27
|
-
testCoverage: 0,
|
|
28
|
-
mutationScore: 0,
|
|
29
|
-
contracts: 'none',
|
|
30
|
-
},
|
|
31
|
-
riskTiers: ['T3'],
|
|
32
|
-
commands: {
|
|
33
|
-
init: true,
|
|
34
|
-
status: true,
|
|
35
|
-
worktree: true,
|
|
36
|
-
},
|
|
37
|
-
},
|
|
38
|
-
|
|
39
|
-
simple: {
|
|
40
|
-
name: 'Simple',
|
|
41
|
-
description: 'Minimal CAWS for small projects and quick prototyping',
|
|
42
|
-
color: chalk.green,
|
|
43
|
-
icon: '',
|
|
44
|
-
features: {
|
|
45
|
-
workingSpec: true,
|
|
46
|
-
basicValidation: true,
|
|
47
|
-
statusDisplay: true,
|
|
48
|
-
noQualityGates: true,
|
|
49
|
-
noProvenance: true,
|
|
50
|
-
noWaivers: true,
|
|
51
|
-
noChangeBudgets: true,
|
|
52
|
-
noMultiSpec: false, // Can use multi-spec but simplified
|
|
53
|
-
},
|
|
54
|
-
qualityRequirements: {
|
|
55
|
-
testCoverage: 70,
|
|
56
|
-
mutationScore: 30,
|
|
57
|
-
contracts: 'optional',
|
|
58
|
-
},
|
|
59
|
-
riskTiers: ['T3'], // Only T3 supported
|
|
60
|
-
commands: {
|
|
61
|
-
init: true,
|
|
62
|
-
validate: true,
|
|
63
|
-
status: true,
|
|
64
|
-
specs: true, // Basic specs support
|
|
65
|
-
// No: diagnose, evaluate, iterate, provenance, waivers, hooks, archive
|
|
66
|
-
},
|
|
67
|
-
},
|
|
68
|
-
|
|
69
|
-
standard: {
|
|
70
|
-
name: 'Standard',
|
|
71
|
-
description: 'Balanced CAWS with change management and quality gates',
|
|
72
|
-
color: chalk.yellow,
|
|
73
|
-
icon: '',
|
|
74
|
-
features: {
|
|
75
|
-
workingSpec: true,
|
|
76
|
-
fullValidation: true,
|
|
77
|
-
statusDisplay: true,
|
|
78
|
-
qualityGates: true,
|
|
79
|
-
provenance: true,
|
|
80
|
-
waivers: true,
|
|
81
|
-
changeBudgets: true,
|
|
82
|
-
multiSpec: true,
|
|
83
|
-
changeFolders: true,
|
|
84
|
-
},
|
|
85
|
-
qualityRequirements: {
|
|
86
|
-
testCoverage: 80,
|
|
87
|
-
mutationScore: 50,
|
|
88
|
-
contracts: 'required',
|
|
89
|
-
},
|
|
90
|
-
riskTiers: ['T1', 'T2', 'T3'],
|
|
91
|
-
commands: {
|
|
92
|
-
init: true,
|
|
93
|
-
validate: true,
|
|
94
|
-
status: true,
|
|
95
|
-
specs: true,
|
|
96
|
-
diagnose: true,
|
|
97
|
-
evaluate: true,
|
|
98
|
-
iterate: true,
|
|
99
|
-
provenance: true,
|
|
100
|
-
waivers: true,
|
|
101
|
-
hooks: true,
|
|
102
|
-
archive: true,
|
|
103
|
-
},
|
|
104
|
-
},
|
|
105
|
-
|
|
106
|
-
enterprise: {
|
|
107
|
-
name: 'Enterprise',
|
|
108
|
-
description: 'Full CAWS with comprehensive audit trails and compliance',
|
|
109
|
-
color: chalk.red,
|
|
110
|
-
icon: '',
|
|
111
|
-
features: {
|
|
112
|
-
workingSpec: true,
|
|
113
|
-
fullValidation: true,
|
|
114
|
-
statusDisplay: true,
|
|
115
|
-
qualityGates: true,
|
|
116
|
-
provenance: true,
|
|
117
|
-
waivers: true,
|
|
118
|
-
changeBudgets: true,
|
|
119
|
-
multiSpec: true,
|
|
120
|
-
changeFolders: true,
|
|
121
|
-
auditTrails: true,
|
|
122
|
-
compliance: true,
|
|
123
|
-
advancedMonitoring: true,
|
|
124
|
-
},
|
|
125
|
-
qualityRequirements: {
|
|
126
|
-
testCoverage: 90,
|
|
127
|
-
mutationScore: 70,
|
|
128
|
-
contracts: 'required',
|
|
129
|
-
},
|
|
130
|
-
riskTiers: ['T1', 'T2', 'T3'],
|
|
131
|
-
commands: {
|
|
132
|
-
init: true,
|
|
133
|
-
validate: true,
|
|
134
|
-
status: true,
|
|
135
|
-
specs: true,
|
|
136
|
-
diagnose: true,
|
|
137
|
-
evaluate: true,
|
|
138
|
-
iterate: true,
|
|
139
|
-
provenance: true,
|
|
140
|
-
waivers: true,
|
|
141
|
-
hooks: true,
|
|
142
|
-
archive: true,
|
|
143
|
-
troubleshoot: true,
|
|
144
|
-
testAnalysis: true,
|
|
145
|
-
qualityMonitor: true,
|
|
146
|
-
},
|
|
147
|
-
},
|
|
148
|
-
};
|
|
149
|
-
|
|
150
|
-
/**
|
|
151
|
-
* Get tier information
|
|
152
|
-
* @param {string} tier - Tier name
|
|
153
|
-
* @returns {Object} Tier configuration
|
|
154
|
-
*/
|
|
155
|
-
function getTier(tier) {
|
|
156
|
-
return COMPLEXITY_TIERS[tier] || COMPLEXITY_TIERS.standard;
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
/**
|
|
160
|
-
* Get available tiers
|
|
161
|
-
* @returns {string[]} Array of tier names
|
|
162
|
-
*/
|
|
163
|
-
function getAvailableTiers() {
|
|
164
|
-
return Object.keys(COMPLEXITY_TIERS);
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
/**
|
|
168
|
-
* Check if a command is available in the current tier
|
|
169
|
-
* @param {string} command - Command name
|
|
170
|
-
* @param {string} tier - Tier name
|
|
171
|
-
* @returns {boolean} Whether command is available
|
|
172
|
-
*/
|
|
173
|
-
function isCommandAvailable(command, tier = 'standard') {
|
|
174
|
-
const tierConfig = getTier(tier);
|
|
175
|
-
return tierConfig.commands[command] === true;
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
/**
|
|
179
|
-
* Check if a feature is enabled in the current tier
|
|
180
|
-
* @param {string} feature - Feature name
|
|
181
|
-
* @param {string} tier - Tier name
|
|
182
|
-
* @returns {boolean} Whether feature is enabled
|
|
183
|
-
*/
|
|
184
|
-
function isFeatureEnabled(feature, tier = 'standard') {
|
|
185
|
-
const tierConfig = getTier(tier);
|
|
186
|
-
return tierConfig.features[feature] === true;
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
/**
|
|
190
|
-
* Get quality requirements for a tier
|
|
191
|
-
* @param {string} tier - Tier name
|
|
192
|
-
* @returns {Object} Quality requirements
|
|
193
|
-
*/
|
|
194
|
-
function getQualityRequirements(tier = 'standard') {
|
|
195
|
-
const tierConfig = getTier(tier);
|
|
196
|
-
return tierConfig.qualityRequirements;
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
/**
|
|
200
|
-
* Get supported risk tiers for a complexity tier
|
|
201
|
-
* @param {string} tier - Tier name
|
|
202
|
-
* @returns {string[]} Supported risk tiers
|
|
203
|
-
*/
|
|
204
|
-
function getSupportedRiskTiers(tier = 'standard') {
|
|
205
|
-
const tierConfig = getTier(tier);
|
|
206
|
-
return tierConfig.riskTiers;
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
/**
|
|
210
|
-
* Validate if a risk tier is supported in the current complexity tier
|
|
211
|
-
* @param {string} riskTier - Risk tier to validate
|
|
212
|
-
* @param {string} complexityTier - Complexity tier
|
|
213
|
-
* @returns {boolean} Whether risk tier is supported
|
|
214
|
-
*/
|
|
215
|
-
function isRiskTierSupported(riskTier, complexityTier = 'standard') {
|
|
216
|
-
const supportedTiers = getSupportedRiskTiers(complexityTier);
|
|
217
|
-
return supportedTiers.includes(riskTier);
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
/**
|
|
221
|
-
* Display tier comparison
|
|
222
|
-
*/
|
|
223
|
-
function displayTierComparison() {
|
|
224
|
-
console.log(chalk.bold.cyan('\nCAWS Complexity Tiers'));
|
|
225
|
-
console.log(chalk.cyan('=========================================================\n'));
|
|
226
|
-
|
|
227
|
-
// Header
|
|
228
|
-
console.log(
|
|
229
|
-
chalk.bold(
|
|
230
|
-
'Tier'.padEnd(12) +
|
|
231
|
-
'Features'.padEnd(15) +
|
|
232
|
-
'Coverage'.padEnd(10) +
|
|
233
|
-
'Commands'.padEnd(12) +
|
|
234
|
-
'Use Case'
|
|
235
|
-
)
|
|
236
|
-
);
|
|
237
|
-
console.log(chalk.gray('-'.repeat(90)));
|
|
238
|
-
|
|
239
|
-
Object.entries(COMPLEXITY_TIERS).forEach(([tierName, tier]) => {
|
|
240
|
-
const tierColor = tier.color;
|
|
241
|
-
const icon = tier.icon;
|
|
242
|
-
|
|
243
|
-
const features = Object.entries(tier.features)
|
|
244
|
-
.filter(([, enabled]) => enabled)
|
|
245
|
-
.map(([feature]) => feature.replace(/([A-Z])/g, ' $1').toLowerCase())
|
|
246
|
-
.slice(0, 3)
|
|
247
|
-
.join(', ');
|
|
248
|
-
|
|
249
|
-
const commands = Object.keys(tier.commands).filter((cmd) => tier.commands[cmd]).length;
|
|
250
|
-
|
|
251
|
-
console.log(
|
|
252
|
-
`${icon} ${tierColor(tierName.padEnd(10))} ${features.padEnd(13)} ${tier.qualityRequirements.testCoverage}%${' '.padEnd(8)}${commands}${' '.padEnd(10)}${tier.description}`
|
|
253
|
-
);
|
|
254
|
-
});
|
|
255
|
-
|
|
256
|
-
console.log('');
|
|
257
|
-
}
|
|
258
|
-
|
|
259
|
-
/**
|
|
260
|
-
* Get current mode from configuration
|
|
261
|
-
* @returns {Promise<string>} Current mode
|
|
262
|
-
*/
|
|
263
|
-
async function getCurrentMode() {
|
|
264
|
-
const fs = require('fs-extra');
|
|
265
|
-
const MODE_CONFIG = '.caws/mode.json';
|
|
266
|
-
|
|
267
|
-
try {
|
|
268
|
-
if (!(await fs.pathExists(MODE_CONFIG))) {
|
|
269
|
-
return 'standard'; // Default to standard mode
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
const config = JSON.parse(await fs.readFile(MODE_CONFIG, 'utf8'));
|
|
273
|
-
return config.current || 'standard';
|
|
274
|
-
} catch (error) {
|
|
275
|
-
return 'standard'; // Default to standard mode on error
|
|
276
|
-
}
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
/**
|
|
280
|
-
* Set current mode in configuration
|
|
281
|
-
* @param {string} mode - Mode to set
|
|
282
|
-
* @returns {Promise<boolean>} Success status
|
|
283
|
-
*/
|
|
284
|
-
async function setCurrentMode(mode) {
|
|
285
|
-
const fs = require('fs-extra');
|
|
286
|
-
const path = require('path');
|
|
287
|
-
const MODE_CONFIG = '.caws/mode.json';
|
|
288
|
-
|
|
289
|
-
if (!getAvailableTiers().includes(mode)) {
|
|
290
|
-
return false;
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
try {
|
|
294
|
-
await fs.ensureDir(path.dirname(MODE_CONFIG));
|
|
295
|
-
const config = {
|
|
296
|
-
current: mode,
|
|
297
|
-
initialized: true,
|
|
298
|
-
lastChanged: new Date().toISOString(),
|
|
299
|
-
};
|
|
300
|
-
await fs.writeFile(MODE_CONFIG, JSON.stringify(config, null, 2));
|
|
301
|
-
return true;
|
|
302
|
-
} catch (error) {
|
|
303
|
-
return false;
|
|
304
|
-
}
|
|
305
|
-
}
|
|
306
|
-
|
|
307
|
-
/**
|
|
308
|
-
* Get tier recommendation based on project characteristics
|
|
309
|
-
* @param {Object} projectInfo - Project information
|
|
310
|
-
* @returns {string} Recommended tier
|
|
311
|
-
*/
|
|
312
|
-
function getTierRecommendation(projectInfo = {}) {
|
|
313
|
-
const { size = 'medium', teamSize = 1, compliance = false, auditRequired = false } = projectInfo;
|
|
314
|
-
|
|
315
|
-
// Enterprise tier for compliance/audit requirements
|
|
316
|
-
if (compliance || auditRequired) {
|
|
317
|
-
return 'enterprise';
|
|
318
|
-
}
|
|
319
|
-
|
|
320
|
-
// Enterprise for large teams or projects
|
|
321
|
-
if (teamSize > 5 || size === 'large') {
|
|
322
|
-
return 'enterprise';
|
|
323
|
-
}
|
|
324
|
-
|
|
325
|
-
// Standard for medium teams/projects
|
|
326
|
-
if (teamSize > 1 || size === 'medium') {
|
|
327
|
-
return 'standard';
|
|
328
|
-
}
|
|
329
|
-
|
|
330
|
-
// Simple for solo/small projects
|
|
331
|
-
return 'simple';
|
|
332
|
-
}
|
|
333
|
-
|
|
334
|
-
module.exports = {
|
|
335
|
-
COMPLEXITY_TIERS,
|
|
336
|
-
getTier,
|
|
337
|
-
getAvailableTiers,
|
|
338
|
-
getCurrentMode,
|
|
339
|
-
setCurrentMode,
|
|
340
|
-
isCommandAvailable,
|
|
341
|
-
isFeatureEnabled,
|
|
342
|
-
getQualityRequirements,
|
|
343
|
-
getSupportedRiskTiers,
|
|
344
|
-
isRiskTierSupported,
|
|
345
|
-
displayTierComparison,
|
|
346
|
-
getTierRecommendation,
|
|
347
|
-
};
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview Spec Types and Status Constants
|
|
3
|
-
* Defines spec types, statuses, and their metadata for consistent display
|
|
4
|
-
* @author @darianrosebrook
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
const chalk = require('chalk');
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Spec types and their metadata
|
|
11
|
-
*/
|
|
12
|
-
const SPEC_TYPES = {
|
|
13
|
-
feature: {
|
|
14
|
-
color: chalk.green,
|
|
15
|
-
icon: '',
|
|
16
|
-
description: 'New feature development',
|
|
17
|
-
},
|
|
18
|
-
fix: {
|
|
19
|
-
color: chalk.red,
|
|
20
|
-
icon: '',
|
|
21
|
-
description: 'Bug fixes and patches',
|
|
22
|
-
},
|
|
23
|
-
refactor: {
|
|
24
|
-
color: chalk.blue,
|
|
25
|
-
icon: '',
|
|
26
|
-
description: 'Code refactoring and improvements',
|
|
27
|
-
},
|
|
28
|
-
chore: {
|
|
29
|
-
color: chalk.gray,
|
|
30
|
-
icon: '',
|
|
31
|
-
description: 'Maintenance and cleanup',
|
|
32
|
-
},
|
|
33
|
-
docs: {
|
|
34
|
-
color: chalk.cyan,
|
|
35
|
-
icon: '',
|
|
36
|
-
description: 'Documentation updates',
|
|
37
|
-
},
|
|
38
|
-
};
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Spec statuses and lifecycle metadata.
|
|
42
|
-
* Terminal statuses mean the spec is done — its scope restrictions
|
|
43
|
-
* should NOT be enforced by the scope guard.
|
|
44
|
-
*/
|
|
45
|
-
const SPEC_STATUSES = {
|
|
46
|
-
draft: { label: 'Draft', color: chalk.yellow, terminal: false },
|
|
47
|
-
active: { label: 'Active', color: chalk.green, terminal: false },
|
|
48
|
-
in_progress: { label: 'In Progress', color: chalk.green, terminal: false },
|
|
49
|
-
completed: { label: 'Completed', color: chalk.blue, terminal: true },
|
|
50
|
-
closed: { label: 'Closed', color: chalk.gray, terminal: true },
|
|
51
|
-
archived: { label: 'Archived', color: chalk.gray, terminal: true },
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* Status keys that indicate a spec is done (scope no longer enforced).
|
|
56
|
-
*/
|
|
57
|
-
const TERMINAL_STATUSES = Object.entries(SPEC_STATUSES)
|
|
58
|
-
.filter(([, v]) => v.terminal)
|
|
59
|
-
.map(([k]) => k);
|
|
60
|
-
|
|
61
|
-
module.exports = {
|
|
62
|
-
SPEC_TYPES,
|
|
63
|
-
SPEC_STATUSES,
|
|
64
|
-
TERMINAL_STATUSES,
|
|
65
|
-
};
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview Budget enforcement gate
|
|
3
|
-
* Checks changes against tier budget limits from policy.
|
|
4
|
-
* Context-aware: commit context counts staged changes, cli context skips (budget is per-change, not per-repo).
|
|
5
|
-
* @author @darianrosebrook
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
const { deriveBudget, checkBudgetCompliance } = require('../budget-derivation');
|
|
9
|
-
const { execSync } = require('child_process');
|
|
10
|
-
|
|
11
|
-
const name = 'budget_limit';
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Count staged files and lines of code from git diff
|
|
15
|
-
* @param {string[]} stagedFiles - List of staged file paths
|
|
16
|
-
* @param {string} projectRoot - Project root directory
|
|
17
|
-
* @returns {Object} Stats with files_changed and lines_changed
|
|
18
|
-
*/
|
|
19
|
-
function getStagedStats(stagedFiles, projectRoot) {
|
|
20
|
-
const filesChanged = stagedFiles.length;
|
|
21
|
-
let linesChanged = 0;
|
|
22
|
-
|
|
23
|
-
try {
|
|
24
|
-
const numstat = execSync('git diff --cached --numstat', {
|
|
25
|
-
cwd: projectRoot,
|
|
26
|
-
encoding: 'utf8',
|
|
27
|
-
stdio: ['ignore', 'pipe', 'pipe'],
|
|
28
|
-
});
|
|
29
|
-
for (const line of numstat.trim().split('\n').filter(Boolean)) {
|
|
30
|
-
const [added, removed] = line.split('\t');
|
|
31
|
-
const addedNum = added === '-' ? 0 : parseInt(added, 10) || 0;
|
|
32
|
-
const removedNum = removed === '-' ? 0 : parseInt(removed, 10) || 0;
|
|
33
|
-
linesChanged += addedNum + removedNum;
|
|
34
|
-
}
|
|
35
|
-
} catch (err) {
|
|
36
|
-
// Fail-closed: if git fails, we cannot verify budget compliance
|
|
37
|
-
return {
|
|
38
|
-
files_changed: filesChanged,
|
|
39
|
-
lines_changed: -1,
|
|
40
|
-
error: `Cannot count staged line changes: ${err.message}`,
|
|
41
|
-
};
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
return { files_changed: filesChanged, lines_changed: linesChanged };
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* Run the budget limit gate
|
|
49
|
-
* @param {Object} params - Gate parameters
|
|
50
|
-
* @param {string[]} params.stagedFiles - Staged file paths
|
|
51
|
-
* @param {Object} params.spec - Working spec
|
|
52
|
-
* @param {Object} params.policy - Policy configuration
|
|
53
|
-
* @param {string} params.projectRoot - Project root
|
|
54
|
-
* @param {number} params.riskTier - Risk tier number
|
|
55
|
-
* @param {string} [params.context] - Execution context (commit, cli, edit)
|
|
56
|
-
* @returns {Promise<Object>} Gate result with status and messages
|
|
57
|
-
*/
|
|
58
|
-
async function run({ stagedFiles, spec, _policy, projectRoot, riskTier, context }) {
|
|
59
|
-
const messages = [];
|
|
60
|
-
|
|
61
|
-
// Budget limits apply to changes, not to the entire repo.
|
|
62
|
-
// In cli context with all tracked files, budget check is meaningless.
|
|
63
|
-
// Return 'skipped' (not 'pass') so the pipeline summary counts this gate under
|
|
64
|
-
// `skipped`, matching pipeline.js semantics for gates that did not actually run.
|
|
65
|
-
if (context === 'cli') {
|
|
66
|
-
return {
|
|
67
|
-
status: 'skipped',
|
|
68
|
-
messages: ['Budget check skipped in CLI context (budget applies to changes, not full repo)'],
|
|
69
|
-
};
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
// Build a minimal spec for deriveBudget
|
|
73
|
-
const specForBudget = {
|
|
74
|
-
risk_tier: riskTier,
|
|
75
|
-
waiver_ids: spec?.waiver_ids || [],
|
|
76
|
-
};
|
|
77
|
-
|
|
78
|
-
try {
|
|
79
|
-
const budget = await deriveBudget(specForBudget, projectRoot, { useCache: true });
|
|
80
|
-
const stats = getStagedStats(stagedFiles, projectRoot);
|
|
81
|
-
|
|
82
|
-
// Fail-closed: if git stats errored, report it
|
|
83
|
-
if (stats.error) {
|
|
84
|
-
messages.push(stats.error);
|
|
85
|
-
return { status: 'fail', messages };
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
const compliance = checkBudgetCompliance(budget, stats);
|
|
89
|
-
|
|
90
|
-
if (!compliance.compliant) {
|
|
91
|
-
for (const violation of compliance.violations) {
|
|
92
|
-
messages.push(violation.message);
|
|
93
|
-
}
|
|
94
|
-
return { status: 'fail', messages };
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
// Emit budget:pressure if usage > 80% but still compliant
|
|
98
|
-
try {
|
|
99
|
-
const filePercent = budget.max_files > 0 ? stats.files_changed / budget.max_files : 0;
|
|
100
|
-
const locPercent = budget.max_loc > 0 ? stats.lines_changed / budget.max_loc : 0;
|
|
101
|
-
if (filePercent > 0.8 || locPercent > 0.8) {
|
|
102
|
-
const { lifecycle, EVENTS } = require('../utils/lifecycle-events');
|
|
103
|
-
lifecycle.emit(EVENTS.BUDGET_PRESSURE, {
|
|
104
|
-
specId: spec?.id || null,
|
|
105
|
-
filesUsed: stats.files_changed,
|
|
106
|
-
filesLimit: budget.max_files,
|
|
107
|
-
locUsed: stats.lines_changed,
|
|
108
|
-
locLimit: budget.max_loc,
|
|
109
|
-
percentUsed: Math.round(Math.max(filePercent, locPercent) * 100),
|
|
110
|
-
timestamp: new Date().toISOString(),
|
|
111
|
-
});
|
|
112
|
-
}
|
|
113
|
-
} catch { /* non-fatal */ }
|
|
114
|
-
|
|
115
|
-
return { status: 'pass', messages };
|
|
116
|
-
} catch (err) {
|
|
117
|
-
return { status: 'fail', messages: [`Budget check error: ${err.message}`] };
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
module.exports = { name, run };
|