raptor-aios 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +26 -0
- package/LICENSE +21 -0
- package/README.md +315 -0
- package/bin/raptor.js +5 -0
- package/dist/_core/dist/agents/adapters/antigravity.d.ts +9 -0
- package/dist/_core/dist/agents/adapters/antigravity.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/antigravity.js +72 -0
- package/dist/_core/dist/agents/adapters/antigravity.js.map +1 -0
- package/dist/_core/dist/agents/adapters/claude-code.d.ts +9 -0
- package/dist/_core/dist/agents/adapters/claude-code.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/claude-code.js +71 -0
- package/dist/_core/dist/agents/adapters/claude-code.js.map +1 -0
- package/dist/_core/dist/agents/adapters/codex.d.ts +12 -0
- package/dist/_core/dist/agents/adapters/codex.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/codex.js +69 -0
- package/dist/_core/dist/agents/adapters/codex.js.map +1 -0
- package/dist/_core/dist/agents/adapters/copilot.d.ts +12 -0
- package/dist/_core/dist/agents/adapters/copilot.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/copilot.js +71 -0
- package/dist/_core/dist/agents/adapters/copilot.js.map +1 -0
- package/dist/_core/dist/agents/adapters/cursor.d.ts +9 -0
- package/dist/_core/dist/agents/adapters/cursor.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/cursor.js +62 -0
- package/dist/_core/dist/agents/adapters/cursor.js.map +1 -0
- package/dist/_core/dist/agents/adapters/gemini.d.ts +11 -0
- package/dist/_core/dist/agents/adapters/gemini.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/gemini.js +68 -0
- package/dist/_core/dist/agents/adapters/gemini.js.map +1 -0
- package/dist/_core/dist/agents/adapters/human.d.ts +10 -0
- package/dist/_core/dist/agents/adapters/human.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/human.js +48 -0
- package/dist/_core/dist/agents/adapters/human.js.map +1 -0
- package/dist/_core/dist/agents/artifact-watcher.d.ts +86 -0
- package/dist/_core/dist/agents/artifact-watcher.d.ts.map +1 -0
- package/dist/_core/dist/agents/artifact-watcher.js +214 -0
- package/dist/_core/dist/agents/artifact-watcher.js.map +1 -0
- package/dist/_core/dist/agents/backup.d.ts +69 -0
- package/dist/_core/dist/agents/backup.d.ts.map +1 -0
- package/dist/_core/dist/agents/backup.js +107 -0
- package/dist/_core/dist/agents/backup.js.map +1 -0
- package/dist/_core/dist/agents/config.d.ts +36 -0
- package/dist/_core/dist/agents/config.d.ts.map +1 -0
- package/dist/_core/dist/agents/config.js +270 -0
- package/dist/_core/dist/agents/config.js.map +1 -0
- package/dist/_core/dist/agents/context-file.d.ts +35 -0
- package/dist/_core/dist/agents/context-file.d.ts.map +1 -0
- package/dist/_core/dist/agents/context-file.js +106 -0
- package/dist/_core/dist/agents/context-file.js.map +1 -0
- package/dist/_core/dist/agents/handoff.d.ts +57 -0
- package/dist/_core/dist/agents/handoff.d.ts.map +1 -0
- package/dist/_core/dist/agents/handoff.js +71 -0
- package/dist/_core/dist/agents/handoff.js.map +1 -0
- package/dist/_core/dist/agents/index.d.ts +32 -0
- package/dist/_core/dist/agents/index.d.ts.map +1 -0
- package/dist/_core/dist/agents/index.js +37 -0
- package/dist/_core/dist/agents/index.js.map +1 -0
- package/dist/_core/dist/agents/keys.d.ts +50 -0
- package/dist/_core/dist/agents/keys.d.ts.map +1 -0
- package/dist/_core/dist/agents/keys.js +91 -0
- package/dist/_core/dist/agents/keys.js.map +1 -0
- package/dist/_core/dist/agents/materialize.d.ts +37 -0
- package/dist/_core/dist/agents/materialize.d.ts.map +1 -0
- package/dist/_core/dist/agents/materialize.js +157 -0
- package/dist/_core/dist/agents/materialize.js.map +1 -0
- package/dist/_core/dist/agents/prompt-builder.d.ts +35 -0
- package/dist/_core/dist/agents/prompt-builder.d.ts.map +1 -0
- package/dist/_core/dist/agents/prompt-builder.js +261 -0
- package/dist/_core/dist/agents/prompt-builder.js.map +1 -0
- package/dist/_core/dist/agents/prompt-markers.d.ts +69 -0
- package/dist/_core/dist/agents/prompt-markers.d.ts.map +1 -0
- package/dist/_core/dist/agents/prompt-markers.js +111 -0
- package/dist/_core/dist/agents/prompt-markers.js.map +1 -0
- package/dist/_core/dist/agents/registry.d.ts +35 -0
- package/dist/_core/dist/agents/registry.d.ts.map +1 -0
- package/dist/_core/dist/agents/registry.js +102 -0
- package/dist/_core/dist/agents/registry.js.map +1 -0
- package/dist/_core/dist/agents/selector.d.ts +33 -0
- package/dist/_core/dist/agents/selector.d.ts.map +1 -0
- package/dist/_core/dist/agents/selector.js +120 -0
- package/dist/_core/dist/agents/selector.js.map +1 -0
- package/dist/_core/dist/agents/slash-materializer.d.ts +63 -0
- package/dist/_core/dist/agents/slash-materializer.d.ts.map +1 -0
- package/dist/_core/dist/agents/slash-materializer.js +131 -0
- package/dist/_core/dist/agents/slash-materializer.js.map +1 -0
- package/dist/_core/dist/agents/types.d.ts +121 -0
- package/dist/_core/dist/agents/types.d.ts.map +1 -0
- package/dist/_core/dist/agents/types.js +10 -0
- package/dist/_core/dist/agents/types.js.map +1 -0
- package/dist/_core/dist/audit/hash.d.ts +4 -0
- package/dist/_core/dist/audit/hash.d.ts.map +1 -0
- package/dist/_core/dist/audit/hash.js +12 -0
- package/dist/_core/dist/audit/hash.js.map +1 -0
- package/dist/_core/dist/audit/index.d.ts +6 -0
- package/dist/_core/dist/audit/index.d.ts.map +1 -0
- package/dist/_core/dist/audit/index.js +6 -0
- package/dist/_core/dist/audit/index.js.map +1 -0
- package/dist/_core/dist/audit/logger.d.ts +77 -0
- package/dist/_core/dist/audit/logger.d.ts.map +1 -0
- package/dist/_core/dist/audit/logger.js +93 -0
- package/dist/_core/dist/audit/logger.js.map +1 -0
- package/dist/_core/dist/audit/query.d.ts +13 -0
- package/dist/_core/dist/audit/query.d.ts.map +1 -0
- package/dist/_core/dist/audit/query.js +57 -0
- package/dist/_core/dist/audit/query.js.map +1 -0
- package/dist/_core/dist/audit/schema.d.ts +455 -0
- package/dist/_core/dist/audit/schema.d.ts.map +1 -0
- package/dist/_core/dist/audit/schema.js +341 -0
- package/dist/_core/dist/audit/schema.js.map +1 -0
- package/dist/_core/dist/audit/validate.d.ts +21 -0
- package/dist/_core/dist/audit/validate.d.ts.map +1 -0
- package/dist/_core/dist/audit/validate.js +139 -0
- package/dist/_core/dist/audit/validate.js.map +1 -0
- package/dist/_core/dist/constitution/core.d.ts +22 -0
- package/dist/_core/dist/constitution/core.d.ts.map +1 -0
- package/dist/_core/dist/constitution/core.js +102 -0
- package/dist/_core/dist/constitution/core.js.map +1 -0
- package/dist/_core/dist/constitution/index.d.ts +2 -0
- package/dist/_core/dist/constitution/index.d.ts.map +1 -0
- package/dist/_core/dist/constitution/index.js +2 -0
- package/dist/_core/dist/constitution/index.js.map +1 -0
- package/dist/_core/dist/extensions/index.d.ts +12 -0
- package/dist/_core/dist/extensions/index.d.ts.map +1 -0
- package/dist/_core/dist/extensions/index.js +12 -0
- package/dist/_core/dist/extensions/index.js.map +1 -0
- package/dist/_core/dist/extensions/integrate.d.ts +69 -0
- package/dist/_core/dist/extensions/integrate.d.ts.map +1 -0
- package/dist/_core/dist/extensions/integrate.js +181 -0
- package/dist/_core/dist/extensions/integrate.js.map +1 -0
- package/dist/_core/dist/extensions/loader.d.ts +24 -0
- package/dist/_core/dist/extensions/loader.d.ts.map +1 -0
- package/dist/_core/dist/extensions/loader.js +73 -0
- package/dist/_core/dist/extensions/loader.js.map +1 -0
- package/dist/_core/dist/extensions/manifest.d.ts +23 -0
- package/dist/_core/dist/extensions/manifest.d.ts.map +1 -0
- package/dist/_core/dist/extensions/manifest.js +176 -0
- package/dist/_core/dist/extensions/manifest.js.map +1 -0
- package/dist/_core/dist/extensions/registry.d.ts +32 -0
- package/dist/_core/dist/extensions/registry.d.ts.map +1 -0
- package/dist/_core/dist/extensions/registry.js +57 -0
- package/dist/_core/dist/extensions/registry.js.map +1 -0
- package/dist/_core/dist/extensions/resolver.d.ts +55 -0
- package/dist/_core/dist/extensions/resolver.d.ts.map +1 -0
- package/dist/_core/dist/extensions/resolver.js +143 -0
- package/dist/_core/dist/extensions/resolver.js.map +1 -0
- package/dist/_core/dist/extensions/types.d.ts +173 -0
- package/dist/_core/dist/extensions/types.d.ts.map +1 -0
- package/dist/_core/dist/extensions/types.js +83 -0
- package/dist/_core/dist/extensions/types.js.map +1 -0
- package/dist/_core/dist/frontmatter/index.d.ts +10 -0
- package/dist/_core/dist/frontmatter/index.d.ts.map +1 -0
- package/dist/_core/dist/frontmatter/index.js +24 -0
- package/dist/_core/dist/frontmatter/index.js.map +1 -0
- package/dist/_core/dist/gates/agent-gates.d.ts +16 -0
- package/dist/_core/dist/gates/agent-gates.d.ts.map +1 -0
- package/dist/_core/dist/gates/agent-gates.js +205 -0
- package/dist/_core/dist/gates/agent-gates.js.map +1 -0
- package/dist/_core/dist/gates/builtin.d.ts +18 -0
- package/dist/_core/dist/gates/builtin.d.ts.map +1 -0
- package/dist/_core/dist/gates/builtin.js +860 -0
- package/dist/_core/dist/gates/builtin.js.map +1 -0
- package/dist/_core/dist/gates/index.d.ts +7 -0
- package/dist/_core/dist/gates/index.d.ts.map +1 -0
- package/dist/_core/dist/gates/index.js +7 -0
- package/dist/_core/dist/gates/index.js.map +1 -0
- package/dist/_core/dist/gates/m7-gates.d.ts +17 -0
- package/dist/_core/dist/gates/m7-gates.d.ts.map +1 -0
- package/dist/_core/dist/gates/m7-gates.js +309 -0
- package/dist/_core/dist/gates/m7-gates.js.map +1 -0
- package/dist/_core/dist/gates/phase-gates.d.ts +18 -0
- package/dist/_core/dist/gates/phase-gates.d.ts.map +1 -0
- package/dist/_core/dist/gates/phase-gates.js +275 -0
- package/dist/_core/dist/gates/phase-gates.js.map +1 -0
- package/dist/_core/dist/gates/runner.d.ts +4 -0
- package/dist/_core/dist/gates/runner.d.ts.map +1 -0
- package/dist/_core/dist/gates/runner.js +64 -0
- package/dist/_core/dist/gates/runner.js.map +1 -0
- package/dist/_core/dist/gates/types.d.ts +36 -0
- package/dist/_core/dist/gates/types.d.ts.map +1 -0
- package/dist/_core/dist/gates/types.js +2 -0
- package/dist/_core/dist/gates/types.js.map +1 -0
- package/dist/_core/dist/hooks/index.d.ts +4 -0
- package/dist/_core/dist/hooks/index.d.ts.map +1 -0
- package/dist/_core/dist/hooks/index.js +4 -0
- package/dist/_core/dist/hooks/index.js.map +1 -0
- package/dist/_core/dist/hooks/runner.d.ts +28 -0
- package/dist/_core/dist/hooks/runner.d.ts.map +1 -0
- package/dist/_core/dist/hooks/runner.js +294 -0
- package/dist/_core/dist/hooks/runner.js.map +1 -0
- package/dist/_core/dist/hooks/runtime.d.ts +65 -0
- package/dist/_core/dist/hooks/runtime.d.ts.map +1 -0
- package/dist/_core/dist/hooks/runtime.js +212 -0
- package/dist/_core/dist/hooks/runtime.js.map +1 -0
- package/dist/_core/dist/hooks/types.d.ts +36 -0
- package/dist/_core/dist/hooks/types.d.ts.map +1 -0
- package/dist/_core/dist/hooks/types.js +23 -0
- package/dist/_core/dist/hooks/types.js.map +1 -0
- package/dist/_core/dist/index.d.ts +21 -0
- package/dist/_core/dist/index.d.ts.map +1 -0
- package/dist/_core/dist/index.js +20 -0
- package/dist/_core/dist/index.js.map +1 -0
- package/dist/_core/dist/manifest/index.d.ts +119 -0
- package/dist/_core/dist/manifest/index.d.ts.map +1 -0
- package/dist/_core/dist/manifest/index.js +125 -0
- package/dist/_core/dist/manifest/index.js.map +1 -0
- package/dist/_core/dist/markers/index.d.ts +47 -0
- package/dist/_core/dist/markers/index.d.ts.map +1 -0
- package/dist/_core/dist/markers/index.js +97 -0
- package/dist/_core/dist/markers/index.js.map +1 -0
- package/dist/_core/dist/mcp/config.d.ts +19 -0
- package/dist/_core/dist/mcp/config.d.ts.map +1 -0
- package/dist/_core/dist/mcp/config.js +114 -0
- package/dist/_core/dist/mcp/config.js.map +1 -0
- package/dist/_core/dist/mcp/index.d.ts +9 -0
- package/dist/_core/dist/mcp/index.d.ts.map +1 -0
- package/dist/_core/dist/mcp/index.js +8 -0
- package/dist/_core/dist/mcp/index.js.map +1 -0
- package/dist/_core/dist/mcp/materializer.d.ts +40 -0
- package/dist/_core/dist/mcp/materializer.d.ts.map +1 -0
- package/dist/_core/dist/mcp/materializer.js +161 -0
- package/dist/_core/dist/mcp/materializer.js.map +1 -0
- package/dist/_core/dist/mcp/targets.d.ts +37 -0
- package/dist/_core/dist/mcp/targets.d.ts.map +1 -0
- package/dist/_core/dist/mcp/targets.js +56 -0
- package/dist/_core/dist/mcp/targets.js.map +1 -0
- package/dist/_core/dist/mcp/types.d.ts +34 -0
- package/dist/_core/dist/mcp/types.d.ts.map +1 -0
- package/dist/_core/dist/mcp/types.js +8 -0
- package/dist/_core/dist/mcp/types.js.map +1 -0
- package/dist/_core/dist/models/analyze.d.ts +131 -0
- package/dist/_core/dist/models/analyze.d.ts.map +1 -0
- package/dist/_core/dist/models/analyze.js +301 -0
- package/dist/_core/dist/models/analyze.js.map +1 -0
- package/dist/_core/dist/models/checklist.d.ts +113 -0
- package/dist/_core/dist/models/checklist.d.ts.map +1 -0
- package/dist/_core/dist/models/checklist.js +159 -0
- package/dist/_core/dist/models/checklist.js.map +1 -0
- package/dist/_core/dist/models/clarify.d.ts +116 -0
- package/dist/_core/dist/models/clarify.d.ts.map +1 -0
- package/dist/_core/dist/models/clarify.js +166 -0
- package/dist/_core/dist/models/clarify.js.map +1 -0
- package/dist/_core/dist/models/impl-log.d.ts +64 -0
- package/dist/_core/dist/models/impl-log.d.ts.map +1 -0
- package/dist/_core/dist/models/impl-log.js +137 -0
- package/dist/_core/dist/models/impl-log.js.map +1 -0
- package/dist/_core/dist/models/index.d.ts +8 -0
- package/dist/_core/dist/models/index.d.ts.map +1 -0
- package/dist/_core/dist/models/index.js +8 -0
- package/dist/_core/dist/models/index.js.map +1 -0
- package/dist/_core/dist/models/plan.d.ts +24 -0
- package/dist/_core/dist/models/plan.d.ts.map +1 -0
- package/dist/_core/dist/models/plan.js +15 -0
- package/dist/_core/dist/models/plan.js.map +1 -0
- package/dist/_core/dist/models/spec.d.ts +23 -0
- package/dist/_core/dist/models/spec.d.ts.map +1 -0
- package/dist/_core/dist/models/spec.js +22 -0
- package/dist/_core/dist/models/spec.js.map +1 -0
- package/dist/_core/dist/models/tasks.d.ts +33 -0
- package/dist/_core/dist/models/tasks.d.ts.map +1 -0
- package/dist/_core/dist/models/tasks.js +78 -0
- package/dist/_core/dist/models/tasks.js.map +1 -0
- package/dist/_core/dist/presets/gates.d.ts +9 -0
- package/dist/_core/dist/presets/gates.d.ts.map +1 -0
- package/dist/_core/dist/presets/gates.js +173 -0
- package/dist/_core/dist/presets/gates.js.map +1 -0
- package/dist/_core/dist/presets/index.d.ts +10 -0
- package/dist/_core/dist/presets/index.d.ts.map +1 -0
- package/dist/_core/dist/presets/index.js +7 -0
- package/dist/_core/dist/presets/index.js.map +1 -0
- package/dist/_core/dist/presets/loader.d.ts +56 -0
- package/dist/_core/dist/presets/loader.d.ts.map +1 -0
- package/dist/_core/dist/presets/loader.js +216 -0
- package/dist/_core/dist/presets/loader.js.map +1 -0
- package/dist/_core/dist/presets/mobile-opinionated.d.ts +3 -0
- package/dist/_core/dist/presets/mobile-opinionated.d.ts.map +1 -0
- package/dist/_core/dist/presets/mobile-opinionated.js +78 -0
- package/dist/_core/dist/presets/mobile-opinionated.js.map +1 -0
- package/dist/_core/dist/presets/registry.d.ts +5 -0
- package/dist/_core/dist/presets/registry.d.ts.map +1 -0
- package/dist/_core/dist/presets/registry.js +14 -0
- package/dist/_core/dist/presets/registry.js.map +1 -0
- package/dist/_core/dist/presets/renderer.d.ts +5 -0
- package/dist/_core/dist/presets/renderer.d.ts.map +1 -0
- package/dist/_core/dist/presets/renderer.js +37 -0
- package/dist/_core/dist/presets/renderer.js.map +1 -0
- package/dist/_core/dist/presets/stacking.d.ts +29 -0
- package/dist/_core/dist/presets/stacking.d.ts.map +1 -0
- package/dist/_core/dist/presets/stacking.js +91 -0
- package/dist/_core/dist/presets/stacking.js.map +1 -0
- package/dist/_core/dist/presets/types.d.ts +22 -0
- package/dist/_core/dist/presets/types.d.ts.map +1 -0
- package/dist/_core/dist/presets/types.js +2 -0
- package/dist/_core/dist/presets/types.js.map +1 -0
- package/dist/_core/dist/prompts/audit-log.d.ts +73 -0
- package/dist/_core/dist/prompts/audit-log.d.ts.map +1 -0
- package/dist/_core/dist/prompts/audit-log.js +73 -0
- package/dist/_core/dist/prompts/audit-log.js.map +1 -0
- package/dist/_core/dist/prompts/index.d.ts +9 -0
- package/dist/_core/dist/prompts/index.d.ts.map +1 -0
- package/dist/_core/dist/prompts/index.js +7 -0
- package/dist/_core/dist/prompts/index.js.map +1 -0
- package/dist/_core/dist/prompts/renderer.d.ts +73 -0
- package/dist/_core/dist/prompts/renderer.d.ts.map +1 -0
- package/dist/_core/dist/prompts/renderer.js +179 -0
- package/dist/_core/dist/prompts/renderer.js.map +1 -0
- package/dist/_core/dist/prompts/resumption.d.ts +59 -0
- package/dist/_core/dist/prompts/resumption.d.ts.map +1 -0
- package/dist/_core/dist/prompts/resumption.js +149 -0
- package/dist/_core/dist/prompts/resumption.js.map +1 -0
- package/dist/_core/dist/skills/config.d.ts +27 -0
- package/dist/_core/dist/skills/config.d.ts.map +1 -0
- package/dist/_core/dist/skills/config.js +102 -0
- package/dist/_core/dist/skills/config.js.map +1 -0
- package/dist/_core/dist/skills/index.d.ts +9 -0
- package/dist/_core/dist/skills/index.d.ts.map +1 -0
- package/dist/_core/dist/skills/index.js +8 -0
- package/dist/_core/dist/skills/index.js.map +1 -0
- package/dist/_core/dist/skills/materializer.d.ts +45 -0
- package/dist/_core/dist/skills/materializer.d.ts.map +1 -0
- package/dist/_core/dist/skills/materializer.js +97 -0
- package/dist/_core/dist/skills/materializer.js.map +1 -0
- package/dist/_core/dist/skills/registry.d.ts +18 -0
- package/dist/_core/dist/skills/registry.d.ts.map +1 -0
- package/dist/_core/dist/skills/registry.js +36 -0
- package/dist/_core/dist/skills/registry.js.map +1 -0
- package/dist/_core/dist/skills/types.d.ts +39 -0
- package/dist/_core/dist/skills/types.d.ts.map +1 -0
- package/dist/_core/dist/skills/types.js +13 -0
- package/dist/_core/dist/skills/types.js.map +1 -0
- package/dist/_core/dist/state/feature.d.ts +58 -0
- package/dist/_core/dist/state/feature.d.ts.map +1 -0
- package/dist/_core/dist/state/feature.js +81 -0
- package/dist/_core/dist/state/feature.js.map +1 -0
- package/dist/_core/dist/state/index.d.ts +8 -0
- package/dist/_core/dist/state/index.d.ts.map +1 -0
- package/dist/_core/dist/state/index.js +6 -0
- package/dist/_core/dist/state/index.js.map +1 -0
- package/dist/_core/dist/state/init-options.d.ts +60 -0
- package/dist/_core/dist/state/init-options.d.ts.map +1 -0
- package/dist/_core/dist/state/init-options.js +74 -0
- package/dist/_core/dist/state/init-options.js.map +1 -0
- package/dist/_core/dist/template/engine.d.ts +7 -0
- package/dist/_core/dist/template/engine.d.ts.map +1 -0
- package/dist/_core/dist/template/engine.js +86 -0
- package/dist/_core/dist/template/engine.js.map +1 -0
- package/dist/_core/dist/template/helpers.d.ts +5 -0
- package/dist/_core/dist/template/helpers.d.ts.map +1 -0
- package/dist/_core/dist/template/helpers.js +59 -0
- package/dist/_core/dist/template/helpers.js.map +1 -0
- package/dist/_core/dist/template/index.d.ts +6 -0
- package/dist/_core/dist/template/index.d.ts.map +1 -0
- package/dist/_core/dist/template/index.js +6 -0
- package/dist/_core/dist/template/index.js.map +1 -0
- package/dist/_core/dist/template/loader.d.ts +36 -0
- package/dist/_core/dist/template/loader.d.ts.map +1 -0
- package/dist/_core/dist/template/loader.js +62 -0
- package/dist/_core/dist/template/loader.js.map +1 -0
- package/dist/_core/dist/template/parser.d.ts +3 -0
- package/dist/_core/dist/template/parser.d.ts.map +1 -0
- package/dist/_core/dist/template/parser.js +234 -0
- package/dist/_core/dist/template/parser.js.map +1 -0
- package/dist/_core/dist/template/types.d.ts +40 -0
- package/dist/_core/dist/template/types.d.ts.map +1 -0
- package/dist/_core/dist/template/types.js +14 -0
- package/dist/_core/dist/template/types.js.map +1 -0
- package/dist/_core/dist/verify/a11y.d.ts +36 -0
- package/dist/_core/dist/verify/a11y.d.ts.map +1 -0
- package/dist/_core/dist/verify/a11y.js +153 -0
- package/dist/_core/dist/verify/a11y.js.map +1 -0
- package/dist/_core/dist/verify/architecture.d.ts +37 -0
- package/dist/_core/dist/verify/architecture.d.ts.map +1 -0
- package/dist/_core/dist/verify/architecture.js +113 -0
- package/dist/_core/dist/verify/architecture.js.map +1 -0
- package/dist/_core/dist/verify/index.d.ts +10 -0
- package/dist/_core/dist/verify/index.d.ts.map +1 -0
- package/dist/_core/dist/verify/index.js +10 -0
- package/dist/_core/dist/verify/index.js.map +1 -0
- package/dist/_core/dist/verify/os-matrix.d.ts +35 -0
- package/dist/_core/dist/verify/os-matrix.d.ts.map +1 -0
- package/dist/_core/dist/verify/os-matrix.js +104 -0
- package/dist/_core/dist/verify/os-matrix.js.map +1 -0
- package/dist/_core/dist/verify/perf.d.ts +43 -0
- package/dist/_core/dist/verify/perf.d.ts.map +1 -0
- package/dist/_core/dist/verify/perf.js +69 -0
- package/dist/_core/dist/verify/perf.js.map +1 -0
- package/dist/_core/dist/verify/stores.d.ts +38 -0
- package/dist/_core/dist/verify/stores.d.ts.map +1 -0
- package/dist/_core/dist/verify/stores.js +57 -0
- package/dist/_core/dist/verify/stores.js.map +1 -0
- package/dist/_core/dist/version.d.ts +8 -0
- package/dist/_core/dist/version.d.ts.map +1 -0
- package/dist/_core/dist/version.js +11 -0
- package/dist/_core/dist/version.js.map +1 -0
- package/dist/_core/dist/workflows/bundled.d.ts +32 -0
- package/dist/_core/dist/workflows/bundled.d.ts.map +1 -0
- package/dist/_core/dist/workflows/bundled.js +254 -0
- package/dist/_core/dist/workflows/bundled.js.map +1 -0
- package/dist/_core/dist/workflows/engine.d.ts +74 -0
- package/dist/_core/dist/workflows/engine.d.ts.map +1 -0
- package/dist/_core/dist/workflows/engine.js +574 -0
- package/dist/_core/dist/workflows/engine.js.map +1 -0
- package/dist/_core/dist/workflows/expressions.d.ts +48 -0
- package/dist/_core/dist/workflows/expressions.d.ts.map +1 -0
- package/dist/_core/dist/workflows/expressions.js +336 -0
- package/dist/_core/dist/workflows/expressions.js.map +1 -0
- package/dist/_core/dist/workflows/index.d.ts +16 -0
- package/dist/_core/dist/workflows/index.d.ts.map +1 -0
- package/dist/_core/dist/workflows/index.js +15 -0
- package/dist/_core/dist/workflows/index.js.map +1 -0
- package/dist/_core/dist/workflows/parser.d.ts +38 -0
- package/dist/_core/dist/workflows/parser.d.ts.map +1 -0
- package/dist/_core/dist/workflows/parser.js +386 -0
- package/dist/_core/dist/workflows/parser.js.map +1 -0
- package/dist/_core/dist/workflows/sdd-flow.d.ts +85 -0
- package/dist/_core/dist/workflows/sdd-flow.d.ts.map +1 -0
- package/dist/_core/dist/workflows/sdd-flow.js +269 -0
- package/dist/_core/dist/workflows/sdd-flow.js.map +1 -0
- package/dist/_core/dist/workflows/types.d.ts +285 -0
- package/dist/_core/dist/workflows/types.d.ts.map +1 -0
- package/dist/_core/dist/workflows/types.js +13 -0
- package/dist/_core/dist/workflows/types.js.map +1 -0
- package/dist/_core/package.json +6 -0
- package/dist/_core/templates/constitution.md.hbs +46 -0
- package/dist/_core/templates/ghaWorkflow.yml.hbs +58 -0
- package/dist/_core/templates/hotfix.md.hbs +39 -0
- package/dist/_core/templates/plan.md.hbs +212 -0
- package/dist/_core/templates/preCommitHook.sh.hbs +30 -0
- package/dist/_core/templates/prePushHook.sh.hbs +45 -0
- package/dist/_core/templates/raptor.yml.hbs +24 -0
- package/dist/_core/templates/spec.md.hbs +127 -0
- package/dist/_core/templates/tasks.md.hbs +71 -0
- package/dist/commands/add-agent.d.ts +22 -0
- package/dist/commands/add-agent.d.ts.map +1 -0
- package/dist/commands/add-agent.js +121 -0
- package/dist/commands/add-agent.js.map +1 -0
- package/dist/commands/add-extension.d.ts +18 -0
- package/dist/commands/add-extension.d.ts.map +1 -0
- package/dist/commands/add-extension.js +83 -0
- package/dist/commands/add-extension.js.map +1 -0
- package/dist/commands/analyze.d.ts +18 -0
- package/dist/commands/analyze.d.ts.map +1 -0
- package/dist/commands/analyze.js +323 -0
- package/dist/commands/analyze.js.map +1 -0
- package/dist/commands/approve.d.ts +14 -0
- package/dist/commands/approve.d.ts.map +1 -0
- package/dist/commands/approve.js +116 -0
- package/dist/commands/approve.js.map +1 -0
- package/dist/commands/audit/query.d.ts +23 -0
- package/dist/commands/audit/query.d.ts.map +1 -0
- package/dist/commands/audit/query.js +118 -0
- package/dist/commands/audit/query.js.map +1 -0
- package/dist/commands/audit/show.d.ts +17 -0
- package/dist/commands/audit/show.d.ts.map +1 -0
- package/dist/commands/audit/show.js +53 -0
- package/dist/commands/audit/show.js.map +1 -0
- package/dist/commands/checklist.d.ts +17 -0
- package/dist/commands/checklist.d.ts.map +1 -0
- package/dist/commands/checklist.js +255 -0
- package/dist/commands/checklist.js.map +1 -0
- package/dist/commands/clarify.d.ts +17 -0
- package/dist/commands/clarify.d.ts.map +1 -0
- package/dist/commands/clarify.js +254 -0
- package/dist/commands/clarify.js.map +1 -0
- package/dist/commands/doctor.d.ts +8 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +435 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/extension/add.d.ts +15 -0
- package/dist/commands/extension/add.d.ts.map +1 -0
- package/dist/commands/extension/add.js +93 -0
- package/dist/commands/extension/add.js.map +1 -0
- package/dist/commands/extension/info.d.ts +13 -0
- package/dist/commands/extension/info.d.ts.map +1 -0
- package/dist/commands/extension/info.js +75 -0
- package/dist/commands/extension/info.js.map +1 -0
- package/dist/commands/extension/list.d.ts +10 -0
- package/dist/commands/extension/list.d.ts.map +1 -0
- package/dist/commands/extension/list.js +71 -0
- package/dist/commands/extension/list.js.map +1 -0
- package/dist/commands/extension/remove.d.ts +14 -0
- package/dist/commands/extension/remove.d.ts.map +1 -0
- package/dist/commands/extension/remove.js +49 -0
- package/dist/commands/extension/remove.js.map +1 -0
- package/dist/commands/gate/approve.d.ts +15 -0
- package/dist/commands/gate/approve.d.ts.map +1 -0
- package/dist/commands/gate/approve.js +106 -0
- package/dist/commands/gate/approve.js.map +1 -0
- package/dist/commands/gate/list.d.ts +6 -0
- package/dist/commands/gate/list.d.ts.map +1 -0
- package/dist/commands/gate/list.js +38 -0
- package/dist/commands/gate/list.js.map +1 -0
- package/dist/commands/gate/skip.d.ts +14 -0
- package/dist/commands/gate/skip.d.ts.map +1 -0
- package/dist/commands/gate/skip.js +95 -0
- package/dist/commands/gate/skip.js.map +1 -0
- package/dist/commands/hook/list.d.ts +11 -0
- package/dist/commands/hook/list.d.ts.map +1 -0
- package/dist/commands/hook/list.js +152 -0
- package/dist/commands/hook/list.js.map +1 -0
- package/dist/commands/hook/run.d.ts +16 -0
- package/dist/commands/hook/run.d.ts.map +1 -0
- package/dist/commands/hook/run.js +74 -0
- package/dist/commands/hook/run.js.map +1 -0
- package/dist/commands/hotfix.d.ts +21 -0
- package/dist/commands/hotfix.d.ts.map +1 -0
- package/dist/commands/hotfix.js +216 -0
- package/dist/commands/hotfix.js.map +1 -0
- package/dist/commands/implement.d.ts +19 -0
- package/dist/commands/implement.d.ts.map +1 -0
- package/dist/commands/implement.js +282 -0
- package/dist/commands/implement.js.map +1 -0
- package/dist/commands/init.d.ts +43 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +465 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/list-agents.d.ts +12 -0
- package/dist/commands/list-agents.d.ts.map +1 -0
- package/dist/commands/list-agents.js +55 -0
- package/dist/commands/list-agents.js.map +1 -0
- package/dist/commands/mcp/add.d.ts +21 -0
- package/dist/commands/mcp/add.d.ts.map +1 -0
- package/dist/commands/mcp/add.js +119 -0
- package/dist/commands/mcp/add.js.map +1 -0
- package/dist/commands/mcp/list.d.ts +10 -0
- package/dist/commands/mcp/list.d.ts.map +1 -0
- package/dist/commands/mcp/list.js +54 -0
- package/dist/commands/mcp/list.js.map +1 -0
- package/dist/commands/mcp/remove.d.ts +10 -0
- package/dist/commands/mcp/remove.d.ts.map +1 -0
- package/dist/commands/mcp/remove.js +53 -0
- package/dist/commands/mcp/remove.js.map +1 -0
- package/dist/commands/mcp/sync.d.ts +7 -0
- package/dist/commands/mcp/sync.d.ts.map +1 -0
- package/dist/commands/mcp/sync.js +31 -0
- package/dist/commands/mcp/sync.js.map +1 -0
- package/dist/commands/new.d.ts +19 -0
- package/dist/commands/new.d.ts.map +1 -0
- package/dist/commands/new.js +306 -0
- package/dist/commands/new.js.map +1 -0
- package/dist/commands/plan.d.ts +17 -0
- package/dist/commands/plan.d.ts.map +1 -0
- package/dist/commands/plan.js +200 -0
- package/dist/commands/plan.js.map +1 -0
- package/dist/commands/preset/add.d.ts +13 -0
- package/dist/commands/preset/add.d.ts.map +1 -0
- package/dist/commands/preset/add.js +66 -0
- package/dist/commands/preset/add.js.map +1 -0
- package/dist/commands/preset/info.d.ts +13 -0
- package/dist/commands/preset/info.d.ts.map +1 -0
- package/dist/commands/preset/info.js +80 -0
- package/dist/commands/preset/info.js.map +1 -0
- package/dist/commands/preset/list.d.ts +10 -0
- package/dist/commands/preset/list.d.ts.map +1 -0
- package/dist/commands/preset/list.js +63 -0
- package/dist/commands/preset/list.js.map +1 -0
- package/dist/commands/preset/remove.d.ts +14 -0
- package/dist/commands/preset/remove.d.ts.map +1 -0
- package/dist/commands/preset/remove.js +60 -0
- package/dist/commands/preset/remove.js.map +1 -0
- package/dist/commands/repair/constitution.d.ts +11 -0
- package/dist/commands/repair/constitution.d.ts.map +1 -0
- package/dist/commands/repair/constitution.js +117 -0
- package/dist/commands/repair/constitution.js.map +1 -0
- package/dist/commands/resync.d.ts +22 -0
- package/dist/commands/resync.d.ts.map +1 -0
- package/dist/commands/resync.js +103 -0
- package/dist/commands/resync.js.map +1 -0
- package/dist/commands/skill/add.d.ts +19 -0
- package/dist/commands/skill/add.d.ts.map +1 -0
- package/dist/commands/skill/add.js +107 -0
- package/dist/commands/skill/add.js.map +1 -0
- package/dist/commands/skill/list.d.ts +10 -0
- package/dist/commands/skill/list.d.ts.map +1 -0
- package/dist/commands/skill/list.js +56 -0
- package/dist/commands/skill/list.js.map +1 -0
- package/dist/commands/skill/remove.d.ts +10 -0
- package/dist/commands/skill/remove.d.ts.map +1 -0
- package/dist/commands/skill/remove.js +47 -0
- package/dist/commands/skill/remove.js.map +1 -0
- package/dist/commands/skill/sync.d.ts +7 -0
- package/dist/commands/skill/sync.d.ts.map +1 -0
- package/dist/commands/skill/sync.js +30 -0
- package/dist/commands/skill/sync.js.map +1 -0
- package/dist/commands/status.d.ts +17 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +265 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/tasks.d.ts +16 -0
- package/dist/commands/tasks.d.ts.map +1 -0
- package/dist/commands/tasks.js +176 -0
- package/dist/commands/tasks.js.map +1 -0
- package/dist/commands/trace.d.ts +16 -0
- package/dist/commands/trace.d.ts.map +1 -0
- package/dist/commands/trace.js +113 -0
- package/dist/commands/trace.js.map +1 -0
- package/dist/commands/upgrade.d.ts +20 -0
- package/dist/commands/upgrade.d.ts.map +1 -0
- package/dist/commands/upgrade.js +178 -0
- package/dist/commands/upgrade.js.map +1 -0
- package/dist/commands/verify/a11y.d.ts +15 -0
- package/dist/commands/verify/a11y.d.ts.map +1 -0
- package/dist/commands/verify/a11y.js +121 -0
- package/dist/commands/verify/a11y.js.map +1 -0
- package/dist/commands/verify/architecture.d.ts +11 -0
- package/dist/commands/verify/architecture.d.ts.map +1 -0
- package/dist/commands/verify/architecture.js +71 -0
- package/dist/commands/verify/architecture.js.map +1 -0
- package/dist/commands/verify/audit.d.ts +18 -0
- package/dist/commands/verify/audit.d.ts.map +1 -0
- package/dist/commands/verify/audit.js +108 -0
- package/dist/commands/verify/audit.js.map +1 -0
- package/dist/commands/verify/constitution.d.ts +10 -0
- package/dist/commands/verify/constitution.d.ts.map +1 -0
- package/dist/commands/verify/constitution.js +91 -0
- package/dist/commands/verify/constitution.js.map +1 -0
- package/dist/commands/verify/os-matrix.d.ts +14 -0
- package/dist/commands/verify/os-matrix.d.ts.map +1 -0
- package/dist/commands/verify/os-matrix.js +108 -0
- package/dist/commands/verify/os-matrix.js.map +1 -0
- package/dist/commands/verify/perf.d.ts +17 -0
- package/dist/commands/verify/perf.d.ts.map +1 -0
- package/dist/commands/verify/perf.js +106 -0
- package/dist/commands/verify/perf.js.map +1 -0
- package/dist/commands/verify/stores.d.ts +14 -0
- package/dist/commands/verify/stores.d.ts.map +1 -0
- package/dist/commands/verify/stores.js +98 -0
- package/dist/commands/verify/stores.js.map +1 -0
- package/dist/commands/verify.d.ts +14 -0
- package/dist/commands/verify.d.ts.map +1 -0
- package/dist/commands/verify.js +97 -0
- package/dist/commands/verify.js.map +1 -0
- package/dist/commands/workflow/catalog.d.ts +11 -0
- package/dist/commands/workflow/catalog.d.ts.map +1 -0
- package/dist/commands/workflow/catalog.js +164 -0
- package/dist/commands/workflow/catalog.js.map +1 -0
- package/dist/commands/workflow/list.d.ts +7 -0
- package/dist/commands/workflow/list.d.ts.map +1 -0
- package/dist/commands/workflow/list.js +50 -0
- package/dist/commands/workflow/list.js.map +1 -0
- package/dist/commands/workflow/resume.d.ts +13 -0
- package/dist/commands/workflow/resume.d.ts.map +1 -0
- package/dist/commands/workflow/resume.js +126 -0
- package/dist/commands/workflow/resume.js.map +1 -0
- package/dist/commands/workflow/run.d.ts +14 -0
- package/dist/commands/workflow/run.d.ts.map +1 -0
- package/dist/commands/workflow/run.js +139 -0
- package/dist/commands/workflow/run.js.map +1 -0
- package/dist/commands/workflow/status.d.ts +10 -0
- package/dist/commands/workflow/status.d.ts.map +1 -0
- package/dist/commands/workflow/status.js +86 -0
- package/dist/commands/workflow/status.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/dist/shared/agents.d.ts +12 -0
- package/dist/shared/agents.d.ts.map +1 -0
- package/dist/shared/agents.js +31 -0
- package/dist/shared/agents.js.map +1 -0
- package/dist/shared/artifact-io.d.ts +54 -0
- package/dist/shared/artifact-io.d.ts.map +1 -0
- package/dist/shared/artifact-io.js +71 -0
- package/dist/shared/artifact-io.js.map +1 -0
- package/dist/shared/feature-prompt.d.ts +18 -0
- package/dist/shared/feature-prompt.d.ts.map +1 -0
- package/dist/shared/feature-prompt.js +21 -0
- package/dist/shared/feature-prompt.js.map +1 -0
- package/dist/shared/hooks.d.ts +7 -0
- package/dist/shared/hooks.d.ts.map +1 -0
- package/dist/shared/hooks.js +52 -0
- package/dist/shared/hooks.js.map +1 -0
- package/dist/shared/mcp.d.ts +9 -0
- package/dist/shared/mcp.d.ts.map +1 -0
- package/dist/shared/mcp.js +15 -0
- package/dist/shared/mcp.js.map +1 -0
- package/dist/shared/project.d.ts +42 -0
- package/dist/shared/project.d.ts.map +1 -0
- package/dist/shared/project.js +98 -0
- package/dist/shared/project.js.map +1 -0
- package/dist/shared/workflow-resolver.d.ts +19 -0
- package/dist/shared/workflow-resolver.d.ts.map +1 -0
- package/dist/shared/workflow-resolver.js +71 -0
- package/dist/shared/workflow-resolver.js.map +1 -0
- package/dist/workflow/args-builder.d.ts +31 -0
- package/dist/workflow/args-builder.d.ts.map +1 -0
- package/dist/workflow/args-builder.js +110 -0
- package/dist/workflow/args-builder.js.map +1 -0
- package/dist/workflow/executor.d.ts +18 -0
- package/dist/workflow/executor.d.ts.map +1 -0
- package/dist/workflow/executor.js +112 -0
- package/dist/workflow/executor.js.map +1 -0
- package/extensions/git/commands/rpt.git.feature.md +85 -0
- package/extensions/git/extension.yml +47 -0
- package/package.json +58 -0
- package/scripts/bash/check-prerequisites.sh +149 -0
- package/scripts/bash/common.sh +389 -0
- package/scripts/bash/create-new-feature.sh +164 -0
- package/scripts/bash/setup-plan.sh +113 -0
- package/scripts/check-naming.sh +138 -0
- package/scripts/check-prompts.sh +165 -0
- package/scripts/check-tasks.sh +166 -0
- package/scripts/powershell/check-prerequisites.ps1 +117 -0
- package/scripts/powershell/common.ps1 +328 -0
- package/scripts/powershell/create-new-feature.ps1 +138 -0
- package/scripts/powershell/setup-plan.ps1 +96 -0
- package/scripts/prepare-npm.mjs +157 -0
- package/templates/checklist-template.md +103 -0
- package/templates/commands/analyze.md +103 -0
- package/templates/commands/checklist.md +87 -0
- package/templates/commands/clarify.md +85 -0
- package/templates/commands/constitution.md +126 -0
- package/templates/commands/implement.md +117 -0
- package/templates/commands/plan.md +125 -0
- package/templates/commands/specify.md +127 -0
- package/templates/commands/tasks.md +98 -0
- package/templates/commands/taskstoissues.md +81 -0
- package/templates/constitution-template.md +48 -0
- package/templates/plan-template.md +150 -0
- package/templates/spec-template.md +116 -0
- package/templates/tasks-template.md +77 -0
|
@@ -0,0 +1,328 @@
|
|
|
1
|
+
# common.ps1 — Shared utility functions for Raptor I/O scripts (PowerShell port).
|
|
2
|
+
#
|
|
3
|
+
# Spec Kit ref: E04 — "Scripts deliberadamente 'burros' cuja única função é
|
|
4
|
+
# resolver paths, manipular filesystem e devolver JSON estável."
|
|
5
|
+
#
|
|
6
|
+
# Contract:
|
|
7
|
+
# - stdout: JSON only (when -Json is used)
|
|
8
|
+
# - stderr: human-readable messages (Write-Error)
|
|
9
|
+
# - exit codes: 0=success, 1=validation error, 2=I/O error
|
|
10
|
+
#
|
|
11
|
+
# Usage: dot-source from other scripts:
|
|
12
|
+
# . "$PSScriptRoot/common.ps1"
|
|
13
|
+
|
|
14
|
+
$ErrorActionPreference = 'Stop'
|
|
15
|
+
|
|
16
|
+
# ---------------------------------------------------------------------------
|
|
17
|
+
# Constants
|
|
18
|
+
# ---------------------------------------------------------------------------
|
|
19
|
+
$script:RAPTOR_DIR = ".raptor"
|
|
20
|
+
$script:FEATURE_JSON = ".raptor/feature.json"
|
|
21
|
+
$script:INIT_OPTIONS_JSON = ".raptor/init-options.json"
|
|
22
|
+
$script:EXTENSIONS_YML = ".raptor/extensions.yml"
|
|
23
|
+
$script:CONSTITUTION_PATH = ".raptor/memory/constitution.md"
|
|
24
|
+
$script:MANIFEST_JSON = ".raptor/raptor.manifest.json"
|
|
25
|
+
$script:SPECS_DIR = "specs"
|
|
26
|
+
|
|
27
|
+
# ---------------------------------------------------------------------------
|
|
28
|
+
# Has-Git — Is git available and are we in a repo?
|
|
29
|
+
# ---------------------------------------------------------------------------
|
|
30
|
+
function Has-Git {
|
|
31
|
+
if (-not (Get-Command git -ErrorAction SilentlyContinue)) {
|
|
32
|
+
return $false
|
|
33
|
+
}
|
|
34
|
+
try {
|
|
35
|
+
git rev-parse --git-dir 2>$null | Out-Null
|
|
36
|
+
return $LASTEXITCODE -eq 0
|
|
37
|
+
} catch {
|
|
38
|
+
return $false
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
# ---------------------------------------------------------------------------
|
|
43
|
+
# Get-RepoRoot — Walk up to find .git or return cwd
|
|
44
|
+
# ---------------------------------------------------------------------------
|
|
45
|
+
function Get-RepoRoot {
|
|
46
|
+
$dir = (Get-Location).Path
|
|
47
|
+
while ($dir -and $dir -ne [System.IO.Path]::GetPathRoot($dir)) {
|
|
48
|
+
if (Test-Path (Join-Path $dir ".git")) {
|
|
49
|
+
return $dir
|
|
50
|
+
}
|
|
51
|
+
$parent = Split-Path -Parent $dir
|
|
52
|
+
if ($parent -eq $dir) { break }
|
|
53
|
+
$dir = $parent
|
|
54
|
+
}
|
|
55
|
+
return (Get-Location).Path
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
# ---------------------------------------------------------------------------
|
|
59
|
+
# Get-CurrentBranch — Current git branch or empty string
|
|
60
|
+
# ---------------------------------------------------------------------------
|
|
61
|
+
function Get-CurrentBranch {
|
|
62
|
+
if (Has-Git) {
|
|
63
|
+
try {
|
|
64
|
+
$branch = git rev-parse --abbrev-ref HEAD 2>$null
|
|
65
|
+
if ($LASTEXITCODE -eq 0) { return $branch.Trim() }
|
|
66
|
+
} catch { }
|
|
67
|
+
}
|
|
68
|
+
return ""
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
# ---------------------------------------------------------------------------
|
|
72
|
+
# ConvertTo-JsonEscape — Escape a string for safe JSON embedding
|
|
73
|
+
# ---------------------------------------------------------------------------
|
|
74
|
+
function ConvertTo-JsonEscape {
|
|
75
|
+
param([string]$Value)
|
|
76
|
+
if ($null -eq $Value) { return "" }
|
|
77
|
+
$s = $Value
|
|
78
|
+
$s = $s -replace '\\', '\\\\'
|
|
79
|
+
$s = $s -replace '"', '\"'
|
|
80
|
+
$s = $s -replace "`n", '\n'
|
|
81
|
+
$s = $s -replace "`r", '\r'
|
|
82
|
+
$s = $s -replace "`t", '\t'
|
|
83
|
+
return $s
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
# ---------------------------------------------------------------------------
|
|
87
|
+
# Get-JsonValue — Read a key from a JSON file
|
|
88
|
+
# ---------------------------------------------------------------------------
|
|
89
|
+
function Get-JsonValue {
|
|
90
|
+
param(
|
|
91
|
+
[string]$File,
|
|
92
|
+
[string]$Key
|
|
93
|
+
)
|
|
94
|
+
if (-not (Test-Path $File)) { return "" }
|
|
95
|
+
try {
|
|
96
|
+
$content = Get-Content $File -Raw | ConvertFrom-Json
|
|
97
|
+
$val = $content.$Key
|
|
98
|
+
if ($null -eq $val) { return "" }
|
|
99
|
+
return [string]$val
|
|
100
|
+
} catch {
|
|
101
|
+
return ""
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
# ---------------------------------------------------------------------------
|
|
106
|
+
# Find-FeatureDirByPrefix — Find specs/ dir matching branch prefix
|
|
107
|
+
# ---------------------------------------------------------------------------
|
|
108
|
+
function Find-FeatureDirByPrefix {
|
|
109
|
+
param(
|
|
110
|
+
[string]$RepoRoot,
|
|
111
|
+
[string]$Branch
|
|
112
|
+
)
|
|
113
|
+
$specsPath = Join-Path $RepoRoot "specs"
|
|
114
|
+
if (-not (Test-Path $specsPath)) { return "" }
|
|
115
|
+
|
|
116
|
+
if ($Branch -match '^(\d+)') {
|
|
117
|
+
$prefix = $matches[1]
|
|
118
|
+
$candidate = Get-ChildItem -Path $specsPath -Directory -Filter "$prefix-*" -ErrorAction SilentlyContinue | Select-Object -First 1
|
|
119
|
+
if ($candidate) {
|
|
120
|
+
return "specs/$($candidate.Name)"
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
return ""
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
# ---------------------------------------------------------------------------
|
|
127
|
+
# Get-FeaturePaths — Resolve the active feature directory.
|
|
128
|
+
#
|
|
129
|
+
# Resolution order (Spec Kit E06):
|
|
130
|
+
# 1. env RAPTOR_FEATURE_DIRECTORY
|
|
131
|
+
# 2. .raptor/feature.json (feature_directory field)
|
|
132
|
+
# 3. Fallback by branch prefix
|
|
133
|
+
#
|
|
134
|
+
# Returns hashtable: @{ FEATURE_DIR; FEATURE_NAME; SPECS_DIR }
|
|
135
|
+
# ---------------------------------------------------------------------------
|
|
136
|
+
function Get-FeaturePaths {
|
|
137
|
+
$repoRoot = Get-RepoRoot
|
|
138
|
+
$featureDir = ""
|
|
139
|
+
|
|
140
|
+
# 1. Environment variable
|
|
141
|
+
if ($env:RAPTOR_FEATURE_DIRECTORY) {
|
|
142
|
+
$featureDir = $env:RAPTOR_FEATURE_DIRECTORY
|
|
143
|
+
Write-Error -ErrorAction Continue -Message "[raptor] Using RAPTOR_FEATURE_DIRECTORY=$featureDir"
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
# 2. feature.json
|
|
147
|
+
if (-not $featureDir) {
|
|
148
|
+
$featureJsonPath = Join-Path $repoRoot $script:FEATURE_JSON
|
|
149
|
+
if (Test-Path $featureJsonPath) {
|
|
150
|
+
$featureDir = Get-JsonValue -File $featureJsonPath -Key 'feature_directory'
|
|
151
|
+
if ($featureDir) {
|
|
152
|
+
Write-Error -ErrorAction Continue -Message "[raptor] Using feature.json: $featureDir"
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
# 3. Fallback by branch prefix
|
|
158
|
+
if (-not $featureDir -and (Has-Git)) {
|
|
159
|
+
$branch = Get-CurrentBranch
|
|
160
|
+
if ($branch) {
|
|
161
|
+
$featureDir = Find-FeatureDirByPrefix -RepoRoot $repoRoot -Branch $branch
|
|
162
|
+
if ($featureDir) {
|
|
163
|
+
Write-Error -ErrorAction Continue -Message "[raptor] Resolved from branch prefix: $featureDir"
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
if (-not $featureDir) {
|
|
169
|
+
Write-Error -ErrorAction Continue -Message "[raptor] ERROR: Cannot resolve feature directory."
|
|
170
|
+
Write-Error -ErrorAction Continue -Message "[raptor] Set RAPTOR_FEATURE_DIRECTORY, create .raptor/feature.json,"
|
|
171
|
+
Write-Error -ErrorAction Continue -Message "[raptor] or switch to a feature branch."
|
|
172
|
+
throw "Cannot resolve feature directory"
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
if (-not [System.IO.Path]::IsPathRooted($featureDir)) {
|
|
176
|
+
$featureDir = Join-Path $repoRoot $featureDir
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
return @{
|
|
180
|
+
FEATURE_DIR = $featureDir
|
|
181
|
+
FEATURE_NAME = (Split-Path -Leaf $featureDir)
|
|
182
|
+
SPECS_DIR = (Join-Path $repoRoot "specs")
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
# ---------------------------------------------------------------------------
|
|
187
|
+
# Test-FeatureBranch — Validate branch name format
|
|
188
|
+
# ---------------------------------------------------------------------------
|
|
189
|
+
function Test-FeatureBranch {
|
|
190
|
+
param([string]$Branch = (Get-CurrentBranch))
|
|
191
|
+
|
|
192
|
+
if (-not $Branch) { return $false }
|
|
193
|
+
|
|
194
|
+
if ($Branch -match '^[0-9]+-[a-z][a-z0-9-]*$') { return $true }
|
|
195
|
+
if ($Branch -match '^[0-9]{8}-[0-9]{6}-[a-z][a-z0-9-]*$') { return $true }
|
|
196
|
+
|
|
197
|
+
return $false
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
# ---------------------------------------------------------------------------
|
|
201
|
+
# Resolve-Template — Priority stack resolution for templates (E14)
|
|
202
|
+
#
|
|
203
|
+
# Order:
|
|
204
|
+
# 1. .raptor/templates/overrides/<name>.md
|
|
205
|
+
# 2. .raptor/presets/<id>/templates/<name>.md
|
|
206
|
+
# 3. .raptor/extensions/<id>/templates/<name>.md
|
|
207
|
+
# 4. .raptor/templates/<name>.md (core fallback)
|
|
208
|
+
# ---------------------------------------------------------------------------
|
|
209
|
+
function Resolve-Template {
|
|
210
|
+
param([string]$Name)
|
|
211
|
+
|
|
212
|
+
$repoRoot = Get-RepoRoot
|
|
213
|
+
|
|
214
|
+
# 1. Project override
|
|
215
|
+
$override = Join-Path $repoRoot "$($script:RAPTOR_DIR)/templates/overrides/$Name"
|
|
216
|
+
if (Test-Path $override) { return $override }
|
|
217
|
+
|
|
218
|
+
# 2. Presets (by registry priority)
|
|
219
|
+
$presetsDir = Join-Path $repoRoot "$($script:RAPTOR_DIR)/presets"
|
|
220
|
+
$registry = Join-Path $presetsDir ".registry"
|
|
221
|
+
if (Test-Path $registry) {
|
|
222
|
+
try {
|
|
223
|
+
$entries = Get-Content $registry -Raw | ConvertFrom-Json
|
|
224
|
+
$entries = $entries | Sort-Object priority
|
|
225
|
+
foreach ($e in $entries) {
|
|
226
|
+
$candidate = Join-Path $presetsDir "$($e.id)/templates/$Name"
|
|
227
|
+
if (Test-Path $candidate) { return $candidate }
|
|
228
|
+
}
|
|
229
|
+
} catch { }
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
# 3. Extensions
|
|
233
|
+
$extDir = Join-Path $repoRoot "$($script:RAPTOR_DIR)/extensions"
|
|
234
|
+
if (Test-Path $extDir) {
|
|
235
|
+
Get-ChildItem -Path $extDir -Directory -ErrorAction SilentlyContinue | ForEach-Object {
|
|
236
|
+
$candidate = Join-Path $_.FullName "templates/$Name"
|
|
237
|
+
if (Test-Path $candidate) { return $candidate }
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
# 4. Core fallback
|
|
242
|
+
$core = Join-Path $repoRoot "$($script:RAPTOR_DIR)/templates/$Name"
|
|
243
|
+
if (Test-Path $core) { return $core }
|
|
244
|
+
|
|
245
|
+
Write-Error -ErrorAction Continue -Message "[raptor] WARNING: Template '$Name' not found in any layer."
|
|
246
|
+
return ""
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
# ---------------------------------------------------------------------------
|
|
250
|
+
# Get-NextFeatureNumber — Calculate next sequential number
|
|
251
|
+
# ---------------------------------------------------------------------------
|
|
252
|
+
function Get-NextFeatureNumber {
|
|
253
|
+
$repoRoot = Get-RepoRoot
|
|
254
|
+
$max = 0
|
|
255
|
+
|
|
256
|
+
$specsPath = Join-Path $repoRoot "specs"
|
|
257
|
+
if (Test-Path $specsPath) {
|
|
258
|
+
Get-ChildItem -Path $specsPath -Directory -ErrorAction SilentlyContinue | ForEach-Object {
|
|
259
|
+
if ($_.Name -match '^([0-9]+)') {
|
|
260
|
+
$num = [int]$matches[1]
|
|
261
|
+
if ($num -gt $max) { $max = $num }
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
if (Has-Git) {
|
|
267
|
+
try {
|
|
268
|
+
$localBranches = git branch 2>$null
|
|
269
|
+
foreach ($b in $localBranches) {
|
|
270
|
+
$clean = $b -replace '^[\* ]+', ''
|
|
271
|
+
if ($clean -match '^([0-9]+)') {
|
|
272
|
+
$num = [int]$matches[1]
|
|
273
|
+
if ($num -gt $max) { $max = $num }
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
$remoteBranches = git branch -r 2>$null
|
|
277
|
+
foreach ($b in $remoteBranches) {
|
|
278
|
+
$clean = $b -replace '.*/', ''
|
|
279
|
+
if ($clean -match '^([0-9]+)') {
|
|
280
|
+
$num = [int]$matches[1]
|
|
281
|
+
if ($num -gt $max) { $max = $num }
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
} catch { }
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
return ($max + 1)
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
# ---------------------------------------------------------------------------
|
|
291
|
+
# Format-FeatureNumber — Pad a number with leading zeros (auto-expands at 1000)
|
|
292
|
+
# ---------------------------------------------------------------------------
|
|
293
|
+
function Format-FeatureNumber {
|
|
294
|
+
param(
|
|
295
|
+
[int]$Number,
|
|
296
|
+
[int]$Width = 3
|
|
297
|
+
)
|
|
298
|
+
if ($Number -ge 1000 -and $Width -lt 4) { $Width = 4 }
|
|
299
|
+
return ('{0:D' + $Width + '}') -f $Number
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
# ---------------------------------------------------------------------------
|
|
303
|
+
# ConvertTo-RaptorJson — Build a JSON object from key/value pairs
|
|
304
|
+
# Usage: ConvertTo-RaptorJson @{ KEY1='val1'; KEY2='val2' }
|
|
305
|
+
# ---------------------------------------------------------------------------
|
|
306
|
+
function ConvertTo-RaptorJson {
|
|
307
|
+
param([hashtable]$Data)
|
|
308
|
+
|
|
309
|
+
$parts = @()
|
|
310
|
+
foreach ($k in $Data.Keys) {
|
|
311
|
+
$key = ConvertTo-JsonEscape -Value $k
|
|
312
|
+
$val = ConvertTo-JsonEscape -Value ([string]$Data[$k])
|
|
313
|
+
$parts += '"' + $key + '":"' + $val + '"'
|
|
314
|
+
}
|
|
315
|
+
return '{' + ($parts -join ',') + '}'
|
|
316
|
+
}
|
|
317
|
+
|
|
318
|
+
# ---------------------------------------------------------------------------
|
|
319
|
+
# Stop-WithError — Print error to stderr and exit
|
|
320
|
+
# ---------------------------------------------------------------------------
|
|
321
|
+
function Stop-WithError {
|
|
322
|
+
param(
|
|
323
|
+
[string]$Message,
|
|
324
|
+
[int]$Code = 1
|
|
325
|
+
)
|
|
326
|
+
Write-Error -ErrorAction Continue -Message "[raptor] ERROR: $Message"
|
|
327
|
+
exit $Code
|
|
328
|
+
}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
# create-new-feature.ps1 — Create a new feature branch and spec directory.
|
|
2
|
+
#
|
|
3
|
+
# Spec Kit ref: E04 (PowerShell parity port).
|
|
4
|
+
#
|
|
5
|
+
# Args:
|
|
6
|
+
# -Json Output JSON to stdout (default: human-readable)
|
|
7
|
+
# -DryRun Show what would be done without doing it
|
|
8
|
+
# -AllowExistingBranch Allow reuse of an existing branch
|
|
9
|
+
# -ShortName <name> Feature short name (kebab-case, 2-4 words) [REQUIRED]
|
|
10
|
+
# -Number <N> Force a specific feature number
|
|
11
|
+
# -Timestamp Use timestamp-based prefix instead of sequential
|
|
12
|
+
|
|
13
|
+
[CmdletBinding()]
|
|
14
|
+
param(
|
|
15
|
+
[switch]$Json,
|
|
16
|
+
[switch]$DryRun,
|
|
17
|
+
[switch]$AllowExistingBranch,
|
|
18
|
+
[Parameter(Mandatory=$true)]
|
|
19
|
+
[string]$ShortName,
|
|
20
|
+
[int]$Number = 0,
|
|
21
|
+
[switch]$Timestamp
|
|
22
|
+
)
|
|
23
|
+
|
|
24
|
+
$ErrorActionPreference = 'Stop'
|
|
25
|
+
|
|
26
|
+
. (Join-Path $PSScriptRoot 'common.ps1')
|
|
27
|
+
|
|
28
|
+
# ---------------------------------------------------------------------------
|
|
29
|
+
# Validate
|
|
30
|
+
# ---------------------------------------------------------------------------
|
|
31
|
+
if (-not ($ShortName -match '^[a-z][a-z0-9-]*$')) {
|
|
32
|
+
Stop-WithError -Message "Invalid short-name '$ShortName': must be lowercase kebab-case (e.g., 'user-auth', 'payment-flow')" -Code 1
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
# ---------------------------------------------------------------------------
|
|
36
|
+
# Resolve repo root and read options
|
|
37
|
+
# ---------------------------------------------------------------------------
|
|
38
|
+
$repoRoot = Get-RepoRoot
|
|
39
|
+
Set-Location $repoRoot
|
|
40
|
+
|
|
41
|
+
$useTimestamp = $Timestamp.IsPresent
|
|
42
|
+
|
|
43
|
+
if (-not $useTimestamp) {
|
|
44
|
+
$initOptionsPath = Join-Path $repoRoot $script:INIT_OPTIONS_JSON
|
|
45
|
+
if (Test-Path $initOptionsPath) {
|
|
46
|
+
$numbering = Get-JsonValue -File $initOptionsPath -Key 'branch_numbering'
|
|
47
|
+
if ($numbering -eq 'timestamp') {
|
|
48
|
+
$useTimestamp = $true
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
# ---------------------------------------------------------------------------
|
|
54
|
+
# Calculate prefix
|
|
55
|
+
# ---------------------------------------------------------------------------
|
|
56
|
+
if ($useTimestamp) {
|
|
57
|
+
$prefix = (Get-Date -Format 'yyyyMMdd-HHmmss')
|
|
58
|
+
} else {
|
|
59
|
+
if ($Number -gt 0) {
|
|
60
|
+
$num = $Number
|
|
61
|
+
} else {
|
|
62
|
+
$num = Get-NextFeatureNumber
|
|
63
|
+
}
|
|
64
|
+
$prefix = Format-FeatureNumber -Number $num
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
$branchName = "$prefix-$ShortName"
|
|
68
|
+
$featureDir = "specs/$branchName"
|
|
69
|
+
|
|
70
|
+
# ---------------------------------------------------------------------------
|
|
71
|
+
# Check existing
|
|
72
|
+
# ---------------------------------------------------------------------------
|
|
73
|
+
if ((Test-Path $featureDir) -and (-not $AllowExistingBranch)) {
|
|
74
|
+
Stop-WithError -Message "Feature directory already exists: $featureDir (use -AllowExistingBranch to reuse)" -Code 1
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
if (Has-Git) {
|
|
78
|
+
$existing = git branch --list $branchName 2>$null
|
|
79
|
+
if ($existing -and (-not $AllowExistingBranch)) {
|
|
80
|
+
Stop-WithError -Message "Branch already exists: $branchName (use -AllowExistingBranch to reuse)" -Code 1
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
# ---------------------------------------------------------------------------
|
|
85
|
+
# Execute
|
|
86
|
+
# ---------------------------------------------------------------------------
|
|
87
|
+
$hasGitRepo = "false"
|
|
88
|
+
|
|
89
|
+
if ($DryRun) {
|
|
90
|
+
Write-Error -ErrorAction Continue -Message "[raptor] DRY RUN — would create:"
|
|
91
|
+
Write-Error -ErrorAction Continue -Message " Branch: $branchName"
|
|
92
|
+
Write-Error -ErrorAction Continue -Message " Directory: $featureDir"
|
|
93
|
+
} else {
|
|
94
|
+
New-Item -ItemType Directory -Path $featureDir -Force | Out-Null
|
|
95
|
+
Write-Error -ErrorAction Continue -Message "[raptor] Created directory: $featureDir"
|
|
96
|
+
|
|
97
|
+
if (Has-Git) {
|
|
98
|
+
$hasGitRepo = "true"
|
|
99
|
+
$existing = git branch --list $branchName 2>$null
|
|
100
|
+
if (-not $existing) {
|
|
101
|
+
git checkout -b $branchName 2>$null | Out-Null
|
|
102
|
+
if ($LASTEXITCODE -eq 0) {
|
|
103
|
+
Write-Error -ErrorAction Continue -Message "[raptor] Created and switched to branch: $branchName"
|
|
104
|
+
} else {
|
|
105
|
+
Write-Error -ErrorAction Continue -Message "[raptor] WARNING: Could not create branch $branchName (git error)"
|
|
106
|
+
}
|
|
107
|
+
} elseif ($AllowExistingBranch) {
|
|
108
|
+
git checkout $branchName 2>$null | Out-Null
|
|
109
|
+
Write-Error -ErrorAction Continue -Message "[raptor] Switched to existing branch: $branchName"
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
if (Test-Path $script:RAPTOR_DIR) {
|
|
114
|
+
@{ feature_directory = $featureDir } |
|
|
115
|
+
ConvertTo-Json |
|
|
116
|
+
Set-Content -Path $script:FEATURE_JSON -Encoding utf8
|
|
117
|
+
Write-Error -ErrorAction Continue -Message "[raptor] Updated $($script:FEATURE_JSON)"
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
# ---------------------------------------------------------------------------
|
|
122
|
+
# Output
|
|
123
|
+
# ---------------------------------------------------------------------------
|
|
124
|
+
if ($Json) {
|
|
125
|
+
$payload = [ordered]@{
|
|
126
|
+
BRANCH_NAME = $branchName
|
|
127
|
+
FEATURE_NUM = $prefix
|
|
128
|
+
FEATURE_DIR = $featureDir
|
|
129
|
+
PREFIX = $prefix
|
|
130
|
+
HAS_GIT = $hasGitRepo
|
|
131
|
+
DRY_RUN = ([string]$DryRun.IsPresent).ToLower()
|
|
132
|
+
}
|
|
133
|
+
Write-Output (ConvertTo-RaptorJson -Data $payload)
|
|
134
|
+
} else {
|
|
135
|
+
Write-Output "Feature: $branchName"
|
|
136
|
+
Write-Output "Directory: $featureDir"
|
|
137
|
+
Write-Output "Prefix: $prefix"
|
|
138
|
+
}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
# setup-plan.ps1 — Prepare plan artifacts for a feature (PowerShell parity port).
|
|
2
|
+
#
|
|
3
|
+
# Spec Kit ref: E04
|
|
4
|
+
#
|
|
5
|
+
# Output JSON (-Json):
|
|
6
|
+
# { "FEATURE_SPEC": "...", "IMPL_PLAN": "...", "SPECS_DIR": "...",
|
|
7
|
+
# "BRANCH": "...", "HAS_GIT": "..." }
|
|
8
|
+
|
|
9
|
+
[CmdletBinding()]
|
|
10
|
+
param(
|
|
11
|
+
[switch]$Json
|
|
12
|
+
)
|
|
13
|
+
|
|
14
|
+
$ErrorActionPreference = 'Stop'
|
|
15
|
+
|
|
16
|
+
. (Join-Path $PSScriptRoot 'common.ps1')
|
|
17
|
+
|
|
18
|
+
# ---------------------------------------------------------------------------
|
|
19
|
+
# Resolve feature paths
|
|
20
|
+
# ---------------------------------------------------------------------------
|
|
21
|
+
try {
|
|
22
|
+
$paths = Get-FeaturePaths
|
|
23
|
+
} catch {
|
|
24
|
+
Stop-WithError -Message "Cannot resolve feature paths" -Code 1
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
$featureDir = $paths.FEATURE_DIR
|
|
28
|
+
$specsDir = $paths.SPECS_DIR
|
|
29
|
+
$repoRoot = Get-RepoRoot
|
|
30
|
+
$branch = Get-CurrentBranch
|
|
31
|
+
$hasGitRepo = if (Has-Git) { "true" } else { "false" }
|
|
32
|
+
|
|
33
|
+
# ---------------------------------------------------------------------------
|
|
34
|
+
# Validate spec exists
|
|
35
|
+
# ---------------------------------------------------------------------------
|
|
36
|
+
$featureSpec = Join-Path $featureDir 'spec.md'
|
|
37
|
+
if (-not (Test-Path $featureSpec)) {
|
|
38
|
+
Stop-WithError -Message "spec.md not found at $featureSpec. Run /rpt.specify first." -Code 1
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
# ---------------------------------------------------------------------------
|
|
42
|
+
# Copy plan template if plan doesn't exist
|
|
43
|
+
# ---------------------------------------------------------------------------
|
|
44
|
+
$implPlan = Join-Path $featureDir 'plan.md'
|
|
45
|
+
if (-not (Test-Path $implPlan)) {
|
|
46
|
+
$templatePath = Resolve-Template -Name 'plan-template.md'
|
|
47
|
+
if ($templatePath -and (Test-Path $templatePath)) {
|
|
48
|
+
Copy-Item -Path $templatePath -Destination $implPlan
|
|
49
|
+
Write-Error -ErrorAction Continue -Message "[raptor] Copied plan template from: $templatePath"
|
|
50
|
+
} else {
|
|
51
|
+
@"
|
|
52
|
+
# Implementation Plan
|
|
53
|
+
|
|
54
|
+
## Context & Constraints
|
|
55
|
+
|
|
56
|
+
[NEEDS CLARIFICATION]
|
|
57
|
+
|
|
58
|
+
## Architecture Overview
|
|
59
|
+
|
|
60
|
+
[NEEDS CLARIFICATION]
|
|
61
|
+
|
|
62
|
+
## Constitution Check
|
|
63
|
+
|
|
64
|
+
### Initial Check (pre-design)
|
|
65
|
+
|
|
66
|
+
| Principle | Status | Notes |
|
|
67
|
+
|-----------|--------|-------|
|
|
68
|
+
|
|
69
|
+
### Post-Design Check (after Phase 1)
|
|
70
|
+
|
|
71
|
+
| Principle | Status | Notes |
|
|
72
|
+
|-----------|--------|-------|
|
|
73
|
+
"@ | Set-Content -Path $implPlan -Encoding utf8
|
|
74
|
+
Write-Error -ErrorAction Continue -Message "[raptor] Created minimal plan.md (no template found)"
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
# ---------------------------------------------------------------------------
|
|
79
|
+
# Output
|
|
80
|
+
# ---------------------------------------------------------------------------
|
|
81
|
+
if ($Json) {
|
|
82
|
+
$payload = [ordered]@{
|
|
83
|
+
FEATURE_SPEC = $featureSpec
|
|
84
|
+
IMPL_PLAN = $implPlan
|
|
85
|
+
SPECS_DIR = $specsDir
|
|
86
|
+
BRANCH = $branch
|
|
87
|
+
HAS_GIT = $hasGitRepo
|
|
88
|
+
}
|
|
89
|
+
Write-Output (ConvertTo-RaptorJson -Data $payload)
|
|
90
|
+
} else {
|
|
91
|
+
Write-Output "Feature spec: $featureSpec"
|
|
92
|
+
Write-Output "Plan: $implPlan"
|
|
93
|
+
Write-Output "Specs dir: $specsDir"
|
|
94
|
+
Write-Output "Branch: $branch"
|
|
95
|
+
Write-Output "Git: $hasGitRepo"
|
|
96
|
+
}
|