@contractspec/bundle.workspace 1.46.2 → 1.48.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/dist/_virtual/rolldown_runtime.mjs +20 -0
- package/dist/adapters/ai.d.mts +12 -0
- package/dist/adapters/ai.d.mts.map +1 -0
- package/dist/adapters/ai.mjs +83 -0
- package/dist/adapters/ai.mjs.map +1 -0
- package/dist/adapters/factory.d.mts +29 -0
- package/dist/adapters/factory.d.mts.map +1 -0
- package/dist/adapters/factory.mjs +37 -0
- package/dist/adapters/factory.mjs.map +1 -0
- package/dist/adapters/fs.d.mts +12 -0
- package/dist/adapters/fs.d.mts.map +1 -0
- package/dist/adapters/fs.mjs +133 -0
- package/dist/adapters/fs.mjs.map +1 -0
- package/dist/adapters/git.d.mts +11 -0
- package/dist/adapters/git.d.mts.map +1 -0
- package/dist/adapters/git.mjs +84 -0
- package/dist/adapters/git.mjs.map +1 -0
- package/dist/adapters/index.d.mts +7 -0
- package/dist/adapters/index.mjs +9 -0
- package/dist/adapters/logger.d.mts +18 -0
- package/dist/adapters/logger.d.mts.map +1 -0
- package/dist/adapters/logger.mjs +81 -0
- package/dist/adapters/logger.mjs.map +1 -0
- package/dist/adapters/watcher.d.mts +11 -0
- package/dist/adapters/watcher.d.mts.map +1 -0
- package/dist/adapters/watcher.mjs +74 -0
- package/dist/adapters/watcher.mjs.map +1 -0
- package/dist/adapters/workspace.d.mts +148 -0
- package/dist/adapters/workspace.d.mts.map +1 -0
- package/dist/adapters/workspace.mjs +275 -0
- package/dist/adapters/workspace.mjs.map +1 -0
- package/dist/ai/agents/claude-code-agent.d.mts +22 -0
- package/dist/ai/agents/claude-code-agent.d.mts.map +1 -0
- package/dist/ai/agents/claude-code-agent.mjs +182 -0
- package/dist/ai/agents/claude-code-agent.mjs.map +1 -0
- package/dist/ai/agents/cursor-agent.d.mts +68 -0
- package/dist/ai/agents/cursor-agent.d.mts.map +1 -0
- package/dist/ai/agents/cursor-agent.mjs +436 -0
- package/dist/ai/agents/cursor-agent.mjs.map +1 -0
- package/dist/ai/agents/index.mjs +7 -0
- package/dist/ai/agents/openai-codex-agent.d.mts +22 -0
- package/dist/ai/agents/openai-codex-agent.d.mts.map +1 -0
- package/dist/ai/agents/openai-codex-agent.mjs +167 -0
- package/dist/ai/agents/openai-codex-agent.mjs.map +1 -0
- package/dist/ai/agents/orchestrator.d.mts +50 -0
- package/dist/ai/agents/orchestrator.d.mts.map +1 -0
- package/dist/ai/agents/orchestrator.mjs +143 -0
- package/dist/ai/agents/orchestrator.mjs.map +1 -0
- package/dist/ai/agents/simple-agent.d.mts +17 -0
- package/dist/ai/agents/simple-agent.d.mts.map +1 -0
- package/dist/ai/agents/simple-agent.mjs +92 -0
- package/dist/ai/agents/simple-agent.mjs.map +1 -0
- package/dist/ai/agents/types.d.mts +36 -0
- package/dist/ai/agents/types.d.mts.map +1 -0
- package/dist/ai/client.d.mts +97 -0
- package/dist/ai/client.d.mts.map +1 -0
- package/dist/ai/client.mjs +189 -0
- package/dist/ai/client.mjs.map +1 -0
- package/dist/ai/index.d.mts +9 -0
- package/dist/ai/index.mjs +11 -0
- package/dist/ai/prompts/code-generation.d.mts +26 -0
- package/dist/ai/prompts/code-generation.d.mts.map +1 -0
- package/dist/ai/prompts/code-generation.mjs +143 -0
- package/dist/ai/prompts/code-generation.mjs.map +1 -0
- package/dist/ai/prompts/index.d.mts +10 -0
- package/dist/ai/prompts/index.d.mts.map +1 -0
- package/dist/ai/prompts/index.mjs +13 -0
- package/dist/ai/prompts/index.mjs.map +1 -0
- package/dist/ai/prompts/spec-creation.d.mts +29 -0
- package/dist/ai/prompts/spec-creation.d.mts.map +1 -0
- package/dist/ai/prompts/spec-creation.mjs +111 -0
- package/dist/ai/prompts/spec-creation.mjs.map +1 -0
- package/dist/ai/providers.d.mts +29 -0
- package/dist/ai/providers.d.mts.map +1 -0
- package/dist/ai/providers.mjs +39 -0
- package/dist/ai/providers.mjs.map +1 -0
- package/dist/formatters/index.d.mts +11 -0
- package/dist/formatters/index.d.mts.map +1 -0
- package/dist/formatters/index.mjs +17 -0
- package/dist/formatters/index.mjs.map +1 -0
- package/dist/formatters/json.d.mts +56 -0
- package/dist/formatters/json.d.mts.map +1 -0
- package/dist/formatters/json.mjs +43 -0
- package/dist/formatters/json.mjs.map +1 -0
- package/dist/formatters/sarif.d.mts +101 -0
- package/dist/formatters/sarif.d.mts.map +1 -0
- package/dist/formatters/sarif.mjs +163 -0
- package/dist/formatters/sarif.mjs.map +1 -0
- package/dist/formatters/text.d.mts +35 -0
- package/dist/formatters/text.d.mts.map +1 -0
- package/dist/formatters/text.mjs +209 -0
- package/dist/formatters/text.mjs.map +1 -0
- package/dist/index.d.mts +128 -0
- package/dist/index.mjs +113 -0
- package/dist/ports/ai.d.mts +59 -0
- package/dist/ports/ai.d.mts.map +1 -0
- package/dist/ports/fs.d.mts +81 -0
- package/dist/ports/fs.d.mts.map +1 -0
- package/dist/ports/git.d.mts +46 -0
- package/dist/ports/git.d.mts.map +1 -0
- package/dist/ports/index.d.mts +6 -0
- package/dist/ports/logger.d.mts +88 -0
- package/dist/ports/logger.d.mts.map +1 -0
- package/dist/ports/rulesync.d.mts +38 -0
- package/dist/ports/rulesync.d.mts.map +1 -0
- package/dist/ports/watcher.d.mts +52 -0
- package/dist/ports/watcher.d.mts.map +1 -0
- package/dist/services/agent-guide/adapters/claude-code.d.mts +35 -0
- package/dist/services/agent-guide/adapters/claude-code.d.mts.map +1 -0
- package/dist/services/agent-guide/adapters/claude-code.mjs +144 -0
- package/dist/services/agent-guide/adapters/claude-code.mjs.map +1 -0
- package/dist/services/agent-guide/adapters/cursor-cli.d.mts +39 -0
- package/dist/services/agent-guide/adapters/cursor-cli.d.mts.map +1 -0
- package/dist/services/agent-guide/adapters/cursor-cli.mjs +135 -0
- package/dist/services/agent-guide/adapters/cursor-cli.mjs.map +1 -0
- package/dist/services/agent-guide/adapters/generic-mcp.d.mts +53 -0
- package/dist/services/agent-guide/adapters/generic-mcp.d.mts.map +1 -0
- package/dist/services/agent-guide/adapters/generic-mcp.mjs +159 -0
- package/dist/services/agent-guide/adapters/generic-mcp.mjs.map +1 -0
- package/dist/services/agent-guide/adapters/index.d.mts +23 -0
- package/dist/services/agent-guide/adapters/index.d.mts.map +1 -0
- package/dist/services/agent-guide/adapters/index.mjs +31 -0
- package/dist/services/agent-guide/adapters/index.mjs.map +1 -0
- package/dist/services/agent-guide/agent-guide-service.d.mts +56 -0
- package/dist/services/agent-guide/agent-guide-service.d.mts.map +1 -0
- package/dist/services/agent-guide/agent-guide-service.mjs +147 -0
- package/dist/services/agent-guide/agent-guide-service.mjs.map +1 -0
- package/dist/services/agent-guide/index.d.mts +6 -0
- package/dist/services/agent-guide/index.mjs +7 -0
- package/dist/services/agent-guide/types.d.mts +58 -0
- package/dist/services/agent-guide/types.d.mts.map +1 -0
- package/dist/services/build.d.mts +61 -0
- package/dist/services/build.d.mts.map +1 -0
- package/dist/services/build.mjs +151 -0
- package/dist/services/build.mjs.map +1 -0
- package/dist/services/ci-check/checks/coverage.mjs +77 -0
- package/dist/services/ci-check/checks/coverage.mjs.map +1 -0
- package/dist/services/ci-check/checks/deps.mjs +32 -0
- package/dist/services/ci-check/checks/deps.mjs.map +1 -0
- package/dist/services/ci-check/checks/doctor.mjs +38 -0
- package/dist/services/ci-check/checks/doctor.mjs.map +1 -0
- package/dist/services/ci-check/checks/drift.mjs +40 -0
- package/dist/services/ci-check/checks/drift.mjs.map +1 -0
- package/dist/services/ci-check/checks/handlers.mjs +38 -0
- package/dist/services/ci-check/checks/handlers.mjs.map +1 -0
- package/dist/services/ci-check/checks/implementation.mjs +73 -0
- package/dist/services/ci-check/checks/implementation.mjs.map +1 -0
- package/dist/services/ci-check/checks/index.mjs +13 -0
- package/dist/services/ci-check/checks/integrity.mjs +31 -0
- package/dist/services/ci-check/checks/integrity.mjs.map +1 -0
- package/dist/services/ci-check/checks/layers.mjs +66 -0
- package/dist/services/ci-check/checks/layers.mjs.map +1 -0
- package/dist/services/ci-check/checks/structure.mjs +35 -0
- package/dist/services/ci-check/checks/structure.mjs.map +1 -0
- package/dist/services/ci-check/checks/test-refs.mjs +63 -0
- package/dist/services/ci-check/checks/test-refs.mjs.map +1 -0
- package/dist/services/ci-check/checks/tests.mjs +38 -0
- package/dist/services/ci-check/checks/tests.mjs.map +1 -0
- package/dist/services/ci-check/ci-check-service.d.mts +16 -0
- package/dist/services/ci-check/ci-check-service.d.mts.map +1 -0
- package/dist/services/ci-check/ci-check-service.mjs +129 -0
- package/dist/services/ci-check/ci-check-service.mjs.map +1 -0
- package/dist/services/ci-check/index.d.mts +2 -0
- package/dist/services/ci-check/index.mjs +4 -0
- package/dist/services/ci-check/types.d.mts +147 -0
- package/dist/services/ci-check/types.d.mts.map +1 -0
- package/dist/services/ci-check/types.mjs +37 -0
- package/dist/services/ci-check/types.mjs.map +1 -0
- package/dist/services/ci-check/utils.mjs +76 -0
- package/dist/services/ci-check/utils.mjs.map +1 -0
- package/dist/services/clean.d.mts +41 -0
- package/dist/services/clean.d.mts.map +1 -0
- package/dist/services/clean.mjs +72 -0
- package/dist/services/clean.mjs.map +1 -0
- package/dist/services/config.d.mts +16 -0
- package/dist/services/config.d.mts.map +1 -0
- package/dist/services/config.mjs +63 -0
- package/dist/services/config.mjs.map +1 -0
- package/dist/services/coverage/parsers/index.mjs +34 -0
- package/dist/services/coverage/parsers/index.mjs.map +1 -0
- package/dist/services/coverage/parsers/istanbul-parser.mjs +108 -0
- package/dist/services/coverage/parsers/istanbul-parser.mjs.map +1 -0
- package/dist/services/coverage/validator.mjs +55 -0
- package/dist/services/coverage/validator.mjs.map +1 -0
- package/dist/services/create/ai-generator.d.mts +84 -0
- package/dist/services/create/ai-generator.d.mts.map +1 -0
- package/dist/services/create/ai-generator.mjs +178 -0
- package/dist/services/create/ai-generator.mjs.map +1 -0
- package/dist/services/create/index.d.mts +28 -0
- package/dist/services/create/index.d.mts.map +1 -0
- package/dist/services/create/index.mjs +37 -0
- package/dist/services/create/index.mjs.map +1 -0
- package/dist/services/create/templates.d.mts +22 -0
- package/dist/services/create/templates.d.mts.map +1 -0
- package/dist/services/create/templates.mjs +39 -0
- package/dist/services/create/templates.mjs.map +1 -0
- package/dist/services/deps.d.mts +53 -0
- package/dist/services/deps.d.mts.map +1 -0
- package/dist/services/deps.mjs +62 -0
- package/dist/services/deps.mjs.map +1 -0
- package/dist/services/diff.d.mts +34 -0
- package/dist/services/diff.d.mts.map +1 -0
- package/dist/services/diff.mjs +34 -0
- package/dist/services/diff.mjs.map +1 -0
- package/dist/services/docs/docs-service.d.mts +20 -0
- package/dist/services/docs/docs-service.d.mts.map +1 -0
- package/dist/services/docs/docs-service.mjs +59 -0
- package/dist/services/docs/docs-service.mjs.map +1 -0
- package/dist/services/docs/index.d.mts +1 -0
- package/dist/services/docs/index.mjs +3 -0
- package/dist/services/doctor/checks/ai.mjs +119 -0
- package/dist/services/doctor/checks/ai.mjs.map +1 -0
- package/dist/services/doctor/checks/cli.mjs +156 -0
- package/dist/services/doctor/checks/cli.mjs.map +1 -0
- package/dist/services/doctor/checks/config.mjs +303 -0
- package/dist/services/doctor/checks/config.mjs.map +1 -0
- package/dist/services/doctor/checks/deps.mjs +267 -0
- package/dist/services/doctor/checks/deps.mjs.map +1 -0
- package/dist/services/doctor/checks/index.mjs +9 -0
- package/dist/services/doctor/checks/layers.mjs +139 -0
- package/dist/services/doctor/checks/layers.mjs.map +1 -0
- package/dist/services/doctor/checks/mcp.mjs +145 -0
- package/dist/services/doctor/checks/mcp.mjs.map +1 -0
- package/dist/services/doctor/checks/workspace.mjs +263 -0
- package/dist/services/doctor/checks/workspace.mjs.map +1 -0
- package/dist/services/doctor/doctor-service.d.mts +24 -0
- package/dist/services/doctor/doctor-service.d.mts.map +1 -0
- package/dist/services/doctor/doctor-service.mjs +118 -0
- package/dist/services/doctor/doctor-service.mjs.map +1 -0
- package/dist/services/doctor/index.d.mts +2 -0
- package/dist/services/doctor/index.mjs +4 -0
- package/dist/services/doctor/types.d.mts +118 -0
- package/dist/services/doctor/types.d.mts.map +1 -0
- package/dist/services/doctor/types.mjs +29 -0
- package/dist/services/doctor/types.mjs.map +1 -0
- package/dist/services/drift.mjs +73 -0
- package/dist/services/drift.mjs.map +1 -0
- package/dist/services/extract.d.mts +12 -0
- package/dist/services/extract.d.mts.map +1 -0
- package/dist/services/extract.mjs +33 -0
- package/dist/services/extract.mjs.map +1 -0
- package/dist/services/features/completion.d.mts +21 -0
- package/dist/services/features/completion.d.mts.map +1 -0
- package/dist/services/features/completion.mjs +70 -0
- package/dist/services/features/completion.mjs.map +1 -0
- package/dist/services/features/feature-editor.d.mts +27 -0
- package/dist/services/features/feature-editor.d.mts.map +1 -0
- package/dist/services/features/feature-editor.mjs +37 -0
- package/dist/services/features/feature-editor.mjs.map +1 -0
- package/dist/services/features/index.d.mts +11 -0
- package/dist/services/features/index.d.mts.map +1 -0
- package/dist/services/features/index.mjs +16 -0
- package/dist/services/features/index.mjs.map +1 -0
- package/dist/services/features/validation.d.mts +21 -0
- package/dist/services/features/validation.d.mts.map +1 -0
- package/dist/services/features/validation.mjs +27 -0
- package/dist/services/features/validation.mjs.map +1 -0
- package/dist/services/fix/fix-link-formatter.d.mts +12 -0
- package/dist/services/fix/fix-link-formatter.d.mts.map +1 -0
- package/dist/services/fix/fix-link-formatter.mjs +38 -0
- package/dist/services/fix/fix-link-formatter.mjs.map +1 -0
- package/dist/services/fix/fix-service.d.mts +74 -0
- package/dist/services/fix/fix-service.d.mts.map +1 -0
- package/dist/services/fix/fix-service.mjs +169 -0
- package/dist/services/fix/fix-service.mjs.map +1 -0
- package/dist/services/fix/index.d.mts +16 -0
- package/dist/services/fix/index.d.mts.map +1 -0
- package/dist/services/fix/index.mjs +24 -0
- package/dist/services/fix/index.mjs.map +1 -0
- package/dist/services/fix/path-resolver.mjs +83 -0
- package/dist/services/fix/path-resolver.mjs.map +1 -0
- package/dist/services/fix/schemas.d.mts +17 -0
- package/dist/services/fix/schemas.d.mts.map +1 -0
- package/dist/services/fix/schemas.mjs +12 -0
- package/dist/services/fix/schemas.mjs.map +1 -0
- package/dist/services/fix/strategies/implement-ai.d.mts +18 -0
- package/dist/services/fix/strategies/implement-ai.d.mts.map +1 -0
- package/dist/services/fix/strategies/implement-ai.mjs +139 -0
- package/dist/services/fix/strategies/implement-ai.mjs.map +1 -0
- package/dist/services/fix/strategies/implement-skeleton.d.mts +14 -0
- package/dist/services/fix/strategies/implement-skeleton.d.mts.map +1 -0
- package/dist/services/fix/strategies/implement-skeleton.mjs +77 -0
- package/dist/services/fix/strategies/implement-skeleton.mjs.map +1 -0
- package/dist/services/fix/strategies/index.d.mts +3 -0
- package/dist/services/fix/strategies/remove-reference.d.mts +17 -0
- package/dist/services/fix/strategies/remove-reference.d.mts.map +1 -0
- package/dist/services/fix/strategies/remove-reference.mjs +98 -0
- package/dist/services/fix/strategies/remove-reference.mjs.map +1 -0
- package/dist/services/fix/types.d.mts +207 -0
- package/dist/services/fix/types.d.mts.map +1 -0
- package/dist/services/fix/types.mjs +20 -0
- package/dist/services/fix/types.mjs.map +1 -0
- package/dist/services/formatter.d.mts +15 -0
- package/dist/services/formatter.d.mts.map +1 -0
- package/dist/services/formatter.mjs +26 -0
- package/dist/services/formatter.mjs.map +1 -0
- package/dist/services/gap.d.mts +18 -0
- package/dist/services/gap.d.mts.map +1 -0
- package/dist/services/gap.mjs +44 -0
- package/dist/services/gap.mjs.map +1 -0
- package/dist/services/generate-artifacts.d.mts +11 -0
- package/dist/services/generate-artifacts.d.mts.map +1 -0
- package/dist/services/generate-artifacts.mjs +27 -0
- package/dist/services/generate-artifacts.mjs.map +1 -0
- package/dist/services/hooks/hooks-service.d.mts +24 -0
- package/dist/services/hooks/hooks-service.d.mts.map +1 -0
- package/dist/services/hooks/hooks-service.mjs +126 -0
- package/dist/services/hooks/hooks-service.mjs.map +1 -0
- package/dist/services/hooks/index.d.mts +10 -0
- package/dist/services/hooks/index.d.mts.map +1 -0
- package/dist/services/hooks/index.mjs +12 -0
- package/dist/services/hooks/index.mjs.map +1 -0
- package/dist/services/hooks/types.d.mts +56 -0
- package/dist/services/hooks/types.d.mts.map +1 -0
- package/dist/services/impact/formatters.d.mts +27 -0
- package/dist/services/impact/formatters.d.mts.map +1 -0
- package/dist/services/impact/formatters.mjs +139 -0
- package/dist/services/impact/formatters.mjs.map +1 -0
- package/dist/services/impact/impact-detection-service.d.mts +22 -0
- package/dist/services/impact/impact-detection-service.d.mts.map +1 -0
- package/dist/services/impact/impact-detection-service.mjs +96 -0
- package/dist/services/impact/impact-detection-service.mjs.map +1 -0
- package/dist/services/impact/index.d.mts +11 -0
- package/dist/services/impact/index.d.mts.map +1 -0
- package/dist/services/impact/index.mjs +16 -0
- package/dist/services/impact/index.mjs.map +1 -0
- package/dist/services/impact/types.d.mts +63 -0
- package/dist/services/impact/types.d.mts.map +1 -0
- package/dist/services/implementation/discovery.d.mts +30 -0
- package/dist/services/implementation/discovery.d.mts.map +1 -0
- package/dist/services/implementation/discovery.mjs +144 -0
- package/dist/services/implementation/discovery.mjs.map +1 -0
- package/dist/services/implementation/index.d.mts +6 -0
- package/dist/services/implementation/index.mjs +7 -0
- package/dist/services/implementation/resolver/conventions.d.mts +18 -0
- package/dist/services/implementation/resolver/conventions.d.mts.map +1 -0
- package/dist/services/implementation/resolver/conventions.mjs +59 -0
- package/dist/services/implementation/resolver/conventions.mjs.map +1 -0
- package/dist/services/implementation/resolver/index.d.mts +24 -0
- package/dist/services/implementation/resolver/index.d.mts.map +1 -0
- package/dist/services/implementation/resolver/index.mjs +111 -0
- package/dist/services/implementation/resolver/index.mjs.map +1 -0
- package/dist/services/implementation/resolver/parsers.d.mts +16 -0
- package/dist/services/implementation/resolver/parsers.d.mts.map +1 -0
- package/dist/services/implementation/resolver/parsers.mjs +100 -0
- package/dist/services/implementation/resolver/parsers.mjs.map +1 -0
- package/dist/services/implementation/resolver/status.d.mts +21 -0
- package/dist/services/implementation/resolver/status.d.mts.map +1 -0
- package/dist/services/implementation/resolver/status.mjs +31 -0
- package/dist/services/implementation/resolver/status.mjs.map +1 -0
- package/dist/services/implementation/types.d.mts +89 -0
- package/dist/services/implementation/types.d.mts.map +1 -0
- package/dist/services/import/import-service.d.mts +47 -0
- package/dist/services/import/import-service.d.mts.map +1 -0
- package/dist/services/import/import-service.mjs +196 -0
- package/dist/services/import/import-service.mjs.map +1 -0
- package/dist/services/import/index.d.mts +3 -0
- package/dist/services/import/index.mjs +5 -0
- package/dist/services/import/report-service.d.mts +31 -0
- package/dist/services/import/report-service.d.mts.map +1 -0
- package/dist/services/import/report-service.mjs +124 -0
- package/dist/services/import/report-service.mjs.map +1 -0
- package/dist/services/import/verify-service.d.mts +67 -0
- package/dist/services/import/verify-service.d.mts.map +1 -0
- package/dist/services/import/verify-service.mjs +105 -0
- package/dist/services/import/verify-service.mjs.map +1 -0
- package/dist/services/index.d.mts +107 -0
- package/dist/services/index.mjs +104 -0
- package/dist/services/integrity-diagram.d.mts +36 -0
- package/dist/services/integrity-diagram.d.mts.map +1 -0
- package/dist/services/integrity-diagram.mjs +275 -0
- package/dist/services/integrity-diagram.mjs.map +1 -0
- package/dist/services/integrity.d.mts +152 -0
- package/dist/services/integrity.d.mts.map +1 -0
- package/dist/services/integrity.mjs +361 -0
- package/dist/services/integrity.mjs.map +1 -0
- package/dist/services/layer-discovery.d.mts +77 -0
- package/dist/services/layer-discovery.d.mts.map +1 -0
- package/dist/services/layer-discovery.mjs +121 -0
- package/dist/services/layer-discovery.mjs.map +1 -0
- package/dist/services/list.d.mts +37 -0
- package/dist/services/list.d.mts.map +1 -0
- package/dist/services/list.mjs +46 -0
- package/dist/services/list.mjs.map +1 -0
- package/dist/services/llm/index.d.mts +28 -0
- package/dist/services/llm/index.d.mts.map +1 -0
- package/dist/services/llm/index.mjs +187 -0
- package/dist/services/llm/index.mjs.map +1 -0
- package/dist/services/llm/verify-static.d.mts +26 -0
- package/dist/services/llm/verify-static.d.mts.map +1 -0
- package/dist/services/llm/verify-static.mjs +82 -0
- package/dist/services/llm/verify-static.mjs.map +1 -0
- package/dist/services/modules/module-resolver.mjs +61 -0
- package/dist/services/modules/module-resolver.mjs.map +1 -0
- package/dist/services/openapi/export-service.d.mts +53 -0
- package/dist/services/openapi/export-service.d.mts.map +1 -0
- package/dist/services/openapi/export-service.mjs +50 -0
- package/dist/services/openapi/export-service.mjs.map +1 -0
- package/dist/services/openapi/import-service.d.mts +17 -0
- package/dist/services/openapi/import-service.d.mts.map +1 -0
- package/dist/services/openapi/import-service.mjs +165 -0
- package/dist/services/openapi/import-service.mjs.map +1 -0
- package/dist/services/openapi/index.d.mts +5 -0
- package/dist/services/openapi/index.mjs +6 -0
- package/dist/services/openapi/sync-service.d.mts +17 -0
- package/dist/services/openapi/sync-service.d.mts.map +1 -0
- package/dist/services/openapi/sync-service.mjs +120 -0
- package/dist/services/openapi/sync-service.mjs.map +1 -0
- package/dist/services/openapi/types.d.mts +162 -0
- package/dist/services/openapi/types.d.mts.map +1 -0
- package/dist/services/openapi/validate-service.d.mts +16 -0
- package/dist/services/openapi/validate-service.d.mts.map +1 -0
- package/dist/services/openapi/validate-service.mjs +130 -0
- package/dist/services/openapi/validate-service.mjs.map +1 -0
- package/dist/services/quickstart/dependencies.d.mts +31 -0
- package/dist/services/quickstart/dependencies.d.mts.map +1 -0
- package/dist/services/quickstart/dependencies.mjs +57 -0
- package/dist/services/quickstart/dependencies.mjs.map +1 -0
- package/dist/services/quickstart/index.mjs +4 -0
- package/dist/services/quickstart/quickstart-service.d.mts +20 -0
- package/dist/services/quickstart/quickstart-service.d.mts.map +1 -0
- package/dist/services/quickstart/quickstart-service.mjs +196 -0
- package/dist/services/quickstart/quickstart-service.mjs.map +1 -0
- package/dist/services/quickstart/types.d.mts +81 -0
- package/dist/services/quickstart/types.d.mts.map +1 -0
- package/dist/services/regenerator.d.mts +18 -0
- package/dist/services/regenerator.d.mts.map +1 -0
- package/dist/services/regenerator.mjs +23 -0
- package/dist/services/regenerator.mjs.map +1 -0
- package/dist/services/registry.d.mts +53 -0
- package/dist/services/registry.d.mts.map +1 -0
- package/dist/services/registry.mjs +74 -0
- package/dist/services/registry.mjs.map +1 -0
- package/dist/services/rulesync.d.mts +17 -0
- package/dist/services/rulesync.d.mts.map +1 -0
- package/dist/services/rulesync.mjs +72 -0
- package/dist/services/rulesync.mjs.map +1 -0
- package/dist/services/setup/config-generators.d.mts +42 -0
- package/dist/services/setup/config-generators.d.mts.map +1 -0
- package/dist/services/setup/config-generators.mjs +252 -0
- package/dist/services/setup/config-generators.mjs.map +1 -0
- package/dist/services/setup/file-merger.d.mts +27 -0
- package/dist/services/setup/file-merger.d.mts.map +1 -0
- package/dist/services/setup/file-merger.mjs +61 -0
- package/dist/services/setup/file-merger.mjs.map +1 -0
- package/dist/services/setup/setup-service.d.mts +12 -0
- package/dist/services/setup/setup-service.d.mts.map +1 -0
- package/dist/services/setup/setup-service.mjs +96 -0
- package/dist/services/setup/setup-service.mjs.map +1 -0
- package/dist/services/setup/targets/agents-md.mjs +47 -0
- package/dist/services/setup/targets/agents-md.mjs.map +1 -0
- package/dist/services/setup/targets/cli-config.mjs +60 -0
- package/dist/services/setup/targets/cli-config.mjs.map +1 -0
- package/dist/services/setup/targets/cursor-rules.mjs +48 -0
- package/dist/services/setup/targets/cursor-rules.mjs.map +1 -0
- package/dist/services/setup/targets/mcp-claude.mjs +60 -0
- package/dist/services/setup/targets/mcp-claude.mjs.map +1 -0
- package/dist/services/setup/targets/mcp-cursor.mjs +59 -0
- package/dist/services/setup/targets/mcp-cursor.mjs.map +1 -0
- package/dist/services/setup/targets/vscode-settings.mjs +63 -0
- package/dist/services/setup/targets/vscode-settings.mjs.map +1 -0
- package/dist/services/setup/types.d.mts +85 -0
- package/dist/services/setup/types.d.mts.map +1 -0
- package/dist/services/setup/types.mjs +27 -0
- package/dist/services/setup/types.mjs.map +1 -0
- package/dist/services/sync.d.mts +42 -0
- package/dist/services/sync.d.mts.map +1 -0
- package/dist/services/sync.mjs +64 -0
- package/dist/services/sync.mjs.map +1 -0
- package/dist/services/test/index.d.mts +2 -0
- package/dist/services/test/index.mjs +4 -0
- package/dist/services/test/test-generator-service.d.mts +24 -0
- package/dist/services/test/test-generator-service.d.mts.map +1 -0
- package/dist/services/test/test-generator-service.mjs +92 -0
- package/dist/services/test/test-generator-service.mjs.map +1 -0
- package/dist/services/test/test-service.d.mts +27 -0
- package/dist/services/test/test-service.d.mts.map +1 -0
- package/dist/services/test/test-service.mjs +94 -0
- package/dist/services/test/test-service.mjs.map +1 -0
- package/dist/services/test-link/index.d.mts +18 -0
- package/dist/services/test-link/index.d.mts.map +1 -0
- package/dist/services/test-link/index.mjs +60 -0
- package/dist/services/test-link/index.mjs.map +1 -0
- package/dist/services/test-link/test-ref-validator.d.mts +2 -0
- package/dist/services/test-link/test-ref-validator.mjs +50 -0
- package/dist/services/test-link/test-ref-validator.mjs.map +1 -0
- package/dist/services/upgrade/index.d.mts +10 -0
- package/dist/services/upgrade/index.d.mts.map +1 -0
- package/dist/services/upgrade/index.mjs +15 -0
- package/dist/services/upgrade/index.mjs.map +1 -0
- package/dist/services/upgrade/types.d.mts +78 -0
- package/dist/services/upgrade/types.d.mts.map +1 -0
- package/dist/services/upgrade/upgrade-service.d.mts +38 -0
- package/dist/services/upgrade/upgrade-service.d.mts.map +1 -0
- package/dist/services/upgrade/upgrade-service.mjs +201 -0
- package/dist/services/upgrade/upgrade-service.mjs.map +1 -0
- package/dist/services/validate/blueprint-validator.d.mts +23 -0
- package/dist/services/validate/blueprint-validator.d.mts.map +1 -0
- package/dist/services/validate/blueprint-validator.mjs +50 -0
- package/dist/services/validate/blueprint-validator.mjs.map +1 -0
- package/dist/services/validate/implementation-agent-validator.d.mts +20 -0
- package/dist/services/validate/implementation-agent-validator.d.mts.map +1 -0
- package/dist/services/validate/implementation-agent-validator.mjs +42 -0
- package/dist/services/validate/implementation-agent-validator.mjs.map +1 -0
- package/dist/services/validate/implementation-validator.d.mts +32 -0
- package/dist/services/validate/implementation-validator.d.mts.map +1 -0
- package/dist/services/validate/implementation-validator.mjs +64 -0
- package/dist/services/validate/implementation-validator.mjs.map +1 -0
- package/dist/services/validate/index.d.mts +5 -0
- package/dist/services/validate/index.mjs +7 -0
- package/dist/services/validate/spec-validator.d.mts +42 -0
- package/dist/services/validate/spec-validator.d.mts.map +1 -0
- package/dist/services/validate/spec-validator.mjs +49 -0
- package/dist/services/validate/spec-validator.mjs.map +1 -0
- package/dist/services/validate/tenant-validator.d.mts +21 -0
- package/dist/services/validate/tenant-validator.d.mts.map +1 -0
- package/dist/services/validate/tenant-validator.mjs +165 -0
- package/dist/services/validate/tenant-validator.mjs.map +1 -0
- package/dist/services/verification-cache/adapters/filesystem.d.mts +46 -0
- package/dist/services/verification-cache/adapters/filesystem.d.mts.map +1 -0
- package/dist/services/verification-cache/adapters/filesystem.mjs +120 -0
- package/dist/services/verification-cache/adapters/filesystem.mjs.map +1 -0
- package/dist/services/verification-cache/adapters/in-memory.d.mts +27 -0
- package/dist/services/verification-cache/adapters/in-memory.d.mts.map +1 -0
- package/dist/services/verification-cache/adapters/in-memory.mjs +46 -0
- package/dist/services/verification-cache/adapters/in-memory.mjs.map +1 -0
- package/dist/services/verification-cache/adapters/index.d.mts +3 -0
- package/dist/services/verification-cache/adapters/index.mjs +5 -0
- package/dist/services/verification-cache/adapters/workspace-state.d.mts +49 -0
- package/dist/services/verification-cache/adapters/workspace-state.d.mts.map +1 -0
- package/dist/services/verification-cache/adapters/workspace-state.mjs +91 -0
- package/dist/services/verification-cache/adapters/workspace-state.mjs.map +1 -0
- package/dist/services/verification-cache/cache-service.d.mts +70 -0
- package/dist/services/verification-cache/cache-service.d.mts.map +1 -0
- package/dist/services/verification-cache/cache-service.mjs +256 -0
- package/dist/services/verification-cache/cache-service.mjs.map +1 -0
- package/dist/services/verification-cache/index.d.mts +6 -0
- package/dist/services/verification-cache/index.mjs +8 -0
- package/dist/services/verification-cache/types.d.mts +124 -0
- package/dist/services/verification-cache/types.d.mts.map +1 -0
- package/dist/services/verification-cache/types.mjs +16 -0
- package/dist/services/verification-cache/types.mjs.map +1 -0
- package/dist/services/verify/ai-verifier.d.mts +25 -0
- package/dist/services/verify/ai-verifier.d.mts.map +1 -0
- package/dist/services/verify/ai-verifier.mjs +403 -0
- package/dist/services/verify/ai-verifier.mjs.map +1 -0
- package/dist/services/verify/behavior-verifier.d.mts +12 -0
- package/dist/services/verify/behavior-verifier.d.mts.map +1 -0
- package/dist/services/verify/behavior-verifier.mjs +186 -0
- package/dist/services/verify/behavior-verifier.mjs.map +1 -0
- package/dist/services/verify/index.d.mts +5 -0
- package/dist/services/verify/index.mjs +6 -0
- package/dist/services/verify/structure-verifier.d.mts +12 -0
- package/dist/services/verify/structure-verifier.d.mts.map +1 -0
- package/dist/services/verify/structure-verifier.mjs +196 -0
- package/dist/services/verify/structure-verifier.mjs.map +1 -0
- package/dist/services/verify/types.d.mts +137 -0
- package/dist/services/verify/types.d.mts.map +1 -0
- package/dist/services/verify/verify-service.d.mts +60 -0
- package/dist/services/verify/verify-service.d.mts.map +1 -0
- package/dist/services/verify/verify-service.mjs +204 -0
- package/dist/services/verify/verify-service.mjs.map +1 -0
- package/dist/services/versioning/changelog-formatter.d.mts +24 -0
- package/dist/services/versioning/changelog-formatter.d.mts.map +1 -0
- package/dist/services/versioning/changelog-formatter.mjs +155 -0
- package/dist/services/versioning/changelog-formatter.mjs.map +1 -0
- package/dist/services/versioning/conventional-commits.d.mts +95 -0
- package/dist/services/versioning/conventional-commits.d.mts.map +1 -0
- package/dist/services/versioning/conventional-commits.mjs +184 -0
- package/dist/services/versioning/conventional-commits.mjs.map +1 -0
- package/dist/services/versioning/index.d.mts +12 -0
- package/dist/services/versioning/index.d.mts.map +1 -0
- package/dist/services/versioning/index.mjs +28 -0
- package/dist/services/versioning/index.mjs.map +1 -0
- package/dist/services/versioning/types.d.mts +135 -0
- package/dist/services/versioning/types.d.mts.map +1 -0
- package/dist/services/versioning/versioning-service.d.mts +74 -0
- package/dist/services/versioning/versioning-service.d.mts.map +1 -0
- package/dist/services/versioning/versioning-service.mjs +501 -0
- package/dist/services/versioning/versioning-service.mjs.map +1 -0
- package/dist/services/vibe/config.d.mts +12 -0
- package/dist/services/vibe/config.d.mts.map +1 -0
- package/dist/services/vibe/config.mjs +43 -0
- package/dist/services/vibe/config.mjs.map +1 -0
- package/dist/services/vibe/context.d.mts +19 -0
- package/dist/services/vibe/context.d.mts.map +1 -0
- package/dist/services/vibe/context.mjs +92 -0
- package/dist/services/vibe/context.mjs.map +1 -0
- package/dist/services/vibe/definitions.d.mts +8 -0
- package/dist/services/vibe/definitions.d.mts.map +1 -0
- package/dist/services/vibe/definitions.mjs +129 -0
- package/dist/services/vibe/definitions.mjs.map +1 -0
- package/dist/services/vibe/engine.d.mts +44 -0
- package/dist/services/vibe/engine.d.mts.map +1 -0
- package/dist/services/vibe/engine.mjs +147 -0
- package/dist/services/vibe/engine.mjs.map +1 -0
- package/dist/services/vibe/index.d.mts +15 -0
- package/dist/services/vibe/index.d.mts.map +1 -0
- package/dist/services/vibe/index.mjs +26 -0
- package/dist/services/vibe/index.mjs.map +1 -0
- package/dist/services/vibe/loader.d.mts +15 -0
- package/dist/services/vibe/loader.d.mts.map +1 -0
- package/dist/services/vibe/loader.mjs +48 -0
- package/dist/services/vibe/loader.mjs.map +1 -0
- package/dist/services/vibe/pack.d.mts +19 -0
- package/dist/services/vibe/pack.d.mts.map +1 -0
- package/dist/services/vibe/pack.mjs +66 -0
- package/dist/services/vibe/pack.mjs.map +1 -0
- package/dist/services/vibe/types.d.mts +59 -0
- package/dist/services/vibe/types.d.mts.map +1 -0
- package/dist/services/vibe/types.mjs +12 -0
- package/dist/services/vibe/types.mjs.map +1 -0
- package/dist/services/view/index.d.mts +11 -0
- package/dist/services/view/index.d.mts.map +1 -0
- package/dist/services/view/index.mjs +119 -0
- package/dist/services/view/index.mjs.map +1 -0
- package/dist/services/watch.d.mts +25 -0
- package/dist/services/watch.d.mts.map +1 -0
- package/dist/services/watch.mjs +33 -0
- package/dist/services/watch.mjs.map +1 -0
- package/dist/services/workspace-info.d.mts +62 -0
- package/dist/services/workspace-info.d.mts.map +1 -0
- package/dist/services/workspace-info.mjs +103 -0
- package/dist/services/workspace-info.mjs.map +1 -0
- package/dist/templates/app-config.template.d.mts +7 -0
- package/dist/templates/app-config.template.d.mts.map +1 -0
- package/dist/templates/app-config.template.mjs +107 -0
- package/dist/templates/app-config.template.mjs.map +1 -0
- package/dist/templates/data-view.template.d.mts +7 -0
- package/dist/templates/data-view.template.d.mts.map +1 -0
- package/dist/templates/data-view.template.mjs +70 -0
- package/dist/templates/data-view.template.mjs.map +1 -0
- package/dist/templates/event.template.d.mts +11 -0
- package/dist/templates/event.template.d.mts.map +1 -0
- package/dist/templates/event.template.mjs +42 -0
- package/dist/templates/event.template.mjs.map +1 -0
- package/dist/templates/experiment.template.d.mts +7 -0
- package/dist/templates/experiment.template.d.mts.map +1 -0
- package/dist/templates/experiment.template.mjs +89 -0
- package/dist/templates/experiment.template.mjs.map +1 -0
- package/dist/templates/feature.template.d.mts +33 -0
- package/dist/templates/feature.template.d.mts.map +1 -0
- package/dist/templates/feature.template.mjs +52 -0
- package/dist/templates/feature.template.mjs.map +1 -0
- package/dist/templates/fix/skeleton-capability.mjs +49 -0
- package/dist/templates/fix/skeleton-capability.mjs.map +1 -0
- package/dist/templates/fix/skeleton-event.mjs +56 -0
- package/dist/templates/fix/skeleton-event.mjs.map +1 -0
- package/dist/templates/fix/skeleton-operation.mjs +122 -0
- package/dist/templates/fix/skeleton-operation.mjs.map +1 -0
- package/dist/templates/fix/skeleton-presentation.mjs +65 -0
- package/dist/templates/fix/skeleton-presentation.mjs.map +1 -0
- package/dist/templates/fix/utils.mjs +34 -0
- package/dist/templates/fix/utils.mjs.map +1 -0
- package/dist/templates/handler.template.d.mts +16 -0
- package/dist/templates/handler.template.d.mts.map +1 -0
- package/dist/templates/handler.template.mjs +100 -0
- package/dist/templates/handler.template.mjs.map +1 -0
- package/dist/templates/index.d.mts +22 -0
- package/dist/templates/index.d.mts.map +1 -0
- package/dist/templates/index.mjs +39 -0
- package/dist/templates/index.mjs.map +1 -0
- package/dist/templates/integration.template.d.mts +7 -0
- package/dist/templates/integration.template.d.mts.map +1 -0
- package/dist/templates/integration.template.mjs +160 -0
- package/dist/templates/integration.template.mjs.map +1 -0
- package/dist/templates/knowledge.template.d.mts +7 -0
- package/dist/templates/knowledge.template.d.mts.map +1 -0
- package/dist/templates/knowledge.template.mjs +75 -0
- package/dist/templates/knowledge.template.mjs.map +1 -0
- package/dist/templates/migration.template.d.mts +7 -0
- package/dist/templates/migration.template.d.mts.map +1 -0
- package/dist/templates/migration.template.mjs +62 -0
- package/dist/templates/migration.template.mjs.map +1 -0
- package/dist/templates/operation.template.d.mts +11 -0
- package/dist/templates/operation.template.d.mts.map +1 -0
- package/dist/templates/operation.template.mjs +107 -0
- package/dist/templates/operation.template.mjs.map +1 -0
- package/dist/templates/presentation.template.d.mts +11 -0
- package/dist/templates/presentation.template.d.mts.map +1 -0
- package/dist/templates/presentation.template.mjs +80 -0
- package/dist/templates/presentation.template.mjs.map +1 -0
- package/dist/templates/telemetry.template.d.mts +7 -0
- package/dist/templates/telemetry.template.d.mts.map +1 -0
- package/dist/templates/telemetry.template.mjs +91 -0
- package/dist/templates/telemetry.template.mjs.map +1 -0
- package/dist/templates/workflow-runner.template.d.mts +16 -0
- package/dist/templates/workflow-runner.template.d.mts.map +1 -0
- package/dist/templates/workflow-runner.template.mjs +50 -0
- package/dist/templates/workflow-runner.template.mjs.map +1 -0
- package/dist/templates/workflow.template.d.mts +7 -0
- package/dist/templates/workflow.template.d.mts.map +1 -0
- package/dist/templates/workflow.template.mjs +69 -0
- package/dist/templates/workflow.template.mjs.map +1 -0
- package/dist/types/config.d.mts +34 -0
- package/dist/types/config.d.mts.map +1 -0
- package/dist/types.d.mts +324 -0
- package/dist/types.d.mts.map +1 -0
- package/dist/utils/filter.d.mts +16 -0
- package/dist/utils/filter.d.mts.map +1 -0
- package/dist/utils/filter.mjs +22 -0
- package/dist/utils/filter.mjs.map +1 -0
- package/dist/utils/index.d.mts +11 -0
- package/dist/utils/index.d.mts.map +1 -0
- package/dist/utils/index.mjs +20 -0
- package/dist/utils/index.mjs.map +1 -0
- package/dist/utils/module-loader.d.mts +5 -0
- package/dist/utils/module-loader.d.mts.map +1 -0
- package/dist/utils/module-loader.mjs +41 -0
- package/dist/utils/module-loader.mjs.map +1 -0
- package/dist/utils/validation.d.mts +37 -0
- package/dist/utils/validation.d.mts.map +1 -0
- package/dist/utils/validation.mjs +43 -0
- package/dist/utils/validation.mjs.map +1 -0
- package/package.json +24 -19
- package/dist/_virtual/rolldown_runtime.js +0 -18
- package/dist/adapters/ai.d.ts +0 -12
- package/dist/adapters/ai.d.ts.map +0 -1
- package/dist/adapters/ai.js +0 -83
- package/dist/adapters/ai.js.map +0 -1
- package/dist/adapters/factory.d.ts +0 -29
- package/dist/adapters/factory.d.ts.map +0 -1
- package/dist/adapters/factory.js +0 -37
- package/dist/adapters/factory.js.map +0 -1
- package/dist/adapters/fs.d.ts +0 -12
- package/dist/adapters/fs.d.ts.map +0 -1
- package/dist/adapters/fs.js +0 -131
- package/dist/adapters/fs.js.map +0 -1
- package/dist/adapters/git.d.ts +0 -11
- package/dist/adapters/git.d.ts.map +0 -1
- package/dist/adapters/git.js +0 -84
- package/dist/adapters/git.js.map +0 -1
- package/dist/adapters/index.d.ts +0 -7
- package/dist/adapters/index.js +0 -7
- package/dist/adapters/logger.d.ts +0 -18
- package/dist/adapters/logger.d.ts.map +0 -1
- package/dist/adapters/logger.js +0 -81
- package/dist/adapters/logger.js.map +0 -1
- package/dist/adapters/watcher.d.ts +0 -11
- package/dist/adapters/watcher.d.ts.map +0 -1
- package/dist/adapters/watcher.js +0 -74
- package/dist/adapters/watcher.js.map +0 -1
- package/dist/adapters/workspace.d.ts +0 -148
- package/dist/adapters/workspace.d.ts.map +0 -1
- package/dist/adapters/workspace.js +0 -275
- package/dist/adapters/workspace.js.map +0 -1
- package/dist/ai/agents/claude-code-agent.d.ts +0 -22
- package/dist/ai/agents/claude-code-agent.d.ts.map +0 -1
- package/dist/ai/agents/claude-code-agent.js +0 -182
- package/dist/ai/agents/claude-code-agent.js.map +0 -1
- package/dist/ai/agents/cursor-agent.d.ts +0 -68
- package/dist/ai/agents/cursor-agent.d.ts.map +0 -1
- package/dist/ai/agents/cursor-agent.js +0 -436
- package/dist/ai/agents/cursor-agent.js.map +0 -1
- package/dist/ai/agents/index.js +0 -5
- package/dist/ai/agents/openai-codex-agent.d.ts +0 -22
- package/dist/ai/agents/openai-codex-agent.d.ts.map +0 -1
- package/dist/ai/agents/openai-codex-agent.js +0 -167
- package/dist/ai/agents/openai-codex-agent.js.map +0 -1
- package/dist/ai/agents/orchestrator.d.ts +0 -50
- package/dist/ai/agents/orchestrator.d.ts.map +0 -1
- package/dist/ai/agents/orchestrator.js +0 -143
- package/dist/ai/agents/orchestrator.js.map +0 -1
- package/dist/ai/agents/simple-agent.d.ts +0 -17
- package/dist/ai/agents/simple-agent.d.ts.map +0 -1
- package/dist/ai/agents/simple-agent.js +0 -92
- package/dist/ai/agents/simple-agent.js.map +0 -1
- package/dist/ai/agents/types.d.ts +0 -36
- package/dist/ai/agents/types.d.ts.map +0 -1
- package/dist/ai/client.d.ts +0 -97
- package/dist/ai/client.d.ts.map +0 -1
- package/dist/ai/client.js +0 -189
- package/dist/ai/client.js.map +0 -1
- package/dist/ai/index.d.ts +0 -9
- package/dist/ai/index.js +0 -9
- package/dist/ai/prompts/code-generation.d.ts +0 -26
- package/dist/ai/prompts/code-generation.d.ts.map +0 -1
- package/dist/ai/prompts/code-generation.js +0 -143
- package/dist/ai/prompts/code-generation.js.map +0 -1
- package/dist/ai/prompts/index.d.ts +0 -10
- package/dist/ai/prompts/index.d.ts.map +0 -1
- package/dist/ai/prompts/index.js +0 -13
- package/dist/ai/prompts/index.js.map +0 -1
- package/dist/ai/prompts/spec-creation.d.ts +0 -29
- package/dist/ai/prompts/spec-creation.d.ts.map +0 -1
- package/dist/ai/prompts/spec-creation.js +0 -111
- package/dist/ai/prompts/spec-creation.js.map +0 -1
- package/dist/ai/providers.d.ts +0 -29
- package/dist/ai/providers.d.ts.map +0 -1
- package/dist/ai/providers.js +0 -39
- package/dist/ai/providers.js.map +0 -1
- package/dist/formatters/index.d.ts +0 -11
- package/dist/formatters/index.d.ts.map +0 -1
- package/dist/formatters/index.js +0 -19
- package/dist/formatters/index.js.map +0 -1
- package/dist/formatters/json.d.ts +0 -89
- package/dist/formatters/json.d.ts.map +0 -1
- package/dist/formatters/json.js +0 -72
- package/dist/formatters/json.js.map +0 -1
- package/dist/formatters/sarif.d.ts +0 -101
- package/dist/formatters/sarif.d.ts.map +0 -1
- package/dist/formatters/sarif.js +0 -163
- package/dist/formatters/sarif.js.map +0 -1
- package/dist/formatters/text.d.ts +0 -35
- package/dist/formatters/text.d.ts.map +0 -1
- package/dist/formatters/text.js +0 -209
- package/dist/formatters/text.js.map +0 -1
- package/dist/index.d.ts +0 -111
- package/dist/index.js +0 -97
- package/dist/ports/ai.d.ts +0 -59
- package/dist/ports/ai.d.ts.map +0 -1
- package/dist/ports/fs.d.ts +0 -81
- package/dist/ports/fs.d.ts.map +0 -1
- package/dist/ports/git.d.ts +0 -46
- package/dist/ports/git.d.ts.map +0 -1
- package/dist/ports/index.d.ts +0 -6
- package/dist/ports/logger.d.ts +0 -88
- package/dist/ports/logger.d.ts.map +0 -1
- package/dist/ports/rulesync.d.ts +0 -38
- package/dist/ports/rulesync.d.ts.map +0 -1
- package/dist/ports/watcher.d.ts +0 -52
- package/dist/ports/watcher.d.ts.map +0 -1
- package/dist/services/agent-guide/adapters/claude-code.d.ts +0 -35
- package/dist/services/agent-guide/adapters/claude-code.d.ts.map +0 -1
- package/dist/services/agent-guide/adapters/claude-code.js +0 -144
- package/dist/services/agent-guide/adapters/claude-code.js.map +0 -1
- package/dist/services/agent-guide/adapters/cursor-cli.d.ts +0 -39
- package/dist/services/agent-guide/adapters/cursor-cli.d.ts.map +0 -1
- package/dist/services/agent-guide/adapters/cursor-cli.js +0 -135
- package/dist/services/agent-guide/adapters/cursor-cli.js.map +0 -1
- package/dist/services/agent-guide/adapters/generic-mcp.d.ts +0 -53
- package/dist/services/agent-guide/adapters/generic-mcp.d.ts.map +0 -1
- package/dist/services/agent-guide/adapters/generic-mcp.js +0 -159
- package/dist/services/agent-guide/adapters/generic-mcp.js.map +0 -1
- package/dist/services/agent-guide/adapters/index.d.ts +0 -23
- package/dist/services/agent-guide/adapters/index.d.ts.map +0 -1
- package/dist/services/agent-guide/adapters/index.js +0 -31
- package/dist/services/agent-guide/adapters/index.js.map +0 -1
- package/dist/services/agent-guide/agent-guide-service.d.ts +0 -56
- package/dist/services/agent-guide/agent-guide-service.d.ts.map +0 -1
- package/dist/services/agent-guide/agent-guide-service.js +0 -147
- package/dist/services/agent-guide/agent-guide-service.js.map +0 -1
- package/dist/services/agent-guide/index.d.ts +0 -6
- package/dist/services/agent-guide/index.js +0 -5
- package/dist/services/agent-guide/types.d.ts +0 -58
- package/dist/services/agent-guide/types.d.ts.map +0 -1
- package/dist/services/build.d.ts +0 -59
- package/dist/services/build.d.ts.map +0 -1
- package/dist/services/build.js +0 -140
- package/dist/services/build.js.map +0 -1
- package/dist/services/ci-check/ci-check-service.d.ts +0 -16
- package/dist/services/ci-check/ci-check-service.d.ts.map +0 -1
- package/dist/services/ci-check/ci-check-service.js +0 -459
- package/dist/services/ci-check/ci-check-service.js.map +0 -1
- package/dist/services/ci-check/index.d.ts +0 -2
- package/dist/services/ci-check/index.js +0 -2
- package/dist/services/ci-check/types.d.ts +0 -143
- package/dist/services/ci-check/types.d.ts.map +0 -1
- package/dist/services/ci-check/types.js +0 -31
- package/dist/services/ci-check/types.js.map +0 -1
- package/dist/services/clean.d.ts +0 -41
- package/dist/services/clean.d.ts.map +0 -1
- package/dist/services/clean.js +0 -72
- package/dist/services/clean.js.map +0 -1
- package/dist/services/config.d.ts +0 -16
- package/dist/services/config.d.ts.map +0 -1
- package/dist/services/config.js +0 -63
- package/dist/services/config.js.map +0 -1
- package/dist/services/create/ai-generator.d.ts +0 -84
- package/dist/services/create/ai-generator.d.ts.map +0 -1
- package/dist/services/create/ai-generator.js +0 -178
- package/dist/services/create/ai-generator.js.map +0 -1
- package/dist/services/create/index.d.ts +0 -27
- package/dist/services/create/index.d.ts.map +0 -1
- package/dist/services/create/index.js +0 -36
- package/dist/services/create/index.js.map +0 -1
- package/dist/services/create/templates.d.ts +0 -21
- package/dist/services/create/templates.d.ts.map +0 -1
- package/dist/services/create/templates.js +0 -37
- package/dist/services/create/templates.js.map +0 -1
- package/dist/services/deps.d.ts +0 -53
- package/dist/services/deps.d.ts.map +0 -1
- package/dist/services/deps.js +0 -62
- package/dist/services/deps.js.map +0 -1
- package/dist/services/diff.d.ts +0 -34
- package/dist/services/diff.d.ts.map +0 -1
- package/dist/services/diff.js +0 -34
- package/dist/services/diff.js.map +0 -1
- package/dist/services/docs/docs-service.d.ts +0 -19
- package/dist/services/docs/docs-service.d.ts.map +0 -1
- package/dist/services/docs/docs-service.js +0 -41
- package/dist/services/docs/docs-service.js.map +0 -1
- package/dist/services/docs/index.d.ts +0 -1
- package/dist/services/docs/index.js +0 -1
- package/dist/services/doctor/checks/ai.js +0 -119
- package/dist/services/doctor/checks/ai.js.map +0 -1
- package/dist/services/doctor/checks/cli.js +0 -156
- package/dist/services/doctor/checks/cli.js.map +0 -1
- package/dist/services/doctor/checks/config.js +0 -303
- package/dist/services/doctor/checks/config.js.map +0 -1
- package/dist/services/doctor/checks/deps.js +0 -267
- package/dist/services/doctor/checks/deps.js.map +0 -1
- package/dist/services/doctor/checks/index.js +0 -7
- package/dist/services/doctor/checks/layers.js +0 -139
- package/dist/services/doctor/checks/layers.js.map +0 -1
- package/dist/services/doctor/checks/mcp.js +0 -145
- package/dist/services/doctor/checks/mcp.js.map +0 -1
- package/dist/services/doctor/checks/workspace.js +0 -263
- package/dist/services/doctor/checks/workspace.js.map +0 -1
- package/dist/services/doctor/doctor-service.d.ts +0 -24
- package/dist/services/doctor/doctor-service.d.ts.map +0 -1
- package/dist/services/doctor/doctor-service.js +0 -118
- package/dist/services/doctor/doctor-service.js.map +0 -1
- package/dist/services/doctor/index.d.ts +0 -2
- package/dist/services/doctor/index.js +0 -2
- package/dist/services/doctor/types.d.ts +0 -118
- package/dist/services/doctor/types.d.ts.map +0 -1
- package/dist/services/doctor/types.js +0 -29
- package/dist/services/doctor/types.js.map +0 -1
- package/dist/services/formatter.d.ts +0 -15
- package/dist/services/formatter.d.ts.map +0 -1
- package/dist/services/formatter.js +0 -26
- package/dist/services/formatter.js.map +0 -1
- package/dist/services/hooks/hooks-service.d.ts +0 -24
- package/dist/services/hooks/hooks-service.d.ts.map +0 -1
- package/dist/services/hooks/hooks-service.js +0 -126
- package/dist/services/hooks/hooks-service.js.map +0 -1
- package/dist/services/hooks/index.d.ts +0 -10
- package/dist/services/hooks/index.d.ts.map +0 -1
- package/dist/services/hooks/index.js +0 -12
- package/dist/services/hooks/index.js.map +0 -1
- package/dist/services/hooks/types.d.ts +0 -56
- package/dist/services/hooks/types.d.ts.map +0 -1
- package/dist/services/impact/formatters.d.ts +0 -27
- package/dist/services/impact/formatters.d.ts.map +0 -1
- package/dist/services/impact/formatters.js +0 -111
- package/dist/services/impact/formatters.js.map +0 -1
- package/dist/services/impact/impact-detection-service.d.ts +0 -22
- package/dist/services/impact/impact-detection-service.d.ts.map +0 -1
- package/dist/services/impact/impact-detection-service.js +0 -96
- package/dist/services/impact/impact-detection-service.js.map +0 -1
- package/dist/services/impact/index.d.ts +0 -11
- package/dist/services/impact/index.d.ts.map +0 -1
- package/dist/services/impact/index.js +0 -16
- package/dist/services/impact/index.js.map +0 -1
- package/dist/services/impact/types.d.ts +0 -58
- package/dist/services/impact/types.d.ts.map +0 -1
- package/dist/services/implementation/discovery.d.ts +0 -30
- package/dist/services/implementation/discovery.d.ts.map +0 -1
- package/dist/services/implementation/discovery.js +0 -144
- package/dist/services/implementation/discovery.js.map +0 -1
- package/dist/services/implementation/index.d.ts +0 -3
- package/dist/services/implementation/index.js +0 -2
- package/dist/services/implementation/resolver.d.ts +0 -44
- package/dist/services/implementation/resolver.d.ts.map +0 -1
- package/dist/services/implementation/resolver.js +0 -224
- package/dist/services/implementation/resolver.js.map +0 -1
- package/dist/services/implementation/types.d.ts +0 -79
- package/dist/services/implementation/types.d.ts.map +0 -1
- package/dist/services/index.d.ts +0 -91
- package/dist/services/index.js +0 -87
- package/dist/services/integrity-diagram.d.ts +0 -36
- package/dist/services/integrity-diagram.d.ts.map +0 -1
- package/dist/services/integrity-diagram.js +0 -275
- package/dist/services/integrity-diagram.js.map +0 -1
- package/dist/services/integrity.d.ts +0 -134
- package/dist/services/integrity.d.ts.map +0 -1
- package/dist/services/integrity.js +0 -272
- package/dist/services/integrity.js.map +0 -1
- package/dist/services/layer-discovery.d.ts +0 -77
- package/dist/services/layer-discovery.d.ts.map +0 -1
- package/dist/services/layer-discovery.js +0 -121
- package/dist/services/layer-discovery.js.map +0 -1
- package/dist/services/list.d.ts +0 -31
- package/dist/services/list.d.ts.map +0 -1
- package/dist/services/list.js +0 -36
- package/dist/services/list.js.map +0 -1
- package/dist/services/llm/index.d.ts +0 -28
- package/dist/services/llm/index.d.ts.map +0 -1
- package/dist/services/llm/index.js +0 -187
- package/dist/services/llm/index.js.map +0 -1
- package/dist/services/llm/verify-static.d.ts +0 -26
- package/dist/services/llm/verify-static.d.ts.map +0 -1
- package/dist/services/llm/verify-static.js +0 -82
- package/dist/services/llm/verify-static.js.map +0 -1
- package/dist/services/openapi/export-service.d.ts +0 -53
- package/dist/services/openapi/export-service.d.ts.map +0 -1
- package/dist/services/openapi/export-service.js +0 -50
- package/dist/services/openapi/export-service.js.map +0 -1
- package/dist/services/openapi/import-service.d.ts +0 -17
- package/dist/services/openapi/import-service.d.ts.map +0 -1
- package/dist/services/openapi/import-service.js +0 -168
- package/dist/services/openapi/import-service.js.map +0 -1
- package/dist/services/openapi/index.d.ts +0 -5
- package/dist/services/openapi/index.js +0 -4
- package/dist/services/openapi/sync-service.d.ts +0 -17
- package/dist/services/openapi/sync-service.d.ts.map +0 -1
- package/dist/services/openapi/sync-service.js +0 -120
- package/dist/services/openapi/sync-service.js.map +0 -1
- package/dist/services/openapi/types.d.ts +0 -162
- package/dist/services/openapi/types.d.ts.map +0 -1
- package/dist/services/openapi/validate-service.d.ts +0 -16
- package/dist/services/openapi/validate-service.d.ts.map +0 -1
- package/dist/services/openapi/validate-service.js +0 -130
- package/dist/services/openapi/validate-service.js.map +0 -1
- package/dist/services/quickstart/dependencies.d.ts +0 -31
- package/dist/services/quickstart/dependencies.d.ts.map +0 -1
- package/dist/services/quickstart/dependencies.js +0 -57
- package/dist/services/quickstart/dependencies.js.map +0 -1
- package/dist/services/quickstart/index.js +0 -2
- package/dist/services/quickstart/quickstart-service.d.ts +0 -20
- package/dist/services/quickstart/quickstart-service.d.ts.map +0 -1
- package/dist/services/quickstart/quickstart-service.js +0 -196
- package/dist/services/quickstart/quickstart-service.js.map +0 -1
- package/dist/services/quickstart/types.d.ts +0 -81
- package/dist/services/quickstart/types.d.ts.map +0 -1
- package/dist/services/regenerator.d.ts +0 -18
- package/dist/services/regenerator.d.ts.map +0 -1
- package/dist/services/regenerator.js +0 -23
- package/dist/services/regenerator.js.map +0 -1
- package/dist/services/registry.d.ts +0 -53
- package/dist/services/registry.d.ts.map +0 -1
- package/dist/services/registry.js +0 -74
- package/dist/services/registry.js.map +0 -1
- package/dist/services/rulesync.d.ts +0 -17
- package/dist/services/rulesync.d.ts.map +0 -1
- package/dist/services/rulesync.js +0 -71
- package/dist/services/rulesync.js.map +0 -1
- package/dist/services/setup/config-generators.d.ts +0 -42
- package/dist/services/setup/config-generators.d.ts.map +0 -1
- package/dist/services/setup/config-generators.js +0 -252
- package/dist/services/setup/config-generators.js.map +0 -1
- package/dist/services/setup/file-merger.d.ts +0 -27
- package/dist/services/setup/file-merger.d.ts.map +0 -1
- package/dist/services/setup/file-merger.js +0 -61
- package/dist/services/setup/file-merger.js.map +0 -1
- package/dist/services/setup/index.js +0 -4
- package/dist/services/setup/setup-service.d.ts +0 -12
- package/dist/services/setup/setup-service.d.ts.map +0 -1
- package/dist/services/setup/setup-service.js +0 -96
- package/dist/services/setup/setup-service.js.map +0 -1
- package/dist/services/setup/targets/agents-md.js +0 -47
- package/dist/services/setup/targets/agents-md.js.map +0 -1
- package/dist/services/setup/targets/cli-config.js +0 -60
- package/dist/services/setup/targets/cli-config.js.map +0 -1
- package/dist/services/setup/targets/cursor-rules.js +0 -48
- package/dist/services/setup/targets/cursor-rules.js.map +0 -1
- package/dist/services/setup/targets/mcp-claude.js +0 -60
- package/dist/services/setup/targets/mcp-claude.js.map +0 -1
- package/dist/services/setup/targets/mcp-cursor.js +0 -59
- package/dist/services/setup/targets/mcp-cursor.js.map +0 -1
- package/dist/services/setup/targets/vscode-settings.js +0 -63
- package/dist/services/setup/targets/vscode-settings.js.map +0 -1
- package/dist/services/setup/types.d.ts +0 -85
- package/dist/services/setup/types.d.ts.map +0 -1
- package/dist/services/setup/types.js +0 -27
- package/dist/services/setup/types.js.map +0 -1
- package/dist/services/sync.d.ts +0 -42
- package/dist/services/sync.d.ts.map +0 -1
- package/dist/services/sync.js +0 -64
- package/dist/services/sync.js.map +0 -1
- package/dist/services/test/index.d.ts +0 -1
- package/dist/services/test/index.js +0 -1
- package/dist/services/test/test-service.d.ts +0 -22
- package/dist/services/test/test-service.d.ts.map +0 -1
- package/dist/services/test/test-service.js +0 -81
- package/dist/services/test/test-service.js.map +0 -1
- package/dist/services/upgrade/index.d.ts +0 -10
- package/dist/services/upgrade/index.d.ts.map +0 -1
- package/dist/services/upgrade/index.js +0 -15
- package/dist/services/upgrade/index.js.map +0 -1
- package/dist/services/upgrade/types.d.ts +0 -78
- package/dist/services/upgrade/types.d.ts.map +0 -1
- package/dist/services/upgrade/upgrade-service.d.ts +0 -38
- package/dist/services/upgrade/upgrade-service.d.ts.map +0 -1
- package/dist/services/upgrade/upgrade-service.js +0 -201
- package/dist/services/upgrade/upgrade-service.js.map +0 -1
- package/dist/services/validate/blueprint-validator.d.ts +0 -23
- package/dist/services/validate/blueprint-validator.d.ts.map +0 -1
- package/dist/services/validate/blueprint-validator.js +0 -50
- package/dist/services/validate/blueprint-validator.js.map +0 -1
- package/dist/services/validate/implementation-agent-validator.d.ts +0 -20
- package/dist/services/validate/implementation-agent-validator.d.ts.map +0 -1
- package/dist/services/validate/implementation-agent-validator.js +0 -42
- package/dist/services/validate/implementation-agent-validator.js.map +0 -1
- package/dist/services/validate/implementation-validator.d.ts +0 -32
- package/dist/services/validate/implementation-validator.d.ts.map +0 -1
- package/dist/services/validate/implementation-validator.js +0 -64
- package/dist/services/validate/implementation-validator.js.map +0 -1
- package/dist/services/validate/index.d.ts +0 -5
- package/dist/services/validate/index.js +0 -5
- package/dist/services/validate/spec-validator.d.ts +0 -42
- package/dist/services/validate/spec-validator.d.ts.map +0 -1
- package/dist/services/validate/spec-validator.js +0 -50
- package/dist/services/validate/spec-validator.js.map +0 -1
- package/dist/services/validate/tenant-validator.d.ts +0 -21
- package/dist/services/validate/tenant-validator.d.ts.map +0 -1
- package/dist/services/validate/tenant-validator.js +0 -165
- package/dist/services/validate/tenant-validator.js.map +0 -1
- package/dist/services/verification-cache/adapters/filesystem.d.ts +0 -46
- package/dist/services/verification-cache/adapters/filesystem.d.ts.map +0 -1
- package/dist/services/verification-cache/adapters/filesystem.js +0 -120
- package/dist/services/verification-cache/adapters/filesystem.js.map +0 -1
- package/dist/services/verification-cache/adapters/in-memory.d.ts +0 -27
- package/dist/services/verification-cache/adapters/in-memory.d.ts.map +0 -1
- package/dist/services/verification-cache/adapters/in-memory.js +0 -46
- package/dist/services/verification-cache/adapters/in-memory.js.map +0 -1
- package/dist/services/verification-cache/adapters/index.d.ts +0 -3
- package/dist/services/verification-cache/adapters/index.js +0 -3
- package/dist/services/verification-cache/adapters/workspace-state.d.ts +0 -49
- package/dist/services/verification-cache/adapters/workspace-state.d.ts.map +0 -1
- package/dist/services/verification-cache/adapters/workspace-state.js +0 -91
- package/dist/services/verification-cache/adapters/workspace-state.js.map +0 -1
- package/dist/services/verification-cache/cache-service.d.ts +0 -70
- package/dist/services/verification-cache/cache-service.d.ts.map +0 -1
- package/dist/services/verification-cache/cache-service.js +0 -256
- package/dist/services/verification-cache/cache-service.js.map +0 -1
- package/dist/services/verification-cache/index.d.ts +0 -6
- package/dist/services/verification-cache/index.js +0 -6
- package/dist/services/verification-cache/types.d.ts +0 -124
- package/dist/services/verification-cache/types.d.ts.map +0 -1
- package/dist/services/verification-cache/types.js +0 -16
- package/dist/services/verification-cache/types.js.map +0 -1
- package/dist/services/verify/ai-verifier.d.ts +0 -25
- package/dist/services/verify/ai-verifier.d.ts.map +0 -1
- package/dist/services/verify/ai-verifier.js +0 -403
- package/dist/services/verify/ai-verifier.js.map +0 -1
- package/dist/services/verify/behavior-verifier.d.ts +0 -12
- package/dist/services/verify/behavior-verifier.d.ts.map +0 -1
- package/dist/services/verify/behavior-verifier.js +0 -186
- package/dist/services/verify/behavior-verifier.js.map +0 -1
- package/dist/services/verify/index.d.ts +0 -5
- package/dist/services/verify/index.js +0 -4
- package/dist/services/verify/structure-verifier.d.ts +0 -12
- package/dist/services/verify/structure-verifier.d.ts.map +0 -1
- package/dist/services/verify/structure-verifier.js +0 -196
- package/dist/services/verify/structure-verifier.js.map +0 -1
- package/dist/services/verify/types.d.ts +0 -137
- package/dist/services/verify/types.d.ts.map +0 -1
- package/dist/services/verify/verify-service.d.ts +0 -60
- package/dist/services/verify/verify-service.d.ts.map +0 -1
- package/dist/services/verify/verify-service.js +0 -204
- package/dist/services/verify/verify-service.js.map +0 -1
- package/dist/services/versioning/changelog-formatter.d.ts +0 -24
- package/dist/services/versioning/changelog-formatter.d.ts.map +0 -1
- package/dist/services/versioning/changelog-formatter.js +0 -155
- package/dist/services/versioning/changelog-formatter.js.map +0 -1
- package/dist/services/versioning/conventional-commits.d.ts +0 -95
- package/dist/services/versioning/conventional-commits.d.ts.map +0 -1
- package/dist/services/versioning/conventional-commits.js +0 -184
- package/dist/services/versioning/conventional-commits.js.map +0 -1
- package/dist/services/versioning/index.d.ts +0 -12
- package/dist/services/versioning/index.d.ts.map +0 -1
- package/dist/services/versioning/index.js +0 -28
- package/dist/services/versioning/index.js.map +0 -1
- package/dist/services/versioning/types.d.ts +0 -135
- package/dist/services/versioning/types.d.ts.map +0 -1
- package/dist/services/versioning/versioning-service.d.ts +0 -74
- package/dist/services/versioning/versioning-service.d.ts.map +0 -1
- package/dist/services/versioning/versioning-service.js +0 -501
- package/dist/services/versioning/versioning-service.js.map +0 -1
- package/dist/services/watch.d.ts +0 -25
- package/dist/services/watch.d.ts.map +0 -1
- package/dist/services/watch.js +0 -33
- package/dist/services/watch.js.map +0 -1
- package/dist/services/workspace-info.d.ts +0 -62
- package/dist/services/workspace-info.d.ts.map +0 -1
- package/dist/services/workspace-info.js +0 -103
- package/dist/services/workspace-info.js.map +0 -1
- package/dist/templates/app-config.template.d.ts +0 -7
- package/dist/templates/app-config.template.d.ts.map +0 -1
- package/dist/templates/app-config.template.js +0 -107
- package/dist/templates/app-config.template.js.map +0 -1
- package/dist/templates/data-view.template.d.ts +0 -7
- package/dist/templates/data-view.template.d.ts.map +0 -1
- package/dist/templates/data-view.template.js +0 -70
- package/dist/templates/data-view.template.js.map +0 -1
- package/dist/templates/event.template.d.ts +0 -11
- package/dist/templates/event.template.d.ts.map +0 -1
- package/dist/templates/event.template.js +0 -42
- package/dist/templates/event.template.js.map +0 -1
- package/dist/templates/experiment.template.d.ts +0 -7
- package/dist/templates/experiment.template.d.ts.map +0 -1
- package/dist/templates/experiment.template.js +0 -89
- package/dist/templates/experiment.template.js.map +0 -1
- package/dist/templates/handler.template.d.ts +0 -16
- package/dist/templates/handler.template.d.ts.map +0 -1
- package/dist/templates/handler.template.js +0 -100
- package/dist/templates/handler.template.js.map +0 -1
- package/dist/templates/index.d.ts +0 -21
- package/dist/templates/index.d.ts.map +0 -1
- package/dist/templates/index.js +0 -37
- package/dist/templates/index.js.map +0 -1
- package/dist/templates/integration.template.d.ts +0 -7
- package/dist/templates/integration.template.d.ts.map +0 -1
- package/dist/templates/integration.template.js +0 -160
- package/dist/templates/integration.template.js.map +0 -1
- package/dist/templates/knowledge.template.d.ts +0 -7
- package/dist/templates/knowledge.template.d.ts.map +0 -1
- package/dist/templates/knowledge.template.js +0 -75
- package/dist/templates/knowledge.template.js.map +0 -1
- package/dist/templates/migration.template.d.ts +0 -7
- package/dist/templates/migration.template.d.ts.map +0 -1
- package/dist/templates/migration.template.js +0 -62
- package/dist/templates/migration.template.js.map +0 -1
- package/dist/templates/operation.template.d.ts +0 -11
- package/dist/templates/operation.template.d.ts.map +0 -1
- package/dist/templates/operation.template.js +0 -107
- package/dist/templates/operation.template.js.map +0 -1
- package/dist/templates/presentation.template.d.ts +0 -11
- package/dist/templates/presentation.template.d.ts.map +0 -1
- package/dist/templates/presentation.template.js +0 -80
- package/dist/templates/presentation.template.js.map +0 -1
- package/dist/templates/telemetry.template.d.ts +0 -7
- package/dist/templates/telemetry.template.d.ts.map +0 -1
- package/dist/templates/telemetry.template.js +0 -91
- package/dist/templates/telemetry.template.js.map +0 -1
- package/dist/templates/workflow-runner.template.d.ts +0 -16
- package/dist/templates/workflow-runner.template.d.ts.map +0 -1
- package/dist/templates/workflow-runner.template.js +0 -50
- package/dist/templates/workflow-runner.template.js.map +0 -1
- package/dist/templates/workflow.template.d.ts +0 -7
- package/dist/templates/workflow.template.d.ts.map +0 -1
- package/dist/templates/workflow.template.js +0 -69
- package/dist/templates/workflow.template.js.map +0 -1
- package/dist/types/config.d.ts +0 -34
- package/dist/types/config.d.ts.map +0 -1
- package/dist/types.d.ts +0 -324
- package/dist/types.d.ts.map +0 -1
- package/dist/utils/module-loader.js +0 -41
- package/dist/utils/module-loader.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-guide-service.mjs","names":[],"sources":["../../../src/services/agent-guide/agent-guide-service.ts"],"sourcesContent":["/**\n * Agent Guide Service\n *\n * Generates implementation plans and prompts for AI coding agents.\n * Bridges ContractSpec specifications with agent-specific formats.\n */\n\nimport type {\n AnyOperationSpec,\n OperationSpecRegistry,\n PresentationRegistry,\n} from '@contractspec/lib.contracts';\nimport type { FeatureModuleSpec } from '@contractspec/lib.contracts/features';\nimport type {\n AgentType,\n ImplementationPlan,\n} from '@contractspec/lib.contracts/llm';\nimport {\n featureToMarkdown,\n generateImplementationPlan,\n operationSpecToAgentPrompt,\n operationSpecToFullMarkdown,\n} from '@contractspec/lib.contracts/llm';\nimport { getAgentAdapter, listAgentTypes } from './adapters';\nimport type { AgentGuideConfig, GuideOptions, GuideResult } from './types';\n\nconst DEFAULT_CONFIG: AgentGuideConfig = {\n defaultAgent: 'generic-mcp',\n verbose: false,\n};\n\n/**\n * Agent Guide Service\n *\n * Main service for generating implementation guidance for AI coding agents.\n */\nexport class AgentGuideService {\n private config: AgentGuideConfig;\n\n constructor(config: Partial<AgentGuideConfig> = {}) {\n this.config = { ...DEFAULT_CONFIG, ...config };\n }\n\n /**\n * Generate an implementation guide for a spec.\n */\n generateGuide(\n spec: AnyOperationSpec,\n options: GuideOptions = {}\n ): GuideResult {\n const agent = options.agent ?? this.config.defaultAgent;\n const adapter = getAgentAdapter(agent);\n\n // Generate the implementation plan\n const plan = generateImplementationPlan(spec, {\n projectRoot: this.config.projectRoot,\n existingFiles: options.targetPath ? [options.targetPath] : undefined,\n });\n\n // Format for the target agent\n const prompt = adapter.formatPlan(plan);\n\n // Generate raw markdown for clipboard/export\n const markdown = operationSpecToFullMarkdown(spec);\n\n return {\n plan,\n prompt,\n markdown,\n };\n }\n\n /**\n * Generate a guide for a feature (includes all related specs).\n */\n generateFeatureGuide(\n feature: FeatureModuleSpec,\n deps: {\n specs?: OperationSpecRegistry;\n presentations?: PresentationRegistry;\n },\n options: GuideOptions = {}\n ): GuideResult {\n const agent = options.agent ?? this.config.defaultAgent;\n const adapter = getAgentAdapter(agent);\n\n // Create a composite plan for the feature\n const firstOp = feature.operations?.[0];\n const spec = firstOp\n ? deps.specs?.get(firstOp.key, firstOp.version)\n : undefined;\n\n // Generate base plan from first spec or create feature-level plan\n let plan: ImplementationPlan;\n if (spec) {\n plan = generateImplementationPlan(spec, {\n projectRoot: this.config.projectRoot,\n });\n // Override target to indicate it's a feature\n plan.target = {\n type: 'feature',\n key: feature.meta.key,\n version: '1.0.0',\n };\n plan.context.goal = feature.meta.description ?? plan.context.goal;\n } else {\n // Create a minimal plan for features without specs\n plan = {\n target: {\n type: 'feature',\n key: feature.meta.key,\n version: '1.0.0',\n },\n context: {\n goal:\n feature.meta.description ?? `Implement feature ${feature.meta.key}`,\n description: feature.meta.title ?? feature.meta.key,\n background: '',\n },\n specMarkdown: featureToMarkdown(feature, deps),\n fileStructure: [],\n steps: [\n {\n order: 1,\n title: 'Implement Feature',\n description: `Implement the ${feature.meta.key} feature`,\n acceptanceCriteria: [],\n },\n ],\n constraints: { policy: [], security: [], pii: [] },\n verificationChecklist: [],\n };\n }\n\n // Enhance spec markdown with full feature context\n plan.specMarkdown = featureToMarkdown(feature, deps, {\n format: 'full',\n includeRelatedSpecs: true,\n includeRelatedEvents: true,\n includeRelatedPresentations: true,\n });\n\n // Add steps for each operation\n if (feature.operations?.length) {\n plan.steps = feature.operations.map((op, idx) => ({\n order: idx + 1,\n title: `Implement ${op.key}`,\n description: `Implement operation ${op.key}.v${op.version}`,\n acceptanceCriteria: [`Operation ${op.key} works as specified`],\n }));\n }\n\n const prompt = adapter.formatPlan(plan);\n const markdown = featureToMarkdown(feature, deps);\n\n return {\n plan,\n prompt,\n markdown,\n };\n }\n\n /**\n * Generate agent-specific configuration (e.g., cursor rules).\n */\n generateAgentConfig(\n spec: AnyOperationSpec,\n agent?: AgentType\n ): string | undefined {\n const adapter = getAgentAdapter(agent ?? this.config.defaultAgent);\n return adapter.generateConfig?.(spec);\n }\n\n /**\n * Export a spec in a specific format for an agent.\n */\n exportForAgent(\n spec: AnyOperationSpec,\n _agent: AgentType,\n taskType: 'implement' | 'test' | 'refactor' | 'review' = 'implement',\n existingCode?: string\n ): string {\n return operationSpecToAgentPrompt(spec, { taskType, existingCode });\n }\n\n /**\n * List available agent types.\n */\n listAgentTypes(): AgentType[] {\n return listAgentTypes();\n }\n\n /**\n * Get the default agent type.\n */\n getDefaultAgent(): AgentType {\n return this.config.defaultAgent;\n }\n\n /**\n * Update configuration.\n */\n configure(config: Partial<AgentGuideConfig>): void {\n this.config = { ...this.config, ...config };\n }\n}\n\n/**\n * Create a new AgentGuideService instance.\n */\nexport function createAgentGuideService(\n config?: Partial<AgentGuideConfig>\n): AgentGuideService {\n return new AgentGuideService(config);\n}\n\n/** Default singleton instance */\nexport const agentGuideService = new AgentGuideService();\n"],"mappings":";;;;AA0BA,MAAM,iBAAmC;CACvC,cAAc;CACd,SAAS;CACV;;;;;;AAOD,IAAa,oBAAb,MAA+B;CAC7B,AAAQ;CAER,YAAY,SAAoC,EAAE,EAAE;AAClD,OAAK,SAAS;GAAE,GAAG;GAAgB,GAAG;GAAQ;;;;;CAMhD,cACE,MACA,UAAwB,EAAE,EACb;EAEb,MAAM,UAAU,gBADF,QAAQ,SAAS,KAAK,OAAO,aACL;EAGtC,MAAM,OAAO,2BAA2B,MAAM;GAC5C,aAAa,KAAK,OAAO;GACzB,eAAe,QAAQ,aAAa,CAAC,QAAQ,WAAW,GAAG;GAC5D,CAAC;AAQF,SAAO;GACL;GACA,QAPa,QAAQ,WAAW,KAAK;GAQrC,UALe,4BAA4B,KAAK;GAMjD;;;;;CAMH,qBACE,SACA,MAIA,UAAwB,EAAE,EACb;EAEb,MAAM,UAAU,gBADF,QAAQ,SAAS,KAAK,OAAO,aACL;EAGtC,MAAM,UAAU,QAAQ,aAAa;EACrC,MAAM,OAAO,UACT,KAAK,OAAO,IAAI,QAAQ,KAAK,QAAQ,QAAQ,GAC7C;EAGJ,IAAI;AACJ,MAAI,MAAM;AACR,UAAO,2BAA2B,MAAM,EACtC,aAAa,KAAK,OAAO,aAC1B,CAAC;AAEF,QAAK,SAAS;IACZ,MAAM;IACN,KAAK,QAAQ,KAAK;IAClB,SAAS;IACV;AACD,QAAK,QAAQ,OAAO,QAAQ,KAAK,eAAe,KAAK,QAAQ;QAG7D,QAAO;GACL,QAAQ;IACN,MAAM;IACN,KAAK,QAAQ,KAAK;IAClB,SAAS;IACV;GACD,SAAS;IACP,MACE,QAAQ,KAAK,eAAe,qBAAqB,QAAQ,KAAK;IAChE,aAAa,QAAQ,KAAK,SAAS,QAAQ,KAAK;IAChD,YAAY;IACb;GACD,cAAc,kBAAkB,SAAS,KAAK;GAC9C,eAAe,EAAE;GACjB,OAAO,CACL;IACE,OAAO;IACP,OAAO;IACP,aAAa,iBAAiB,QAAQ,KAAK,IAAI;IAC/C,oBAAoB,EAAE;IACvB,CACF;GACD,aAAa;IAAE,QAAQ,EAAE;IAAE,UAAU,EAAE;IAAE,KAAK,EAAE;IAAE;GAClD,uBAAuB,EAAE;GAC1B;AAIH,OAAK,eAAe,kBAAkB,SAAS,MAAM;GACnD,QAAQ;GACR,qBAAqB;GACrB,sBAAsB;GACtB,6BAA6B;GAC9B,CAAC;AAGF,MAAI,QAAQ,YAAY,OACtB,MAAK,QAAQ,QAAQ,WAAW,KAAK,IAAI,SAAS;GAChD,OAAO,MAAM;GACb,OAAO,aAAa,GAAG;GACvB,aAAa,uBAAuB,GAAG,IAAI,IAAI,GAAG;GAClD,oBAAoB,CAAC,aAAa,GAAG,IAAI,qBAAqB;GAC/D,EAAE;EAGL,MAAM,SAAS,QAAQ,WAAW,KAAK;EACvC,MAAM,WAAW,kBAAkB,SAAS,KAAK;AAEjD,SAAO;GACL;GACA;GACA;GACD;;;;;CAMH,oBACE,MACA,OACoB;AAEpB,SADgB,gBAAgB,SAAS,KAAK,OAAO,aAAa,CACnD,iBAAiB,KAAK;;;;;CAMvC,eACE,MACA,QACA,WAAyD,aACzD,cACQ;AACR,SAAO,2BAA2B,MAAM;GAAE;GAAU;GAAc,CAAC;;;;;CAMrE,iBAA8B;AAC5B,SAAO,gBAAgB;;;;;CAMzB,kBAA6B;AAC3B,SAAO,KAAK,OAAO;;;;;CAMrB,UAAU,QAAyC;AACjD,OAAK,SAAS;GAAE,GAAG,KAAK;GAAQ,GAAG;GAAQ;;;;;;AAO/C,SAAgB,wBACd,QACmB;AACnB,QAAO,IAAI,kBAAkB,OAAO;;;AAItC,MAAa,oBAAoB,IAAI,mBAAmB"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { AgentAdapter, AgentGuideConfig, FormatOptions, GuideOptions, GuideResult } from "./types.mjs";
|
|
2
|
+
import { AgentGuideService, agentGuideService, createAgentGuideService } from "./agent-guide-service.mjs";
|
|
3
|
+
import { ClaudeCodeAdapter, claudeCodeAdapter } from "./adapters/claude-code.mjs";
|
|
4
|
+
import { CursorCLIAdapter, cursorCLIAdapter } from "./adapters/cursor-cli.mjs";
|
|
5
|
+
import { GenericMCPAdapter, genericMCPAdapter } from "./adapters/generic-mcp.mjs";
|
|
6
|
+
import { agentAdapters, getAgentAdapter, listAgentTypes } from "./adapters/index.mjs";
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ClaudeCodeAdapter, claudeCodeAdapter } from "./adapters/claude-code.mjs";
|
|
2
|
+
import { CursorCLIAdapter, cursorCLIAdapter } from "./adapters/cursor-cli.mjs";
|
|
3
|
+
import { GenericMCPAdapter, genericMCPAdapter } from "./adapters/generic-mcp.mjs";
|
|
4
|
+
import { agentAdapters, getAgentAdapter, listAgentTypes } from "./adapters/index.mjs";
|
|
5
|
+
import { AgentGuideService, agentGuideService, createAgentGuideService } from "./agent-guide-service.mjs";
|
|
6
|
+
|
|
7
|
+
export { };
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { AnyOperationSpec } from "@contractspec/lib.contracts";
|
|
2
|
+
import { AgentPrompt, AgentType, ImplementationPlan } from "@contractspec/lib.contracts/llm";
|
|
3
|
+
|
|
4
|
+
//#region src/services/agent-guide/types.d.ts
|
|
5
|
+
|
|
6
|
+
/** Configuration for the agent guide service */
|
|
7
|
+
interface AgentGuideConfig {
|
|
8
|
+
/** Default agent to use if not specified */
|
|
9
|
+
defaultAgent: AgentType;
|
|
10
|
+
/** Project root path */
|
|
11
|
+
projectRoot?: string;
|
|
12
|
+
/** Enable verbose logging */
|
|
13
|
+
verbose?: boolean;
|
|
14
|
+
}
|
|
15
|
+
/** Options for generating an implementation guide */
|
|
16
|
+
interface GuideOptions {
|
|
17
|
+
/** Target agent type */
|
|
18
|
+
agent?: AgentType;
|
|
19
|
+
/** Existing code to consider */
|
|
20
|
+
existingCode?: string;
|
|
21
|
+
/** Target file path for implementation */
|
|
22
|
+
targetPath?: string;
|
|
23
|
+
/** Include related specs */
|
|
24
|
+
includeRelated?: boolean;
|
|
25
|
+
}
|
|
26
|
+
/** Options for formatting output */
|
|
27
|
+
interface FormatOptions {
|
|
28
|
+
/** Output format */
|
|
29
|
+
format: 'markdown' | 'json' | 'cursor-rules';
|
|
30
|
+
/** Include system prompt */
|
|
31
|
+
includeSystemPrompt?: boolean;
|
|
32
|
+
}
|
|
33
|
+
/** Result of generating a guide */
|
|
34
|
+
interface GuideResult {
|
|
35
|
+
/** The generated plan */
|
|
36
|
+
plan: ImplementationPlan;
|
|
37
|
+
/** Formatted prompt for the target agent */
|
|
38
|
+
prompt: AgentPrompt;
|
|
39
|
+
/** Raw markdown for clipboard/export */
|
|
40
|
+
markdown: string;
|
|
41
|
+
}
|
|
42
|
+
/** Adapter interface for specific agent types */
|
|
43
|
+
interface AgentAdapter {
|
|
44
|
+
/** Agent type this adapter handles */
|
|
45
|
+
agentType: AgentType;
|
|
46
|
+
/** Format a plan for this agent */
|
|
47
|
+
formatPlan(plan: ImplementationPlan): AgentPrompt;
|
|
48
|
+
/** Generate agent-specific configuration (e.g., cursor rules) */
|
|
49
|
+
generateConfig?(spec: AnyOperationSpec): string;
|
|
50
|
+
/** Parse agent output to extract code */
|
|
51
|
+
parseOutput?(output: string): {
|
|
52
|
+
code?: string;
|
|
53
|
+
errors?: string[];
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
//#endregion
|
|
57
|
+
export { AgentAdapter, AgentGuideConfig, FormatOptions, GuideOptions, GuideResult };
|
|
58
|
+
//# sourceMappingURL=types.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.mts","names":[],"sources":["../../../src/services/agent-guide/types.ts"],"sourcesContent":[],"mappings":";;;;;AAsBA;AAYiB,UAtBA,gBAAA,CAsBa;EAQb;EAUA,YAAA,EAtCD,SAsCa;EAEhB;EAGM,WAAA,CAAA,EAAA,MAAA;EAAqB;EAGhB,OAAA,CAAA,EAAA,OAAA;;;UAtCP,YAAA;;UAEP;;;;;;;;;UAUO,aAAA;;;;;;;UAQA,WAAA;;QAET;;UAEE;;;;;UAMO,YAAA;;aAEJ;;mBAGM,qBAAqB;;wBAGhB"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { FsAdapter } from "../ports/fs.mjs";
|
|
2
|
+
import { LoggerAdapter } from "../ports/logger.mjs";
|
|
3
|
+
import * as _contractspec_module_workspace0 from "@contractspec/module.workspace";
|
|
4
|
+
import { SpecScanResult, WorkspaceConfig } from "@contractspec/module.workspace";
|
|
5
|
+
|
|
6
|
+
//#region src/services/build.d.ts
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Build target types.
|
|
10
|
+
*/
|
|
11
|
+
type BuildTarget = 'handler' | 'component' | 'test';
|
|
12
|
+
/**
|
|
13
|
+
* Options for building from a spec.
|
|
14
|
+
*/
|
|
15
|
+
interface BuildSpecOptions {
|
|
16
|
+
/**
|
|
17
|
+
* Which artifacts to generate.
|
|
18
|
+
*/
|
|
19
|
+
targets?: BuildTarget[];
|
|
20
|
+
/**
|
|
21
|
+
* Override output directory.
|
|
22
|
+
*/
|
|
23
|
+
outputDir?: string;
|
|
24
|
+
/**
|
|
25
|
+
* Whether to overwrite existing files.
|
|
26
|
+
*/
|
|
27
|
+
overwrite?: boolean;
|
|
28
|
+
/**
|
|
29
|
+
* Skip writing files (dry run).
|
|
30
|
+
*/
|
|
31
|
+
dryRun?: boolean;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Result of a single build target.
|
|
35
|
+
*/
|
|
36
|
+
interface BuildTargetResult {
|
|
37
|
+
target: BuildTarget;
|
|
38
|
+
outputPath: string;
|
|
39
|
+
success: boolean;
|
|
40
|
+
skipped?: boolean;
|
|
41
|
+
error?: string;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Result of building from a spec.
|
|
45
|
+
*/
|
|
46
|
+
interface BuildSpecResult {
|
|
47
|
+
specPath: string;
|
|
48
|
+
specInfo: SpecScanResult;
|
|
49
|
+
results: BuildTargetResult[];
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Build implementation files from a spec.
|
|
53
|
+
*/
|
|
54
|
+
declare function buildSpec(specPath: string, adapters: {
|
|
55
|
+
fs: FsAdapter;
|
|
56
|
+
logger: LoggerAdapter;
|
|
57
|
+
workspace?: typeof _contractspec_module_workspace0;
|
|
58
|
+
}, config: WorkspaceConfig, options?: BuildSpecOptions): Promise<BuildSpecResult>;
|
|
59
|
+
//#endregion
|
|
60
|
+
export { BuildSpecOptions, BuildSpecResult, BuildTarget, BuildTargetResult, buildSpec };
|
|
61
|
+
//# sourceMappingURL=build.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build.d.mts","names":[],"sources":["../../src/services/build.ts"],"sourcesContent":[],"mappings":";;;;;;;AA+DA;AASA;;AAIY,KAtDA,WAAA,GAsDA,SAAA,GAAA,WAAA,GAAA,MAAA;;;;AAKD,UAtDM,gBAAA,CAsDN;EAAR;;;YAlDS;;;;;;;;;;;;;;;;;UAqBK,iBAAA;UACP;;;;;;;;;UAUO,eAAA;;YAEL;WACD;;;;;iBAMW,SAAA;MAGd;UACI;qBAAa;WAGf,2BACC,mBACR,QAAQ"}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { generateComponentTemplate, generateHandlerTemplate, generateTestTemplate, inferSpecTypeFromFilePath, scanSpecSource } from "@contractspec/module.workspace";
|
|
2
|
+
|
|
3
|
+
//#region src/services/build.ts
|
|
4
|
+
/**
|
|
5
|
+
* Build/scaffold service for generating implementation files from specs.
|
|
6
|
+
*
|
|
7
|
+
* Uses templates from @contractspec/module.workspace to generate
|
|
8
|
+
* handler, component, and test skeletons without requiring AI.
|
|
9
|
+
*/
|
|
10
|
+
/**
|
|
11
|
+
* Build implementation files from a spec.
|
|
12
|
+
*/
|
|
13
|
+
async function buildSpec(specPath, adapters, config, options = {}) {
|
|
14
|
+
const { fs, logger, workspace } = adapters;
|
|
15
|
+
const scan = workspace?.scanSpecSource ?? scanSpecSource;
|
|
16
|
+
const inferType = workspace?.inferSpecTypeFromFilePath ?? inferSpecTypeFromFilePath;
|
|
17
|
+
const genHandler = workspace?.generateHandlerTemplate ?? generateHandlerTemplate;
|
|
18
|
+
const genComponent = workspace?.generateComponentTemplate ?? generateComponentTemplate;
|
|
19
|
+
const genTest = workspace?.generateTestTemplate ?? generateTestTemplate;
|
|
20
|
+
const { targets = detectDefaultTargets(specPath, inferType), outputDir = config.outputDir, overwrite = false, dryRun = false } = options;
|
|
21
|
+
const specCode = await fs.readFile(specPath);
|
|
22
|
+
const specInfo = scan(specCode, specPath);
|
|
23
|
+
const specType = inferType(specPath);
|
|
24
|
+
logger.info(`Building from spec: ${specPath}`, { specType });
|
|
25
|
+
const results = [];
|
|
26
|
+
for (const target of targets) try {
|
|
27
|
+
const result = await buildTarget(target, specPath, specCode, specInfo, specType, {
|
|
28
|
+
fs,
|
|
29
|
+
logger
|
|
30
|
+
}, outputDir, overwrite, dryRun, {
|
|
31
|
+
genHandler,
|
|
32
|
+
genComponent,
|
|
33
|
+
genTest
|
|
34
|
+
});
|
|
35
|
+
results.push(result);
|
|
36
|
+
} catch (error) {
|
|
37
|
+
results.push({
|
|
38
|
+
target,
|
|
39
|
+
outputPath: "",
|
|
40
|
+
success: false,
|
|
41
|
+
error: error instanceof Error ? error.message : String(error),
|
|
42
|
+
skipped: false
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
return {
|
|
46
|
+
specPath,
|
|
47
|
+
specInfo,
|
|
48
|
+
results
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Build a single target from a spec.
|
|
53
|
+
*/
|
|
54
|
+
async function buildTarget(target, specPath, _specCode, specInfo, specType, adapters, outputDir, overwrite, dryRun, generators) {
|
|
55
|
+
const { fs, logger } = adapters;
|
|
56
|
+
const { genHandler, genComponent, genTest } = generators;
|
|
57
|
+
let code;
|
|
58
|
+
let outputPath;
|
|
59
|
+
switch (target) {
|
|
60
|
+
case "handler": {
|
|
61
|
+
if (specType !== "operation") return {
|
|
62
|
+
target,
|
|
63
|
+
outputPath: "",
|
|
64
|
+
success: false,
|
|
65
|
+
skipped: true,
|
|
66
|
+
error: `Handler generation only supported for operation specs (got ${specType})`
|
|
67
|
+
};
|
|
68
|
+
const kind = specInfo.kind === "command" || specInfo.kind === "query" ? specInfo.kind : "command";
|
|
69
|
+
code = genHandler(specInfo.key ?? "unknown", kind);
|
|
70
|
+
outputPath = resolveOutputPath(specPath, outputDir, "handlers", specInfo.key ?? "unknown", ".handler.ts", adapters.fs);
|
|
71
|
+
break;
|
|
72
|
+
}
|
|
73
|
+
case "component":
|
|
74
|
+
if (specType !== "presentation") return {
|
|
75
|
+
target,
|
|
76
|
+
outputPath: "",
|
|
77
|
+
success: false,
|
|
78
|
+
skipped: true,
|
|
79
|
+
error: `Component generation only supported for presentation specs (got ${specType})`
|
|
80
|
+
};
|
|
81
|
+
code = genComponent(specInfo.key ?? "unknown", specInfo.description ?? "");
|
|
82
|
+
outputPath = resolveOutputPath(specPath, outputDir, "components", specInfo.key ?? "unknown", ".tsx", adapters.fs);
|
|
83
|
+
break;
|
|
84
|
+
case "test": {
|
|
85
|
+
const testType = specType === "operation" ? "handler" : "component";
|
|
86
|
+
code = genTest(specInfo.key ?? "unknown", testType);
|
|
87
|
+
outputPath = resolveOutputPath(specPath, outputDir, "__tests__", specInfo.key ?? "unknown", ".test.ts", adapters.fs);
|
|
88
|
+
break;
|
|
89
|
+
}
|
|
90
|
+
default: return {
|
|
91
|
+
target,
|
|
92
|
+
outputPath: "",
|
|
93
|
+
success: false,
|
|
94
|
+
error: `Unknown target: ${target}`
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
if (await fs.exists(outputPath) && !overwrite) return {
|
|
98
|
+
target,
|
|
99
|
+
outputPath,
|
|
100
|
+
success: false,
|
|
101
|
+
skipped: true,
|
|
102
|
+
error: "File already exists (use overwrite option)"
|
|
103
|
+
};
|
|
104
|
+
if (dryRun) {
|
|
105
|
+
logger.info(`[dry-run] Would write: ${outputPath}`);
|
|
106
|
+
return {
|
|
107
|
+
target,
|
|
108
|
+
outputPath,
|
|
109
|
+
success: true
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
const dirPath = fs.dirname(outputPath);
|
|
113
|
+
await fs.mkdir(dirPath);
|
|
114
|
+
await fs.writeFile(outputPath, code);
|
|
115
|
+
logger.info(`Generated: ${outputPath}`);
|
|
116
|
+
return {
|
|
117
|
+
target,
|
|
118
|
+
outputPath,
|
|
119
|
+
success: true
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Detect default targets based on spec type.
|
|
124
|
+
*/
|
|
125
|
+
function detectDefaultTargets(specPath, inferType) {
|
|
126
|
+
switch (inferType(specPath)) {
|
|
127
|
+
case "operation": return ["handler"];
|
|
128
|
+
case "presentation": return ["component"];
|
|
129
|
+
default: return [];
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Resolve output path for generated file.
|
|
134
|
+
*/
|
|
135
|
+
function resolveOutputPath(specPath, outputDir, subdir, specName, extension, fs) {
|
|
136
|
+
const sanitizedName = toKebabCase(specName.split(".").pop() ?? "unknown");
|
|
137
|
+
let baseDir;
|
|
138
|
+
if (outputDir.startsWith(".")) baseDir = fs.resolve(fs.dirname(specPath), "..", outputDir, subdir);
|
|
139
|
+
else baseDir = fs.resolve(outputDir, subdir);
|
|
140
|
+
return fs.join(baseDir, `${sanitizedName}${extension}`);
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Convert string to kebab-case.
|
|
144
|
+
*/
|
|
145
|
+
function toKebabCase(str) {
|
|
146
|
+
return str.replace(/\./g, "-").replace(/([a-z])([A-Z])/g, "$1-$2").toLowerCase();
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
//#endregion
|
|
150
|
+
export { buildSpec };
|
|
151
|
+
//# sourceMappingURL=build.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build.mjs","names":[],"sources":["../../src/services/build.ts"],"sourcesContent":["/**\n * Build/scaffold service for generating implementation files from specs.\n *\n * Uses templates from @contractspec/module.workspace to generate\n * handler, component, and test skeletons without requiring AI.\n */\n\nimport {\n generateComponentTemplate,\n generateHandlerTemplate,\n generateTestTemplate,\n inferSpecTypeFromFilePath,\n scanSpecSource,\n type SpecScanResult,\n type WorkspaceConfig,\n} from '@contractspec/module.workspace';\nimport type { FsAdapter } from '../ports/fs';\nimport type { LoggerAdapter } from '../ports/logger';\n\n/**\n * Build target types.\n */\nexport type BuildTarget = 'handler' | 'component' | 'test';\n\n/**\n * Options for building from a spec.\n */\nexport interface BuildSpecOptions {\n /**\n * Which artifacts to generate.\n */\n targets?: BuildTarget[];\n\n /**\n * Override output directory.\n */\n outputDir?: string;\n\n /**\n * Whether to overwrite existing files.\n */\n overwrite?: boolean;\n\n /**\n * Skip writing files (dry run).\n */\n dryRun?: boolean;\n}\n\n/**\n * Result of a single build target.\n */\nexport interface BuildTargetResult {\n target: BuildTarget;\n outputPath: string;\n success: boolean;\n skipped?: boolean;\n error?: string;\n}\n\n/**\n * Result of building from a spec.\n */\nexport interface BuildSpecResult {\n specPath: string;\n specInfo: SpecScanResult;\n results: BuildTargetResult[];\n}\n\n/**\n * Build implementation files from a spec.\n */\nexport async function buildSpec(\n specPath: string,\n adapters: {\n fs: FsAdapter;\n logger: LoggerAdapter;\n workspace?: typeof import('@contractspec/module.workspace');\n },\n config: WorkspaceConfig,\n options: BuildSpecOptions = {}\n): Promise<BuildSpecResult> {\n const { fs, logger, workspace } = adapters;\n\n // Use injected modules or defaults\n const scan = workspace?.scanSpecSource ?? scanSpecSource;\n const inferType =\n workspace?.inferSpecTypeFromFilePath ?? inferSpecTypeFromFilePath;\n const genHandler =\n workspace?.generateHandlerTemplate ?? generateHandlerTemplate;\n const genComponent =\n workspace?.generateComponentTemplate ?? generateComponentTemplate;\n const genTest = workspace?.generateTestTemplate ?? generateTestTemplate;\n\n const {\n targets = detectDefaultTargets(specPath, inferType),\n outputDir = config.outputDir,\n overwrite = false,\n dryRun = false,\n } = options;\n\n // Read and scan spec\n const specCode = await fs.readFile(specPath);\n const specInfo = scan(specCode, specPath);\n const specType = inferType(specPath);\n\n logger.info(`Building from spec: ${specPath}`, { specType });\n\n const results: BuildTargetResult[] = [];\n\n for (const target of targets) {\n try {\n const result = await buildTarget(\n target,\n specPath,\n specCode,\n specInfo,\n specType,\n { fs, logger },\n outputDir,\n overwrite,\n dryRun,\n { genHandler, genComponent, genTest }\n );\n results.push(result);\n } catch (error) {\n results.push({\n target,\n outputPath: '',\n success: false,\n error: error instanceof Error ? error.message : String(error),\n skipped: false, // Default to false unless overridden\n });\n }\n }\n\n return {\n specPath,\n specInfo,\n results,\n };\n}\n\n/**\n * Build a single target from a spec.\n */\nasync function buildTarget(\n target: BuildTarget,\n specPath: string,\n _specCode: string,\n specInfo: SpecScanResult,\n specType: string,\n adapters: { fs: FsAdapter; logger: LoggerAdapter },\n outputDir: string,\n overwrite: boolean,\n dryRun: boolean,\n generators: {\n genHandler: typeof generateHandlerTemplate;\n genComponent: typeof generateComponentTemplate;\n genTest: typeof generateTestTemplate;\n }\n): Promise<BuildTargetResult> {\n const { fs, logger } = adapters;\n const { genHandler, genComponent, genTest } = generators;\n\n let code: string;\n let outputPath: string;\n\n switch (target) {\n case 'handler': {\n if (specType !== 'operation') {\n return {\n target,\n outputPath: '',\n success: false,\n skipped: true,\n error: `Handler generation only supported for operation specs (got ${specType})`,\n };\n }\n\n const kind =\n specInfo.kind === 'command' || specInfo.kind === 'query'\n ? specInfo.kind\n : 'command';\n\n code = genHandler(specInfo.key ?? 'unknown', kind);\n outputPath = resolveOutputPath(\n specPath,\n outputDir,\n 'handlers',\n specInfo.key ?? 'unknown',\n '.handler.ts',\n adapters.fs\n );\n break;\n }\n\n case 'component': {\n if (specType !== 'presentation') {\n return {\n target,\n outputPath: '',\n success: false,\n skipped: true,\n error: `Component generation only supported for presentation specs (got ${specType})`,\n };\n }\n\n code = genComponent(\n specInfo.key ?? 'unknown',\n specInfo.description ?? ''\n );\n outputPath = resolveOutputPath(\n specPath,\n outputDir,\n 'components',\n specInfo.key ?? 'unknown',\n '.tsx',\n adapters.fs\n );\n break;\n }\n\n case 'test': {\n const testType = specType === 'operation' ? 'handler' : 'component';\n code = genTest(specInfo.key ?? 'unknown', testType);\n outputPath = resolveOutputPath(\n specPath,\n outputDir,\n '__tests__',\n specInfo.key ?? 'unknown',\n '.test.ts',\n adapters.fs\n );\n break;\n }\n\n default:\n return {\n target,\n outputPath: '',\n success: false,\n error: `Unknown target: ${target}`,\n };\n }\n\n // Check if file exists\n const exists = await fs.exists(outputPath);\n if (exists && !overwrite) {\n return {\n target,\n outputPath,\n success: false,\n skipped: true,\n error: 'File already exists (use overwrite option)',\n };\n }\n\n if (dryRun) {\n logger.info(`[dry-run] Would write: ${outputPath}`);\n return {\n target,\n outputPath,\n success: true,\n };\n }\n\n // Ensure directory exists\n const dirPath = fs.dirname(outputPath);\n await fs.mkdir(dirPath);\n\n // Write file\n await fs.writeFile(outputPath, code);\n logger.info(`Generated: ${outputPath}`);\n\n return {\n target,\n outputPath,\n success: true,\n };\n}\n\n/**\n * Detect default targets based on spec type.\n */\nfunction detectDefaultTargets(\n specPath: string,\n inferType: typeof inferSpecTypeFromFilePath\n): BuildTarget[] {\n const specType = inferType(specPath);\n\n switch (specType) {\n case 'operation':\n return ['handler'];\n case 'presentation':\n return ['component'];\n default:\n return [];\n }\n}\n\n/**\n * Resolve output path for generated file.\n */\nfunction resolveOutputPath(\n specPath: string,\n outputDir: string,\n subdir: string,\n specName: string,\n extension: string,\n fs: FsAdapter\n): string {\n const sanitizedName = toKebabCase(specName.split('.').pop() ?? 'unknown');\n\n let baseDir: string;\n if (outputDir.startsWith('.')) {\n // Relative to spec file location\n baseDir = fs.resolve(fs.dirname(specPath), '..', outputDir, subdir);\n } else {\n // Absolute or relative to cwd\n baseDir = fs.resolve(outputDir, subdir);\n }\n\n return fs.join(baseDir, `${sanitizedName}${extension}`);\n}\n\n/**\n * Convert string to kebab-case.\n */\nfunction toKebabCase(str: string): string {\n return str\n .replace(/\\./g, '-')\n .replace(/([a-z])([A-Z])/g, '$1-$2')\n .toLowerCase();\n}\n"],"mappings":";;;;;;;;;;;;AAwEA,eAAsB,UACpB,UACA,UAKA,QACA,UAA4B,EAAE,EACJ;CAC1B,MAAM,EAAE,IAAI,QAAQ,cAAc;CAGlC,MAAM,OAAO,WAAW,kBAAkB;CAC1C,MAAM,YACJ,WAAW,6BAA6B;CAC1C,MAAM,aACJ,WAAW,2BAA2B;CACxC,MAAM,eACJ,WAAW,6BAA6B;CAC1C,MAAM,UAAU,WAAW,wBAAwB;CAEnD,MAAM,EACJ,UAAU,qBAAqB,UAAU,UAAU,EACnD,YAAY,OAAO,WACnB,YAAY,OACZ,SAAS,UACP;CAGJ,MAAM,WAAW,MAAM,GAAG,SAAS,SAAS;CAC5C,MAAM,WAAW,KAAK,UAAU,SAAS;CACzC,MAAM,WAAW,UAAU,SAAS;AAEpC,QAAO,KAAK,uBAAuB,YAAY,EAAE,UAAU,CAAC;CAE5D,MAAM,UAA+B,EAAE;AAEvC,MAAK,MAAM,UAAU,QACnB,KAAI;EACF,MAAM,SAAS,MAAM,YACnB,QACA,UACA,UACA,UACA,UACA;GAAE;GAAI;GAAQ,EACd,WACA,WACA,QACA;GAAE;GAAY;GAAc;GAAS,CACtC;AACD,UAAQ,KAAK,OAAO;UACb,OAAO;AACd,UAAQ,KAAK;GACX;GACA,YAAY;GACZ,SAAS;GACT,OAAO,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;GAC7D,SAAS;GACV,CAAC;;AAIN,QAAO;EACL;EACA;EACA;EACD;;;;;AAMH,eAAe,YACb,QACA,UACA,WACA,UACA,UACA,UACA,WACA,WACA,QACA,YAK4B;CAC5B,MAAM,EAAE,IAAI,WAAW;CACvB,MAAM,EAAE,YAAY,cAAc,YAAY;CAE9C,IAAI;CACJ,IAAI;AAEJ,SAAQ,QAAR;EACE,KAAK,WAAW;AACd,OAAI,aAAa,YACf,QAAO;IACL;IACA,YAAY;IACZ,SAAS;IACT,SAAS;IACT,OAAO,8DAA8D,SAAS;IAC/E;GAGH,MAAM,OACJ,SAAS,SAAS,aAAa,SAAS,SAAS,UAC7C,SAAS,OACT;AAEN,UAAO,WAAW,SAAS,OAAO,WAAW,KAAK;AAClD,gBAAa,kBACX,UACA,WACA,YACA,SAAS,OAAO,WAChB,eACA,SAAS,GACV;AACD;;EAGF,KAAK;AACH,OAAI,aAAa,eACf,QAAO;IACL;IACA,YAAY;IACZ,SAAS;IACT,SAAS;IACT,OAAO,mEAAmE,SAAS;IACpF;AAGH,UAAO,aACL,SAAS,OAAO,WAChB,SAAS,eAAe,GACzB;AACD,gBAAa,kBACX,UACA,WACA,cACA,SAAS,OAAO,WAChB,QACA,SAAS,GACV;AACD;EAGF,KAAK,QAAQ;GACX,MAAM,WAAW,aAAa,cAAc,YAAY;AACxD,UAAO,QAAQ,SAAS,OAAO,WAAW,SAAS;AACnD,gBAAa,kBACX,UACA,WACA,aACA,SAAS,OAAO,WAChB,YACA,SAAS,GACV;AACD;;EAGF,QACE,QAAO;GACL;GACA,YAAY;GACZ,SAAS;GACT,OAAO,mBAAmB;GAC3B;;AAKL,KADe,MAAM,GAAG,OAAO,WAAW,IAC5B,CAAC,UACb,QAAO;EACL;EACA;EACA,SAAS;EACT,SAAS;EACT,OAAO;EACR;AAGH,KAAI,QAAQ;AACV,SAAO,KAAK,0BAA0B,aAAa;AACnD,SAAO;GACL;GACA;GACA,SAAS;GACV;;CAIH,MAAM,UAAU,GAAG,QAAQ,WAAW;AACtC,OAAM,GAAG,MAAM,QAAQ;AAGvB,OAAM,GAAG,UAAU,YAAY,KAAK;AACpC,QAAO,KAAK,cAAc,aAAa;AAEvC,QAAO;EACL;EACA;EACA,SAAS;EACV;;;;;AAMH,SAAS,qBACP,UACA,WACe;AAGf,SAFiB,UAAU,SAAS,EAEpC;EACE,KAAK,YACH,QAAO,CAAC,UAAU;EACpB,KAAK,eACH,QAAO,CAAC,YAAY;EACtB,QACE,QAAO,EAAE;;;;;;AAOf,SAAS,kBACP,UACA,WACA,QACA,UACA,WACA,IACQ;CACR,MAAM,gBAAgB,YAAY,SAAS,MAAM,IAAI,CAAC,KAAK,IAAI,UAAU;CAEzE,IAAI;AACJ,KAAI,UAAU,WAAW,IAAI,CAE3B,WAAU,GAAG,QAAQ,GAAG,QAAQ,SAAS,EAAE,MAAM,WAAW,OAAO;KAGnE,WAAU,GAAG,QAAQ,WAAW,OAAO;AAGzC,QAAO,GAAG,KAAK,SAAS,GAAG,gBAAgB,YAAY;;;;;AAMzD,SAAS,YAAY,KAAqB;AACxC,QAAO,IACJ,QAAQ,OAAO,IAAI,CACnB,QAAQ,mBAAmB,QAAQ,CACnC,aAAa"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { createParser, detectFormat } from "../../coverage/parsers/index.mjs";
|
|
2
|
+
import { validateCoverage } from "../../coverage/validator.mjs";
|
|
3
|
+
import { scanAllSpecsFromSource } from "@contractspec/module.workspace";
|
|
4
|
+
|
|
5
|
+
//#region src/services/ci-check/checks/coverage.ts
|
|
6
|
+
/**
|
|
7
|
+
* Coverage goal enforcement checks.
|
|
8
|
+
*
|
|
9
|
+
* Validates that TestSpec.coverage requirements are met by actual coverage data.
|
|
10
|
+
* Requires a coverage report file to exist (from a previous test run).
|
|
11
|
+
*/
|
|
12
|
+
/**
|
|
13
|
+
* Run coverage goal enforcement checks.
|
|
14
|
+
*/
|
|
15
|
+
async function runCoverageChecks(adapters, specFiles, options) {
|
|
16
|
+
const { fs, logger } = adapters;
|
|
17
|
+
const issues = [];
|
|
18
|
+
const coverageDir = options.workspaceRoot ? `${options.workspaceRoot}/coverage` : "./coverage";
|
|
19
|
+
const possiblePaths = [
|
|
20
|
+
`${coverageDir}/coverage-final.json`,
|
|
21
|
+
`${coverageDir}/coverage.json`,
|
|
22
|
+
`${coverageDir}/coverage-summary.json`
|
|
23
|
+
];
|
|
24
|
+
let coverageContent;
|
|
25
|
+
let coveragePath;
|
|
26
|
+
for (const path of possiblePaths) if (await fs.exists(path)) {
|
|
27
|
+
coverageContent = await fs.readFile(path);
|
|
28
|
+
coveragePath = path;
|
|
29
|
+
break;
|
|
30
|
+
}
|
|
31
|
+
if (!coverageContent) {
|
|
32
|
+
logger.info("No coverage report found, skipping coverage checks");
|
|
33
|
+
return issues;
|
|
34
|
+
}
|
|
35
|
+
const coverageReport = createParser(detectFormat(coveragePath ?? "coverage.json")).parse(coverageContent);
|
|
36
|
+
for (const specFile of specFiles) {
|
|
37
|
+
if (!specFile.includes(".test-spec.")) continue;
|
|
38
|
+
const content = await fs.readFile(specFile);
|
|
39
|
+
const scans = scanAllSpecsFromSource(content, specFile);
|
|
40
|
+
for (const scan of scans) {
|
|
41
|
+
if (scan.specType !== "test-spec" || !scan.key || !scan.version) continue;
|
|
42
|
+
const coverageMatch = content.match(/coverage\s*:\s*\{([^}]+)\}/);
|
|
43
|
+
if (!coverageMatch || !coverageMatch[1]) continue;
|
|
44
|
+
const coverageBlock = coverageMatch[1];
|
|
45
|
+
const requirements = {};
|
|
46
|
+
const statementsMatch = coverageBlock.match(/statements\s*:\s*(\d+)/);
|
|
47
|
+
if (statementsMatch && statementsMatch[1]) requirements.statements = parseInt(statementsMatch[1], 10);
|
|
48
|
+
const branchesMatch = coverageBlock.match(/branches\s*:\s*(\d+)/);
|
|
49
|
+
if (branchesMatch && branchesMatch[1]) requirements.branches = parseInt(branchesMatch[1], 10);
|
|
50
|
+
const functionsMatch = coverageBlock.match(/functions\s*:\s*(\d+)/);
|
|
51
|
+
if (functionsMatch && functionsMatch[1]) requirements.functions = parseInt(functionsMatch[1], 10);
|
|
52
|
+
const linesMatch = coverageBlock.match(/lines\s*:\s*(\d+)/);
|
|
53
|
+
if (linesMatch && linesMatch[1]) requirements.lines = parseInt(linesMatch[1], 10);
|
|
54
|
+
if (Object.keys(requirements).length === 0) continue;
|
|
55
|
+
const result = validateCoverage(scan.key, scan.version, requirements, coverageReport.total);
|
|
56
|
+
for (const failure of result.failures) issues.push({
|
|
57
|
+
ruleId: "coverage-below-threshold",
|
|
58
|
+
severity: "error",
|
|
59
|
+
message: failure.message,
|
|
60
|
+
category: "coverage",
|
|
61
|
+
file: specFile,
|
|
62
|
+
context: {
|
|
63
|
+
specKey: scan.key,
|
|
64
|
+
specVersion: scan.version,
|
|
65
|
+
metric: failure.metric,
|
|
66
|
+
required: failure.required,
|
|
67
|
+
actual: failure.actual
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return issues;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
//#endregion
|
|
76
|
+
export { runCoverageChecks };
|
|
77
|
+
//# sourceMappingURL=coverage.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coverage.mjs","names":[],"sources":["../../../../src/services/ci-check/checks/coverage.ts"],"sourcesContent":["/**\n * Coverage goal enforcement checks.\n *\n * Validates that TestSpec.coverage requirements are met by actual coverage data.\n * Requires a coverage report file to exist (from a previous test run).\n */\n\nimport { scanAllSpecsFromSource } from '@contractspec/module.workspace';\nimport type { FsAdapter } from '../../../ports/fs';\nimport type { LoggerAdapter } from '../../../ports/logger';\nimport { createParser, detectFormat, validateCoverage } from '../../coverage';\nimport type { CICheckOptions, CIIssue } from '../types';\n\n/**\n * Run coverage goal enforcement checks.\n */\nexport async function runCoverageChecks(\n adapters: { fs: FsAdapter; logger: LoggerAdapter },\n specFiles: string[],\n options: CICheckOptions\n): Promise<CIIssue[]> {\n const { fs, logger } = adapters;\n const issues: CIIssue[] = [];\n\n // Try to find coverage report\n const coverageDir = options.workspaceRoot\n ? `${options.workspaceRoot}/coverage`\n : './coverage';\n\n const possiblePaths = [\n `${coverageDir}/coverage-final.json`,\n `${coverageDir}/coverage.json`,\n `${coverageDir}/coverage-summary.json`,\n ];\n\n let coverageContent: string | undefined;\n let coveragePath: string | undefined;\n\n for (const path of possiblePaths) {\n const exists = await fs.exists(path);\n if (exists) {\n coverageContent = await fs.readFile(path);\n coveragePath = path;\n break;\n }\n }\n\n if (!coverageContent) {\n logger.info('No coverage report found, skipping coverage checks');\n return issues;\n }\n\n // Parse coverage report\n const format = detectFormat(coveragePath ?? 'coverage.json');\n const parser = createParser(format);\n const coverageReport = parser.parse(coverageContent);\n\n // Scan for test specs with coverage requirements\n for (const specFile of specFiles) {\n if (!specFile.includes('.test-spec.')) continue;\n\n const content = await fs.readFile(specFile);\n const scans = scanAllSpecsFromSource(content, specFile);\n\n for (const scan of scans) {\n if (scan.specType !== 'test-spec' || !scan.key || !scan.version) continue;\n\n // Extract coverage requirements (simplified - actual extraction would need more parsing)\n const coverageMatch = content.match(/coverage\\s*:\\s*\\{([^}]+)\\}/);\n if (!coverageMatch || !coverageMatch[1]) continue;\n\n // Parse coverage requirements\n const coverageBlock = coverageMatch[1];\n const requirements: Record<string, number> = {};\n\n const statementsMatch = coverageBlock.match(/statements\\s*:\\s*(\\d+)/);\n if (statementsMatch && statementsMatch[1])\n requirements.statements = parseInt(statementsMatch[1], 10);\n\n const branchesMatch = coverageBlock.match(/branches\\s*:\\s*(\\d+)/);\n if (branchesMatch && branchesMatch[1])\n requirements.branches = parseInt(branchesMatch[1], 10);\n\n const functionsMatch = coverageBlock.match(/functions\\s*:\\s*(\\d+)/);\n if (functionsMatch && functionsMatch[1])\n requirements.functions = parseInt(functionsMatch[1], 10);\n\n const linesMatch = coverageBlock.match(/lines\\s*:\\s*(\\d+)/);\n if (linesMatch && linesMatch[1])\n requirements.lines = parseInt(linesMatch[1], 10);\n\n if (Object.keys(requirements).length === 0) continue;\n\n // Validate coverage against requirements\n const result = validateCoverage(\n scan.key,\n scan.version,\n requirements,\n coverageReport.total\n );\n\n // Report failures as errors\n for (const failure of result.failures) {\n issues.push({\n ruleId: 'coverage-below-threshold',\n severity: 'error',\n message: failure.message,\n category: 'coverage',\n file: specFile,\n context: {\n specKey: scan.key,\n specVersion: scan.version,\n metric: failure.metric,\n required: failure.required,\n actual: failure.actual,\n },\n });\n }\n }\n }\n\n return issues;\n}\n"],"mappings":";;;;;;;;;;;;;;AAgBA,eAAsB,kBACpB,UACA,WACA,SACoB;CACpB,MAAM,EAAE,IAAI,WAAW;CACvB,MAAM,SAAoB,EAAE;CAG5B,MAAM,cAAc,QAAQ,gBACxB,GAAG,QAAQ,cAAc,aACzB;CAEJ,MAAM,gBAAgB;EACpB,GAAG,YAAY;EACf,GAAG,YAAY;EACf,GAAG,YAAY;EAChB;CAED,IAAI;CACJ,IAAI;AAEJ,MAAK,MAAM,QAAQ,cAEjB,KADe,MAAM,GAAG,OAAO,KAAK,EACxB;AACV,oBAAkB,MAAM,GAAG,SAAS,KAAK;AACzC,iBAAe;AACf;;AAIJ,KAAI,CAAC,iBAAiB;AACpB,SAAO,KAAK,qDAAqD;AACjE,SAAO;;CAMT,MAAM,iBADS,aADA,aAAa,gBAAgB,gBAAgB,CACzB,CACL,MAAM,gBAAgB;AAGpD,MAAK,MAAM,YAAY,WAAW;AAChC,MAAI,CAAC,SAAS,SAAS,cAAc,CAAE;EAEvC,MAAM,UAAU,MAAM,GAAG,SAAS,SAAS;EAC3C,MAAM,QAAQ,uBAAuB,SAAS,SAAS;AAEvD,OAAK,MAAM,QAAQ,OAAO;AACxB,OAAI,KAAK,aAAa,eAAe,CAAC,KAAK,OAAO,CAAC,KAAK,QAAS;GAGjE,MAAM,gBAAgB,QAAQ,MAAM,6BAA6B;AACjE,OAAI,CAAC,iBAAiB,CAAC,cAAc,GAAI;GAGzC,MAAM,gBAAgB,cAAc;GACpC,MAAM,eAAuC,EAAE;GAE/C,MAAM,kBAAkB,cAAc,MAAM,yBAAyB;AACrE,OAAI,mBAAmB,gBAAgB,GACrC,cAAa,aAAa,SAAS,gBAAgB,IAAI,GAAG;GAE5D,MAAM,gBAAgB,cAAc,MAAM,uBAAuB;AACjE,OAAI,iBAAiB,cAAc,GACjC,cAAa,WAAW,SAAS,cAAc,IAAI,GAAG;GAExD,MAAM,iBAAiB,cAAc,MAAM,wBAAwB;AACnE,OAAI,kBAAkB,eAAe,GACnC,cAAa,YAAY,SAAS,eAAe,IAAI,GAAG;GAE1D,MAAM,aAAa,cAAc,MAAM,oBAAoB;AAC3D,OAAI,cAAc,WAAW,GAC3B,cAAa,QAAQ,SAAS,WAAW,IAAI,GAAG;AAElD,OAAI,OAAO,KAAK,aAAa,CAAC,WAAW,EAAG;GAG5C,MAAM,SAAS,iBACb,KAAK,KACL,KAAK,SACL,cACA,eAAe,MAChB;AAGD,QAAK,MAAM,WAAW,OAAO,SAC3B,QAAO,KAAK;IACV,QAAQ;IACR,UAAU;IACV,SAAS,QAAQ;IACjB,UAAU;IACV,MAAM;IACN,SAAS;KACP,SAAS,KAAK;KACd,aAAa,KAAK;KAClB,QAAQ,QAAQ;KAChB,UAAU,QAAQ;KAClB,QAAQ,QAAQ;KACjB;IACF,CAAC;;;AAKR,QAAO"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { analyzeDeps } from "../../deps.mjs";
|
|
2
|
+
|
|
3
|
+
//#region src/services/ci-check/checks/deps.ts
|
|
4
|
+
/**
|
|
5
|
+
* Run dependency analysis checks.
|
|
6
|
+
*/
|
|
7
|
+
async function runDepsChecks(adapters, options) {
|
|
8
|
+
const issues = [];
|
|
9
|
+
const result = await analyzeDeps(adapters, { pattern: options.pattern });
|
|
10
|
+
for (const cycle of result.cycles) issues.push({
|
|
11
|
+
ruleId: "deps-circular",
|
|
12
|
+
severity: "error",
|
|
13
|
+
message: `Circular dependency detected: ${cycle.join(" → ")}`,
|
|
14
|
+
category: "deps",
|
|
15
|
+
context: { cycle }
|
|
16
|
+
});
|
|
17
|
+
for (const item of result.missing) for (const missing of item.missing) issues.push({
|
|
18
|
+
ruleId: "deps-missing",
|
|
19
|
+
severity: "error",
|
|
20
|
+
message: `Missing dependency: ${item.contract} requires ${missing}`,
|
|
21
|
+
category: "deps",
|
|
22
|
+
context: {
|
|
23
|
+
contract: item.contract,
|
|
24
|
+
missing
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
return issues;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
//#endregion
|
|
31
|
+
export { runDepsChecks };
|
|
32
|
+
//# sourceMappingURL=deps.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deps.mjs","names":[],"sources":["../../../../src/services/ci-check/checks/deps.ts"],"sourcesContent":["/**\n * Dependency analysis checks.\n */\n\nimport type { FsAdapter } from '../../../ports/fs';\nimport type { LoggerAdapter } from '../../../ports/logger';\nimport { analyzeDeps } from '../../deps';\nimport type { CICheckOptions, CIIssue } from '../types';\n\n/**\n * Run dependency analysis checks.\n */\nexport async function runDepsChecks(\n adapters: { fs: FsAdapter; logger: LoggerAdapter },\n options: CICheckOptions\n): Promise<CIIssue[]> {\n const issues: CIIssue[] = [];\n\n const result = await analyzeDeps(adapters, {\n pattern: options.pattern,\n });\n\n // Report circular dependencies as errors\n for (const cycle of result.cycles) {\n issues.push({\n ruleId: 'deps-circular',\n severity: 'error',\n message: `Circular dependency detected: ${cycle.join(' → ')}`,\n category: 'deps',\n context: { cycle },\n });\n }\n\n // Report missing dependencies as errors\n for (const item of result.missing) {\n for (const missing of item.missing) {\n issues.push({\n ruleId: 'deps-missing',\n severity: 'error',\n message: `Missing dependency: ${item.contract} requires ${missing}`,\n category: 'deps',\n context: { contract: item.contract, missing },\n });\n }\n }\n\n return issues;\n}\n"],"mappings":";;;;;;AAYA,eAAsB,cACpB,UACA,SACoB;CACpB,MAAM,SAAoB,EAAE;CAE5B,MAAM,SAAS,MAAM,YAAY,UAAU,EACzC,SAAS,QAAQ,SAClB,CAAC;AAGF,MAAK,MAAM,SAAS,OAAO,OACzB,QAAO,KAAK;EACV,QAAQ;EACR,UAAU;EACV,SAAS,iCAAiC,MAAM,KAAK,MAAM;EAC3D,UAAU;EACV,SAAS,EAAE,OAAO;EACnB,CAAC;AAIJ,MAAK,MAAM,QAAQ,OAAO,QACxB,MAAK,MAAM,WAAW,KAAK,QACzB,QAAO,KAAK;EACV,QAAQ;EACR,UAAU;EACV,SAAS,uBAAuB,KAAK,SAAS,YAAY;EAC1D,UAAU;EACV,SAAS;GAAE,UAAU,KAAK;GAAU;GAAS;EAC9C,CAAC;AAIN,QAAO"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { runDoctor } from "../../doctor/doctor-service.mjs";
|
|
2
|
+
|
|
3
|
+
//#region src/services/ci-check/checks/doctor.ts
|
|
4
|
+
/**
|
|
5
|
+
* Run doctor checks (skipping AI in CI).
|
|
6
|
+
*/
|
|
7
|
+
async function runDoctorChecks(adapters, options) {
|
|
8
|
+
const issues = [];
|
|
9
|
+
const result = await runDoctor(adapters, {
|
|
10
|
+
workspaceRoot: options.workspaceRoot ?? process.cwd(),
|
|
11
|
+
skipAi: true,
|
|
12
|
+
categories: [
|
|
13
|
+
"cli",
|
|
14
|
+
"config",
|
|
15
|
+
"deps",
|
|
16
|
+
"workspace"
|
|
17
|
+
]
|
|
18
|
+
});
|
|
19
|
+
for (const check of result.checks) if (check.status === "fail") issues.push({
|
|
20
|
+
ruleId: `doctor-${check.category}-${check.name.toLowerCase().replace(/\s+/g, "-")}`,
|
|
21
|
+
severity: "error",
|
|
22
|
+
message: `${check.name}: ${check.message}`,
|
|
23
|
+
category: "doctor",
|
|
24
|
+
context: { details: check.details }
|
|
25
|
+
});
|
|
26
|
+
else if (check.status === "warn") issues.push({
|
|
27
|
+
ruleId: `doctor-${check.category}-${check.name.toLowerCase().replace(/\s+/g, "-")}`,
|
|
28
|
+
severity: "warning",
|
|
29
|
+
message: `${check.name}: ${check.message}`,
|
|
30
|
+
category: "doctor",
|
|
31
|
+
context: { details: check.details }
|
|
32
|
+
});
|
|
33
|
+
return issues;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
//#endregion
|
|
37
|
+
export { runDoctorChecks };
|
|
38
|
+
//# sourceMappingURL=doctor.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"doctor.mjs","names":[],"sources":["../../../../src/services/ci-check/checks/doctor.ts"],"sourcesContent":["/**\n * Doctor checks (skipping AI in CI).\n */\n\nimport type { FsAdapter } from '../../../ports/fs';\nimport type { LoggerAdapter } from '../../../ports/logger';\nimport { runDoctor } from '../../doctor/doctor-service';\nimport type { CICheckOptions, CIIssue } from '../types';\n\n/**\n * Run doctor checks (skipping AI in CI).\n */\nexport async function runDoctorChecks(\n adapters: { fs: FsAdapter; logger: LoggerAdapter },\n options: CICheckOptions\n): Promise<CIIssue[]> {\n const issues: CIIssue[] = [];\n\n const workspaceRoot = options.workspaceRoot ?? process.cwd();\n\n const result = await runDoctor(adapters, {\n workspaceRoot,\n skipAi: true, // Always skip AI in CI\n categories: ['cli', 'config', 'deps', 'workspace'], // Skip AI and MCP\n });\n\n for (const check of result.checks) {\n if (check.status === 'fail') {\n issues.push({\n ruleId: `doctor-${check.category}-${check.name.toLowerCase().replace(/\\s+/g, '-')}`,\n severity: 'error',\n message: `${check.name}: ${check.message}`,\n category: 'doctor',\n context: { details: check.details },\n });\n } else if (check.status === 'warn') {\n issues.push({\n ruleId: `doctor-${check.category}-${check.name.toLowerCase().replace(/\\s+/g, '-')}`,\n severity: 'warning',\n message: `${check.name}: ${check.message}`,\n category: 'doctor',\n context: { details: check.details },\n });\n }\n }\n\n return issues;\n}\n"],"mappings":";;;;;;AAYA,eAAsB,gBACpB,UACA,SACoB;CACpB,MAAM,SAAoB,EAAE;CAI5B,MAAM,SAAS,MAAM,UAAU,UAAU;EACvC,eAHoB,QAAQ,iBAAiB,QAAQ,KAAK;EAI1D,QAAQ;EACR,YAAY;GAAC;GAAO;GAAU;GAAQ;GAAY;EACnD,CAAC;AAEF,MAAK,MAAM,SAAS,OAAO,OACzB,KAAI,MAAM,WAAW,OACnB,QAAO,KAAK;EACV,QAAQ,UAAU,MAAM,SAAS,GAAG,MAAM,KAAK,aAAa,CAAC,QAAQ,QAAQ,IAAI;EACjF,UAAU;EACV,SAAS,GAAG,MAAM,KAAK,IAAI,MAAM;EACjC,UAAU;EACV,SAAS,EAAE,SAAS,MAAM,SAAS;EACpC,CAAC;UACO,MAAM,WAAW,OAC1B,QAAO,KAAK;EACV,QAAQ,UAAU,MAAM,SAAS,GAAG,MAAM,KAAK,aAAa,CAAC,QAAQ,QAAQ,IAAI;EACjF,UAAU;EACV,SAAS,GAAG,MAAM,KAAK,IAAI,MAAM;EACjC,UAAU;EACV,SAAS,EAAE,SAAS,MAAM,SAAS;EACpC,CAAC;AAIN,QAAO"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { loadWorkspaceConfig } from "../../config.mjs";
|
|
2
|
+
import { detectDrift } from "../../drift.mjs";
|
|
3
|
+
|
|
4
|
+
//#region src/services/ci-check/checks/drift.ts
|
|
5
|
+
/**
|
|
6
|
+
* Run drift detection checks.
|
|
7
|
+
*/
|
|
8
|
+
async function runDriftChecks(adapters, _options) {
|
|
9
|
+
const { fs, logger } = adapters;
|
|
10
|
+
const issues = [];
|
|
11
|
+
const config = await loadWorkspaceConfig(fs);
|
|
12
|
+
if (!config.outputDir) {
|
|
13
|
+
logger.info("No outputDir configured, skipping drift checks");
|
|
14
|
+
return issues;
|
|
15
|
+
}
|
|
16
|
+
const contractsDir = "./contracts";
|
|
17
|
+
const generatedDir = config.outputDir;
|
|
18
|
+
if (!await fs.exists(generatedDir)) {
|
|
19
|
+
logger.info("Generated directory does not exist, skipping drift checks");
|
|
20
|
+
return issues;
|
|
21
|
+
}
|
|
22
|
+
try {
|
|
23
|
+
const result = await detectDrift(adapters, contractsDir, generatedDir);
|
|
24
|
+
if (result.hasDrift) for (const file of result.files) issues.push({
|
|
25
|
+
ruleId: "drift-detected",
|
|
26
|
+
severity: "error",
|
|
27
|
+
message: `Drift detected: generated file is out of sync with spec: ${file}`,
|
|
28
|
+
category: "drift",
|
|
29
|
+
file: `${generatedDir}/${file}`,
|
|
30
|
+
context: { file }
|
|
31
|
+
});
|
|
32
|
+
} catch (error) {
|
|
33
|
+
logger.warn("Drift detection failed", { error: error instanceof Error ? error.message : String(error) });
|
|
34
|
+
}
|
|
35
|
+
return issues;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
//#endregion
|
|
39
|
+
export { runDriftChecks };
|
|
40
|
+
//# sourceMappingURL=drift.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"drift.mjs","names":[],"sources":["../../../../src/services/ci-check/checks/drift.ts"],"sourcesContent":["/**\n * Drift detection checks.\n *\n * Detects when generated artifacts are out of sync with specs.\n */\n\nimport type { FsAdapter } from '../../../ports/fs';\nimport type { LoggerAdapter } from '../../../ports/logger';\nimport { loadWorkspaceConfig } from '../../config';\nimport { detectDrift } from '../../drift';\nimport type { CICheckOptions, CIIssue } from '../types';\n\n/**\n * Run drift detection checks.\n */\nexport async function runDriftChecks(\n adapters: { fs: FsAdapter; logger: LoggerAdapter },\n _options: CICheckOptions\n): Promise<CIIssue[]> {\n const { fs, logger } = adapters;\n const issues: CIIssue[] = [];\n\n const config = await loadWorkspaceConfig(fs);\n\n // Check if we have the required config\n if (!config.outputDir) {\n logger.info('No outputDir configured, skipping drift checks');\n return issues;\n }\n\n const contractsDir = './contracts';\n const generatedDir = config.outputDir;\n\n // Check if generated dir exists\n if (!(await fs.exists(generatedDir))) {\n logger.info('Generated directory does not exist, skipping drift checks');\n return issues;\n }\n\n try {\n const result = await detectDrift(\n adapters as Parameters<typeof detectDrift>[0],\n contractsDir,\n generatedDir\n );\n\n if (result.hasDrift) {\n for (const file of result.files) {\n issues.push({\n ruleId: 'drift-detected',\n severity: 'error',\n message: `Drift detected: generated file is out of sync with spec: ${file}`,\n category: 'drift',\n file: `${generatedDir}/${file}`,\n context: { file },\n });\n }\n }\n } catch (error) {\n logger.warn('Drift detection failed', {\n error: error instanceof Error ? error.message : String(error),\n });\n }\n\n return issues;\n}\n"],"mappings":";;;;;;;AAeA,eAAsB,eACpB,UACA,UACoB;CACpB,MAAM,EAAE,IAAI,WAAW;CACvB,MAAM,SAAoB,EAAE;CAE5B,MAAM,SAAS,MAAM,oBAAoB,GAAG;AAG5C,KAAI,CAAC,OAAO,WAAW;AACrB,SAAO,KAAK,iDAAiD;AAC7D,SAAO;;CAGT,MAAM,eAAe;CACrB,MAAM,eAAe,OAAO;AAG5B,KAAI,CAAE,MAAM,GAAG,OAAO,aAAa,EAAG;AACpC,SAAO,KAAK,4DAA4D;AACxE,SAAO;;AAGT,KAAI;EACF,MAAM,SAAS,MAAM,YACnB,UACA,cACA,aACD;AAED,MAAI,OAAO,SACT,MAAK,MAAM,QAAQ,OAAO,MACxB,QAAO,KAAK;GACV,QAAQ;GACR,UAAU;GACV,SAAS,4DAA4D;GACrE,UAAU;GACV,MAAM,GAAG,aAAa,GAAG;GACzB,SAAS,EAAE,MAAM;GAClB,CAAC;UAGC,OAAO;AACd,SAAO,KAAK,0BAA0B,EACpC,OAAO,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM,EAC9D,CAAC;;AAGJ,QAAO"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { validateImplementationFiles } from "../../validate/implementation-validator.mjs";
|
|
2
|
+
import { loadWorkspaceConfig } from "../../config.mjs";
|
|
3
|
+
|
|
4
|
+
//#region src/services/ci-check/checks/handlers.ts
|
|
5
|
+
/**
|
|
6
|
+
* Run handler implementation checks.
|
|
7
|
+
*/
|
|
8
|
+
async function runHandlerChecks(adapters, specFiles) {
|
|
9
|
+
const { fs } = adapters;
|
|
10
|
+
const issues = [];
|
|
11
|
+
const config = await loadWorkspaceConfig(fs);
|
|
12
|
+
for (const specFile of specFiles) {
|
|
13
|
+
if (!specFile.includes(".operation.")) continue;
|
|
14
|
+
const result = await validateImplementationFiles(specFile, { fs }, config, {
|
|
15
|
+
checkHandlers: true,
|
|
16
|
+
outputDir: config.outputDir
|
|
17
|
+
});
|
|
18
|
+
for (const error of result.errors) issues.push({
|
|
19
|
+
ruleId: "handler-missing",
|
|
20
|
+
severity: "warning",
|
|
21
|
+
message: error,
|
|
22
|
+
category: "handlers",
|
|
23
|
+
file: specFile
|
|
24
|
+
});
|
|
25
|
+
for (const warning of result.warnings) issues.push({
|
|
26
|
+
ruleId: "handler-warning",
|
|
27
|
+
severity: "warning",
|
|
28
|
+
message: warning,
|
|
29
|
+
category: "handlers",
|
|
30
|
+
file: specFile
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
return issues;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
//#endregion
|
|
37
|
+
export { runHandlerChecks };
|
|
38
|
+
//# sourceMappingURL=handlers.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handlers.mjs","names":[],"sources":["../../../../src/services/ci-check/checks/handlers.ts"],"sourcesContent":["/**\n * Handler implementation checks.\n */\n\nimport type { FsAdapter } from '../../../ports/fs';\nimport type { LoggerAdapter } from '../../../ports/logger';\nimport { loadWorkspaceConfig } from '../../config';\nimport { validateImplementationFiles } from '../../validate/implementation-validator';\nimport type { CIIssue } from '../types';\n\n/**\n * Run handler implementation checks.\n */\nexport async function runHandlerChecks(\n adapters: { fs: FsAdapter; logger: LoggerAdapter },\n specFiles: string[]\n): Promise<CIIssue[]> {\n const { fs } = adapters;\n const issues: CIIssue[] = [];\n\n const config = await loadWorkspaceConfig(fs);\n\n for (const specFile of specFiles) {\n // Only check operation specs\n if (!specFile.includes('.operation.')) continue;\n\n const result = await validateImplementationFiles(specFile, { fs }, config, {\n checkHandlers: true,\n outputDir: config.outputDir,\n });\n\n for (const error of result.errors) {\n issues.push({\n ruleId: 'handler-missing',\n severity: 'warning', // Handler missing is a warning, not error\n message: error,\n category: 'handlers',\n file: specFile,\n });\n }\n\n for (const warning of result.warnings) {\n issues.push({\n ruleId: 'handler-warning',\n severity: 'warning',\n message: warning,\n category: 'handlers',\n file: specFile,\n });\n }\n }\n\n return issues;\n}\n"],"mappings":";;;;;;;AAaA,eAAsB,iBACpB,UACA,WACoB;CACpB,MAAM,EAAE,OAAO;CACf,MAAM,SAAoB,EAAE;CAE5B,MAAM,SAAS,MAAM,oBAAoB,GAAG;AAE5C,MAAK,MAAM,YAAY,WAAW;AAEhC,MAAI,CAAC,SAAS,SAAS,cAAc,CAAE;EAEvC,MAAM,SAAS,MAAM,4BAA4B,UAAU,EAAE,IAAI,EAAE,QAAQ;GACzE,eAAe;GACf,WAAW,OAAO;GACnB,CAAC;AAEF,OAAK,MAAM,SAAS,OAAO,OACzB,QAAO,KAAK;GACV,QAAQ;GACR,UAAU;GACV,SAAS;GACT,UAAU;GACV,MAAM;GACP,CAAC;AAGJ,OAAK,MAAM,WAAW,OAAO,SAC3B,QAAO,KAAK;GACV,QAAQ;GACR,UAAU;GACV,SAAS;GACT,UAAU;GACV,MAAM;GACP,CAAC;;AAIN,QAAO"}
|