@dewtech/dare-cli 3.10.0 → 3.12.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -1
- package/dist/__tests__/ci-pr-regression.test.d.ts +2 -0
- package/dist/__tests__/ci-pr-regression.test.d.ts.map +1 -0
- package/dist/__tests__/ci-pr-regression.test.js +76 -0
- package/dist/__tests__/ci-pr-regression.test.js.map +1 -0
- package/dist/__tests__/dashboard-front.test.d.ts +2 -0
- package/dist/__tests__/dashboard-front.test.d.ts.map +1 -0
- package/dist/__tests__/dashboard-front.test.js +37 -0
- package/dist/__tests__/dashboard-front.test.js.map +1 -0
- package/dist/__tests__/dashboard-regression.test.d.ts +2 -0
- package/dist/__tests__/dashboard-regression.test.d.ts.map +1 -0
- package/dist/__tests__/dashboard-regression.test.js +68 -0
- package/dist/__tests__/dashboard-regression.test.js.map +1 -0
- package/dist/__tests__/dynamic-dag-regression.test.d.ts +2 -0
- package/dist/__tests__/dynamic-dag-regression.test.d.ts.map +1 -0
- package/dist/__tests__/dynamic-dag-regression.test.js +464 -0
- package/dist/__tests__/dynamic-dag-regression.test.js.map +1 -0
- package/dist/__tests__/ensure-skills.test.js +5 -0
- package/dist/__tests__/ensure-skills.test.js.map +1 -1
- package/dist/__tests__/ide-command-parity.test.js +2 -0
- package/dist/__tests__/ide-command-parity.test.js.map +1 -1
- package/dist/__tests__/project-generator.test.js +17 -0
- package/dist/__tests__/project-generator.test.js.map +1 -1
- package/dist/__tests__/reverse-facts.test.js +1 -0
- package/dist/__tests__/reverse-facts.test.js.map +1 -1
- package/dist/__tests__/terminal-parity-regression.test.d.ts +2 -0
- package/dist/__tests__/terminal-parity-regression.test.d.ts.map +1 -0
- package/dist/__tests__/terminal-parity-regression.test.js +116 -0
- package/dist/__tests__/terminal-parity-regression.test.js.map +1 -0
- package/dist/__tests__/terminal-parity.test.d.ts +2 -0
- package/dist/__tests__/terminal-parity.test.d.ts.map +1 -0
- package/dist/__tests__/terminal-parity.test.js +81 -0
- package/dist/__tests__/terminal-parity.test.js.map +1 -0
- package/dist/agent/__tests__/antigravity-driver.test.d.ts +2 -0
- package/dist/agent/__tests__/antigravity-driver.test.d.ts.map +1 -0
- package/dist/agent/__tests__/antigravity-driver.test.js +52 -0
- package/dist/agent/__tests__/antigravity-driver.test.js.map +1 -0
- package/dist/agent/__tests__/codex-driver.test.d.ts +2 -0
- package/dist/agent/__tests__/codex-driver.test.d.ts.map +1 -0
- package/dist/agent/__tests__/codex-driver.test.js +68 -0
- package/dist/agent/__tests__/codex-driver.test.js.map +1 -0
- package/dist/agent/__tests__/cursor-driver.test.d.ts +2 -0
- package/dist/agent/__tests__/cursor-driver.test.d.ts.map +1 -0
- package/dist/agent/__tests__/cursor-driver.test.js +52 -0
- package/dist/agent/__tests__/cursor-driver.test.js.map +1 -0
- package/dist/agent/driver.d.ts +1 -1
- package/dist/agent/driver.d.ts.map +1 -1
- package/dist/agent/drivers/antigravity.d.ts +8 -0
- package/dist/agent/drivers/antigravity.d.ts.map +1 -0
- package/dist/agent/drivers/antigravity.js +99 -0
- package/dist/agent/drivers/antigravity.js.map +1 -0
- package/dist/agent/drivers/codex.d.ts +12 -0
- package/dist/agent/drivers/codex.d.ts.map +1 -0
- package/dist/agent/drivers/codex.js +137 -0
- package/dist/agent/drivers/codex.js.map +1 -0
- package/dist/agent/drivers/cursor.d.ts +8 -0
- package/dist/agent/drivers/cursor.d.ts.map +1 -0
- package/dist/agent/drivers/cursor.js +99 -0
- package/dist/agent/drivers/cursor.js.map +1 -0
- package/dist/ai/__tests__/ai-core.test.d.ts +2 -0
- package/dist/ai/__tests__/ai-core.test.d.ts.map +1 -0
- package/dist/ai/__tests__/ai-core.test.js +41 -0
- package/dist/ai/__tests__/ai-core.test.js.map +1 -0
- package/dist/ai/__tests__/parity.test.d.ts +2 -0
- package/dist/ai/__tests__/parity.test.d.ts.map +1 -0
- package/dist/ai/__tests__/parity.test.js +36 -0
- package/dist/ai/__tests__/parity.test.js.map +1 -0
- package/dist/ai/__tests__/pipeline.test.d.ts +2 -0
- package/dist/ai/__tests__/pipeline.test.d.ts.map +1 -0
- package/dist/ai/__tests__/pipeline.test.js +147 -0
- package/dist/ai/__tests__/pipeline.test.js.map +1 -0
- package/dist/ai/__tests__/refine-bridge.test.d.ts +2 -0
- package/dist/ai/__tests__/refine-bridge.test.d.ts.map +1 -0
- package/dist/ai/__tests__/refine-bridge.test.js +17 -0
- package/dist/ai/__tests__/refine-bridge.test.js.map +1 -0
- package/dist/ai/__tests__/resolve.test.d.ts +2 -0
- package/dist/ai/__tests__/resolve.test.d.ts.map +1 -0
- package/dist/ai/__tests__/resolve.test.js +42 -0
- package/dist/ai/__tests__/resolve.test.js.map +1 -0
- package/dist/ai/capabilities.d.ts +3 -0
- package/dist/ai/capabilities.d.ts.map +1 -0
- package/dist/ai/capabilities.js +11 -0
- package/dist/ai/capabilities.js.map +1 -0
- package/dist/ai/command-options.d.ts +10 -0
- package/dist/ai/command-options.d.ts.map +1 -0
- package/dist/ai/command-options.js +15 -0
- package/dist/ai/command-options.js.map +1 -0
- package/dist/ai/config.d.ts +27 -0
- package/dist/ai/config.d.ts.map +1 -0
- package/dist/ai/config.js +89 -0
- package/dist/ai/config.js.map +1 -0
- package/dist/ai/parity.d.ts +13 -0
- package/dist/ai/parity.d.ts.map +1 -0
- package/dist/ai/parity.js +87 -0
- package/dist/ai/parity.js.map +1 -0
- package/dist/ai/parse-json-output.d.ts +5 -0
- package/dist/ai/parse-json-output.d.ts.map +1 -0
- package/dist/ai/parse-json-output.js +25 -0
- package/dist/ai/parse-json-output.js.map +1 -0
- package/dist/ai/pipeline.d.ts +20 -0
- package/dist/ai/pipeline.d.ts.map +1 -0
- package/dist/ai/pipeline.js +303 -0
- package/dist/ai/pipeline.js.map +1 -0
- package/dist/ai/prompts.d.ts +6 -0
- package/dist/ai/prompts.d.ts.map +1 -0
- package/dist/ai/prompts.js +49 -0
- package/dist/ai/prompts.js.map +1 -0
- package/dist/ai/providers.d.ts +63 -0
- package/dist/ai/providers.d.ts.map +1 -0
- package/dist/ai/providers.js +297 -0
- package/dist/ai/providers.js.map +1 -0
- package/dist/ai/refine-bridge.d.ts +5 -0
- package/dist/ai/refine-bridge.d.ts.map +1 -0
- package/dist/ai/refine-bridge.js +14 -0
- package/dist/ai/refine-bridge.js.map +1 -0
- package/dist/ai/registry.d.ts +12 -0
- package/dist/ai/registry.d.ts.map +1 -0
- package/dist/ai/registry.js +43 -0
- package/dist/ai/registry.js.map +1 -0
- package/dist/ai/resolve.d.ts +28 -0
- package/dist/ai/resolve.d.ts.map +1 -0
- package/dist/ai/resolve.js +83 -0
- package/dist/ai/resolve.js.map +1 -0
- package/dist/ai/schemas.d.ts +175 -0
- package/dist/ai/schemas.d.ts.map +1 -0
- package/dist/ai/schemas.js +199 -0
- package/dist/ai/schemas.js.map +1 -0
- package/dist/ai/types.d.ts +52 -0
- package/dist/ai/types.d.ts.map +1 -0
- package/dist/ai/types.js +8 -0
- package/dist/ai/types.js.map +1 -0
- package/dist/bin/dare.js +4 -0
- package/dist/bin/dare.js.map +1 -1
- package/dist/commands/__tests__/ai-command.test.d.ts +2 -0
- package/dist/commands/__tests__/ai-command.test.d.ts.map +1 -0
- package/dist/commands/__tests__/ai-command.test.js +68 -0
- package/dist/commands/__tests__/ai-command.test.js.map +1 -0
- package/dist/commands/__tests__/dashboard-command.test.d.ts +2 -0
- package/dist/commands/__tests__/dashboard-command.test.d.ts.map +1 -0
- package/dist/commands/__tests__/dashboard-command.test.js +62 -0
- package/dist/commands/__tests__/dashboard-command.test.js.map +1 -0
- package/dist/commands/__tests__/execute-agent.test.js +82 -0
- package/dist/commands/__tests__/execute-agent.test.js.map +1 -1
- package/dist/commands/__tests__/gate-flags.test.d.ts +2 -0
- package/dist/commands/__tests__/gate-flags.test.d.ts.map +1 -0
- package/dist/commands/__tests__/gate-flags.test.js +58 -0
- package/dist/commands/__tests__/gate-flags.test.js.map +1 -0
- package/dist/commands/__tests__/persist-viz.test.d.ts +2 -0
- package/dist/commands/__tests__/persist-viz.test.d.ts.map +1 -0
- package/dist/commands/__tests__/persist-viz.test.js +178 -0
- package/dist/commands/__tests__/persist-viz.test.js.map +1 -0
- package/dist/commands/__tests__/refine-apply.test.d.ts +2 -0
- package/dist/commands/__tests__/refine-apply.test.d.ts.map +1 -0
- package/dist/commands/__tests__/refine-apply.test.js +118 -0
- package/dist/commands/__tests__/refine-apply.test.js.map +1 -0
- package/dist/commands/__tests__/replan-splice.test.d.ts +2 -0
- package/dist/commands/__tests__/replan-splice.test.d.ts.map +1 -0
- package/dist/commands/__tests__/replan-splice.test.js +295 -0
- package/dist/commands/__tests__/replan-splice.test.js.map +1 -0
- package/dist/commands/ai.d.ts +3 -0
- package/dist/commands/ai.d.ts.map +1 -0
- package/dist/commands/ai.js +141 -0
- package/dist/commands/ai.js.map +1 -0
- package/dist/commands/blueprint.d.ts.map +1 -1
- package/dist/commands/blueprint.js +17 -3
- package/dist/commands/blueprint.js.map +1 -1
- package/dist/commands/dag.d.ts.map +1 -1
- package/dist/commands/dag.js +2 -0
- package/dist/commands/dag.js.map +1 -1
- package/dist/commands/dashboard.d.ts +17 -0
- package/dist/commands/dashboard.d.ts.map +1 -0
- package/dist/commands/dashboard.js +77 -0
- package/dist/commands/dashboard.js.map +1 -0
- package/dist/commands/design.d.ts.map +1 -1
- package/dist/commands/design.js +21 -2
- package/dist/commands/design.js.map +1 -1
- package/dist/commands/discover.d.ts.map +1 -1
- package/dist/commands/discover.js +9 -1
- package/dist/commands/discover.js.map +1 -1
- package/dist/commands/dna.d.ts.map +1 -1
- package/dist/commands/dna.js +23 -3
- package/dist/commands/dna.js.map +1 -1
- package/dist/commands/execute.d.ts +11 -0
- package/dist/commands/execute.d.ts.map +1 -1
- package/dist/commands/execute.js +219 -6
- package/dist/commands/execute.js.map +1 -1
- package/dist/commands/graph.d.ts.map +1 -1
- package/dist/commands/graph.js +33 -5
- package/dist/commands/graph.js.map +1 -1
- package/dist/commands/guard.d.ts.map +1 -1
- package/dist/commands/guard.js +27 -3
- package/dist/commands/guard.js.map +1 -1
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +1 -0
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/migrate.d.ts.map +1 -1
- package/dist/commands/migrate.js +14 -2
- package/dist/commands/migrate.js.map +1 -1
- package/dist/commands/patterns.d.ts.map +1 -1
- package/dist/commands/patterns.js +14 -2
- package/dist/commands/patterns.js.map +1 -1
- package/dist/commands/refine.d.ts +2 -0
- package/dist/commands/refine.d.ts.map +1 -1
- package/dist/commands/refine.js +94 -22
- package/dist/commands/refine.js.map +1 -1
- package/dist/commands/reverse.d.ts.map +1 -1
- package/dist/commands/reverse.js +28 -3
- package/dist/commands/reverse.js.map +1 -1
- package/dist/commands/review.d.ts.map +1 -1
- package/dist/commands/review.js +60 -7
- package/dist/commands/review.js.map +1 -1
- package/dist/core/types/project.d.ts +1 -1
- package/dist/core/types/project.d.ts.map +1 -1
- package/dist/dag-runner/__tests__/maxdepth-config.test.d.ts +2 -0
- package/dist/dag-runner/__tests__/maxdepth-config.test.d.ts.map +1 -0
- package/dist/dag-runner/__tests__/maxdepth-config.test.js +28 -0
- package/dist/dag-runner/__tests__/maxdepth-config.test.js.map +1 -0
- package/dist/dag-runner/__tests__/sub-dag.test.d.ts +2 -0
- package/dist/dag-runner/__tests__/sub-dag.test.d.ts.map +1 -0
- package/dist/dag-runner/__tests__/sub-dag.test.js +127 -0
- package/dist/dag-runner/__tests__/sub-dag.test.js.map +1 -0
- package/dist/dag-runner/run_dag.d.ts +3 -1
- package/dist/dag-runner/run_dag.d.ts.map +1 -1
- package/dist/dag-runner/run_dag.js.map +1 -1
- package/dist/dag-runner/state-store.d.ts +2 -0
- package/dist/dag-runner/state-store.d.ts.map +1 -1
- package/dist/dag-runner/state-store.js +44 -8
- package/dist/dag-runner/state-store.js.map +1 -1
- package/dist/dag-runner/sub-dag.d.ts +23 -0
- package/dist/dag-runner/sub-dag.d.ts.map +1 -0
- package/dist/dag-runner/sub-dag.js +117 -0
- package/dist/dag-runner/sub-dag.js.map +1 -0
- package/dist/dashboard/__tests__/dashboard-routes.test.d.ts +2 -0
- package/dist/dashboard/__tests__/dashboard-routes.test.d.ts.map +1 -0
- package/dist/dashboard/__tests__/dashboard-routes.test.js +102 -0
- package/dist/dashboard/__tests__/dashboard-routes.test.js.map +1 -0
- package/dist/dashboard/routes.d.ts +8 -0
- package/dist/dashboard/routes.d.ts.map +1 -0
- package/dist/dashboard/routes.js +70 -0
- package/dist/dashboard/routes.js.map +1 -0
- package/dist/exec/safe-spawn.d.ts.map +1 -1
- package/dist/exec/safe-spawn.js +6 -1
- package/dist/exec/safe-spawn.js.map +1 -1
- package/dist/graphrag/__tests__/hybrid-integration.test.js +1 -1
- package/dist/graphrag/__tests__/hybrid-integration.test.js.map +1 -1
- package/dist/graphrag/__tests__/no-heavy-dep-in-core.test.js +2 -2
- package/dist/graphrag/__tests__/no-heavy-dep-in-core.test.js.map +1 -1
- package/dist/graphrag/embeddings.js +1 -1
- package/dist/graphrag/embeddings.js.map +1 -1
- package/dist/http/__tests__/shared-app.test.d.ts +2 -0
- package/dist/http/__tests__/shared-app.test.d.ts.map +1 -0
- package/dist/http/__tests__/shared-app.test.js +57 -0
- package/dist/http/__tests__/shared-app.test.js.map +1 -0
- package/dist/http/app.d.ts +15 -0
- package/dist/http/app.d.ts.map +1 -0
- package/dist/http/app.js +32 -0
- package/dist/http/app.js.map +1 -0
- package/dist/mcp-server/server.d.ts.map +1 -1
- package/dist/mcp-server/server.js +5 -15
- package/dist/mcp-server/server.js.map +1 -1
- package/dist/reporters/__tests__/github-reporter.test.d.ts +2 -0
- package/dist/reporters/__tests__/github-reporter.test.d.ts.map +1 -0
- package/dist/reporters/__tests__/github-reporter.test.js +93 -0
- package/dist/reporters/__tests__/github-reporter.test.js.map +1 -0
- package/dist/reporters/ci-gate.d.ts +27 -0
- package/dist/reporters/ci-gate.d.ts.map +1 -0
- package/dist/reporters/ci-gate.js +100 -0
- package/dist/reporters/ci-gate.js.map +1 -0
- package/dist/reporters/github.d.ts +36 -0
- package/dist/reporters/github.d.ts.map +1 -0
- package/dist/reporters/github.js +142 -0
- package/dist/reporters/github.js.map +1 -0
- package/dist/skills/bundled.d.ts +5 -0
- package/dist/skills/bundled.d.ts.map +1 -0
- package/dist/skills/bundled.js +34 -0
- package/dist/skills/bundled.js.map +1 -0
- package/dist/skills/commands/add.d.ts +1 -3
- package/dist/skills/commands/add.d.ts.map +1 -1
- package/dist/skills/commands/add.js +20 -3
- package/dist/skills/commands/add.js.map +1 -1
- package/dist/skills/tests/bundled.spec.d.ts +2 -0
- package/dist/skills/tests/bundled.spec.d.ts.map +1 -0
- package/dist/skills/tests/bundled.spec.js +24 -0
- package/dist/skills/tests/bundled.spec.js.map +1 -0
- package/dist/telemetry/__tests__/aggregator.test.d.ts +2 -0
- package/dist/telemetry/__tests__/aggregator.test.d.ts.map +1 -0
- package/dist/telemetry/__tests__/aggregator.test.js +164 -0
- package/dist/telemetry/__tests__/aggregator.test.js.map +1 -0
- package/dist/telemetry/aggregator.d.ts +43 -0
- package/dist/telemetry/aggregator.d.ts.map +1 -0
- package/dist/telemetry/aggregator.js +282 -0
- package/dist/telemetry/aggregator.js.map +1 -0
- package/dist/types/UpdateManifest.types.d.ts +1 -1
- package/dist/types/UpdateManifest.types.d.ts.map +1 -1
- package/dist/utils/dag-converter.js +1 -1
- package/dist/utils/dag-converter.js.map +1 -1
- package/dist/utils/excalidraw-renderer.d.ts.map +1 -1
- package/dist/utils/excalidraw-renderer.js +1 -0
- package/dist/utils/excalidraw-renderer.js.map +1 -1
- package/dist/utils/graph-renderer.d.ts +2 -0
- package/dist/utils/graph-renderer.d.ts.map +1 -1
- package/dist/utils/graph-renderer.js +188 -14
- package/dist/utils/graph-renderer.js.map +1 -1
- package/dist/utils/project-detector.d.ts +1 -0
- package/dist/utils/project-detector.d.ts.map +1 -1
- package/dist/utils/project-detector.js +8 -0
- package/dist/utils/project-detector.js.map +1 -1
- package/dist/utils/project-generator.d.ts +1 -1
- package/dist/utils/project-generator.d.ts.map +1 -1
- package/dist/utils/project-generator.js +23 -2
- package/dist/utils/project-generator.js.map +1 -1
- package/dist/utils/templates.d.ts +2 -0
- package/dist/utils/templates.d.ts.map +1 -1
- package/dist/utils/templates.js +74 -0
- package/dist/utils/templates.js.map +1 -1
- package/dist/verification/__tests__/decay-policy.test.js +1 -0
- package/dist/verification/__tests__/decay-policy.test.js.map +1 -1
- package/dist/verification/__tests__/safe-spawn.test.js +12 -0
- package/dist/verification/__tests__/safe-spawn.test.js.map +1 -1
- package/dist/verification/config.d.ts.map +1 -1
- package/dist/verification/config.js +2 -0
- package/dist/verification/config.js.map +1 -1
- package/dist/verification/types.d.ts +2 -0
- package/dist/verification/types.d.ts.map +1 -1
- package/package.json +3 -2
- package/skills/dare-ax/generator.ts +325 -0
- package/skills/dare-ax/index.ts +19 -0
- package/skills/dare-ax/metrics.ts +352 -0
- package/skills/dare-ax/package-lock.json +1855 -0
- package/skills/dare-ax/package.json +50 -0
- package/skills/dare-ax/secret-detector.ts +123 -0
- package/skills/dare-ax/skill.yml +19 -0
- package/skills/dare-ax/templates/llms.txt.jinja2 +80 -0
- package/skills/dare-ax/tests/generator.spec.ts +193 -0
- package/skills/dare-ax/tests/metrics.spec.ts +394 -0
- package/skills/dare-ax/tests/validator.spec.ts +298 -0
- package/skills/dare-ax/tsconfig.json +18 -0
- package/skills/dare-ax/types.ts +79 -0
- package/skills/dare-ax/validator.ts +238 -0
- package/skills/dare-frontend-design/generator.ts +616 -0
- package/skills/dare-frontend-design/index.ts +25 -0
- package/skills/dare-frontend-design/linter.ts +227 -0
- package/skills/dare-frontend-design/metrics.ts +82 -0
- package/skills/dare-frontend-design/package-lock.json +1855 -0
- package/skills/dare-frontend-design/package.json +43 -0
- package/skills/dare-frontend-design/skill.yml +20 -0
- package/skills/dare-frontend-design/tests/frontend_design.spec.ts +435 -0
- package/skills/dare-frontend-design/tsconfig.json +18 -0
- package/skills/dare-frontend-design/types.ts +62 -0
- package/skills/dare-layered-design/generator.ts +740 -0
- package/skills/dare-layered-design/index.ts +17 -0
- package/skills/dare-layered-design/linter.ts +462 -0
- package/skills/dare-layered-design/metrics.ts +409 -0
- package/skills/dare-layered-design/package-lock.json +1855 -0
- package/skills/dare-layered-design/package.json +50 -0
- package/skills/dare-layered-design/skill.yml +35 -0
- package/skills/dare-layered-design/tests/generator.spec.ts +156 -0
- package/skills/dare-layered-design/tests/linter.spec.ts +255 -0
- package/skills/dare-layered-design/tests/metrics.spec.ts +286 -0
- package/skills/dare-layered-design/tsconfig.json +18 -0
- package/skills/dare-layered-design/types.ts +48 -0
- package/skills/dare-llm-integration/cache/llm_cache.ts +122 -0
- package/skills/dare-llm-integration/index.ts +49 -0
- package/skills/dare-llm-integration/metrics.ts +107 -0
- package/skills/dare-llm-integration/package-lock.json +1855 -0
- package/skills/dare-llm-integration/package.json +49 -0
- package/skills/dare-llm-integration/prompts/prompt_loader.ts +258 -0
- package/skills/dare-llm-integration/providers/anthropic_provider.ts +159 -0
- package/skills/dare-llm-integration/providers/dummy_provider.ts +113 -0
- package/skills/dare-llm-integration/providers/llm_provider.ts +6 -0
- package/skills/dare-llm-integration/providers/openai_provider.ts +215 -0
- package/skills/dare-llm-integration/rate_limit/token_bucket.ts +86 -0
- package/skills/dare-llm-integration/skill.yml +23 -0
- package/skills/dare-llm-integration/tests/fixtures/greet_v1.jinja2 +1 -0
- package/skills/dare-llm-integration/tests/fixtures/summarize_v1.jinja2 +1 -0
- package/skills/dare-llm-integration/tests/fixtures/summarize_v2.jinja2 +3 -0
- package/skills/dare-llm-integration/tests/llm_integration.spec.ts +657 -0
- package/skills/dare-llm-integration/tsconfig.json +23 -0
- package/skills/dare-llm-integration/types.ts +91 -0
- package/skills/dare-llm-integration/validators/output_validator.ts +200 -0
- package/skills/dare-quality-telemetry/collect.ts +134 -0
- package/skills/dare-quality-telemetry/collectors/dare_ax_collector.ts +301 -0
- package/skills/dare-quality-telemetry/collectors/dare_layered_design_collector.ts +406 -0
- package/skills/dare-quality-telemetry/collectors/index.ts +24 -0
- package/skills/dare-quality-telemetry/github_actions_template.ts +25 -0
- package/skills/dare-quality-telemetry/index.ts +18 -0
- package/skills/dare-quality-telemetry/metrics.ts +137 -0
- package/skills/dare-quality-telemetry/package-lock.json +1855 -0
- package/skills/dare-quality-telemetry/package.json +48 -0
- package/skills/dare-quality-telemetry/regression.ts +60 -0
- package/skills/dare-quality-telemetry/reporter.ts +132 -0
- package/skills/dare-quality-telemetry/skill.yml +18 -0
- package/skills/dare-quality-telemetry/tests/quality_telemetry.spec.ts +885 -0
- package/skills/dare-quality-telemetry/tsconfig.json +19 -0
- package/skills/dare-quality-telemetry/types.ts +41 -0
- package/skills/dare-realtime/event_registry.ts +101 -0
- package/skills/dare-realtime/index.ts +30 -0
- package/skills/dare-realtime/metrics.ts +84 -0
- package/skills/dare-realtime/package-lock.json +1855 -0
- package/skills/dare-realtime/package.json +43 -0
- package/skills/dare-realtime/reconnect_strategy.ts +85 -0
- package/skills/dare-realtime/schema_validator.ts +80 -0
- package/skills/dare-realtime/skill.yml +21 -0
- package/skills/dare-realtime/subscription_manager.ts +106 -0
- package/skills/dare-realtime/tests/realtime.spec.ts +482 -0
- package/skills/dare-realtime/tsconfig.json +18 -0
- package/skills/dare-realtime/types.ts +51 -0
- package/templates/.github/workflows/dare-pr.yml +26 -0
- package/templates/dashboard/app.js +184 -0
- package/templates/dashboard/index.html +63 -0
- package/templates/dashboard/style.css +134 -0
- package/templates/ide/antigravity/.agents/skills/dare-ai/SKILL.md +17 -0
- package/templates/ide/antigravity/.agents/skills/dare-blueprint/SKILL.md +2 -0
- package/templates/ide/antigravity/.agents/skills/dare-dashboard/SKILL.md +18 -0
- package/templates/ide/antigravity/.agents/skills/dare-design/SKILL.md +2 -0
- package/templates/ide/antigravity/.agents/skills/dare-dna/SKILL.md +3 -0
- package/templates/ide/antigravity/.agents/skills/dare-migrate/SKILL.md +3 -0
- package/templates/ide/antigravity/.agents/skills/dare-patterns/SKILL.md +3 -0
- package/templates/ide/antigravity/.agents/skills/dare-refine/SKILL.md +3 -0
- package/templates/ide/antigravity/.agents/skills/dare-reverse/SKILL.md +3 -0
- package/templates/ide/antigravity/.agents/skills/dare-review/SKILL.md +3 -0
- package/templates/ide/claude/.claude/commands/dare-ai.md +17 -0
- package/templates/ide/claude/.claude/commands/dare-blueprint.md +2 -0
- package/templates/ide/claude/.claude/commands/dare-dashboard.md +18 -0
- package/templates/ide/claude/.claude/commands/dare-design.md +2 -0
- package/templates/ide/claude/.claude/commands/dare-dna.md +2 -0
- package/templates/ide/claude/.claude/commands/dare-migrate.md +2 -0
- package/templates/ide/claude/.claude/commands/dare-patterns.md +3 -0
- package/templates/ide/claude/.claude/commands/dare-refine.md +3 -0
- package/templates/ide/claude/.claude/commands/dare-reverse.md +2 -0
- package/templates/ide/claude/.claude/commands/dare-review.md +3 -0
- package/templates/ide/cursor/.cursor/commands/dare-ai.md +17 -0
- package/templates/ide/cursor/.cursor/commands/dare-blueprint.md +3 -0
- package/templates/ide/cursor/.cursor/commands/dare-dashboard.md +18 -0
- package/templates/ide/cursor/.cursor/commands/dare-design.md +3 -0
- package/templates/ide/cursor/.cursor/commands/dare-dna.md +2 -0
- package/templates/ide/cursor/.cursor/commands/dare-migrate.md +2 -0
- package/templates/ide/cursor/.cursor/commands/dare-patterns.md +3 -0
- package/templates/ide/cursor/.cursor/commands/dare-refine.md +3 -0
- package/templates/ide/cursor/.cursor/commands/dare-reverse.md +2 -0
- package/templates/ide/cursor/.cursor/commands/dare-review.md +3 -0
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { providerToDriverId } from './resolve.js';
|
|
2
|
+
export function capabilitiesForProvider(name) {
|
|
3
|
+
if (name === 'mock') {
|
|
4
|
+
return { enrichment: true, execution: true };
|
|
5
|
+
}
|
|
6
|
+
return {
|
|
7
|
+
enrichment: true,
|
|
8
|
+
execution: providerToDriverId(name) !== null,
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=capabilities.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"capabilities.js","sourceRoot":"","sources":["../../src/ai/capabilities.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAElD,MAAM,UAAU,uBAAuB,CAAC,IAAoB;IAC1D,IAAI,IAAI,KAAK,MAAM,EAAE,CAAC;QACpB,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;IAC/C,CAAC;IACD,OAAO;QACL,UAAU,EAAE,IAAI;QAChB,SAAS,EAAE,kBAAkB,CAAC,IAAI,CAAC,KAAK,IAAI;KAC7C,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Command } from 'commander';
|
|
2
|
+
import type { AiCommandOptions } from './types.js';
|
|
3
|
+
/** Shared CLI flags for heuristic + AI enrichment on DARE commands. */
|
|
4
|
+
export declare function addAiOptions(cmd: Command): Command;
|
|
5
|
+
export declare function aiOptionsFromFlags(flags: AiCommandOptions): {
|
|
6
|
+
enabled: boolean;
|
|
7
|
+
provider?: string;
|
|
8
|
+
json?: boolean;
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=command-options.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"command-options.d.ts","sourceRoot":"","sources":["../../src/ai/command-options.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEnD,uEAAuE;AACvE,wBAAgB,YAAY,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,CAQlD;AAED,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,gBAAgB,GAAG;IAC3D,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB,CAMA"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/** Shared CLI flags for heuristic + AI enrichment on DARE commands. */
|
|
2
|
+
export function addAiOptions(cmd) {
|
|
3
|
+
return cmd
|
|
4
|
+
.option('--ai', 'Run terminal AI enrichment after deterministic heuristics', false)
|
|
5
|
+
.option('--provider <name>', 'AI provider override (codex, claude-code, cursor-cli, antigravity-cli, mock)')
|
|
6
|
+
.option('--json', 'Emit structured EnrichmentResult JSON when --ai is used', false);
|
|
7
|
+
}
|
|
8
|
+
export function aiOptionsFromFlags(flags) {
|
|
9
|
+
return {
|
|
10
|
+
enabled: Boolean(flags.ai),
|
|
11
|
+
provider: flags.provider?.trim() || undefined,
|
|
12
|
+
json: Boolean(flags.json),
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=command-options.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"command-options.js","sourceRoot":"","sources":["../../src/ai/command-options.ts"],"names":[],"mappings":"AAGA,uEAAuE;AACvE,MAAM,UAAU,YAAY,CAAC,GAAY;IACvC,OAAO,GAAG;SACP,MAAM,CAAC,MAAM,EAAE,2DAA2D,EAAE,KAAK,CAAC;SAClF,MAAM,CACL,mBAAmB,EACnB,8EAA8E,CAC/E;SACA,MAAM,CAAC,QAAQ,EAAE,yDAAyD,EAAE,KAAK,CAAC,CAAC;AACxF,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,KAAuB;IAKxD,OAAO;QACL,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1B,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,SAAS;QAC7C,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC;KAC1B,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { AiProviderName } from './types.js';
|
|
2
|
+
import type { CodexApproval, CodexSandbox } from '../agent/drivers/codex.js';
|
|
3
|
+
export interface CodexProviderConfig {
|
|
4
|
+
readonly command?: string;
|
|
5
|
+
readonly model?: string;
|
|
6
|
+
readonly sandbox?: CodexSandbox;
|
|
7
|
+
readonly approval?: CodexApproval;
|
|
8
|
+
readonly timeoutSeconds?: number;
|
|
9
|
+
}
|
|
10
|
+
export interface ClaudeCodeProviderConfig {
|
|
11
|
+
readonly command?: string;
|
|
12
|
+
readonly model?: string;
|
|
13
|
+
readonly timeoutSeconds?: number;
|
|
14
|
+
}
|
|
15
|
+
export interface CliProviderConfig {
|
|
16
|
+
readonly command?: string;
|
|
17
|
+
readonly timeoutSeconds?: number;
|
|
18
|
+
}
|
|
19
|
+
export interface AiConfig {
|
|
20
|
+
readonly defaultProvider: AiProviderName;
|
|
21
|
+
readonly providers: Partial<Record<AiProviderName, CodexProviderConfig | ClaudeCodeProviderConfig | CliProviderConfig>>;
|
|
22
|
+
}
|
|
23
|
+
export declare function normalizeProviderName(raw: string | undefined): AiProviderName | null;
|
|
24
|
+
export declare function parseAiConfig(raw: Record<string, unknown>): AiConfig;
|
|
25
|
+
export declare function loadAiConfig(cwd: string): Promise<AiConfig>;
|
|
26
|
+
export declare function resolveProviderConfig<T extends Record<string, unknown>>(config: AiConfig, name: AiProviderName): T;
|
|
27
|
+
//# sourceMappingURL=config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/ai/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAG7E,MAAM,WAAW,mBAAmB;IAClC,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,OAAO,CAAC,EAAE,YAAY,CAAC;IAChC,QAAQ,CAAC,QAAQ,CAAC,EAAE,aAAa,CAAC;IAClC,QAAQ,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC;CAClC;AAED,MAAM,WAAW,wBAAwB;IACvC,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC;CAClC;AAED,MAAM,WAAW,iBAAiB;IAChC,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC;CAClC;AAED,MAAM,WAAW,QAAQ;IACvB,QAAQ,CAAC,eAAe,EAAE,cAAc,CAAC;IACzC,QAAQ,CAAC,SAAS,EAAE,OAAO,CACzB,MAAM,CACJ,cAAc,EACd,mBAAmB,GAAG,wBAAwB,GAAG,iBAAiB,CACnE,CACF,CAAC;CACH;AAkBD,wBAAgB,qBAAqB,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,GAAG,cAAc,GAAG,IAAI,CAGpF;AAED,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,QAAQ,CAsEpE;AAED,wBAAsB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC,CAOjE;AAED,wBAAgB,qBAAqB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACrE,MAAM,EAAE,QAAQ,EAChB,IAAI,EAAE,cAAc,GACnB,CAAC,CAGH"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { readProjectConfig } from '../utils/UpdateDetector.js';
|
|
2
|
+
const DEFAULT_PROVIDER = 'codex';
|
|
3
|
+
const PROVIDER_ALIASES = {
|
|
4
|
+
codex: 'codex',
|
|
5
|
+
'codex-cli': 'codex',
|
|
6
|
+
claude: 'claude-code',
|
|
7
|
+
'claude-code': 'claude-code',
|
|
8
|
+
'claude-cli': 'claude-code',
|
|
9
|
+
cursor: 'cursor-cli',
|
|
10
|
+
'cursor-cli': 'cursor-cli',
|
|
11
|
+
'cursor-agent': 'cursor-cli',
|
|
12
|
+
antigravity: 'antigravity-cli',
|
|
13
|
+
'antigravity-cli': 'antigravity-cli',
|
|
14
|
+
mock: 'mock',
|
|
15
|
+
};
|
|
16
|
+
export function normalizeProviderName(raw) {
|
|
17
|
+
if (!raw?.trim())
|
|
18
|
+
return null;
|
|
19
|
+
return PROVIDER_ALIASES[raw.trim().toLowerCase()] ?? null;
|
|
20
|
+
}
|
|
21
|
+
export function parseAiConfig(raw) {
|
|
22
|
+
const ai = typeof raw.ai === 'object' && raw.ai !== null
|
|
23
|
+
? raw.ai
|
|
24
|
+
: {};
|
|
25
|
+
const agent = typeof raw.agent === 'object' && raw.agent !== null
|
|
26
|
+
? raw.agent
|
|
27
|
+
: {};
|
|
28
|
+
const defaultRaw = typeof ai.defaultProvider === 'string'
|
|
29
|
+
? ai.defaultProvider
|
|
30
|
+
: typeof agent.provider === 'string'
|
|
31
|
+
? agent.provider
|
|
32
|
+
: typeof agent.driver === 'string'
|
|
33
|
+
? agent.driver
|
|
34
|
+
: undefined;
|
|
35
|
+
const defaultProvider = normalizeProviderName(defaultRaw) ?? DEFAULT_PROVIDER;
|
|
36
|
+
const providersBlock = typeof ai.providers === 'object' && ai.providers !== null
|
|
37
|
+
? ai.providers
|
|
38
|
+
: {};
|
|
39
|
+
const providers = {};
|
|
40
|
+
for (const [key, value] of Object.entries(providersBlock)) {
|
|
41
|
+
const name = normalizeProviderName(key);
|
|
42
|
+
if (!name || name === 'mock')
|
|
43
|
+
continue;
|
|
44
|
+
if (typeof value === 'object' && value !== null) {
|
|
45
|
+
providers[name] = value;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
// Back-compat: agent.codex / agent.command at root of agent block
|
|
49
|
+
if (!providers.codex && (agent.codex || agent.command || agent.sandbox)) {
|
|
50
|
+
const codex = typeof agent.codex === 'object' && agent.codex !== null
|
|
51
|
+
? agent.codex
|
|
52
|
+
: {};
|
|
53
|
+
providers.codex = {
|
|
54
|
+
command: typeof agent.command === 'string'
|
|
55
|
+
? agent.command
|
|
56
|
+
: typeof codex.command === 'string'
|
|
57
|
+
? codex.command
|
|
58
|
+
: undefined,
|
|
59
|
+
model: typeof agent.model === 'string' ? agent.model : undefined,
|
|
60
|
+
sandbox: typeof agent.sandbox === 'string'
|
|
61
|
+
? agent.sandbox
|
|
62
|
+
: typeof codex.sandbox === 'string'
|
|
63
|
+
? codex.sandbox
|
|
64
|
+
: undefined,
|
|
65
|
+
approval: typeof codex.approval === 'string'
|
|
66
|
+
? codex.approval
|
|
67
|
+
: undefined,
|
|
68
|
+
timeoutSeconds: typeof codex.timeoutSeconds === 'number' ? codex.timeoutSeconds : undefined,
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
if (!providers['claude-code'] && typeof agent.model === 'string') {
|
|
72
|
+
providers['claude-code'] = { model: agent.model };
|
|
73
|
+
}
|
|
74
|
+
return { defaultProvider, providers };
|
|
75
|
+
}
|
|
76
|
+
export async function loadAiConfig(cwd) {
|
|
77
|
+
try {
|
|
78
|
+
const raw = (await readProjectConfig(cwd));
|
|
79
|
+
return parseAiConfig(raw);
|
|
80
|
+
}
|
|
81
|
+
catch {
|
|
82
|
+
return parseAiConfig({});
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
export function resolveProviderConfig(config, name) {
|
|
86
|
+
const block = config.providers[name];
|
|
87
|
+
return (block ?? {});
|
|
88
|
+
}
|
|
89
|
+
//# sourceMappingURL=config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/ai/config.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { AiCommandName } from './types.js';
|
|
2
|
+
/** Terminal ↔ chat parity contract for semantic enrichment commands. */
|
|
3
|
+
export interface ParityContract {
|
|
4
|
+
readonly command: AiCommandName;
|
|
5
|
+
readonly skillSlug: string;
|
|
6
|
+
readonly terminal: string;
|
|
7
|
+
readonly artifacts: ReadonlyArray<string>;
|
|
8
|
+
readonly schemaFields: ReadonlyArray<string>;
|
|
9
|
+
}
|
|
10
|
+
export declare const PARITY_CONTRACTS: ReadonlyArray<ParityContract>;
|
|
11
|
+
export declare function parityFor(command: AiCommandName): ParityContract;
|
|
12
|
+
export declare const SEMANTIC_COMMANDS: ReadonlyArray<AiCommandName>;
|
|
13
|
+
//# sourceMappingURL=parity.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parity.d.ts","sourceRoot":"","sources":["../../src/ai/parity.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAEhD,wEAAwE;AACxE,MAAM,WAAW,cAAc;IAC7B,QAAQ,CAAC,OAAO,EAAE,aAAa,CAAC;IAChC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,SAAS,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;IAC1C,QAAQ,CAAC,YAAY,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;CAC9C;AAED,eAAO,MAAM,gBAAgB,EAAE,aAAa,CAAC,cAAc,CA4E1D,CAAC;AAMF,wBAAgB,SAAS,CAAC,OAAO,EAAE,aAAa,GAAG,cAAc,CAMhE;AAED,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAAC,aAAa,CAE1D,CAAC"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
export const PARITY_CONTRACTS = [
|
|
2
|
+
{
|
|
3
|
+
command: 'reverse',
|
|
4
|
+
skillSlug: '/dare-reverse',
|
|
5
|
+
terminal: 'dare reverse --ai',
|
|
6
|
+
artifacts: ['DARE/REVERSE/semantic-enrichment.json', 'DARE/IDEIA.md'],
|
|
7
|
+
schemaFields: [
|
|
8
|
+
'purpose',
|
|
9
|
+
'domainGlossary',
|
|
10
|
+
'mainFlowMermaid',
|
|
11
|
+
'openQuestions',
|
|
12
|
+
'modulePurposes',
|
|
13
|
+
'domainRules',
|
|
14
|
+
'stateMachinesMermaid',
|
|
15
|
+
'permissionsMarkdown',
|
|
16
|
+
'c4ContextMermaid',
|
|
17
|
+
'c4ContainerMermaid',
|
|
18
|
+
],
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
command: 'dna',
|
|
22
|
+
skillSlug: '/dare-dna',
|
|
23
|
+
terminal: 'dare dna --ai',
|
|
24
|
+
artifacts: ['DARE/dna-semantic.json', 'DARE/PROJECT-DNA.md'],
|
|
25
|
+
schemaFields: [
|
|
26
|
+
'namingNotes',
|
|
27
|
+
'architecturePattern',
|
|
28
|
+
'layerRules',
|
|
29
|
+
'testingStyle',
|
|
30
|
+
'errorHandling',
|
|
31
|
+
'goldenRules',
|
|
32
|
+
'ambiguities',
|
|
33
|
+
],
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
command: 'migrate',
|
|
37
|
+
skillSlug: '/dare-migrate',
|
|
38
|
+
terminal: 'dare migrate --ai',
|
|
39
|
+
artifacts: ['DARE/migrate-semantic.json', 'DARE/MIGRATION/MIGRATION.md'],
|
|
40
|
+
schemaFields: ['strategySummary', 'riskAreas', 'parityNotes', 'blockingGaps'],
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
command: 'design',
|
|
44
|
+
skillSlug: '/dare-design',
|
|
45
|
+
terminal: 'dare design "<description>" --ai',
|
|
46
|
+
artifacts: ['DARE/design-semantic.json', 'DARE/DESIGN.md'],
|
|
47
|
+
schemaFields: ['goals', 'constraints', 'successCriteria', 'userJourneys', 'openQuestions'],
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
command: 'patterns',
|
|
51
|
+
skillSlug: '/dare-patterns',
|
|
52
|
+
terminal: 'dare patterns --ai',
|
|
53
|
+
artifacts: ['DARE/patterns-semantic.json', 'DARE/PATTERNS.md'],
|
|
54
|
+
schemaFields: ['summary', 'recommendations', 'antiPatterns', 'injectionNotes'],
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
command: 'blueprint',
|
|
58
|
+
skillSlug: '/dare-blueprint',
|
|
59
|
+
terminal: 'dare blueprint --ai',
|
|
60
|
+
artifacts: ['DARE/blueprint-semantic.json', 'DARE/BLUEPRINT.md'],
|
|
61
|
+
schemaFields: ['architectureSummary', 'keyDecisions', 'risks', 'taskNotes'],
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
command: 'review',
|
|
65
|
+
skillSlug: '/dare-review',
|
|
66
|
+
terminal: 'dare review <task-id> --ai',
|
|
67
|
+
artifacts: ['DARE/review-semantic.json'],
|
|
68
|
+
schemaFields: ['passed', 'unmetCriteria', 'notes'],
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
command: 'refine',
|
|
72
|
+
skillSlug: '/dare-refine',
|
|
73
|
+
terminal: 'dare refine <task-id> --split --ai',
|
|
74
|
+
artifacts: ['DARE/refine-semantic.json'],
|
|
75
|
+
schemaFields: ['rationale', 'subtasks'],
|
|
76
|
+
},
|
|
77
|
+
];
|
|
78
|
+
const BY_COMMAND = new Map(PARITY_CONTRACTS.map((c) => [c.command, c]));
|
|
79
|
+
export function parityFor(command) {
|
|
80
|
+
const contract = BY_COMMAND.get(command);
|
|
81
|
+
if (!contract) {
|
|
82
|
+
throw new Error(`No parity contract for command: ${command}`);
|
|
83
|
+
}
|
|
84
|
+
return contract;
|
|
85
|
+
}
|
|
86
|
+
export const SEMANTIC_COMMANDS = PARITY_CONTRACTS.map((c) => c.command);
|
|
87
|
+
//# sourceMappingURL=parity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parity.js","sourceRoot":"","sources":["../../src/ai/parity.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parse-json-output.d.ts","sourceRoot":"","sources":["../../src/ai/parse-json-output.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAsBtD"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Extract JSON object from provider stdout (raw JSON or fenced code block).
|
|
3
|
+
*/
|
|
4
|
+
export function extractJsonObject(raw) {
|
|
5
|
+
const trimmed = raw.trim();
|
|
6
|
+
if (!trimmed)
|
|
7
|
+
throw new Error('empty provider output');
|
|
8
|
+
try {
|
|
9
|
+
return JSON.parse(trimmed);
|
|
10
|
+
}
|
|
11
|
+
catch {
|
|
12
|
+
// fall through
|
|
13
|
+
}
|
|
14
|
+
const fenceMatch = trimmed.match(/```(?:json)?\s*([\s\S]*?)```/i);
|
|
15
|
+
if (fenceMatch?.[1]) {
|
|
16
|
+
return JSON.parse(fenceMatch[1].trim());
|
|
17
|
+
}
|
|
18
|
+
const firstBrace = trimmed.indexOf('{');
|
|
19
|
+
const lastBrace = trimmed.lastIndexOf('}');
|
|
20
|
+
if (firstBrace >= 0 && lastBrace > firstBrace) {
|
|
21
|
+
return JSON.parse(trimmed.slice(firstBrace, lastBrace + 1));
|
|
22
|
+
}
|
|
23
|
+
throw new Error('provider output is not valid JSON');
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=parse-json-output.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parse-json-output.js","sourceRoot":"","sources":["../../src/ai/parse-json-output.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,UAAU,iBAAiB,CAAC,GAAW;IAC3C,MAAM,OAAO,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC;IAC3B,IAAI,CAAC,OAAO;QAAE,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;IAEvD,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;IAAC,MAAM,CAAC;QACP,eAAe;IACjB,CAAC;IAED,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,+BAA+B,CAAC,CAAC;IAClE,IAAI,UAAU,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACpB,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IAC1C,CAAC;IAED,MAAM,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IACxC,MAAM,SAAS,GAAG,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IAC3C,IAAI,UAAU,IAAI,CAAC,IAAI,SAAS,GAAG,UAAU,EAAE,CAAC;QAC9C,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,EAAE,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;AACvD,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { AiCommandName, EnrichmentResult } from './types.js';
|
|
2
|
+
export declare function runCommandEnrichment(args: {
|
|
3
|
+
command: AiCommandName;
|
|
4
|
+
cwd: string;
|
|
5
|
+
facts: unknown;
|
|
6
|
+
provider?: string;
|
|
7
|
+
deep?: boolean;
|
|
8
|
+
extra?: string;
|
|
9
|
+
}): Promise<EnrichmentResult>;
|
|
10
|
+
export declare function maybeRunAiEnrichment(args: {
|
|
11
|
+
enabled: boolean;
|
|
12
|
+
provider?: string;
|
|
13
|
+
command: AiCommandName;
|
|
14
|
+
cwd: string;
|
|
15
|
+
facts: unknown;
|
|
16
|
+
deep?: boolean;
|
|
17
|
+
extra?: string;
|
|
18
|
+
json?: boolean;
|
|
19
|
+
}): Promise<EnrichmentResult | null>;
|
|
20
|
+
//# sourceMappingURL=pipeline.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pipeline.d.ts","sourceRoot":"","sources":["../../src/ai/pipeline.ts"],"names":[],"mappings":"AAoBA,OAAO,KAAK,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAqBlE,wBAAsB,oBAAoB,CAAC,IAAI,EAAE;IAC/C,OAAO,EAAE,aAAa,CAAC;IACvB,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,OAAO,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,GAAG,OAAO,CAAC,gBAAgB,CAAC,CA4C5B;AAgTD,wBAAsB,oBAAoB,CAAC,IAAI,EAAE;IAC/C,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,aAAa,CAAC;IACvB,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,OAAO,CAAC;IACf,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB,GAAG,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC,CA0BnC"}
|