@zigrivers/scaffold 2.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +477 -0
- package/dist/cli/commands/adopt.d.ts +12 -0
- package/dist/cli/commands/adopt.d.ts.map +1 -0
- package/dist/cli/commands/adopt.js +107 -0
- package/dist/cli/commands/adopt.js.map +1 -0
- package/dist/cli/commands/adopt.test.d.ts +2 -0
- package/dist/cli/commands/adopt.test.d.ts.map +1 -0
- package/dist/cli/commands/adopt.test.js +277 -0
- package/dist/cli/commands/adopt.test.js.map +1 -0
- package/dist/cli/commands/build.d.ts +12 -0
- package/dist/cli/commands/build.d.ts.map +1 -0
- package/dist/cli/commands/build.js +105 -0
- package/dist/cli/commands/build.js.map +1 -0
- package/dist/cli/commands/build.test.d.ts +2 -0
- package/dist/cli/commands/build.test.d.ts.map +1 -0
- package/dist/cli/commands/build.test.js +272 -0
- package/dist/cli/commands/build.test.js.map +1 -0
- package/dist/cli/commands/dashboard.d.ts +14 -0
- package/dist/cli/commands/dashboard.d.ts.map +1 -0
- package/dist/cli/commands/dashboard.js +102 -0
- package/dist/cli/commands/dashboard.js.map +1 -0
- package/dist/cli/commands/dashboard.test.d.ts +2 -0
- package/dist/cli/commands/dashboard.test.d.ts.map +1 -0
- package/dist/cli/commands/dashboard.test.js +142 -0
- package/dist/cli/commands/dashboard.test.js.map +1 -0
- package/dist/cli/commands/decisions.d.ts +13 -0
- package/dist/cli/commands/decisions.d.ts.map +1 -0
- package/dist/cli/commands/decisions.js +62 -0
- package/dist/cli/commands/decisions.js.map +1 -0
- package/dist/cli/commands/decisions.test.d.ts +2 -0
- package/dist/cli/commands/decisions.test.d.ts.map +1 -0
- package/dist/cli/commands/decisions.test.js +154 -0
- package/dist/cli/commands/decisions.test.js.map +1 -0
- package/dist/cli/commands/info.d.ts +12 -0
- package/dist/cli/commands/info.d.ts.map +1 -0
- package/dist/cli/commands/info.js +110 -0
- package/dist/cli/commands/info.js.map +1 -0
- package/dist/cli/commands/info.test.d.ts +2 -0
- package/dist/cli/commands/info.test.d.ts.map +1 -0
- package/dist/cli/commands/info.test.js +392 -0
- package/dist/cli/commands/info.test.js.map +1 -0
- package/dist/cli/commands/init.d.ts +13 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +46 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/init.test.d.ts +2 -0
- package/dist/cli/commands/init.test.d.ts.map +1 -0
- package/dist/cli/commands/init.test.js +156 -0
- package/dist/cli/commands/init.test.js.map +1 -0
- package/dist/cli/commands/knowledge.d.ts +4 -0
- package/dist/cli/commands/knowledge.d.ts.map +1 -0
- package/dist/cli/commands/knowledge.js +346 -0
- package/dist/cli/commands/knowledge.js.map +1 -0
- package/dist/cli/commands/knowledge.test.d.ts +2 -0
- package/dist/cli/commands/knowledge.test.d.ts.map +1 -0
- package/dist/cli/commands/knowledge.test.js +293 -0
- package/dist/cli/commands/knowledge.test.js.map +1 -0
- package/dist/cli/commands/list.d.ts +12 -0
- package/dist/cli/commands/list.d.ts.map +1 -0
- package/dist/cli/commands/list.js +73 -0
- package/dist/cli/commands/list.js.map +1 -0
- package/dist/cli/commands/list.test.d.ts +2 -0
- package/dist/cli/commands/list.test.d.ts.map +1 -0
- package/dist/cli/commands/list.test.js +166 -0
- package/dist/cli/commands/list.test.js.map +1 -0
- package/dist/cli/commands/next.d.ts +12 -0
- package/dist/cli/commands/next.d.ts.map +1 -0
- package/dist/cli/commands/next.js +75 -0
- package/dist/cli/commands/next.js.map +1 -0
- package/dist/cli/commands/next.test.d.ts +2 -0
- package/dist/cli/commands/next.test.d.ts.map +1 -0
- package/dist/cli/commands/next.test.js +236 -0
- package/dist/cli/commands/next.test.js.map +1 -0
- package/dist/cli/commands/reset.d.ts +13 -0
- package/dist/cli/commands/reset.d.ts.map +1 -0
- package/dist/cli/commands/reset.js +105 -0
- package/dist/cli/commands/reset.js.map +1 -0
- package/dist/cli/commands/reset.test.d.ts +2 -0
- package/dist/cli/commands/reset.test.d.ts.map +1 -0
- package/dist/cli/commands/reset.test.js +211 -0
- package/dist/cli/commands/reset.test.js.map +1 -0
- package/dist/cli/commands/run.d.ts +14 -0
- package/dist/cli/commands/run.d.ts.map +1 -0
- package/dist/cli/commands/run.js +379 -0
- package/dist/cli/commands/run.js.map +1 -0
- package/dist/cli/commands/run.test.d.ts +2 -0
- package/dist/cli/commands/run.test.d.ts.map +1 -0
- package/dist/cli/commands/run.test.js +535 -0
- package/dist/cli/commands/run.test.js.map +1 -0
- package/dist/cli/commands/skip.d.ts +13 -0
- package/dist/cli/commands/skip.d.ts.map +1 -0
- package/dist/cli/commands/skip.js +123 -0
- package/dist/cli/commands/skip.js.map +1 -0
- package/dist/cli/commands/skip.test.d.ts +2 -0
- package/dist/cli/commands/skip.test.d.ts.map +1 -0
- package/dist/cli/commands/skip.test.js +339 -0
- package/dist/cli/commands/skip.test.js.map +1 -0
- package/dist/cli/commands/status.d.ts +12 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/status.js +79 -0
- package/dist/cli/commands/status.js.map +1 -0
- package/dist/cli/commands/status.test.d.ts +2 -0
- package/dist/cli/commands/status.test.d.ts.map +1 -0
- package/dist/cli/commands/status.test.js +245 -0
- package/dist/cli/commands/status.test.js.map +1 -0
- package/dist/cli/commands/update.d.ts +11 -0
- package/dist/cli/commands/update.d.ts.map +1 -0
- package/dist/cli/commands/update.js +159 -0
- package/dist/cli/commands/update.js.map +1 -0
- package/dist/cli/commands/update.test.d.ts +2 -0
- package/dist/cli/commands/update.test.d.ts.map +1 -0
- package/dist/cli/commands/update.test.js +140 -0
- package/dist/cli/commands/update.test.js.map +1 -0
- package/dist/cli/commands/validate.d.ts +12 -0
- package/dist/cli/commands/validate.d.ts.map +1 -0
- package/dist/cli/commands/validate.js +65 -0
- package/dist/cli/commands/validate.js.map +1 -0
- package/dist/cli/commands/validate.test.d.ts +2 -0
- package/dist/cli/commands/validate.test.d.ts.map +1 -0
- package/dist/cli/commands/validate.test.js +159 -0
- package/dist/cli/commands/validate.test.js.map +1 -0
- package/dist/cli/commands/version.d.ts +13 -0
- package/dist/cli/commands/version.d.ts.map +1 -0
- package/dist/cli/commands/version.js +89 -0
- package/dist/cli/commands/version.js.map +1 -0
- package/dist/cli/commands/version.test.d.ts +2 -0
- package/dist/cli/commands/version.test.d.ts.map +1 -0
- package/dist/cli/commands/version.test.js +63 -0
- package/dist/cli/commands/version.test.js.map +1 -0
- package/dist/cli/index.d.ts +4 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +72 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/index.test.d.ts +2 -0
- package/dist/cli/index.test.d.ts.map +1 -0
- package/dist/cli/index.test.js +8 -0
- package/dist/cli/index.test.js.map +1 -0
- package/dist/cli/middleware/output-mode.d.ts +21 -0
- package/dist/cli/middleware/output-mode.d.ts.map +1 -0
- package/dist/cli/middleware/output-mode.js +27 -0
- package/dist/cli/middleware/output-mode.js.map +1 -0
- package/dist/cli/middleware/output-mode.test.d.ts +2 -0
- package/dist/cli/middleware/output-mode.test.d.ts.map +1 -0
- package/dist/cli/middleware/output-mode.test.js +41 -0
- package/dist/cli/middleware/output-mode.test.js.map +1 -0
- package/dist/cli/middleware/project-root.d.ts +21 -0
- package/dist/cli/middleware/project-root.d.ts.map +1 -0
- package/dist/cli/middleware/project-root.js +54 -0
- package/dist/cli/middleware/project-root.js.map +1 -0
- package/dist/cli/middleware/project-root.test.d.ts +2 -0
- package/dist/cli/middleware/project-root.test.d.ts.map +1 -0
- package/dist/cli/middleware/project-root.test.js +112 -0
- package/dist/cli/middleware/project-root.test.js.map +1 -0
- package/dist/cli/output/auto.d.ts +18 -0
- package/dist/cli/output/auto.d.ts.map +1 -0
- package/dist/cli/output/auto.js +43 -0
- package/dist/cli/output/auto.js.map +1 -0
- package/dist/cli/output/context.d.ts +19 -0
- package/dist/cli/output/context.d.ts.map +1 -0
- package/dist/cli/output/context.js +15 -0
- package/dist/cli/output/context.js.map +1 -0
- package/dist/cli/output/context.test.d.ts +2 -0
- package/dist/cli/output/context.test.d.ts.map +1 -0
- package/dist/cli/output/context.test.js +335 -0
- package/dist/cli/output/context.test.js.map +1 -0
- package/dist/cli/output/error-display.d.ts +31 -0
- package/dist/cli/output/error-display.d.ts.map +1 -0
- package/dist/cli/output/error-display.js +79 -0
- package/dist/cli/output/error-display.js.map +1 -0
- package/dist/cli/output/error-display.test.d.ts +2 -0
- package/dist/cli/output/error-display.test.d.ts.map +1 -0
- package/dist/cli/output/error-display.test.js +230 -0
- package/dist/cli/output/error-display.test.js.map +1 -0
- package/dist/cli/output/interactive.d.ts +22 -0
- package/dist/cli/output/interactive.d.ts.map +1 -0
- package/dist/cli/output/interactive.js +126 -0
- package/dist/cli/output/interactive.js.map +1 -0
- package/dist/cli/output/json.d.ts +17 -0
- package/dist/cli/output/json.d.ts.map +1 -0
- package/dist/cli/output/json.js +62 -0
- package/dist/cli/output/json.js.map +1 -0
- package/dist/cli/types.d.ts +11 -0
- package/dist/cli/types.d.ts.map +1 -0
- package/dist/cli/types.js +2 -0
- package/dist/cli/types.js.map +1 -0
- package/dist/config/loader.d.ts +22 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +159 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/loader.test.d.ts +2 -0
- package/dist/config/loader.test.d.ts.map +1 -0
- package/dist/config/loader.test.js +226 -0
- package/dist/config/loader.test.js.map +1 -0
- package/dist/config/migration.d.ts +15 -0
- package/dist/config/migration.d.ts.map +1 -0
- package/dist/config/migration.js +39 -0
- package/dist/config/migration.js.map +1 -0
- package/dist/config/migration.test.d.ts +2 -0
- package/dist/config/migration.test.d.ts.map +1 -0
- package/dist/config/migration.test.js +44 -0
- package/dist/config/migration.test.js.map +1 -0
- package/dist/config/schema.d.ts +121 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +22 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/config/schema.test.d.ts +2 -0
- package/dist/config/schema.test.d.ts.map +1 -0
- package/dist/config/schema.test.js +126 -0
- package/dist/config/schema.test.js.map +1 -0
- package/dist/core/adapters/adapter.d.ts +64 -0
- package/dist/core/adapters/adapter.d.ts.map +1 -0
- package/dist/core/adapters/adapter.js +25 -0
- package/dist/core/adapters/adapter.js.map +1 -0
- package/dist/core/adapters/adapter.test.d.ts +2 -0
- package/dist/core/adapters/adapter.test.d.ts.map +1 -0
- package/dist/core/adapters/adapter.test.js +175 -0
- package/dist/core/adapters/adapter.test.js.map +1 -0
- package/dist/core/adapters/claude-code.d.ts +9 -0
- package/dist/core/adapters/claude-code.d.ts.map +1 -0
- package/dist/core/adapters/claude-code.js +34 -0
- package/dist/core/adapters/claude-code.js.map +1 -0
- package/dist/core/adapters/claude-code.test.d.ts +2 -0
- package/dist/core/adapters/claude-code.test.d.ts.map +1 -0
- package/dist/core/adapters/claude-code.test.js +100 -0
- package/dist/core/adapters/claude-code.test.js.map +1 -0
- package/dist/core/adapters/codex.d.ts +10 -0
- package/dist/core/adapters/codex.d.ts.map +1 -0
- package/dist/core/adapters/codex.js +61 -0
- package/dist/core/adapters/codex.js.map +1 -0
- package/dist/core/adapters/codex.test.d.ts +2 -0
- package/dist/core/adapters/codex.test.d.ts.map +1 -0
- package/dist/core/adapters/codex.test.js +122 -0
- package/dist/core/adapters/codex.test.js.map +1 -0
- package/dist/core/adapters/universal.d.ts +10 -0
- package/dist/core/adapters/universal.d.ts.map +1 -0
- package/dist/core/adapters/universal.js +45 -0
- package/dist/core/adapters/universal.js.map +1 -0
- package/dist/core/adapters/universal.test.d.ts +2 -0
- package/dist/core/adapters/universal.test.d.ts.map +1 -0
- package/dist/core/adapters/universal.test.js +121 -0
- package/dist/core/adapters/universal.test.js.map +1 -0
- package/dist/core/assembly/context-gatherer.d.ts +17 -0
- package/dist/core/assembly/context-gatherer.d.ts.map +1 -0
- package/dist/core/assembly/context-gatherer.js +49 -0
- package/dist/core/assembly/context-gatherer.js.map +1 -0
- package/dist/core/assembly/context-gatherer.test.d.ts +2 -0
- package/dist/core/assembly/context-gatherer.test.d.ts.map +1 -0
- package/dist/core/assembly/context-gatherer.test.js +252 -0
- package/dist/core/assembly/context-gatherer.test.js.map +1 -0
- package/dist/core/assembly/depth-resolver.d.ts +11 -0
- package/dist/core/assembly/depth-resolver.d.ts.map +1 -0
- package/dist/core/assembly/depth-resolver.js +23 -0
- package/dist/core/assembly/depth-resolver.js.map +1 -0
- package/dist/core/assembly/depth-resolver.test.d.ts +2 -0
- package/dist/core/assembly/depth-resolver.test.d.ts.map +1 -0
- package/dist/core/assembly/depth-resolver.test.js +100 -0
- package/dist/core/assembly/depth-resolver.test.js.map +1 -0
- package/dist/core/assembly/engine.d.ts +22 -0
- package/dist/core/assembly/engine.d.ts.map +1 -0
- package/dist/core/assembly/engine.js +215 -0
- package/dist/core/assembly/engine.js.map +1 -0
- package/dist/core/assembly/engine.test.d.ts +2 -0
- package/dist/core/assembly/engine.test.d.ts.map +1 -0
- package/dist/core/assembly/engine.test.js +462 -0
- package/dist/core/assembly/engine.test.js.map +1 -0
- package/dist/core/assembly/instruction-loader.d.ts +16 -0
- package/dist/core/assembly/instruction-loader.d.ts.map +1 -0
- package/dist/core/assembly/instruction-loader.js +40 -0
- package/dist/core/assembly/instruction-loader.js.map +1 -0
- package/dist/core/assembly/instruction-loader.test.d.ts +2 -0
- package/dist/core/assembly/instruction-loader.test.d.ts.map +1 -0
- package/dist/core/assembly/instruction-loader.test.js +109 -0
- package/dist/core/assembly/instruction-loader.test.js.map +1 -0
- package/dist/core/assembly/knowledge-loader.d.ts +34 -0
- package/dist/core/assembly/knowledge-loader.d.ts.map +1 -0
- package/dist/core/assembly/knowledge-loader.js +204 -0
- package/dist/core/assembly/knowledge-loader.js.map +1 -0
- package/dist/core/assembly/knowledge-loader.test.d.ts +2 -0
- package/dist/core/assembly/knowledge-loader.test.d.ts.map +1 -0
- package/dist/core/assembly/knowledge-loader.test.js +205 -0
- package/dist/core/assembly/knowledge-loader.test.js.map +1 -0
- package/dist/core/assembly/meta-prompt-loader.d.ts +13 -0
- package/dist/core/assembly/meta-prompt-loader.d.ts.map +1 -0
- package/dist/core/assembly/meta-prompt-loader.js +91 -0
- package/dist/core/assembly/meta-prompt-loader.js.map +1 -0
- package/dist/core/assembly/meta-prompt-loader.test.d.ts +2 -0
- package/dist/core/assembly/meta-prompt-loader.test.d.ts.map +1 -0
- package/dist/core/assembly/meta-prompt-loader.test.js +232 -0
- package/dist/core/assembly/meta-prompt-loader.test.js.map +1 -0
- package/dist/core/assembly/methodology-change.d.ts +27 -0
- package/dist/core/assembly/methodology-change.d.ts.map +1 -0
- package/dist/core/assembly/methodology-change.js +41 -0
- package/dist/core/assembly/methodology-change.js.map +1 -0
- package/dist/core/assembly/methodology-change.test.d.ts +2 -0
- package/dist/core/assembly/methodology-change.test.d.ts.map +1 -0
- package/dist/core/assembly/methodology-change.test.js +145 -0
- package/dist/core/assembly/methodology-change.test.js.map +1 -0
- package/dist/core/assembly/methodology-resolver.d.ts +11 -0
- package/dist/core/assembly/methodology-resolver.d.ts.map +1 -0
- package/dist/core/assembly/methodology-resolver.js +19 -0
- package/dist/core/assembly/methodology-resolver.js.map +1 -0
- package/dist/core/assembly/methodology-resolver.test.d.ts +2 -0
- package/dist/core/assembly/methodology-resolver.test.d.ts.map +1 -0
- package/dist/core/assembly/methodology-resolver.test.js +87 -0
- package/dist/core/assembly/methodology-resolver.test.js.map +1 -0
- package/dist/core/assembly/preset-loader.d.ts +26 -0
- package/dist/core/assembly/preset-loader.d.ts.map +1 -0
- package/dist/core/assembly/preset-loader.js +146 -0
- package/dist/core/assembly/preset-loader.js.map +1 -0
- package/dist/core/assembly/preset-loader.test.d.ts +2 -0
- package/dist/core/assembly/preset-loader.test.d.ts.map +1 -0
- package/dist/core/assembly/preset-loader.test.js +107 -0
- package/dist/core/assembly/preset-loader.test.js.map +1 -0
- package/dist/core/assembly/update-mode.d.ts +25 -0
- package/dist/core/assembly/update-mode.d.ts.map +1 -0
- package/dist/core/assembly/update-mode.js +70 -0
- package/dist/core/assembly/update-mode.js.map +1 -0
- package/dist/core/assembly/update-mode.test.d.ts +2 -0
- package/dist/core/assembly/update-mode.test.d.ts.map +1 -0
- package/dist/core/assembly/update-mode.test.js +235 -0
- package/dist/core/assembly/update-mode.test.js.map +1 -0
- package/dist/core/dependency/dependency.d.ts +20 -0
- package/dist/core/dependency/dependency.d.ts.map +1 -0
- package/dist/core/dependency/dependency.js +104 -0
- package/dist/core/dependency/dependency.js.map +1 -0
- package/dist/core/dependency/dependency.test.d.ts +2 -0
- package/dist/core/dependency/dependency.test.d.ts.map +1 -0
- package/dist/core/dependency/dependency.test.js +166 -0
- package/dist/core/dependency/dependency.test.js.map +1 -0
- package/dist/core/dependency/eligibility.d.ts +17 -0
- package/dist/core/dependency/eligibility.d.ts.map +1 -0
- package/dist/core/dependency/eligibility.js +60 -0
- package/dist/core/dependency/eligibility.js.map +1 -0
- package/dist/core/dependency/eligibility.test.d.ts +2 -0
- package/dist/core/dependency/eligibility.test.d.ts.map +1 -0
- package/dist/core/dependency/eligibility.test.js +198 -0
- package/dist/core/dependency/eligibility.test.js.map +1 -0
- package/dist/core/dependency/graph.d.ts +12 -0
- package/dist/core/dependency/graph.d.ts.map +1 -0
- package/dist/core/dependency/graph.js +34 -0
- package/dist/core/dependency/graph.js.map +1 -0
- package/dist/core/knowledge/knowledge-update-assembler.d.ts +24 -0
- package/dist/core/knowledge/knowledge-update-assembler.d.ts.map +1 -0
- package/dist/core/knowledge/knowledge-update-assembler.js +46 -0
- package/dist/core/knowledge/knowledge-update-assembler.js.map +1 -0
- package/dist/core/knowledge/knowledge-update-assembler.test.d.ts +2 -0
- package/dist/core/knowledge/knowledge-update-assembler.test.d.ts.map +1 -0
- package/dist/core/knowledge/knowledge-update-assembler.test.js +93 -0
- package/dist/core/knowledge/knowledge-update-assembler.test.js.map +1 -0
- package/dist/core/knowledge/knowledge-update-template.md +55 -0
- package/dist/dashboard/generator.d.ts +37 -0
- package/dist/dashboard/generator.d.ts.map +1 -0
- package/dist/dashboard/generator.js +42 -0
- package/dist/dashboard/generator.js.map +1 -0
- package/dist/dashboard/generator.test.d.ts +2 -0
- package/dist/dashboard/generator.test.d.ts.map +1 -0
- package/dist/dashboard/generator.test.js +186 -0
- package/dist/dashboard/generator.test.js.map +1 -0
- package/dist/dashboard/template.d.ts +4 -0
- package/dist/dashboard/template.d.ts.map +1 -0
- package/dist/dashboard/template.js +190 -0
- package/dist/dashboard/template.js.map +1 -0
- package/dist/e2e/commands.test.d.ts +9 -0
- package/dist/e2e/commands.test.d.ts.map +1 -0
- package/dist/e2e/commands.test.js +499 -0
- package/dist/e2e/commands.test.js.map +1 -0
- package/dist/e2e/init.test.d.ts +10 -0
- package/dist/e2e/init.test.d.ts.map +1 -0
- package/dist/e2e/init.test.js +180 -0
- package/dist/e2e/init.test.js.map +1 -0
- package/dist/e2e/knowledge.test.d.ts +2 -0
- package/dist/e2e/knowledge.test.d.ts.map +1 -0
- package/dist/e2e/knowledge.test.js +103 -0
- package/dist/e2e/knowledge.test.js.map +1 -0
- package/dist/e2e/pipeline.test.d.ts +8 -0
- package/dist/e2e/pipeline.test.d.ts.map +1 -0
- package/dist/e2e/pipeline.test.js +295 -0
- package/dist/e2e/pipeline.test.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/project/adopt.d.ts +28 -0
- package/dist/project/adopt.d.ts.map +1 -0
- package/dist/project/adopt.js +49 -0
- package/dist/project/adopt.js.map +1 -0
- package/dist/project/adopt.test.d.ts +2 -0
- package/dist/project/adopt.test.d.ts.map +1 -0
- package/dist/project/adopt.test.js +220 -0
- package/dist/project/adopt.test.js.map +1 -0
- package/dist/project/claude-md.d.ts +33 -0
- package/dist/project/claude-md.d.ts.map +1 -0
- package/dist/project/claude-md.js +112 -0
- package/dist/project/claude-md.js.map +1 -0
- package/dist/project/claude-md.test.d.ts +2 -0
- package/dist/project/claude-md.test.d.ts.map +1 -0
- package/dist/project/claude-md.test.js +151 -0
- package/dist/project/claude-md.test.js.map +1 -0
- package/dist/project/detector.d.ts +7 -0
- package/dist/project/detector.d.ts.map +1 -0
- package/dist/project/detector.js +78 -0
- package/dist/project/detector.js.map +1 -0
- package/dist/project/detector.test.d.ts +2 -0
- package/dist/project/detector.test.d.ts.map +1 -0
- package/dist/project/detector.test.js +137 -0
- package/dist/project/detector.test.js.map +1 -0
- package/dist/project/frontmatter.d.ts +17 -0
- package/dist/project/frontmatter.d.ts.map +1 -0
- package/dist/project/frontmatter.js +236 -0
- package/dist/project/frontmatter.js.map +1 -0
- package/dist/project/frontmatter.test.d.ts +2 -0
- package/dist/project/frontmatter.test.d.ts.map +1 -0
- package/dist/project/frontmatter.test.js +218 -0
- package/dist/project/frontmatter.test.js.map +1 -0
- package/dist/project/signals.d.ts +12 -0
- package/dist/project/signals.d.ts.map +1 -0
- package/dist/project/signals.js +2 -0
- package/dist/project/signals.js.map +1 -0
- package/dist/state/completion.d.ts +22 -0
- package/dist/state/completion.d.ts.map +1 -0
- package/dist/state/completion.js +82 -0
- package/dist/state/completion.js.map +1 -0
- package/dist/state/completion.test.d.ts +2 -0
- package/dist/state/completion.test.d.ts.map +1 -0
- package/dist/state/completion.test.js +246 -0
- package/dist/state/completion.test.js.map +1 -0
- package/dist/state/decision-logger.d.ts +16 -0
- package/dist/state/decision-logger.d.ts.map +1 -0
- package/dist/state/decision-logger.js +80 -0
- package/dist/state/decision-logger.js.map +1 -0
- package/dist/state/decision-logger.test.d.ts +2 -0
- package/dist/state/decision-logger.test.d.ts.map +1 -0
- package/dist/state/decision-logger.test.js +182 -0
- package/dist/state/decision-logger.test.js.map +1 -0
- package/dist/state/lock-manager.d.ts +18 -0
- package/dist/state/lock-manager.d.ts.map +1 -0
- package/dist/state/lock-manager.js +134 -0
- package/dist/state/lock-manager.js.map +1 -0
- package/dist/state/lock-manager.test.d.ts +2 -0
- package/dist/state/lock-manager.test.d.ts.map +1 -0
- package/dist/state/lock-manager.test.js +190 -0
- package/dist/state/lock-manager.test.js.map +1 -0
- package/dist/state/state-manager.d.ts +37 -0
- package/dist/state/state-manager.d.ts.map +1 -0
- package/dist/state/state-manager.js +125 -0
- package/dist/state/state-manager.js.map +1 -0
- package/dist/state/state-manager.test.d.ts +2 -0
- package/dist/state/state-manager.test.d.ts.map +1 -0
- package/dist/state/state-manager.test.js +240 -0
- package/dist/state/state-manager.test.js.map +1 -0
- package/dist/types/adapter.d.ts +24 -0
- package/dist/types/adapter.d.ts.map +1 -0
- package/dist/types/adapter.js +2 -0
- package/dist/types/adapter.js.map +1 -0
- package/dist/types/assembly.d.ts +89 -0
- package/dist/types/assembly.d.ts.map +1 -0
- package/dist/types/assembly.js +2 -0
- package/dist/types/assembly.js.map +1 -0
- package/dist/types/claude-md.d.ts +11 -0
- package/dist/types/claude-md.d.ts.map +1 -0
- package/dist/types/claude-md.js +2 -0
- package/dist/types/claude-md.js.map +1 -0
- package/dist/types/cli.d.ts +15 -0
- package/dist/types/cli.d.ts.map +1 -0
- package/dist/types/cli.js +2 -0
- package/dist/types/cli.js.map +1 -0
- package/dist/types/config.d.ts +40 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +2 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/decision.d.ts +14 -0
- package/dist/types/decision.d.ts.map +1 -0
- package/dist/types/decision.js +2 -0
- package/dist/types/decision.js.map +1 -0
- package/dist/types/dependency.d.ts +12 -0
- package/dist/types/dependency.d.ts.map +1 -0
- package/dist/types/dependency.js +2 -0
- package/dist/types/dependency.js.map +1 -0
- package/dist/types/enums.d.ts +23 -0
- package/dist/types/enums.d.ts.map +1 -0
- package/dist/types/enums.js +11 -0
- package/dist/types/enums.js.map +1 -0
- package/dist/types/enums.test.d.ts +2 -0
- package/dist/types/enums.test.d.ts.map +1 -0
- package/dist/types/enums.test.js +13 -0
- package/dist/types/enums.test.js.map +1 -0
- package/dist/types/errors.d.ts +24 -0
- package/dist/types/errors.d.ts.map +1 -0
- package/dist/types/errors.js +2 -0
- package/dist/types/errors.js.map +1 -0
- package/dist/types/frontmatter.d.ts +43 -0
- package/dist/types/frontmatter.d.ts.map +1 -0
- package/dist/types/frontmatter.js +2 -0
- package/dist/types/frontmatter.js.map +1 -0
- package/dist/types/index.d.ts +14 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +14 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/lock.d.ts +10 -0
- package/dist/types/lock.d.ts.map +1 -0
- package/dist/types/lock.js +2 -0
- package/dist/types/lock.js.map +1 -0
- package/dist/types/state.d.ts +49 -0
- package/dist/types/state.d.ts.map +1 -0
- package/dist/types/state.js +2 -0
- package/dist/types/state.js.map +1 -0
- package/dist/types/wizard.d.ts +14 -0
- package/dist/types/wizard.d.ts.map +1 -0
- package/dist/types/wizard.js +2 -0
- package/dist/types/wizard.js.map +1 -0
- package/dist/utils/errors.d.ts +42 -0
- package/dist/utils/errors.d.ts.map +1 -0
- package/dist/utils/errors.js +232 -0
- package/dist/utils/errors.js.map +1 -0
- package/dist/utils/errors.test.d.ts +2 -0
- package/dist/utils/errors.test.d.ts.map +1 -0
- package/dist/utils/errors.test.js +91 -0
- package/dist/utils/errors.test.js.map +1 -0
- package/dist/utils/fs.d.ts +11 -0
- package/dist/utils/fs.d.ts.map +1 -0
- package/dist/utils/fs.js +20 -0
- package/dist/utils/fs.js.map +1 -0
- package/dist/utils/fs.test.d.ts +2 -0
- package/dist/utils/fs.test.d.ts.map +1 -0
- package/dist/utils/fs.test.js +93 -0
- package/dist/utils/fs.test.js.map +1 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +4 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/levenshtein.d.ts +11 -0
- package/dist/utils/levenshtein.d.ts.map +1 -0
- package/dist/utils/levenshtein.js +37 -0
- package/dist/utils/levenshtein.js.map +1 -0
- package/dist/utils/levenshtein.test.d.ts +2 -0
- package/dist/utils/levenshtein.test.d.ts.map +1 -0
- package/dist/utils/levenshtein.test.js +34 -0
- package/dist/utils/levenshtein.test.js.map +1 -0
- package/dist/validation/config-validator.d.ts +10 -0
- package/dist/validation/config-validator.d.ts.map +1 -0
- package/dist/validation/config-validator.js +11 -0
- package/dist/validation/config-validator.js.map +1 -0
- package/dist/validation/dependency-validator.d.ts +10 -0
- package/dist/validation/dependency-validator.d.ts.map +1 -0
- package/dist/validation/dependency-validator.js +34 -0
- package/dist/validation/dependency-validator.js.map +1 -0
- package/dist/validation/frontmatter-validator.d.ts +12 -0
- package/dist/validation/frontmatter-validator.d.ts.map +1 -0
- package/dist/validation/frontmatter-validator.js +50 -0
- package/dist/validation/frontmatter-validator.js.map +1 -0
- package/dist/validation/index.d.ts +19 -0
- package/dist/validation/index.d.ts.map +1 -0
- package/dist/validation/index.js +64 -0
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/index.test.d.ts +2 -0
- package/dist/validation/index.test.d.ts.map +1 -0
- package/dist/validation/index.test.js +241 -0
- package/dist/validation/index.test.js.map +1 -0
- package/dist/validation/state-validator.d.ts +15 -0
- package/dist/validation/state-validator.d.ts.map +1 -0
- package/dist/validation/state-validator.js +104 -0
- package/dist/validation/state-validator.js.map +1 -0
- package/dist/wizard/questions.d.ts +18 -0
- package/dist/wizard/questions.d.ts.map +1 -0
- package/dist/wizard/questions.js +46 -0
- package/dist/wizard/questions.js.map +1 -0
- package/dist/wizard/suggestion.d.ts +10 -0
- package/dist/wizard/suggestion.d.ts.map +1 -0
- package/dist/wizard/suggestion.js +17 -0
- package/dist/wizard/suggestion.js.map +1 -0
- package/dist/wizard/wizard.d.ts +19 -0
- package/dist/wizard/wizard.d.ts.map +1 -0
- package/dist/wizard/wizard.js +104 -0
- package/dist/wizard/wizard.js.map +1 -0
- package/dist/wizard/wizard.test.d.ts +2 -0
- package/dist/wizard/wizard.test.d.ts.map +1 -0
- package/dist/wizard/wizard.test.js +167 -0
- package/dist/wizard/wizard.test.js.map +1 -0
- package/knowledge/core/adr-craft.md +281 -0
- package/knowledge/core/api-design.md +501 -0
- package/knowledge/core/database-design.md +380 -0
- package/knowledge/core/domain-modeling.md +317 -0
- package/knowledge/core/operations-runbook.md +513 -0
- package/knowledge/core/security-review.md +523 -0
- package/knowledge/core/system-architecture.md +402 -0
- package/knowledge/core/task-decomposition.md +372 -0
- package/knowledge/core/testing-strategy.md +409 -0
- package/knowledge/core/user-stories.md +337 -0
- package/knowledge/core/user-story-innovation.md +171 -0
- package/knowledge/core/ux-specification.md +380 -0
- package/knowledge/finalization/apply-fixes-and-freeze.md +93 -0
- package/knowledge/finalization/developer-onboarding.md +376 -0
- package/knowledge/finalization/implementation-playbook.md +404 -0
- package/knowledge/product/gap-analysis.md +305 -0
- package/knowledge/product/prd-craft.md +324 -0
- package/knowledge/product/prd-innovation.md +204 -0
- package/knowledge/review/review-adr.md +203 -0
- package/knowledge/review/review-api-contracts.md +233 -0
- package/knowledge/review/review-database-schema.md +229 -0
- package/knowledge/review/review-domain-modeling.md +288 -0
- package/knowledge/review/review-implementation-tasks.md +202 -0
- package/knowledge/review/review-methodology.md +215 -0
- package/knowledge/review/review-operations.md +212 -0
- package/knowledge/review/review-prd.md +235 -0
- package/knowledge/review/review-security.md +213 -0
- package/knowledge/review/review-system-architecture.md +296 -0
- package/knowledge/review/review-testing-strategy.md +176 -0
- package/knowledge/review/review-user-stories.md +172 -0
- package/knowledge/review/review-ux-spec.md +208 -0
- package/knowledge/validation/critical-path-analysis.md +203 -0
- package/knowledge/validation/cross-phase-consistency.md +181 -0
- package/knowledge/validation/decision-completeness.md +218 -0
- package/knowledge/validation/dependency-validation.md +233 -0
- package/knowledge/validation/implementability-review.md +252 -0
- package/knowledge/validation/scope-management.md +223 -0
- package/knowledge/validation/traceability.md +198 -0
- package/methodology/custom-defaults.yml +43 -0
- package/methodology/deep.yml +42 -0
- package/methodology/mvp.yml +42 -0
- package/package.json +58 -0
- package/pipeline/architecture/review-architecture.md +44 -0
- package/pipeline/architecture/system-architecture.md +45 -0
- package/pipeline/decisions/adrs.md +45 -0
- package/pipeline/decisions/review-adrs.md +39 -0
- package/pipeline/finalization/apply-fixes-and-freeze.md +39 -0
- package/pipeline/finalization/developer-onboarding-guide.md +36 -0
- package/pipeline/finalization/implementation-playbook.md +45 -0
- package/pipeline/modeling/domain-modeling.md +57 -0
- package/pipeline/modeling/review-domain-modeling.md +41 -0
- package/pipeline/planning/implementation-tasks.md +57 -0
- package/pipeline/planning/review-tasks.md +38 -0
- package/pipeline/pre/create-prd.md +45 -0
- package/pipeline/pre/innovate-prd.md +47 -0
- package/pipeline/pre/innovate-user-stories.md +47 -0
- package/pipeline/pre/review-prd.md +44 -0
- package/pipeline/pre/review-user-stories.md +43 -0
- package/pipeline/pre/user-stories.md +48 -0
- package/pipeline/quality/operations.md +42 -0
- package/pipeline/quality/review-operations.md +37 -0
- package/pipeline/quality/review-security.md +40 -0
- package/pipeline/quality/review-testing.md +39 -0
- package/pipeline/quality/security.md +44 -0
- package/pipeline/quality/testing-strategy.md +42 -0
- package/pipeline/specification/api-contracts.md +44 -0
- package/pipeline/specification/database-schema.md +41 -0
- package/pipeline/specification/review-api.md +40 -0
- package/pipeline/specification/review-database.md +39 -0
- package/pipeline/specification/review-ux.md +38 -0
- package/pipeline/specification/ux-spec.md +43 -0
- package/pipeline/validation/critical-path-walkthrough.md +37 -0
- package/pipeline/validation/cross-phase-consistency.md +35 -0
- package/pipeline/validation/decision-completeness.md +36 -0
- package/pipeline/validation/dependency-graph-validation.md +36 -0
- package/pipeline/validation/implementability-dry-run.md +36 -0
- package/pipeline/validation/scope-creep-check.md +38 -0
- package/pipeline/validation/traceability-matrix.md +36 -0
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { ExitCode } from './enums.js';
|
|
2
|
+
/** Structured error with code, exit code, and recovery hint. */
|
|
3
|
+
export interface ScaffoldError {
|
|
4
|
+
/** Machine-readable error code (e.g., 'CONFIG_MISSING'). */
|
|
5
|
+
code: string;
|
|
6
|
+
/** Human-readable message. */
|
|
7
|
+
message: string;
|
|
8
|
+
/** Process exit code. */
|
|
9
|
+
exitCode: ExitCode;
|
|
10
|
+
/** Suggested fix. */
|
|
11
|
+
recovery?: string;
|
|
12
|
+
/** Context variables (file, line, value, etc.). */
|
|
13
|
+
context?: Record<string, string | number | undefined>;
|
|
14
|
+
}
|
|
15
|
+
/** Non-fatal warning (same shape as error but never causes non-zero exit). */
|
|
16
|
+
export interface ScaffoldWarning {
|
|
17
|
+
/** Machine-readable warning code (e.g., 'CONFIG_UNKNOWN_FIELD'). */
|
|
18
|
+
code: string;
|
|
19
|
+
/** Human-readable message. */
|
|
20
|
+
message: string;
|
|
21
|
+
/** Context variables. */
|
|
22
|
+
context?: Record<string, string | number | undefined>;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/types/errors.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAE1C,gEAAgE;AAChE,MAAM,WAAW,aAAa;IAC5B,4DAA4D;IAC5D,IAAI,EAAE,MAAM,CAAA;IACZ,8BAA8B;IAC9B,OAAO,EAAE,MAAM,CAAA;IACf,yBAAyB;IACzB,QAAQ,EAAE,QAAQ,CAAA;IAClB,qBAAqB;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,mDAAmD;IACnD,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC,CAAA;CACtD;AAED,8EAA8E;AAC9E,MAAM,WAAW,eAAe;IAC9B,oEAAoE;IACpE,IAAI,EAAE,MAAM,CAAA;IACZ,8BAA8B;IAC9B,OAAO,EAAE,MAAM,CAAA;IACf,yBAAyB;IACzB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC,CAAA;CACtD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/types/errors.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Parsed YAML frontmatter from a meta-prompt .md file.
|
|
3
|
+
* See frontmatter-schema.md (authoritative source).
|
|
4
|
+
* Note: kebab-case YAML keys are converted to camelCase on parse.
|
|
5
|
+
*/
|
|
6
|
+
export interface MetaPromptFrontmatter {
|
|
7
|
+
/** Step identifier matching the filename stem. Kebab-case pattern ^[a-z][a-z0-9-]*$ */
|
|
8
|
+
name: string;
|
|
9
|
+
/** One-line purpose. Max 200 chars. */
|
|
10
|
+
description: string;
|
|
11
|
+
/**
|
|
12
|
+
* Pipeline phase: 'pre' | 'modeling' | 'decisions' | 'architecture' |
|
|
13
|
+
* 'specification' | 'planning' | 'quality' | 'validation' | 'finalization'
|
|
14
|
+
*/
|
|
15
|
+
phase: string;
|
|
16
|
+
/** Unique position 1-36. Primary tiebreaker in topological sort. */
|
|
17
|
+
order: number;
|
|
18
|
+
/** Step slugs that must complete before this step can run. */
|
|
19
|
+
dependencies: string[];
|
|
20
|
+
/** Artifact paths this step produces (relative to project root). */
|
|
21
|
+
outputs: string[];
|
|
22
|
+
/** When 'if-needed', step is conditionally evaluated during init. */
|
|
23
|
+
conditional: 'if-needed' | null;
|
|
24
|
+
/** Knowledge base entry names to load during assembly. */
|
|
25
|
+
knowledgeBase: string[];
|
|
26
|
+
/** Cross-cutting artifact references beyond the dependency chain. */
|
|
27
|
+
reads: string[];
|
|
28
|
+
[key: string]: unknown;
|
|
29
|
+
}
|
|
30
|
+
/** A loaded meta-prompt file with parsed frontmatter and body. */
|
|
31
|
+
export interface MetaPromptFile {
|
|
32
|
+
/** The filename stem (matches frontmatter name). */
|
|
33
|
+
stepName: string;
|
|
34
|
+
/** Absolute file path. */
|
|
35
|
+
filePath: string;
|
|
36
|
+
/** Validated frontmatter. */
|
|
37
|
+
frontmatter: MetaPromptFrontmatter;
|
|
38
|
+
/** Raw markdown body (everything after closing ---). */
|
|
39
|
+
body: string;
|
|
40
|
+
/** Parsed level-2 heading sections from the body. */
|
|
41
|
+
sections: Record<string, string>;
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=frontmatter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frontmatter.d.ts","sourceRoot":"","sources":["../../src/types/frontmatter.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,MAAM,WAAW,qBAAqB;IACpC,uFAAuF;IACvF,IAAI,EAAE,MAAM,CAAA;IACZ,uCAAuC;IACvC,WAAW,EAAE,MAAM,CAAA;IACnB;;;OAGG;IACH,KAAK,EAAE,MAAM,CAAA;IACb,oEAAoE;IACpE,KAAK,EAAE,MAAM,CAAA;IACb,8DAA8D;IAC9D,YAAY,EAAE,MAAM,EAAE,CAAA;IACtB,oEAAoE;IACpE,OAAO,EAAE,MAAM,EAAE,CAAA;IACjB,qEAAqE;IACrE,WAAW,EAAE,WAAW,GAAG,IAAI,CAAA;IAC/B,0DAA0D;IAC1D,aAAa,EAAE,MAAM,EAAE,CAAA;IACvB,qEAAqE;IACrE,KAAK,EAAE,MAAM,EAAE,CAAA;IACf,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;CACvB;AAED,kEAAkE;AAClE,MAAM,WAAW,cAAc;IAC7B,oDAAoD;IACpD,QAAQ,EAAE,MAAM,CAAA;IAChB,0BAA0B;IAC1B,QAAQ,EAAE,MAAM,CAAA;IAChB,6BAA6B;IAC7B,WAAW,EAAE,qBAAqB,CAAA;IAClC,wDAAwD;IACxD,IAAI,EAAE,MAAM,CAAA;IACZ,qDAAqD;IACrD,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CACjC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frontmatter.js","sourceRoot":"","sources":["../../src/types/frontmatter.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export * from './enums.js';
|
|
2
|
+
export * from './config.js';
|
|
3
|
+
export * from './state.js';
|
|
4
|
+
export * from './frontmatter.js';
|
|
5
|
+
export * from './assembly.js';
|
|
6
|
+
export * from './dependency.js';
|
|
7
|
+
export * from './decision.js';
|
|
8
|
+
export * from './lock.js';
|
|
9
|
+
export * from './cli.js';
|
|
10
|
+
export * from './adapter.js';
|
|
11
|
+
export * from './wizard.js';
|
|
12
|
+
export * from './errors.js';
|
|
13
|
+
export * from './claude-md.js';
|
|
14
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA;AAC1B,cAAc,aAAa,CAAA;AAC3B,cAAc,YAAY,CAAA;AAC1B,cAAc,kBAAkB,CAAA;AAChC,cAAc,eAAe,CAAA;AAC7B,cAAc,iBAAiB,CAAA;AAC/B,cAAc,eAAe,CAAA;AAC7B,cAAc,WAAW,CAAA;AACzB,cAAc,UAAU,CAAA;AACxB,cAAc,cAAc,CAAA;AAC5B,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,gBAAgB,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export * from './enums.js';
|
|
2
|
+
export * from './config.js';
|
|
3
|
+
export * from './state.js';
|
|
4
|
+
export * from './frontmatter.js';
|
|
5
|
+
export * from './assembly.js';
|
|
6
|
+
export * from './dependency.js';
|
|
7
|
+
export * from './decision.js';
|
|
8
|
+
export * from './lock.js';
|
|
9
|
+
export * from './cli.js';
|
|
10
|
+
export * from './adapter.js';
|
|
11
|
+
export * from './wizard.js';
|
|
12
|
+
export * from './errors.js';
|
|
13
|
+
export * from './claude-md.js';
|
|
14
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA;AAC1B,cAAc,aAAa,CAAA;AAC3B,cAAc,YAAY,CAAA;AAC1B,cAAc,kBAAkB,CAAA;AAChC,cAAc,eAAe,CAAA;AAC7B,cAAc,iBAAiB,CAAA;AAC/B,cAAc,eAAe,CAAA;AAC7B,cAAc,WAAW,CAAA;AACzB,cAAc,UAAU,CAAA;AACxB,cAAc,cAAc,CAAA;AAC5B,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,gBAAgB,CAAA"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export type LockableCommand = 'run' | 'skip' | 'init' | 'reset' | 'adopt';
|
|
2
|
+
export interface LockFile {
|
|
3
|
+
holder: string;
|
|
4
|
+
prompt?: string;
|
|
5
|
+
pid: number;
|
|
6
|
+
started: string;
|
|
7
|
+
processStartedAt: string;
|
|
8
|
+
command: LockableCommand;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=lock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lock.d.ts","sourceRoot":"","sources":["../../src/types/lock.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,eAAe,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,OAAO,CAAA;AAEzE,MAAM,WAAW,QAAQ;IACvB,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,GAAG,EAAE,MAAM,CAAA;IACX,OAAO,EAAE,MAAM,CAAA;IACf,gBAAgB,EAAE,MAAM,CAAA;IACxB,OAAO,EAAE,eAAe,CAAA;CACzB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lock.js","sourceRoot":"","sources":["../../src/types/lock.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import type { StepStatus, StepSource, DepthLevel, MethodologyName } from './enums.js';
|
|
2
|
+
/** A single step's state entry in state.json. */
|
|
3
|
+
export interface StepStateEntry {
|
|
4
|
+
status: StepStatus;
|
|
5
|
+
source: StepSource;
|
|
6
|
+
at?: string;
|
|
7
|
+
produces?: string[];
|
|
8
|
+
artifacts_verified?: boolean;
|
|
9
|
+
completed_by?: string;
|
|
10
|
+
reason?: string;
|
|
11
|
+
depth?: DepthLevel;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* In-progress execution record. Non-null = either active or crashed.
|
|
15
|
+
* See state-json-schema.md InProgressRecord.
|
|
16
|
+
*/
|
|
17
|
+
export interface InProgressRecord {
|
|
18
|
+
step: string;
|
|
19
|
+
started: string;
|
|
20
|
+
partial_artifacts: string[];
|
|
21
|
+
actor: string;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* User-added custom step. Phase 2 — reserved as empty array in Phase 1.
|
|
25
|
+
* See state-json-schema.md ExtraStepEntry.
|
|
26
|
+
*/
|
|
27
|
+
export interface ExtraStepEntry {
|
|
28
|
+
slug: string;
|
|
29
|
+
path: string;
|
|
30
|
+
'depends-on'?: string[];
|
|
31
|
+
phase?: string;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Complete pipeline state file (.scaffold/state.json).
|
|
35
|
+
* See state-json-schema.md.
|
|
36
|
+
*/
|
|
37
|
+
export interface PipelineState {
|
|
38
|
+
'schema-version': 1;
|
|
39
|
+
'scaffold-version': string;
|
|
40
|
+
init_methodology: MethodologyName;
|
|
41
|
+
config_methodology: MethodologyName;
|
|
42
|
+
'init-mode': 'greenfield' | 'brownfield' | 'v1-migration';
|
|
43
|
+
created: string;
|
|
44
|
+
in_progress: InProgressRecord | null;
|
|
45
|
+
steps: Record<string, StepStateEntry>;
|
|
46
|
+
next_eligible: string[];
|
|
47
|
+
'extra-steps': ExtraStepEntry[];
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=state.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state.d.ts","sourceRoot":"","sources":["../../src/types/state.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAErF,iDAAiD;AACjD,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,UAAU,CAAA;IAClB,MAAM,EAAE,UAAU,CAAA;IAClB,EAAE,CAAC,EAAE,MAAM,CAAA;IACX,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;IACnB,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,KAAK,CAAC,EAAE,UAAU,CAAA;CACnB;AAED;;;GAGG;AACH,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,EAAE,MAAM,CAAA;IACf,iBAAiB,EAAE,MAAM,EAAE,CAAA;IAC3B,KAAK,EAAE,MAAM,CAAA;CACd;AAED;;;GAGG;AACH,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;IACZ,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;IACvB,KAAK,CAAC,EAAE,MAAM,CAAA;CACf;AAED;;;GAGG;AACH,MAAM,WAAW,aAAa;IAC5B,gBAAgB,EAAE,CAAC,CAAA;IACnB,kBAAkB,EAAE,MAAM,CAAA;IAC1B,gBAAgB,EAAE,eAAe,CAAA;IACjC,kBAAkB,EAAE,eAAe,CAAA;IACnC,WAAW,EAAE,YAAY,GAAG,YAAY,GAAG,cAAc,CAAA;IACzD,OAAO,EAAE,MAAM,CAAA;IACf,WAAW,EAAE,gBAAgB,GAAG,IAAI,CAAA;IACpC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAA;IACrC,aAAa,EAAE,MAAM,EAAE,CAAA;IACvB,aAAa,EAAE,cAAc,EAAE,CAAA;CAChC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state.js","sourceRoot":"","sources":["../../src/types/state.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { MethodologyName } from './enums.js';
|
|
2
|
+
export interface WizardAnswers {
|
|
3
|
+
projectName: string;
|
|
4
|
+
methodology: MethodologyName;
|
|
5
|
+
platforms: Array<'claude-code' | 'codex'>;
|
|
6
|
+
projectPlatforms?: Array<'web' | 'mobile' | 'desktop'>;
|
|
7
|
+
}
|
|
8
|
+
export interface DetectionResult {
|
|
9
|
+
hasExistingCode: boolean;
|
|
10
|
+
hasScaffoldConfig: boolean;
|
|
11
|
+
hasV1Config: boolean;
|
|
12
|
+
suggestedMode: 'greenfield' | 'brownfield' | 'v1-migration';
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=wizard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wizard.d.ts","sourceRoot":"","sources":["../../src/types/wizard.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAEjD,MAAM,WAAW,aAAa;IAC5B,WAAW,EAAE,MAAM,CAAA;IACnB,WAAW,EAAE,eAAe,CAAA;IAC5B,SAAS,EAAE,KAAK,CAAC,aAAa,GAAG,OAAO,CAAC,CAAA;IACzC,gBAAgB,CAAC,EAAE,KAAK,CAAC,KAAK,GAAG,QAAQ,GAAG,SAAS,CAAC,CAAA;CACvD;AAED,MAAM,WAAW,eAAe;IAC9B,eAAe,EAAE,OAAO,CAAA;IACxB,iBAAiB,EAAE,OAAO,CAAA;IAC1B,WAAW,EAAE,OAAO,CAAA;IACpB,aAAa,EAAE,YAAY,GAAG,YAAY,GAAG,cAAc,CAAA;CAC5D"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wizard.js","sourceRoot":"","sources":["../../src/types/wizard.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/** Structured scaffold error. */
|
|
2
|
+
export interface ScaffoldError {
|
|
3
|
+
code: string;
|
|
4
|
+
message: string;
|
|
5
|
+
exitCode: number;
|
|
6
|
+
recovery?: string;
|
|
7
|
+
context?: Record<string, string | number | undefined>;
|
|
8
|
+
}
|
|
9
|
+
/** Non-fatal warning (never causes non-zero exit). */
|
|
10
|
+
export interface ScaffoldWarning {
|
|
11
|
+
code: string;
|
|
12
|
+
message: string;
|
|
13
|
+
context?: Record<string, string | number | undefined>;
|
|
14
|
+
}
|
|
15
|
+
export declare function configMissing(configPath: string): ScaffoldError;
|
|
16
|
+
export declare function configEmpty(configPath: string): ScaffoldError;
|
|
17
|
+
export declare function configParseError(configPath: string, detail: string): ScaffoldError;
|
|
18
|
+
export declare function configNotObject(configPath: string): ScaffoldError;
|
|
19
|
+
export declare function configUnknownField(field: string, configPath: string): ScaffoldWarning;
|
|
20
|
+
export declare function fieldMissing(field: string, file: string): ScaffoldError;
|
|
21
|
+
export declare function fieldWrongType(field: string, expected: string, actual: string, file: string): ScaffoldError;
|
|
22
|
+
export declare function fieldEmptyValue(field: string, file: string): ScaffoldError;
|
|
23
|
+
export declare function fieldInvalidDepth(value: unknown, file: string): ScaffoldError;
|
|
24
|
+
export declare function fieldInvalidMethodology(value: string, suggestion: string | null, file: string): ScaffoldError;
|
|
25
|
+
export declare function frontmatterMissing(file: string): ScaffoldError;
|
|
26
|
+
export declare function frontmatterUnclosed(file: string): ScaffoldError;
|
|
27
|
+
export declare function frontmatterYamlError(file: string, detail: string): ScaffoldError;
|
|
28
|
+
export declare function frontmatterNameInvalid(name: string, file: string): ScaffoldError;
|
|
29
|
+
export declare function frontmatterUnknownField(field: string, file: string): ScaffoldWarning;
|
|
30
|
+
export declare function stateSchemaVersion(expected: number, actual: number, file: string): ScaffoldError;
|
|
31
|
+
export declare function stateMissing(file: string): ScaffoldError;
|
|
32
|
+
export declare function stateParseError(file: string, detail: string): ScaffoldError;
|
|
33
|
+
export declare function psmAlreadyInProgress(step: string, current: string): ScaffoldError;
|
|
34
|
+
export declare function lockHeld(holder: string, pid: number, command: string): ScaffoldError;
|
|
35
|
+
export declare function lockWriteFailed(file: string, detail: string): ScaffoldError;
|
|
36
|
+
export declare function lockStaleCleared(holder: string, pid: number): ScaffoldWarning;
|
|
37
|
+
export declare function decisionParseError(file: string, line: number, detail: string): ScaffoldError;
|
|
38
|
+
export declare function presetMissing(presetName: string, file: string): ScaffoldError;
|
|
39
|
+
export declare function presetParseError(file: string, detail: string): ScaffoldError;
|
|
40
|
+
export declare function presetInvalidStep(step: string, preset: string): ScaffoldError;
|
|
41
|
+
export declare function presetMissingStep(step: string, preset: string): ScaffoldWarning;
|
|
42
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/utils/errors.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
// src/utils/errors.ts
|
|
2
|
+
// --- Error factories ---
|
|
3
|
+
export function configMissing(configPath) {
|
|
4
|
+
return {
|
|
5
|
+
code: 'CONFIG_MISSING',
|
|
6
|
+
message: `Config file not found at ${configPath}`,
|
|
7
|
+
exitCode: 1,
|
|
8
|
+
recovery: 'Run "scaffold init" to create a project configuration',
|
|
9
|
+
context: { file: configPath },
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
export function configEmpty(configPath) {
|
|
13
|
+
return {
|
|
14
|
+
code: 'CONFIG_EMPTY',
|
|
15
|
+
message: `Config file is empty: ${configPath}`,
|
|
16
|
+
exitCode: 1,
|
|
17
|
+
recovery: 'Run "scaffold init" to create a valid configuration',
|
|
18
|
+
context: { file: configPath },
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
export function configParseError(configPath, detail) {
|
|
22
|
+
return {
|
|
23
|
+
code: 'CONFIG_PARSE_ERROR',
|
|
24
|
+
message: `Failed to parse config file: ${detail}`,
|
|
25
|
+
exitCode: 1,
|
|
26
|
+
recovery: 'Check the YAML syntax in .scaffold/config.yml',
|
|
27
|
+
context: { file: configPath, detail },
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
export function configNotObject(configPath) {
|
|
31
|
+
return {
|
|
32
|
+
code: 'CONFIG_NOT_OBJECT',
|
|
33
|
+
message: 'Config file must contain a YAML object, not a scalar or array',
|
|
34
|
+
exitCode: 1,
|
|
35
|
+
recovery: 'Ensure .scaffold/config.yml contains a valid YAML mapping',
|
|
36
|
+
context: { file: configPath },
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
export function configUnknownField(field, configPath) {
|
|
40
|
+
return {
|
|
41
|
+
code: 'CONFIG_UNKNOWN_FIELD',
|
|
42
|
+
message: `Unknown field "${field}" in config file`,
|
|
43
|
+
context: { file: configPath, field },
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
export function fieldMissing(field, file) {
|
|
47
|
+
return {
|
|
48
|
+
code: 'FIELD_MISSING',
|
|
49
|
+
message: `Required field "${field}" is missing`,
|
|
50
|
+
exitCode: 1,
|
|
51
|
+
recovery: `Add "${field}" to ${file}`,
|
|
52
|
+
context: { file, field },
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
export function fieldWrongType(field, expected, actual, file) {
|
|
56
|
+
return {
|
|
57
|
+
code: 'FIELD_WRONG_TYPE',
|
|
58
|
+
message: `Field "${field}" must be ${expected}, got ${actual}`,
|
|
59
|
+
exitCode: 1,
|
|
60
|
+
context: { file, field, expected, actual },
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
export function fieldEmptyValue(field, file) {
|
|
64
|
+
return {
|
|
65
|
+
code: 'FIELD_EMPTY_VALUE',
|
|
66
|
+
message: `Field "${field}" must not be empty`,
|
|
67
|
+
exitCode: 1,
|
|
68
|
+
context: { file, field },
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
export function fieldInvalidDepth(value, file) {
|
|
72
|
+
return {
|
|
73
|
+
code: 'FIELD_INVALID_DEPTH',
|
|
74
|
+
message: `Depth must be an integer between 1 and 5, got ${value}`,
|
|
75
|
+
exitCode: 1,
|
|
76
|
+
recovery: 'Set depth to a value between 1 (minimal) and 5 (comprehensive)',
|
|
77
|
+
context: { file, value: String(value) },
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
export function fieldInvalidMethodology(value, suggestion, file) {
|
|
81
|
+
const recovery = suggestion
|
|
82
|
+
? `Unknown methodology "${value}". Did you mean "${suggestion}"? Valid options: deep, mvp, custom`
|
|
83
|
+
: `Unknown methodology "${value}". Valid options: deep, mvp, custom`;
|
|
84
|
+
return {
|
|
85
|
+
code: 'FIELD_INVALID_METHODOLOGY',
|
|
86
|
+
message: `Unknown methodology "${value}"`,
|
|
87
|
+
exitCode: 1,
|
|
88
|
+
recovery,
|
|
89
|
+
context: { file, value },
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
export function frontmatterMissing(file) {
|
|
93
|
+
return {
|
|
94
|
+
code: 'FRONTMATTER_MISSING',
|
|
95
|
+
message: 'File does not start with frontmatter delimiter ---',
|
|
96
|
+
exitCode: 1,
|
|
97
|
+
context: { file },
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
export function frontmatterUnclosed(file) {
|
|
101
|
+
return {
|
|
102
|
+
code: 'FRONTMATTER_UNCLOSED',
|
|
103
|
+
message: 'Frontmatter is not closed (missing closing ---)',
|
|
104
|
+
exitCode: 1,
|
|
105
|
+
context: { file },
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
export function frontmatterYamlError(file, detail) {
|
|
109
|
+
return {
|
|
110
|
+
code: 'FRONTMATTER_YAML_ERROR',
|
|
111
|
+
message: `Invalid YAML in frontmatter: ${detail}`,
|
|
112
|
+
exitCode: 1,
|
|
113
|
+
context: { file, detail },
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
export function frontmatterNameInvalid(name, file) {
|
|
117
|
+
return {
|
|
118
|
+
code: 'FRONTMATTER_NAME_INVALID',
|
|
119
|
+
message: `Frontmatter "name" field must be kebab-case, got "${name}"`,
|
|
120
|
+
exitCode: 1,
|
|
121
|
+
recovery: 'Use lowercase letters, numbers, and hyphens only (e.g., "create-prd")',
|
|
122
|
+
context: { file, name },
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
export function frontmatterUnknownField(field, file) {
|
|
126
|
+
return {
|
|
127
|
+
code: 'FRONTMATTER_UNKNOWN_FIELD',
|
|
128
|
+
message: `Unknown frontmatter field "${field}"`,
|
|
129
|
+
context: { file, field },
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
export function stateSchemaVersion(expected, actual, file) {
|
|
133
|
+
return {
|
|
134
|
+
code: 'STATE_SCHEMA_VERSION',
|
|
135
|
+
message: `state.json schema version ${actual} is not supported (expected ${expected})`,
|
|
136
|
+
exitCode: 3,
|
|
137
|
+
recovery: 'Run "scaffold reset" to reinitialize state, or upgrade scaffold',
|
|
138
|
+
context: { file, expected, actual },
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
export function stateMissing(file) {
|
|
142
|
+
return {
|
|
143
|
+
code: 'STATE_MISSING',
|
|
144
|
+
message: `Pipeline state not found at ${file}`,
|
|
145
|
+
exitCode: 1,
|
|
146
|
+
recovery: 'Run "scaffold init" to initialize the pipeline',
|
|
147
|
+
context: { file },
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
export function stateParseError(file, detail) {
|
|
151
|
+
return {
|
|
152
|
+
code: 'STATE_PARSE_ERROR',
|
|
153
|
+
message: `Failed to parse state.json: ${detail}`,
|
|
154
|
+
exitCode: 3,
|
|
155
|
+
recovery: 'Run "scaffold reset" to reinitialize state',
|
|
156
|
+
context: { file, detail },
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
export function psmAlreadyInProgress(step, current) {
|
|
160
|
+
return {
|
|
161
|
+
code: 'PSM_ALREADY_IN_PROGRESS',
|
|
162
|
+
message: `Cannot set "${step}" to in_progress — "${current}" is already in progress`,
|
|
163
|
+
exitCode: 3,
|
|
164
|
+
recovery: 'Wait for the current step to complete or run "scaffold reset"',
|
|
165
|
+
context: { step, current },
|
|
166
|
+
};
|
|
167
|
+
}
|
|
168
|
+
export function lockHeld(holder, pid, command) {
|
|
169
|
+
return {
|
|
170
|
+
code: 'LOCK_HELD',
|
|
171
|
+
message: `Scaffold is already running (${command} by ${holder}, PID ${pid})`,
|
|
172
|
+
exitCode: 3,
|
|
173
|
+
recovery: 'Wait for the other scaffold process to finish, or use --force to override',
|
|
174
|
+
context: { holder, pid, command },
|
|
175
|
+
};
|
|
176
|
+
}
|
|
177
|
+
export function lockWriteFailed(file, detail) {
|
|
178
|
+
return {
|
|
179
|
+
code: 'LOCK_WRITE_FAILED',
|
|
180
|
+
message: `Failed to create lock file: ${detail}`,
|
|
181
|
+
exitCode: 5,
|
|
182
|
+
context: { file, detail },
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
export function lockStaleCleared(holder, pid) {
|
|
186
|
+
return {
|
|
187
|
+
code: 'LOCK_STALE_CLEARED',
|
|
188
|
+
message: `Cleared stale lock from ${holder} (PID ${pid} is no longer running)`,
|
|
189
|
+
context: { holder, pid },
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
export function decisionParseError(file, line, detail) {
|
|
193
|
+
return {
|
|
194
|
+
code: 'DECISION_PARSE_ERROR',
|
|
195
|
+
message: `Failed to parse decision entry at line ${line}: ${detail}`,
|
|
196
|
+
exitCode: 1,
|
|
197
|
+
context: { file, line, detail },
|
|
198
|
+
};
|
|
199
|
+
}
|
|
200
|
+
export function presetMissing(presetName, file) {
|
|
201
|
+
return {
|
|
202
|
+
code: 'PRESET_MISSING',
|
|
203
|
+
message: `Methodology preset "${presetName}" not found at ${file}`,
|
|
204
|
+
exitCode: 1,
|
|
205
|
+
recovery: 'Reinstall scaffold to restore built-in presets',
|
|
206
|
+
context: { presetName, file },
|
|
207
|
+
};
|
|
208
|
+
}
|
|
209
|
+
export function presetParseError(file, detail) {
|
|
210
|
+
return {
|
|
211
|
+
code: 'PRESET_PARSE_ERROR',
|
|
212
|
+
message: `Failed to parse methodology preset: ${detail}`,
|
|
213
|
+
exitCode: 1,
|
|
214
|
+
context: { file, detail },
|
|
215
|
+
};
|
|
216
|
+
}
|
|
217
|
+
export function presetInvalidStep(step, preset) {
|
|
218
|
+
return {
|
|
219
|
+
code: 'PRESET_INVALID_STEP',
|
|
220
|
+
message: `Preset "${preset}" references unknown step "${step}"`,
|
|
221
|
+
exitCode: 1,
|
|
222
|
+
context: { step, preset },
|
|
223
|
+
};
|
|
224
|
+
}
|
|
225
|
+
export function presetMissingStep(step, preset) {
|
|
226
|
+
return {
|
|
227
|
+
code: 'PRESET_MISSING_STEP',
|
|
228
|
+
message: `Step "${step}" exists in pipeline but is not listed in preset "${preset}"`,
|
|
229
|
+
context: { step, preset },
|
|
230
|
+
};
|
|
231
|
+
}
|
|
232
|
+
//# sourceMappingURL=errors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/utils/errors.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.test.d.ts","sourceRoot":"","sources":["../../src/utils/errors.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { configMissing, configUnknownField, lockHeld, fieldInvalidMethodology, psmAlreadyInProgress, configEmpty, configParseError, configNotObject, fieldMissing, fieldWrongType, fieldEmptyValue, fieldInvalidDepth, frontmatterMissing, frontmatterUnclosed, frontmatterYamlError, frontmatterNameInvalid, frontmatterUnknownField, stateSchemaVersion, stateMissing, stateParseError, lockWriteFailed, lockStaleCleared, decisionParseError, presetMissing, presetParseError, presetInvalidStep, presetMissingStep, } from './errors.js';
|
|
3
|
+
describe('error factories — shape', () => {
|
|
4
|
+
it('all error objects have code, message, exitCode', () => {
|
|
5
|
+
const errors = [
|
|
6
|
+
configMissing('/path/config.yml'),
|
|
7
|
+
configEmpty('/path/config.yml'),
|
|
8
|
+
configParseError('/path/config.yml', 'bad yaml'),
|
|
9
|
+
configNotObject('/path/config.yml'),
|
|
10
|
+
fieldMissing('name', '/path/config.yml'),
|
|
11
|
+
fieldWrongType('depth', 'number', 'string', '/path'),
|
|
12
|
+
fieldEmptyValue('name', '/path'),
|
|
13
|
+
fieldInvalidDepth(0, '/path'),
|
|
14
|
+
fieldInvalidMethodology('deap', 'deep', '/path'),
|
|
15
|
+
frontmatterMissing('/path/cmd.md'),
|
|
16
|
+
frontmatterUnclosed('/path/cmd.md'),
|
|
17
|
+
frontmatterYamlError('/path/cmd.md', 'bad yaml'),
|
|
18
|
+
frontmatterNameInvalid('Bad Name', '/path/cmd.md'),
|
|
19
|
+
stateSchemaVersion(1, 2, '/path/state.json'),
|
|
20
|
+
stateMissing('/path/state.json'),
|
|
21
|
+
stateParseError('/path/state.json', 'bad json'),
|
|
22
|
+
psmAlreadyInProgress('step-b', 'step-a'),
|
|
23
|
+
lockHeld('host', 1234, 'run'),
|
|
24
|
+
lockWriteFailed('/path/lock', 'permission denied'),
|
|
25
|
+
decisionParseError('/path/decisions.md', 10, 'bad entry'),
|
|
26
|
+
presetMissing('mvp', '/path/preset.yml'),
|
|
27
|
+
presetParseError('/path/preset.yml', 'bad yaml'),
|
|
28
|
+
presetInvalidStep('unknown-step', 'mvp'),
|
|
29
|
+
];
|
|
30
|
+
for (const err of errors) {
|
|
31
|
+
expect(err).toHaveProperty('code');
|
|
32
|
+
expect(err).toHaveProperty('message');
|
|
33
|
+
expect(err).toHaveProperty('exitCode');
|
|
34
|
+
expect(typeof err.code).toBe('string');
|
|
35
|
+
expect(typeof err.message).toBe('string');
|
|
36
|
+
expect(typeof err.exitCode).toBe('number');
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
it('all warning objects have code and message but no exitCode', () => {
|
|
40
|
+
const warnings = [
|
|
41
|
+
configUnknownField('foo', '/path'),
|
|
42
|
+
frontmatterUnknownField('bar', '/path/cmd.md'),
|
|
43
|
+
lockStaleCleared('host', 1234),
|
|
44
|
+
presetMissingStep('step-x', 'mvp'),
|
|
45
|
+
];
|
|
46
|
+
for (const warn of warnings) {
|
|
47
|
+
expect(warn).toHaveProperty('code');
|
|
48
|
+
expect(warn).toHaveProperty('message');
|
|
49
|
+
expect(warn).not.toHaveProperty('exitCode');
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
describe('configMissing', () => {
|
|
54
|
+
it('returns CONFIG_MISSING with exitCode 1', () => {
|
|
55
|
+
const err = configMissing('/path/config.yml');
|
|
56
|
+
expect(err.code).toBe('CONFIG_MISSING');
|
|
57
|
+
expect(err.exitCode).toBe(1);
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
describe('configUnknownField', () => {
|
|
61
|
+
it('returns CONFIG_UNKNOWN_FIELD warning with no exitCode', () => {
|
|
62
|
+
const warn = configUnknownField('foo', '/path');
|
|
63
|
+
expect(warn.code).toBe('CONFIG_UNKNOWN_FIELD');
|
|
64
|
+
expect(warn['exitCode']).toBeUndefined();
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
describe('lockHeld', () => {
|
|
68
|
+
it('returns LOCK_HELD with exitCode 3', () => {
|
|
69
|
+
const err = lockHeld('host', 1234, 'run');
|
|
70
|
+
expect(err.code).toBe('LOCK_HELD');
|
|
71
|
+
expect(err.exitCode).toBe(3);
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
describe('fieldInvalidMethodology', () => {
|
|
75
|
+
it('includes "Did you mean" in recovery when suggestion is provided', () => {
|
|
76
|
+
const err = fieldInvalidMethodology('deap', 'deep', '/path');
|
|
77
|
+
expect(err.recovery).toContain('Did you mean');
|
|
78
|
+
});
|
|
79
|
+
it('does not include "Did you mean" in recovery when suggestion is null', () => {
|
|
80
|
+
const err = fieldInvalidMethodology('xyz', null, '/path');
|
|
81
|
+
expect(err.recovery).not.toContain('Did you mean');
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
describe('psmAlreadyInProgress', () => {
|
|
85
|
+
it('returns PSM_ALREADY_IN_PROGRESS with exitCode 3', () => {
|
|
86
|
+
const err = psmAlreadyInProgress('step-b', 'step-a');
|
|
87
|
+
expect(err.code).toBe('PSM_ALREADY_IN_PROGRESS');
|
|
88
|
+
expect(err.exitCode).toBe(3);
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
//# sourceMappingURL=errors.test.js.map
|