@contractspec/bundle.workspace 1.44.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +79 -0
- package/dist/_virtual/rolldown_runtime.js +36 -0
- package/dist/adapters/ai.d.ts +12 -0
- package/dist/adapters/ai.d.ts.map +1 -0
- package/dist/adapters/ai.js +83 -0
- package/dist/adapters/ai.js.map +1 -0
- package/dist/adapters/factory.d.ts +29 -0
- package/dist/adapters/factory.d.ts.map +1 -0
- package/dist/adapters/factory.js +37 -0
- package/dist/adapters/factory.js.map +1 -0
- package/dist/adapters/fs.d.ts +11 -0
- package/dist/adapters/fs.d.ts.map +1 -0
- package/dist/adapters/fs.js +131 -0
- package/dist/adapters/fs.js.map +1 -0
- package/dist/adapters/git.d.ts +11 -0
- package/dist/adapters/git.d.ts.map +1 -0
- package/dist/adapters/git.js +55 -0
- package/dist/adapters/git.js.map +1 -0
- package/dist/adapters/index.d.ts +7 -0
- package/dist/adapters/index.js +7 -0
- package/dist/adapters/logger.d.ts +18 -0
- package/dist/adapters/logger.d.ts.map +1 -0
- package/dist/adapters/logger.js +81 -0
- package/dist/adapters/logger.js.map +1 -0
- package/dist/adapters/watcher.d.ts +11 -0
- package/dist/adapters/watcher.d.ts.map +1 -0
- package/dist/adapters/watcher.js +74 -0
- package/dist/adapters/watcher.js.map +1 -0
- package/dist/adapters/workspace.d.ts +148 -0
- package/dist/adapters/workspace.d.ts.map +1 -0
- package/dist/adapters/workspace.js +275 -0
- package/dist/adapters/workspace.js.map +1 -0
- package/dist/ai/agents/claude-code-agent.d.ts +22 -0
- package/dist/ai/agents/claude-code-agent.d.ts.map +1 -0
- package/dist/ai/agents/claude-code-agent.js +182 -0
- package/dist/ai/agents/claude-code-agent.js.map +1 -0
- package/dist/ai/agents/cursor-agent.d.ts +68 -0
- package/dist/ai/agents/cursor-agent.d.ts.map +1 -0
- package/dist/ai/agents/cursor-agent.js +436 -0
- package/dist/ai/agents/cursor-agent.js.map +1 -0
- package/dist/ai/agents/index.js +5 -0
- package/dist/ai/agents/openai-codex-agent.d.ts +22 -0
- package/dist/ai/agents/openai-codex-agent.d.ts.map +1 -0
- package/dist/ai/agents/openai-codex-agent.js +167 -0
- package/dist/ai/agents/openai-codex-agent.js.map +1 -0
- package/dist/ai/agents/orchestrator.d.ts +50 -0
- package/dist/ai/agents/orchestrator.d.ts.map +1 -0
- package/dist/ai/agents/orchestrator.js +143 -0
- package/dist/ai/agents/orchestrator.js.map +1 -0
- package/dist/ai/agents/simple-agent.d.ts +17 -0
- package/dist/ai/agents/simple-agent.d.ts.map +1 -0
- package/dist/ai/agents/simple-agent.js +92 -0
- package/dist/ai/agents/simple-agent.js.map +1 -0
- package/dist/ai/agents/types.d.ts +36 -0
- package/dist/ai/agents/types.d.ts.map +1 -0
- package/dist/ai/client.d.ts +83 -0
- package/dist/ai/client.d.ts.map +1 -0
- package/dist/ai/client.js +163 -0
- package/dist/ai/client.js.map +1 -0
- package/dist/ai/index.d.ts +17 -0
- package/dist/ai/index.d.ts.map +1 -0
- package/dist/ai/index.js +28 -0
- package/dist/ai/index.js.map +1 -0
- package/dist/ai/prompts/code-generation.d.ts +26 -0
- package/dist/ai/prompts/code-generation.d.ts.map +1 -0
- package/dist/ai/prompts/code-generation.js +143 -0
- package/dist/ai/prompts/code-generation.js.map +1 -0
- package/dist/ai/prompts/index.d.ts +10 -0
- package/dist/ai/prompts/index.d.ts.map +1 -0
- package/dist/ai/prompts/index.js +13 -0
- package/dist/ai/prompts/index.js.map +1 -0
- package/dist/ai/prompts/spec-creation.d.ts +29 -0
- package/dist/ai/prompts/spec-creation.d.ts.map +1 -0
- package/dist/ai/prompts/spec-creation.js +111 -0
- package/dist/ai/prompts/spec-creation.js.map +1 -0
- package/dist/ai/providers.d.ts +29 -0
- package/dist/ai/providers.d.ts.map +1 -0
- package/dist/ai/providers.js +39 -0
- package/dist/ai/providers.js.map +1 -0
- package/dist/formatters/index.d.ts +11 -0
- package/dist/formatters/index.d.ts.map +1 -0
- package/dist/formatters/index.js +19 -0
- package/dist/formatters/index.js.map +1 -0
- package/dist/formatters/json.d.ts +89 -0
- package/dist/formatters/json.d.ts.map +1 -0
- package/dist/formatters/json.js +72 -0
- package/dist/formatters/json.js.map +1 -0
- package/dist/formatters/sarif.d.ts +101 -0
- package/dist/formatters/sarif.d.ts.map +1 -0
- package/dist/formatters/sarif.js +163 -0
- package/dist/formatters/sarif.js.map +1 -0
- package/dist/formatters/text.d.ts +35 -0
- package/dist/formatters/text.d.ts.map +1 -0
- package/dist/formatters/text.js +209 -0
- package/dist/formatters/text.js.map +1 -0
- package/dist/index.d.ts +82 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +204 -0
- package/dist/index.js.map +1 -0
- package/dist/ports/ai.d.ts +59 -0
- package/dist/ports/ai.d.ts.map +1 -0
- package/dist/ports/fs.d.ts +81 -0
- package/dist/ports/fs.d.ts.map +1 -0
- package/dist/ports/git.d.ts +33 -0
- package/dist/ports/git.d.ts.map +1 -0
- package/dist/ports/index.d.ts +5 -0
- package/dist/ports/logger.d.ts +88 -0
- package/dist/ports/logger.d.ts.map +1 -0
- package/dist/ports/watcher.d.ts +52 -0
- package/dist/ports/watcher.d.ts.map +1 -0
- package/dist/services/agent-guide/adapters/claude-code.d.ts +35 -0
- package/dist/services/agent-guide/adapters/claude-code.d.ts.map +1 -0
- package/dist/services/agent-guide/adapters/claude-code.js +144 -0
- package/dist/services/agent-guide/adapters/claude-code.js.map +1 -0
- package/dist/services/agent-guide/adapters/cursor-cli.d.ts +39 -0
- package/dist/services/agent-guide/adapters/cursor-cli.d.ts.map +1 -0
- package/dist/services/agent-guide/adapters/cursor-cli.js +135 -0
- package/dist/services/agent-guide/adapters/cursor-cli.js.map +1 -0
- package/dist/services/agent-guide/adapters/generic-mcp.d.ts +53 -0
- package/dist/services/agent-guide/adapters/generic-mcp.d.ts.map +1 -0
- package/dist/services/agent-guide/adapters/generic-mcp.js +159 -0
- package/dist/services/agent-guide/adapters/generic-mcp.js.map +1 -0
- package/dist/services/agent-guide/adapters/index.d.ts +23 -0
- package/dist/services/agent-guide/adapters/index.d.ts.map +1 -0
- package/dist/services/agent-guide/adapters/index.js +31 -0
- package/dist/services/agent-guide/adapters/index.js.map +1 -0
- package/dist/services/agent-guide/agent-guide-service.d.ts +56 -0
- package/dist/services/agent-guide/agent-guide-service.d.ts.map +1 -0
- package/dist/services/agent-guide/agent-guide-service.js +147 -0
- package/dist/services/agent-guide/agent-guide-service.js.map +1 -0
- package/dist/services/agent-guide/index.d.ts +6 -0
- package/dist/services/agent-guide/index.js +5 -0
- package/dist/services/agent-guide/types.d.ts +58 -0
- package/dist/services/agent-guide/types.d.ts.map +1 -0
- package/dist/services/build.d.ts +59 -0
- package/dist/services/build.d.ts.map +1 -0
- package/dist/services/build.js +140 -0
- package/dist/services/build.js.map +1 -0
- package/dist/services/ci-check/ci-check-service.d.ts +16 -0
- package/dist/services/ci-check/ci-check-service.d.ts.map +1 -0
- package/dist/services/ci-check/ci-check-service.js +392 -0
- package/dist/services/ci-check/ci-check-service.js.map +1 -0
- package/dist/services/ci-check/index.d.ts +2 -0
- package/dist/services/ci-check/index.js +2 -0
- package/dist/services/ci-check/types.d.ts +143 -0
- package/dist/services/ci-check/types.d.ts.map +1 -0
- package/dist/services/ci-check/types.js +29 -0
- package/dist/services/ci-check/types.js.map +1 -0
- package/dist/services/clean.d.ts +41 -0
- package/dist/services/clean.d.ts.map +1 -0
- package/dist/services/clean.js +72 -0
- package/dist/services/clean.js.map +1 -0
- package/dist/services/config.d.ts +26 -0
- package/dist/services/config.d.ts.map +1 -0
- package/dist/services/config.js +77 -0
- package/dist/services/config.js.map +1 -0
- package/dist/services/deps.d.ts +53 -0
- package/dist/services/deps.d.ts.map +1 -0
- package/dist/services/deps.js +62 -0
- package/dist/services/deps.js.map +1 -0
- package/dist/services/diff.d.ts +34 -0
- package/dist/services/diff.d.ts.map +1 -0
- package/dist/services/diff.js +34 -0
- package/dist/services/diff.js.map +1 -0
- package/dist/services/doctor/checks/ai.js +119 -0
- package/dist/services/doctor/checks/ai.js.map +1 -0
- package/dist/services/doctor/checks/cli.js +147 -0
- package/dist/services/doctor/checks/cli.js.map +1 -0
- package/dist/services/doctor/checks/config.js +171 -0
- package/dist/services/doctor/checks/config.js.map +1 -0
- package/dist/services/doctor/checks/deps.js +247 -0
- package/dist/services/doctor/checks/deps.js.map +1 -0
- package/dist/services/doctor/checks/index.js +6 -0
- package/dist/services/doctor/checks/mcp.js +145 -0
- package/dist/services/doctor/checks/mcp.js.map +1 -0
- package/dist/services/doctor/checks/workspace.js +244 -0
- package/dist/services/doctor/checks/workspace.js.map +1 -0
- package/dist/services/doctor/doctor-service.d.ts +24 -0
- package/dist/services/doctor/doctor-service.d.ts.map +1 -0
- package/dist/services/doctor/doctor-service.js +116 -0
- package/dist/services/doctor/doctor-service.js.map +1 -0
- package/dist/services/doctor/index.d.ts +2 -0
- package/dist/services/doctor/index.js +2 -0
- package/dist/services/doctor/types.d.ts +118 -0
- package/dist/services/doctor/types.d.ts.map +1 -0
- package/dist/services/doctor/types.js +27 -0
- package/dist/services/doctor/types.js.map +1 -0
- package/dist/services/impact/formatters.d.ts +27 -0
- package/dist/services/impact/formatters.d.ts.map +1 -0
- package/dist/services/impact/formatters.js +111 -0
- package/dist/services/impact/formatters.js.map +1 -0
- package/dist/services/impact/impact-detection-service.d.ts +22 -0
- package/dist/services/impact/impact-detection-service.d.ts.map +1 -0
- package/dist/services/impact/impact-detection-service.js +96 -0
- package/dist/services/impact/impact-detection-service.js.map +1 -0
- package/dist/services/impact/index.d.ts +11 -0
- package/dist/services/impact/index.d.ts.map +1 -0
- package/dist/services/impact/index.js +16 -0
- package/dist/services/impact/index.js.map +1 -0
- package/dist/services/impact/types.d.ts +58 -0
- package/dist/services/impact/types.d.ts.map +1 -0
- package/dist/services/implementation/discovery.d.ts +30 -0
- package/dist/services/implementation/discovery.d.ts.map +1 -0
- package/dist/services/implementation/discovery.js +144 -0
- package/dist/services/implementation/discovery.js.map +1 -0
- package/dist/services/implementation/index.d.ts +3 -0
- package/dist/services/implementation/index.js +2 -0
- package/dist/services/implementation/resolver.d.ts +44 -0
- package/dist/services/implementation/resolver.d.ts.map +1 -0
- package/dist/services/implementation/resolver.js +224 -0
- package/dist/services/implementation/resolver.js.map +1 -0
- package/dist/services/implementation/types.d.ts +79 -0
- package/dist/services/implementation/types.d.ts.map +1 -0
- package/dist/services/index.d.ts +60 -0
- package/dist/services/index.js +57 -0
- package/dist/services/integrity-diagram.d.ts +36 -0
- package/dist/services/integrity-diagram.d.ts.map +1 -0
- package/dist/services/integrity-diagram.js +275 -0
- package/dist/services/integrity-diagram.js.map +1 -0
- package/dist/services/integrity.d.ts +134 -0
- package/dist/services/integrity.d.ts.map +1 -0
- package/dist/services/integrity.js +272 -0
- package/dist/services/integrity.js.map +1 -0
- package/dist/services/list.d.ts +31 -0
- package/dist/services/list.d.ts.map +1 -0
- package/dist/services/list.js +36 -0
- package/dist/services/list.js.map +1 -0
- package/dist/services/openapi/export-service.d.ts +53 -0
- package/dist/services/openapi/export-service.d.ts.map +1 -0
- package/dist/services/openapi/export-service.js +50 -0
- package/dist/services/openapi/export-service.js.map +1 -0
- package/dist/services/openapi/import-service.d.ts +17 -0
- package/dist/services/openapi/import-service.d.ts.map +1 -0
- package/dist/services/openapi/import-service.js +74 -0
- package/dist/services/openapi/import-service.js.map +1 -0
- package/dist/services/openapi/index.d.ts +5 -0
- package/dist/services/openapi/index.js +4 -0
- package/dist/services/openapi/sync-service.d.ts +17 -0
- package/dist/services/openapi/sync-service.d.ts.map +1 -0
- package/dist/services/openapi/sync-service.js +120 -0
- package/dist/services/openapi/sync-service.js.map +1 -0
- package/dist/services/openapi/types.d.ts +162 -0
- package/dist/services/openapi/types.d.ts.map +1 -0
- package/dist/services/openapi/validate-service.d.ts +16 -0
- package/dist/services/openapi/validate-service.d.ts.map +1 -0
- package/dist/services/openapi/validate-service.js +130 -0
- package/dist/services/openapi/validate-service.js.map +1 -0
- package/dist/services/quickstart/dependencies.d.ts +31 -0
- package/dist/services/quickstart/dependencies.d.ts.map +1 -0
- package/dist/services/quickstart/dependencies.js +57 -0
- package/dist/services/quickstart/dependencies.js.map +1 -0
- package/dist/services/quickstart/index.js +2 -0
- package/dist/services/quickstart/quickstart-service.d.ts +20 -0
- package/dist/services/quickstart/quickstart-service.d.ts.map +1 -0
- package/dist/services/quickstart/quickstart-service.js +196 -0
- package/dist/services/quickstart/quickstart-service.js.map +1 -0
- package/dist/services/quickstart/types.d.ts +81 -0
- package/dist/services/quickstart/types.d.ts.map +1 -0
- package/dist/services/regenerator.d.ts +18 -0
- package/dist/services/regenerator.d.ts.map +1 -0
- package/dist/services/regenerator.js +23 -0
- package/dist/services/regenerator.js.map +1 -0
- package/dist/services/registry.d.ts +53 -0
- package/dist/services/registry.d.ts.map +1 -0
- package/dist/services/registry.js +74 -0
- package/dist/services/registry.js.map +1 -0
- package/dist/services/setup/config-generators.d.ts +42 -0
- package/dist/services/setup/config-generators.d.ts.map +1 -0
- package/dist/services/setup/config-generators.js +238 -0
- package/dist/services/setup/config-generators.js.map +1 -0
- package/dist/services/setup/file-merger.d.ts +27 -0
- package/dist/services/setup/file-merger.d.ts.map +1 -0
- package/dist/services/setup/file-merger.js +61 -0
- package/dist/services/setup/file-merger.js.map +1 -0
- package/dist/services/setup/index.js +4 -0
- package/dist/services/setup/setup-service.d.ts +12 -0
- package/dist/services/setup/setup-service.d.ts.map +1 -0
- package/dist/services/setup/setup-service.js +96 -0
- package/dist/services/setup/setup-service.js.map +1 -0
- package/dist/services/setup/targets/agents-md.js +47 -0
- package/dist/services/setup/targets/agents-md.js.map +1 -0
- package/dist/services/setup/targets/cli-config.js +60 -0
- package/dist/services/setup/targets/cli-config.js.map +1 -0
- package/dist/services/setup/targets/cursor-rules.js +48 -0
- package/dist/services/setup/targets/cursor-rules.js.map +1 -0
- package/dist/services/setup/targets/mcp-claude.js +60 -0
- package/dist/services/setup/targets/mcp-claude.js.map +1 -0
- package/dist/services/setup/targets/mcp-cursor.js +59 -0
- package/dist/services/setup/targets/mcp-cursor.js.map +1 -0
- package/dist/services/setup/targets/vscode-settings.js +63 -0
- package/dist/services/setup/targets/vscode-settings.js.map +1 -0
- package/dist/services/setup/types.d.ts +85 -0
- package/dist/services/setup/types.d.ts.map +1 -0
- package/dist/services/setup/types.js +27 -0
- package/dist/services/setup/types.js.map +1 -0
- package/dist/services/sync.d.ts +41 -0
- package/dist/services/sync.d.ts.map +1 -0
- package/dist/services/sync.js +63 -0
- package/dist/services/sync.js.map +1 -0
- package/dist/services/test.d.ts +15 -0
- package/dist/services/test.d.ts.map +1 -0
- package/dist/services/test.js +30 -0
- package/dist/services/test.js.map +1 -0
- package/dist/services/validate-implementation.d.ts +32 -0
- package/dist/services/validate-implementation.d.ts.map +1 -0
- package/dist/services/validate-implementation.js +64 -0
- package/dist/services/validate-implementation.js.map +1 -0
- package/dist/services/validate.d.ts +41 -0
- package/dist/services/validate.d.ts.map +1 -0
- package/dist/services/validate.js +48 -0
- package/dist/services/validate.js.map +1 -0
- package/dist/services/verification-cache/adapters/filesystem.d.ts +46 -0
- package/dist/services/verification-cache/adapters/filesystem.d.ts.map +1 -0
- package/dist/services/verification-cache/adapters/filesystem.js +120 -0
- package/dist/services/verification-cache/adapters/filesystem.js.map +1 -0
- package/dist/services/verification-cache/adapters/in-memory.d.ts +27 -0
- package/dist/services/verification-cache/adapters/in-memory.d.ts.map +1 -0
- package/dist/services/verification-cache/adapters/in-memory.js +46 -0
- package/dist/services/verification-cache/adapters/in-memory.js.map +1 -0
- package/dist/services/verification-cache/adapters/index.d.ts +3 -0
- package/dist/services/verification-cache/adapters/index.js +3 -0
- package/dist/services/verification-cache/adapters/workspace-state.d.ts +49 -0
- package/dist/services/verification-cache/adapters/workspace-state.d.ts.map +1 -0
- package/dist/services/verification-cache/adapters/workspace-state.js +91 -0
- package/dist/services/verification-cache/adapters/workspace-state.js.map +1 -0
- package/dist/services/verification-cache/cache-service.d.ts +70 -0
- package/dist/services/verification-cache/cache-service.d.ts.map +1 -0
- package/dist/services/verification-cache/cache-service.js +256 -0
- package/dist/services/verification-cache/cache-service.js.map +1 -0
- package/dist/services/verification-cache/index.d.ts +6 -0
- package/dist/services/verification-cache/index.js +6 -0
- package/dist/services/verification-cache/types.d.ts +124 -0
- package/dist/services/verification-cache/types.d.ts.map +1 -0
- package/dist/services/verification-cache/types.js +16 -0
- package/dist/services/verification-cache/types.js.map +1 -0
- package/dist/services/verify/ai-verifier.d.ts +25 -0
- package/dist/services/verify/ai-verifier.d.ts.map +1 -0
- package/dist/services/verify/ai-verifier.js +403 -0
- package/dist/services/verify/ai-verifier.js.map +1 -0
- package/dist/services/verify/behavior-verifier.d.ts +12 -0
- package/dist/services/verify/behavior-verifier.d.ts.map +1 -0
- package/dist/services/verify/behavior-verifier.js +186 -0
- package/dist/services/verify/behavior-verifier.js.map +1 -0
- package/dist/services/verify/index.d.ts +5 -0
- package/dist/services/verify/index.js +4 -0
- package/dist/services/verify/structure-verifier.d.ts +12 -0
- package/dist/services/verify/structure-verifier.d.ts.map +1 -0
- package/dist/services/verify/structure-verifier.js +196 -0
- package/dist/services/verify/structure-verifier.js.map +1 -0
- package/dist/services/verify/types.d.ts +137 -0
- package/dist/services/verify/types.d.ts.map +1 -0
- package/dist/services/verify/verify-service.d.ts +60 -0
- package/dist/services/verify/verify-service.d.ts.map +1 -0
- package/dist/services/verify/verify-service.js +204 -0
- package/dist/services/verify/verify-service.js.map +1 -0
- package/dist/services/watch.d.ts +25 -0
- package/dist/services/watch.d.ts.map +1 -0
- package/dist/services/watch.js +32 -0
- package/dist/services/watch.js.map +1 -0
- package/dist/services/workspace-info.d.ts +62 -0
- package/dist/services/workspace-info.d.ts.map +1 -0
- package/dist/services/workspace-info.js +103 -0
- package/dist/services/workspace-info.js.map +1 -0
- package/dist/templates/app-config.template.d.ts +7 -0
- package/dist/templates/app-config.template.d.ts.map +1 -0
- package/dist/templates/app-config.template.js +107 -0
- package/dist/templates/app-config.template.js.map +1 -0
- package/dist/templates/data-view.template.d.ts +7 -0
- package/dist/templates/data-view.template.d.ts.map +1 -0
- package/dist/templates/data-view.template.js +70 -0
- package/dist/templates/data-view.template.js.map +1 -0
- package/dist/templates/event.template.d.ts +11 -0
- package/dist/templates/event.template.d.ts.map +1 -0
- package/dist/templates/event.template.js +40 -0
- package/dist/templates/event.template.js.map +1 -0
- package/dist/templates/experiment.template.d.ts +7 -0
- package/dist/templates/experiment.template.d.ts.map +1 -0
- package/dist/templates/experiment.template.js +89 -0
- package/dist/templates/experiment.template.js.map +1 -0
- package/dist/templates/handler.template.d.ts +16 -0
- package/dist/templates/handler.template.d.ts.map +1 -0
- package/dist/templates/handler.template.js +100 -0
- package/dist/templates/handler.template.js.map +1 -0
- package/dist/templates/index.d.ts +21 -0
- package/dist/templates/index.d.ts.map +1 -0
- package/dist/templates/index.js +37 -0
- package/dist/templates/index.js.map +1 -0
- package/dist/templates/integration.template.d.ts +7 -0
- package/dist/templates/integration.template.d.ts.map +1 -0
- package/dist/templates/integration.template.js +160 -0
- package/dist/templates/integration.template.js.map +1 -0
- package/dist/templates/knowledge.template.d.ts +7 -0
- package/dist/templates/knowledge.template.d.ts.map +1 -0
- package/dist/templates/knowledge.template.js +75 -0
- package/dist/templates/knowledge.template.js.map +1 -0
- package/dist/templates/migration.template.d.ts +7 -0
- package/dist/templates/migration.template.d.ts.map +1 -0
- package/dist/templates/migration.template.js +62 -0
- package/dist/templates/migration.template.js.map +1 -0
- package/dist/templates/operation.template.d.ts +11 -0
- package/dist/templates/operation.template.d.ts.map +1 -0
- package/dist/templates/operation.template.js +105 -0
- package/dist/templates/operation.template.js.map +1 -0
- package/dist/templates/presentation.template.d.ts +11 -0
- package/dist/templates/presentation.template.d.ts.map +1 -0
- package/dist/templates/presentation.template.js +80 -0
- package/dist/templates/presentation.template.js.map +1 -0
- package/dist/templates/telemetry.template.d.ts +7 -0
- package/dist/templates/telemetry.template.d.ts.map +1 -0
- package/dist/templates/telemetry.template.js +91 -0
- package/dist/templates/telemetry.template.js.map +1 -0
- package/dist/templates/workflow-runner.template.d.ts +16 -0
- package/dist/templates/workflow-runner.template.d.ts.map +1 -0
- package/dist/templates/workflow-runner.template.js +50 -0
- package/dist/templates/workflow-runner.template.js.map +1 -0
- package/dist/templates/workflow.template.d.ts +7 -0
- package/dist/templates/workflow.template.d.ts.map +1 -0
- package/dist/templates/workflow.template.js +69 -0
- package/dist/templates/workflow.template.js.map +1 -0
- package/dist/types/config.d.ts +34 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types.d.ts +324 -0
- package/dist/types.d.ts.map +1 -0
- package/package.json +68 -0
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
//#region src/ports/fs.d.ts
|
|
2
|
+
/**
|
|
3
|
+
* Filesystem adapter port.
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* File statistics.
|
|
7
|
+
*/
|
|
8
|
+
interface FileStat {
|
|
9
|
+
size: number;
|
|
10
|
+
isFile: boolean;
|
|
11
|
+
isDirectory: boolean;
|
|
12
|
+
mtime: Date;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Options for file discovery.
|
|
16
|
+
*/
|
|
17
|
+
interface DiscoverOptions {
|
|
18
|
+
pattern?: string;
|
|
19
|
+
patterns?: string[];
|
|
20
|
+
ignore?: string[];
|
|
21
|
+
/** Working directory for glob patterns. Defaults to process.cwd(). */
|
|
22
|
+
cwd?: string;
|
|
23
|
+
/** Return absolute paths instead of relative. Defaults to true. */
|
|
24
|
+
absolute?: boolean;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Filesystem adapter interface.
|
|
28
|
+
*/
|
|
29
|
+
interface FsAdapter {
|
|
30
|
+
/**
|
|
31
|
+
* Check if a file or directory exists.
|
|
32
|
+
*/
|
|
33
|
+
exists(path: string): Promise<boolean>;
|
|
34
|
+
/**
|
|
35
|
+
* Read file contents as string.
|
|
36
|
+
*/
|
|
37
|
+
readFile(path: string): Promise<string>;
|
|
38
|
+
/**
|
|
39
|
+
* Write file contents.
|
|
40
|
+
*/
|
|
41
|
+
writeFile(path: string, content: string): Promise<void>;
|
|
42
|
+
/**
|
|
43
|
+
* Delete a file or directory.
|
|
44
|
+
*/
|
|
45
|
+
remove(path: string): Promise<void>;
|
|
46
|
+
/**
|
|
47
|
+
* Get file statistics.
|
|
48
|
+
*/
|
|
49
|
+
stat(path: string): Promise<FileStat>;
|
|
50
|
+
/**
|
|
51
|
+
* Create directory (recursive).
|
|
52
|
+
*/
|
|
53
|
+
mkdir(path: string): Promise<void>;
|
|
54
|
+
/**
|
|
55
|
+
* Discover files matching patterns.
|
|
56
|
+
*/
|
|
57
|
+
glob(options: DiscoverOptions): Promise<string[]>;
|
|
58
|
+
/**
|
|
59
|
+
* Resolve path relative to cwd.
|
|
60
|
+
*/
|
|
61
|
+
resolve(...paths: string[]): string;
|
|
62
|
+
/**
|
|
63
|
+
* Get directory name from path.
|
|
64
|
+
*/
|
|
65
|
+
dirname(path: string): string;
|
|
66
|
+
/**
|
|
67
|
+
* Get base name from path.
|
|
68
|
+
*/
|
|
69
|
+
basename(path: string): string;
|
|
70
|
+
/**
|
|
71
|
+
* Join path segments.
|
|
72
|
+
*/
|
|
73
|
+
join(...paths: string[]): string;
|
|
74
|
+
/**
|
|
75
|
+
* Get relative path from base.
|
|
76
|
+
*/
|
|
77
|
+
relative(from: string, to: string): string;
|
|
78
|
+
}
|
|
79
|
+
//#endregion
|
|
80
|
+
export { DiscoverOptions, FileStat, FsAdapter };
|
|
81
|
+
//# sourceMappingURL=fs.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fs.d.ts","names":[],"sources":["../../src/ports/fs.ts"],"sourcesContent":[],"mappings":";;AAOA;AAUA;AAaA;;;AAc4C,UArC3B,QAAA,CAqC2B;EAKpB,IAAA,EAAA,MAAA;EAKM,MAAA,EAAA,OAAA;EAAR,WAAA,EAAA,OAAA;EAKC,KAAA,EAhDd,IAgDc;;;;;UA1CN,eAAA;;;;;;;;;;;;UAaA,SAAA;;;;wBAIO;;;;0BAKE;;;;4CAKkB;;;;wBAKpB;;;;sBAKF,QAAQ;;;;uBAKP;;;;gBAKP,kBAAkB"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
//#region src/ports/git.d.ts
|
|
2
|
+
/**
|
|
3
|
+
* Git adapter port.
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Git adapter interface.
|
|
7
|
+
*/
|
|
8
|
+
interface GitAdapter {
|
|
9
|
+
/**
|
|
10
|
+
* Get file contents at a specific git ref (branch, tag, commit).
|
|
11
|
+
*/
|
|
12
|
+
showFile(ref: string, filePath: string): Promise<string>;
|
|
13
|
+
/**
|
|
14
|
+
* Clean untracked files (dangerous operation).
|
|
15
|
+
*/
|
|
16
|
+
clean(options?: GitCleanOptions): Promise<void>;
|
|
17
|
+
/**
|
|
18
|
+
* Check if path is inside a git repository.
|
|
19
|
+
*/
|
|
20
|
+
isGitRepo(path?: string): Promise<boolean>;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Options for git clean.
|
|
24
|
+
*/
|
|
25
|
+
interface GitCleanOptions {
|
|
26
|
+
dryRun?: boolean;
|
|
27
|
+
force?: boolean;
|
|
28
|
+
directories?: boolean;
|
|
29
|
+
ignored?: boolean;
|
|
30
|
+
}
|
|
31
|
+
//#endregion
|
|
32
|
+
export { GitAdapter, GitCleanOptions };
|
|
33
|
+
//# sourceMappingURL=git.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"git.d.ts","names":[],"sources":["../../src/ports/git.ts"],"sourcesContent":[],"mappings":";;AAOA;;;;;AAcmC,UAdlB,UAAA,CAckB;EAMlB;;;2CAhB0B;;;;kBAKzB,kBAAkB;;;;4BAKR;;;;;UAMX,eAAA"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { DiscoverOptions, FileStat, FsAdapter } from "./fs.js";
|
|
2
|
+
import { GitAdapter, GitCleanOptions } from "./git.js";
|
|
3
|
+
import { WatchEvent, WatchEventHandler, WatchEventType, WatchOptions, Watcher, WatcherAdapter } from "./watcher.js";
|
|
4
|
+
import { AiAdapter, AiGenerateOptions, AiGenerateResult, AiGenerateStructuredOptions, AiValidationResult } from "./ai.js";
|
|
5
|
+
import { LogLevel, LoggerAdapter, ProgressReporter, ProgressUpdate, WorkspaceAdapters } from "./logger.js";
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { FsAdapter } from "./fs.js";
|
|
2
|
+
import { GitAdapter } from "./git.js";
|
|
3
|
+
import { WatcherAdapter } from "./watcher.js";
|
|
4
|
+
import { AiAdapter } from "./ai.js";
|
|
5
|
+
|
|
6
|
+
//#region src/ports/logger.d.ts
|
|
7
|
+
/**
|
|
8
|
+
* Logger and progress reporter port.
|
|
9
|
+
*/
|
|
10
|
+
/**
|
|
11
|
+
* Log level.
|
|
12
|
+
*/
|
|
13
|
+
type LogLevel = 'debug' | 'info' | 'warn' | 'error';
|
|
14
|
+
/**
|
|
15
|
+
* Progress update.
|
|
16
|
+
*/
|
|
17
|
+
interface ProgressUpdate {
|
|
18
|
+
message: string;
|
|
19
|
+
current?: number;
|
|
20
|
+
total?: number;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Progress reporter for long-running operations.
|
|
24
|
+
*/
|
|
25
|
+
interface ProgressReporter {
|
|
26
|
+
/**
|
|
27
|
+
* Start progress reporting.
|
|
28
|
+
*/
|
|
29
|
+
start(message: string): void;
|
|
30
|
+
/**
|
|
31
|
+
* Update progress.
|
|
32
|
+
*/
|
|
33
|
+
update(update: ProgressUpdate): void;
|
|
34
|
+
/**
|
|
35
|
+
* Mark as succeeded.
|
|
36
|
+
*/
|
|
37
|
+
succeed(message?: string): void;
|
|
38
|
+
/**
|
|
39
|
+
* Mark as failed.
|
|
40
|
+
*/
|
|
41
|
+
fail(message?: string): void;
|
|
42
|
+
/**
|
|
43
|
+
* Mark as warned.
|
|
44
|
+
*/
|
|
45
|
+
warn(message?: string): void;
|
|
46
|
+
/**
|
|
47
|
+
* Stop progress reporting.
|
|
48
|
+
*/
|
|
49
|
+
stop(): void;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Logger adapter interface.
|
|
53
|
+
*/
|
|
54
|
+
interface LoggerAdapter {
|
|
55
|
+
/**
|
|
56
|
+
* Log debug message.
|
|
57
|
+
*/
|
|
58
|
+
debug(message: string, data?: Record<string, unknown>): void;
|
|
59
|
+
/**
|
|
60
|
+
* Log info message.
|
|
61
|
+
*/
|
|
62
|
+
info(message: string, data?: Record<string, unknown>): void;
|
|
63
|
+
/**
|
|
64
|
+
* Log warning message.
|
|
65
|
+
*/
|
|
66
|
+
warn(message: string, data?: Record<string, unknown>): void;
|
|
67
|
+
/**
|
|
68
|
+
* Log error message.
|
|
69
|
+
*/
|
|
70
|
+
error(message: string, data?: Record<string, unknown>): void;
|
|
71
|
+
/**
|
|
72
|
+
* Create a progress reporter.
|
|
73
|
+
*/
|
|
74
|
+
createProgress(): ProgressReporter;
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Combined adapters for workspace services.
|
|
78
|
+
*/
|
|
79
|
+
interface WorkspaceAdapters {
|
|
80
|
+
fs: FsAdapter;
|
|
81
|
+
git: GitAdapter;
|
|
82
|
+
watcher: WatcherAdapter;
|
|
83
|
+
ai: AiAdapter;
|
|
84
|
+
logger: LoggerAdapter;
|
|
85
|
+
}
|
|
86
|
+
//#endregion
|
|
87
|
+
export { LogLevel, LoggerAdapter, ProgressReporter, ProgressUpdate, WorkspaceAdapters };
|
|
88
|
+
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","names":[],"sources":["../../src/ports/logger.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;;;AAOY,KAAA,QAAA,GAAQ,OAAA,GAAA,MAAA,GAAA,MAAA,GAAA,OAAA;AAKpB;AASA;AAmCA;AAIgC,UAhDf,cAAA,CAgDe;EAKD,OAAA,EAAA,MAAA;EAKA,OAAA,CAAA,EAAA,MAAA;EAKC,KAAA,CAAA,EAAA,MAAA;;;AAWhC;;AAC8B,UAlEb,gBAAA,CAkEa;EACG;;;EAGV,KAAA,CAAA,OAAA,EAAA,MAAA,CAAA,EAAA,IAAA;;;;iBA7DN;;;;;;;;;;;;;;;;;;;;;UA0BA,aAAA;;;;gCAIe;;;;+BAKD;;;;+BAKA;;;;gCAKC;;;;oBAKZ;;;;;UAMH,iBAAA;MAAiB;OACJ;WACG;MACY;UAEnC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
//#region src/ports/watcher.d.ts
|
|
2
|
+
/**
|
|
3
|
+
* File watcher adapter port.
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Watcher event types.
|
|
7
|
+
*/
|
|
8
|
+
type WatchEventType = 'add' | 'change' | 'unlink';
|
|
9
|
+
/**
|
|
10
|
+
* Watcher event.
|
|
11
|
+
*/
|
|
12
|
+
interface WatchEvent {
|
|
13
|
+
type: WatchEventType;
|
|
14
|
+
path: string;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Watcher event handler.
|
|
18
|
+
*/
|
|
19
|
+
type WatchEventHandler = (event: WatchEvent) => void | Promise<void>;
|
|
20
|
+
/**
|
|
21
|
+
* Options for file watching.
|
|
22
|
+
*/
|
|
23
|
+
interface WatchOptions {
|
|
24
|
+
pattern: string;
|
|
25
|
+
ignore?: string[];
|
|
26
|
+
debounceMs?: number;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Watcher instance.
|
|
30
|
+
*/
|
|
31
|
+
interface Watcher {
|
|
32
|
+
/**
|
|
33
|
+
* Register event handler.
|
|
34
|
+
*/
|
|
35
|
+
on(handler: WatchEventHandler): void;
|
|
36
|
+
/**
|
|
37
|
+
* Stop watching.
|
|
38
|
+
*/
|
|
39
|
+
close(): Promise<void>;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* File watcher adapter interface.
|
|
43
|
+
*/
|
|
44
|
+
interface WatcherAdapter {
|
|
45
|
+
/**
|
|
46
|
+
* Start watching files matching pattern.
|
|
47
|
+
*/
|
|
48
|
+
watch(options: WatchOptions): Watcher;
|
|
49
|
+
}
|
|
50
|
+
//#endregion
|
|
51
|
+
export { WatchEvent, WatchEventHandler, WatchEventType, WatchOptions, Watcher, WatcherAdapter };
|
|
52
|
+
//# sourceMappingURL=watcher.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"watcher.d.ts","names":[],"sources":["../../src/ports/watcher.ts"],"sourcesContent":[],"mappings":";;AAOA;AAKA;AAQA;AAKA;AASA;AAeiB,KA1CL,cAAA,GA0CmB,KAId,GAAA,QAAA,GAAe,QAAO;;;;UAzCtB,UAAA;QACT;;;;;;KAOI,iBAAA,WAA4B,sBAAsB;;;;UAK7C,YAAA;;;;;;;;UASA,OAAA;;;;cAIH;;;;WAKH;;;;;UAMM,cAAA;;;;iBAIA,eAAe"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { AgentAdapter } from "../types.js";
|
|
2
|
+
import { AnyOperationSpec } from "@contractspec/lib.contracts";
|
|
3
|
+
import { AgentPrompt, ImplementationPlan } from "@contractspec/lib.contracts/llm";
|
|
4
|
+
|
|
5
|
+
//#region src/services/agent-guide/adapters/claude-code.d.ts
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Claude Code adapter implementation.
|
|
9
|
+
* Optimized for Claude's extended thinking and code generation capabilities.
|
|
10
|
+
*/
|
|
11
|
+
declare class ClaudeCodeAdapter implements AgentAdapter {
|
|
12
|
+
agentType: "claude-code";
|
|
13
|
+
/**
|
|
14
|
+
* Format an implementation plan for Claude Code.
|
|
15
|
+
* Uses structured markdown with clear sections and checklists.
|
|
16
|
+
*/
|
|
17
|
+
formatPlan(plan: ImplementationPlan): AgentPrompt;
|
|
18
|
+
/**
|
|
19
|
+
* Generate agent-specific configuration.
|
|
20
|
+
* For Claude Code, this generates a prompt that can be used as context.
|
|
21
|
+
*/
|
|
22
|
+
generateConfig(spec: AnyOperationSpec): string;
|
|
23
|
+
/**
|
|
24
|
+
* Parse Claude Code output to extract generated code.
|
|
25
|
+
*/
|
|
26
|
+
parseOutput(output: string): {
|
|
27
|
+
code?: string;
|
|
28
|
+
errors?: string[];
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
/** Singleton instance */
|
|
32
|
+
declare const claudeCodeAdapter: ClaudeCodeAdapter;
|
|
33
|
+
//#endregion
|
|
34
|
+
export { ClaudeCodeAdapter, claudeCodeAdapter };
|
|
35
|
+
//# sourceMappingURL=claude-code.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"claude-code.d.ts","names":[],"sources":["../../../../src/services/agent-guide/adapters/claude-code.ts"],"sourcesContent":[],"mappings":";;;;;;;;AAoNA;;cAjMa,iBAAA,YAA6B;;;;;;mBAOvB,qBAAqB;;;;;uBAyHjB;;;;;;;;;;cAiEV,mBAAiB"}
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import { AGENT_SYSTEM_PROMPTS } from "@contractspec/lib.contracts/llm";
|
|
2
|
+
|
|
3
|
+
//#region src/services/agent-guide/adapters/claude-code.ts
|
|
4
|
+
/**
|
|
5
|
+
* Claude Code adapter implementation.
|
|
6
|
+
* Optimized for Claude's extended thinking and code generation capabilities.
|
|
7
|
+
*/
|
|
8
|
+
var ClaudeCodeAdapter = class {
|
|
9
|
+
agentType = "claude-code";
|
|
10
|
+
/**
|
|
11
|
+
* Format an implementation plan for Claude Code.
|
|
12
|
+
* Uses structured markdown with clear sections and checklists.
|
|
13
|
+
*/
|
|
14
|
+
formatPlan(plan) {
|
|
15
|
+
const lines = [];
|
|
16
|
+
lines.push(`# Implement: ${plan.target.key}.v${plan.target.version}`);
|
|
17
|
+
lines.push("");
|
|
18
|
+
lines.push("## Context");
|
|
19
|
+
lines.push("");
|
|
20
|
+
lines.push(`**Goal:** ${plan.context.goal}`);
|
|
21
|
+
lines.push("");
|
|
22
|
+
lines.push(`**Description:** ${plan.context.description}`);
|
|
23
|
+
lines.push("");
|
|
24
|
+
if (plan.context.background) {
|
|
25
|
+
lines.push(`**Background:**`);
|
|
26
|
+
lines.push(plan.context.background);
|
|
27
|
+
lines.push("");
|
|
28
|
+
}
|
|
29
|
+
lines.push("## Specification");
|
|
30
|
+
lines.push("");
|
|
31
|
+
lines.push(plan.specMarkdown);
|
|
32
|
+
lines.push("");
|
|
33
|
+
if (plan.fileStructure.length > 0) {
|
|
34
|
+
lines.push("## Files to Create/Modify");
|
|
35
|
+
lines.push("");
|
|
36
|
+
for (const file of plan.fileStructure) {
|
|
37
|
+
const icon = file.type === "create" ? "📝" : "✏️";
|
|
38
|
+
lines.push(`${icon} \`${file.path}\``);
|
|
39
|
+
lines.push(` ${file.purpose}`);
|
|
40
|
+
lines.push("");
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
lines.push("## Implementation Steps");
|
|
44
|
+
lines.push("");
|
|
45
|
+
for (const step of plan.steps) {
|
|
46
|
+
lines.push(`### ${step.order}. ${step.title}`);
|
|
47
|
+
lines.push("");
|
|
48
|
+
lines.push(step.description);
|
|
49
|
+
lines.push("");
|
|
50
|
+
lines.push("**Acceptance Criteria:**");
|
|
51
|
+
for (const criteria of step.acceptanceCriteria) lines.push(`- [ ] ${criteria}`);
|
|
52
|
+
lines.push("");
|
|
53
|
+
}
|
|
54
|
+
if (plan.constraints.policy.length > 0 || plan.constraints.security.length > 0 || plan.constraints.pii.length > 0) {
|
|
55
|
+
lines.push("## Constraints");
|
|
56
|
+
lines.push("");
|
|
57
|
+
if (plan.constraints.policy.length > 0) {
|
|
58
|
+
lines.push("### Policy");
|
|
59
|
+
for (const p of plan.constraints.policy) lines.push(`- ${p}`);
|
|
60
|
+
lines.push("");
|
|
61
|
+
}
|
|
62
|
+
if (plan.constraints.security.length > 0) {
|
|
63
|
+
lines.push("### Security");
|
|
64
|
+
for (const s of plan.constraints.security) lines.push(`- ⚠️ ${s}`);
|
|
65
|
+
lines.push("");
|
|
66
|
+
}
|
|
67
|
+
if (plan.constraints.pii.length > 0) {
|
|
68
|
+
lines.push("### PII Handling");
|
|
69
|
+
lines.push("The following fields contain personally identifiable information:");
|
|
70
|
+
for (const pii of plan.constraints.pii) lines.push(`- \`${pii}\``);
|
|
71
|
+
lines.push("");
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
lines.push("## Verification Checklist");
|
|
75
|
+
lines.push("");
|
|
76
|
+
lines.push("Before submitting, verify:");
|
|
77
|
+
for (const check of plan.verificationChecklist) lines.push(`- [ ] ${check}`);
|
|
78
|
+
lines.push("");
|
|
79
|
+
lines.push("## Instructions");
|
|
80
|
+
lines.push("");
|
|
81
|
+
lines.push("1. Implement each step in order");
|
|
82
|
+
lines.push("2. Use TypeScript with strict typing (no `any`)");
|
|
83
|
+
lines.push("3. Include JSDoc comments for public APIs");
|
|
84
|
+
lines.push("4. Handle all error cases defined in the spec");
|
|
85
|
+
lines.push("5. Emit events as specified");
|
|
86
|
+
lines.push("6. Mark checklist items as you complete them");
|
|
87
|
+
lines.push("");
|
|
88
|
+
return {
|
|
89
|
+
agent: "claude-code",
|
|
90
|
+
systemPrompt: AGENT_SYSTEM_PROMPTS["claude-code"],
|
|
91
|
+
taskPrompt: lines.join("\n")
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Generate agent-specific configuration.
|
|
96
|
+
* For Claude Code, this generates a prompt that can be used as context.
|
|
97
|
+
*/
|
|
98
|
+
generateConfig(spec) {
|
|
99
|
+
const lines = [];
|
|
100
|
+
lines.push("# ContractSpec Implementation Context");
|
|
101
|
+
lines.push("");
|
|
102
|
+
lines.push("This codebase uses ContractSpec for spec-first development.");
|
|
103
|
+
lines.push("");
|
|
104
|
+
lines.push("## Spec Details");
|
|
105
|
+
lines.push("");
|
|
106
|
+
lines.push(`- **Name:** ${spec.meta.key}`);
|
|
107
|
+
lines.push(`- **Version:** ${spec.meta.version}`);
|
|
108
|
+
lines.push(`- **Kind:** ${spec.meta.kind}`);
|
|
109
|
+
lines.push(`- **Stability:** ${spec.meta.stability}`);
|
|
110
|
+
lines.push("");
|
|
111
|
+
lines.push("## Implementation Requirements");
|
|
112
|
+
lines.push("");
|
|
113
|
+
lines.push("1. Match input/output types exactly");
|
|
114
|
+
lines.push("2. Handle all defined error cases");
|
|
115
|
+
lines.push("3. Emit events as specified");
|
|
116
|
+
lines.push("4. Respect policy constraints");
|
|
117
|
+
lines.push("");
|
|
118
|
+
return lines.join("\n");
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Parse Claude Code output to extract generated code.
|
|
122
|
+
*/
|
|
123
|
+
parseOutput(output) {
|
|
124
|
+
const codeBlockMatch = output.match(/```(?:typescript|ts|tsx)?\n([\s\S]*?)\n```/);
|
|
125
|
+
if (codeBlockMatch?.[1]) return { code: codeBlockMatch[1] };
|
|
126
|
+
const errors = [];
|
|
127
|
+
for (const pattern of [
|
|
128
|
+
/error:\s*(.+)/gi,
|
|
129
|
+
/failed:\s*(.+)/gi,
|
|
130
|
+
/cannot\s+(.+)/gi
|
|
131
|
+
]) {
|
|
132
|
+
const matches = output.matchAll(pattern);
|
|
133
|
+
for (const match of matches) if (match[1]) errors.push(match[1]);
|
|
134
|
+
}
|
|
135
|
+
if (errors.length > 0) return { errors };
|
|
136
|
+
return { code: output };
|
|
137
|
+
}
|
|
138
|
+
};
|
|
139
|
+
/** Singleton instance */
|
|
140
|
+
const claudeCodeAdapter = new ClaudeCodeAdapter();
|
|
141
|
+
|
|
142
|
+
//#endregion
|
|
143
|
+
export { ClaudeCodeAdapter, claudeCodeAdapter };
|
|
144
|
+
//# sourceMappingURL=claude-code.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"claude-code.js","names":["lines: string[]","errors: string[]"],"sources":["../../../../src/services/agent-guide/adapters/claude-code.ts"],"sourcesContent":["/**\n * Claude Code Agent Adapter\n *\n * Formats implementation plans and prompts for Claude Code (Anthropic's\n * advanced coding agent mode).\n */\n\nimport type { AnyOperationSpec } from '@contractspec/lib.contracts';\nimport type {\n AgentPrompt,\n ImplementationPlan,\n} from '@contractspec/lib.contracts/llm';\nimport { AGENT_SYSTEM_PROMPTS } from '@contractspec/lib.contracts/llm';\nimport type { AgentAdapter } from '../types';\n\n/**\n * Claude Code adapter implementation.\n * Optimized for Claude's extended thinking and code generation capabilities.\n */\nexport class ClaudeCodeAdapter implements AgentAdapter {\n agentType = 'claude-code' as const;\n\n /**\n * Format an implementation plan for Claude Code.\n * Uses structured markdown with clear sections and checklists.\n */\n formatPlan(plan: ImplementationPlan): AgentPrompt {\n const lines: string[] = [];\n\n // Header\n lines.push(`# Implement: ${plan.target.key}.v${plan.target.version}`);\n lines.push('');\n\n // Context section\n lines.push('## Context');\n lines.push('');\n lines.push(`**Goal:** ${plan.context.goal}`);\n lines.push('');\n lines.push(`**Description:** ${plan.context.description}`);\n lines.push('');\n if (plan.context.background) {\n lines.push(`**Background:**`);\n lines.push(plan.context.background);\n lines.push('');\n }\n\n // Full specification\n lines.push('## Specification');\n lines.push('');\n lines.push(plan.specMarkdown);\n lines.push('');\n\n // File structure\n if (plan.fileStructure.length > 0) {\n lines.push('## Files to Create/Modify');\n lines.push('');\n for (const file of plan.fileStructure) {\n const icon = file.type === 'create' ? '📝' : '✏️';\n lines.push(`${icon} \\`${file.path}\\``);\n lines.push(` ${file.purpose}`);\n lines.push('');\n }\n }\n\n // Implementation steps\n lines.push('## Implementation Steps');\n lines.push('');\n for (const step of plan.steps) {\n lines.push(`### ${step.order}. ${step.title}`);\n lines.push('');\n lines.push(step.description);\n lines.push('');\n lines.push('**Acceptance Criteria:**');\n for (const criteria of step.acceptanceCriteria) {\n lines.push(`- [ ] ${criteria}`);\n }\n lines.push('');\n }\n\n // Constraints\n if (\n plan.constraints.policy.length > 0 ||\n plan.constraints.security.length > 0 ||\n plan.constraints.pii.length > 0\n ) {\n lines.push('## Constraints');\n lines.push('');\n\n if (plan.constraints.policy.length > 0) {\n lines.push('### Policy');\n for (const p of plan.constraints.policy) {\n lines.push(`- ${p}`);\n }\n lines.push('');\n }\n\n if (plan.constraints.security.length > 0) {\n lines.push('### Security');\n for (const s of plan.constraints.security) {\n lines.push(`- ⚠️ ${s}`);\n }\n lines.push('');\n }\n\n if (plan.constraints.pii.length > 0) {\n lines.push('### PII Handling');\n lines.push(\n 'The following fields contain personally identifiable information:'\n );\n for (const pii of plan.constraints.pii) {\n lines.push(`- \\`${pii}\\``);\n }\n lines.push('');\n }\n }\n\n // Verification checklist\n lines.push('## Verification Checklist');\n lines.push('');\n lines.push('Before submitting, verify:');\n for (const check of plan.verificationChecklist) {\n lines.push(`- [ ] ${check}`);\n }\n lines.push('');\n\n // Instructions\n lines.push('## Instructions');\n lines.push('');\n lines.push('1. Implement each step in order');\n lines.push('2. Use TypeScript with strict typing (no `any`)');\n lines.push('3. Include JSDoc comments for public APIs');\n lines.push('4. Handle all error cases defined in the spec');\n lines.push('5. Emit events as specified');\n lines.push('6. Mark checklist items as you complete them');\n lines.push('');\n\n return {\n agent: 'claude-code',\n systemPrompt: AGENT_SYSTEM_PROMPTS['claude-code'],\n taskPrompt: lines.join('\\n'),\n };\n }\n\n /**\n * Generate agent-specific configuration.\n * For Claude Code, this generates a prompt that can be used as context.\n */\n generateConfig(spec: AnyOperationSpec): string {\n const lines: string[] = [];\n\n lines.push('# ContractSpec Implementation Context');\n lines.push('');\n lines.push('This codebase uses ContractSpec for spec-first development.');\n lines.push('');\n lines.push('## Spec Details');\n lines.push('');\n lines.push(`- **Name:** ${spec.meta.key}`);\n lines.push(`- **Version:** ${spec.meta.version}`);\n lines.push(`- **Kind:** ${spec.meta.kind}`);\n lines.push(`- **Stability:** ${spec.meta.stability}`);\n lines.push('');\n lines.push('## Implementation Requirements');\n lines.push('');\n lines.push('1. Match input/output types exactly');\n lines.push('2. Handle all defined error cases');\n lines.push('3. Emit events as specified');\n lines.push('4. Respect policy constraints');\n lines.push('');\n\n return lines.join('\\n');\n }\n\n /**\n * Parse Claude Code output to extract generated code.\n */\n parseOutput(output: string): { code?: string; errors?: string[] } {\n // Extract code from markdown code blocks\n const codeBlockMatch = output.match(\n /```(?:typescript|ts|tsx)?\\n([\\s\\S]*?)\\n```/\n );\n\n if (codeBlockMatch?.[1]) {\n return { code: codeBlockMatch[1] };\n }\n\n // Check for error indicators\n const errors: string[] = [];\n const errorPatterns = [\n /error:\\s*(.+)/gi,\n /failed:\\s*(.+)/gi,\n /cannot\\s+(.+)/gi,\n ];\n\n for (const pattern of errorPatterns) {\n const matches = output.matchAll(pattern);\n for (const match of matches) {\n if (match[1]) {\n errors.push(match[1]);\n }\n }\n }\n\n if (errors.length > 0) {\n return { errors };\n }\n\n // Return raw output if no code block found\n return { code: output };\n }\n}\n\n/** Singleton instance */\nexport const claudeCodeAdapter = new ClaudeCodeAdapter();\n"],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { AgentAdapter } from "../types.js";
|
|
2
|
+
import { AnyOperationSpec } from "@contractspec/lib.contracts";
|
|
3
|
+
import { AgentPrompt, ImplementationPlan } from "@contractspec/lib.contracts/llm";
|
|
4
|
+
|
|
5
|
+
//#region src/services/agent-guide/adapters/cursor-cli.d.ts
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Cursor CLI adapter implementation.
|
|
9
|
+
* Optimized for Cursor's background/composer mode.
|
|
10
|
+
*/
|
|
11
|
+
declare class CursorCLIAdapter implements AgentAdapter {
|
|
12
|
+
agentType: "cursor-cli";
|
|
13
|
+
/**
|
|
14
|
+
* Format an implementation plan for Cursor CLI.
|
|
15
|
+
* Uses concise format optimized for Cursor's context window.
|
|
16
|
+
*/
|
|
17
|
+
formatPlan(plan: ImplementationPlan): AgentPrompt;
|
|
18
|
+
/**
|
|
19
|
+
* Generate Cursor rules (.mdc format) for a spec.
|
|
20
|
+
* Can be saved to .cursor/rules/ to provide persistent context.
|
|
21
|
+
*/
|
|
22
|
+
generateConfig(spec: AnyOperationSpec): string;
|
|
23
|
+
/**
|
|
24
|
+
* Generate a cursor rules file path for a spec.
|
|
25
|
+
*/
|
|
26
|
+
getCursorRulesPath(spec: AnyOperationSpec): string;
|
|
27
|
+
/**
|
|
28
|
+
* Parse Cursor output to extract generated code.
|
|
29
|
+
*/
|
|
30
|
+
parseOutput(output: string): {
|
|
31
|
+
code?: string;
|
|
32
|
+
errors?: string[];
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
/** Singleton instance */
|
|
36
|
+
declare const cursorCLIAdapter: CursorCLIAdapter;
|
|
37
|
+
//#endregion
|
|
38
|
+
export { CursorCLIAdapter, cursorCLIAdapter };
|
|
39
|
+
//# sourceMappingURL=cursor-cli.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cursor-cli.d.ts","names":[],"sources":["../../../../src/services/agent-guide/adapters/cursor-cli.ts"],"sourcesContent":[],"mappings":";;;;;;;;;AAqNA;cAlMa,gBAAA,YAA4B;;;;;;mBAOtB,qBAAqB;;;;;uBAoEjB;;;;2BA+FI;;;;;;;;;;cAwBd,kBAAgB"}
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
import { AGENT_SYSTEM_PROMPTS } from "@contractspec/lib.contracts/llm";
|
|
2
|
+
|
|
3
|
+
//#region src/services/agent-guide/adapters/cursor-cli.ts
|
|
4
|
+
/**
|
|
5
|
+
* Cursor CLI adapter implementation.
|
|
6
|
+
* Optimized for Cursor's background/composer mode.
|
|
7
|
+
*/
|
|
8
|
+
var CursorCLIAdapter = class {
|
|
9
|
+
agentType = "cursor-cli";
|
|
10
|
+
/**
|
|
11
|
+
* Format an implementation plan for Cursor CLI.
|
|
12
|
+
* Uses concise format optimized for Cursor's context window.
|
|
13
|
+
*/
|
|
14
|
+
formatPlan(plan) {
|
|
15
|
+
const lines = [];
|
|
16
|
+
lines.push(`# ${plan.target.key}.v${plan.target.version}`);
|
|
17
|
+
lines.push("");
|
|
18
|
+
lines.push(`> ${plan.context.goal}`);
|
|
19
|
+
lines.push("");
|
|
20
|
+
if (plan.fileStructure.length > 0) {
|
|
21
|
+
lines.push("## Files");
|
|
22
|
+
lines.push("");
|
|
23
|
+
for (const file of plan.fileStructure) lines.push(`- ${file.type}: \`${file.path}\` - ${file.purpose}`);
|
|
24
|
+
lines.push("");
|
|
25
|
+
}
|
|
26
|
+
lines.push("## Spec");
|
|
27
|
+
lines.push("");
|
|
28
|
+
lines.push(plan.specMarkdown);
|
|
29
|
+
lines.push("");
|
|
30
|
+
lines.push("## Steps");
|
|
31
|
+
lines.push("");
|
|
32
|
+
for (const step of plan.steps) lines.push(`${step.order}. **${step.title}**: ${step.description}`);
|
|
33
|
+
lines.push("");
|
|
34
|
+
const constraints = [...plan.constraints.policy, ...plan.constraints.security.map((s) => `⚠️ ${s}`)];
|
|
35
|
+
if (constraints.length > 0) {
|
|
36
|
+
lines.push("## Constraints");
|
|
37
|
+
lines.push("");
|
|
38
|
+
for (const c of constraints) lines.push(`- ${c}`);
|
|
39
|
+
lines.push("");
|
|
40
|
+
}
|
|
41
|
+
if (plan.constraints.pii.length > 0) {
|
|
42
|
+
lines.push("## PII Fields");
|
|
43
|
+
lines.push("");
|
|
44
|
+
lines.push(`Handle carefully: ${plan.constraints.pii.map((p) => `\`${p}\``).join(", ")}`);
|
|
45
|
+
lines.push("");
|
|
46
|
+
}
|
|
47
|
+
return {
|
|
48
|
+
agent: "cursor-cli",
|
|
49
|
+
systemPrompt: AGENT_SYSTEM_PROMPTS["cursor-cli"],
|
|
50
|
+
taskPrompt: lines.join("\n")
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Generate Cursor rules (.mdc format) for a spec.
|
|
55
|
+
* Can be saved to .cursor/rules/ to provide persistent context.
|
|
56
|
+
*/
|
|
57
|
+
generateConfig(spec) {
|
|
58
|
+
const m = spec.meta;
|
|
59
|
+
const lines = [];
|
|
60
|
+
lines.push("---");
|
|
61
|
+
lines.push(`description: Implementation rules for ${m.key}.v${m.version}`);
|
|
62
|
+
lines.push(`globs: ["**/${m.key.replace(/\./g, "/")}/**"]`);
|
|
63
|
+
lines.push("alwaysApply: false");
|
|
64
|
+
lines.push("---");
|
|
65
|
+
lines.push("");
|
|
66
|
+
lines.push(`# ${m.key} Implementation Rules`);
|
|
67
|
+
lines.push("");
|
|
68
|
+
lines.push(`This ${m.kind} operation must follow the ContractSpec specification.`);
|
|
69
|
+
lines.push("");
|
|
70
|
+
lines.push("## Goal");
|
|
71
|
+
lines.push("");
|
|
72
|
+
lines.push(m.goal);
|
|
73
|
+
lines.push("");
|
|
74
|
+
lines.push("## Requirements");
|
|
75
|
+
lines.push("");
|
|
76
|
+
lines.push("1. Input/output types MUST match the spec schema exactly");
|
|
77
|
+
lines.push("2. All error cases MUST be handled");
|
|
78
|
+
if (spec.sideEffects?.emits?.length) lines.push("3. Events MUST be emitted as specified");
|
|
79
|
+
lines.push(`4. Auth level: ${spec.policy.auth}`);
|
|
80
|
+
if (spec.policy.idempotent !== void 0) lines.push(`5. Idempotency: ${spec.policy.idempotent}`);
|
|
81
|
+
lines.push("");
|
|
82
|
+
if (spec.io.errors && Object.keys(spec.io.errors).length > 0) {
|
|
83
|
+
lines.push("## Error Cases");
|
|
84
|
+
lines.push("");
|
|
85
|
+
for (const [code, err] of Object.entries(spec.io.errors)) lines.push(`- \`${code}\` (HTTP ${err.http ?? 400}): ${err.when}`);
|
|
86
|
+
lines.push("");
|
|
87
|
+
}
|
|
88
|
+
if (spec.sideEffects?.emits?.length) {
|
|
89
|
+
lines.push("## Events to Emit");
|
|
90
|
+
lines.push("");
|
|
91
|
+
for (const e of spec.sideEffects.emits) if ("ref" in e) lines.push(`- \`${e.ref.key}.v${e.ref.version}\`: ${e.when}`);
|
|
92
|
+
else lines.push(`- \`${e.key}.v${e.version}\`: ${e.when}`);
|
|
93
|
+
lines.push("");
|
|
94
|
+
}
|
|
95
|
+
if (spec.policy.pii?.length) {
|
|
96
|
+
lines.push("## PII Handling");
|
|
97
|
+
lines.push("");
|
|
98
|
+
lines.push("These fields contain PII and must be handled with care:");
|
|
99
|
+
for (const field of spec.policy.pii) lines.push(`- \`${field}\``);
|
|
100
|
+
lines.push("");
|
|
101
|
+
}
|
|
102
|
+
if (spec.acceptance?.scenarios?.length) {
|
|
103
|
+
lines.push("## Acceptance Scenarios");
|
|
104
|
+
lines.push("");
|
|
105
|
+
for (const s of spec.acceptance.scenarios) {
|
|
106
|
+
lines.push(`### ${s.key}`);
|
|
107
|
+
lines.push(`- Given: ${s.given.join("; ")}`);
|
|
108
|
+
lines.push(`- When: ${s.when.join("; ")}`);
|
|
109
|
+
lines.push(`- Then: ${s.then.join("; ")}`);
|
|
110
|
+
lines.push("");
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
return lines.join("\n");
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Generate a cursor rules file path for a spec.
|
|
117
|
+
*/
|
|
118
|
+
getCursorRulesPath(spec) {
|
|
119
|
+
return `.cursor/rules/${spec.meta.key.replace(/\./g, "-")}.mdc`;
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Parse Cursor output to extract generated code.
|
|
123
|
+
*/
|
|
124
|
+
parseOutput(output) {
|
|
125
|
+
const codeBlockMatch = output.match(/```(?:typescript|ts|tsx|javascript|js)?\n([\s\S]*?)\n```/);
|
|
126
|
+
if (codeBlockMatch?.[1]) return { code: codeBlockMatch[1] };
|
|
127
|
+
return { code: output };
|
|
128
|
+
}
|
|
129
|
+
};
|
|
130
|
+
/** Singleton instance */
|
|
131
|
+
const cursorCLIAdapter = new CursorCLIAdapter();
|
|
132
|
+
|
|
133
|
+
//#endregion
|
|
134
|
+
export { CursorCLIAdapter, cursorCLIAdapter };
|
|
135
|
+
//# sourceMappingURL=cursor-cli.js.map
|