goatcode-sh 0.0.1 → 0.1.3
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/.github/workflows/ci.yml +85 -0
- package/.github/workflows/release.yml +107 -0
- package/.opencode/plugins/goatcode.js +1 -0
- package/AGENTS.md +59 -0
- package/CONTRIBUTING.md +110 -0
- package/LICENSE +21 -0
- package/README.md +106 -12
- package/bun.lock +2081 -0
- package/bunfig.toml +3 -0
- package/dist/agents/advisor/config.d.ts +4 -0
- package/dist/agents/advisor/index.d.ts +2 -0
- package/dist/agents/advisor/plugin.d.ts +1 -0
- package/dist/agents/advisor/prompt-meta.d.ts +2 -0
- package/dist/agents/advisor/prompt.d.ts +1 -0
- package/dist/agents/agent-builder.d.ts +10 -0
- package/dist/agents/agent-registry.d.ts +8 -0
- package/dist/agents/builtin-agents.d.ts +2 -0
- package/dist/agents/deep-worker/config.d.ts +4 -0
- package/dist/agents/deep-worker/index.d.ts +2 -0
- package/dist/agents/deep-worker/plugin.d.ts +1 -0
- package/dist/agents/deep-worker/prompt-meta.d.ts +2 -0
- package/dist/agents/deep-worker/prompt.d.ts +1 -0
- package/dist/agents/explorer/config.d.ts +4 -0
- package/dist/agents/explorer/index.d.ts +2 -0
- package/dist/agents/explorer/plugin.d.ts +1 -0
- package/dist/agents/explorer/prompt-meta.d.ts +2 -0
- package/dist/agents/explorer/prompt.d.ts +1 -0
- package/dist/agents/fallback-chains.d.ts +2 -0
- package/dist/agents/index.d.ts +14 -0
- package/dist/agents/orchestrator/config.d.ts +4 -0
- package/dist/agents/orchestrator/index.d.ts +2 -0
- package/dist/agents/orchestrator/plugin.d.ts +1 -0
- package/dist/agents/orchestrator/prompt-meta.d.ts +2 -0
- package/dist/agents/orchestrator/prompt.d.ts +1 -0
- package/dist/agents/planner/config.d.ts +4 -0
- package/dist/agents/planner/index.d.ts +2 -0
- package/dist/agents/planner/plugin.d.ts +1 -0
- package/dist/agents/planner/prompt-meta.d.ts +2 -0
- package/dist/agents/planner/prompt.d.ts +1 -0
- package/dist/agents/prompt-meta.d.ts +11 -0
- package/dist/agents/prompt-registry.d.ts +4 -0
- package/dist/agents/researcher/config.d.ts +4 -0
- package/dist/agents/researcher/index.d.ts +2 -0
- package/dist/agents/researcher/plugin.d.ts +1 -0
- package/dist/agents/researcher/prompt-meta.d.ts +2 -0
- package/dist/agents/researcher/prompt.d.ts +1 -0
- package/dist/agents/tool-restrictions.d.ts +7 -0
- package/dist/agents/worker/config.d.ts +4 -0
- package/dist/agents/worker/index.d.ts +2 -0
- package/dist/agents/worker/plugin.d.ts +1 -0
- package/dist/agents/worker/prompt-meta.d.ts +2 -0
- package/dist/agents/worker/prompt.d.ts +1 -0
- package/dist/bootstrap.d.ts +3 -0
- package/dist/cli/cli.d.ts +3 -0
- package/dist/cli/commands/install.d.ts +12 -0
- package/dist/cli/commands/update.d.ts +1 -0
- package/dist/cli/config-generator.d.ts +26 -0
- package/dist/cli/index.d.ts +2 -0
- package/dist/config/defaults.d.ts +3 -0
- package/dist/config/define-config.d.ts +27 -0
- package/dist/config/index.d.ts +6 -0
- package/dist/config/loader.d.ts +3 -0
- package/dist/config/paths.d.ts +4 -0
- package/dist/config/schema.d.ts +273 -0
- package/dist/config/validator.d.ts +9 -0
- package/dist/features/auto-update/index.d.ts +3 -0
- package/dist/features/auto-update/plugin.d.ts +2 -0
- package/dist/features/auto-update/update-checker.d.ts +7 -0
- package/dist/features/background-agent/concurrency.d.ts +10 -0
- package/dist/features/background-agent/index.d.ts +6 -0
- package/dist/features/background-agent/manager.d.ts +18 -0
- package/dist/features/background-agent/poller.d.ts +17 -0
- package/dist/features/background-agent/singleton.d.ts +7 -0
- package/dist/features/background-agent/spawner.d.ts +6 -0
- package/dist/features/background-agent/types.d.ts +18 -0
- package/dist/features/builtin-features.d.ts +2 -0
- package/dist/features/categories/category-config.d.ts +9 -0
- package/dist/features/categories/category-resolver.d.ts +6 -0
- package/dist/features/categories/index.d.ts +3 -0
- package/dist/features/categories/prompt-appends.d.ts +10 -0
- package/dist/features/loops/file-store.d.ts +22 -0
- package/dist/features/loops/handler.d.ts +9 -0
- package/dist/features/loops/index.d.ts +5 -0
- package/dist/features/loops/memory-store.d.ts +11 -0
- package/dist/features/loops/plugin.d.ts +34 -0
- package/dist/features/loops/shared/event-utils.d.ts +7 -0
- package/dist/features/loops/state.d.ts +22 -0
- package/dist/features/prompt-builder/agent-table-builder.d.ts +6 -0
- package/dist/features/prompt-builder/category-section-builder.d.ts +2 -0
- package/dist/features/prompt-builder/dynamic-prompt-builder.d.ts +9 -0
- package/dist/features/prompt-builder/index.d.ts +7 -0
- package/dist/features/prompt-builder/skill-section-builder.d.ts +5 -0
- package/dist/features/session-state/index.d.ts +5 -0
- package/dist/features/session-state/session-cursor.d.ts +13 -0
- package/dist/features/session-state/session-store.d.ts +12 -0
- package/dist/features/session-state/session-tools-store.d.ts +4 -0
- package/dist/features/skills/builtin/git-master.d.ts +2 -0
- package/dist/features/skills/index.d.ts +10 -0
- package/dist/features/skills/skill-loader.d.ts +22 -0
- package/dist/features/skills/skill-merger.d.ts +2 -0
- package/dist/features/slash-commands/command-registry.d.ts +3 -0
- package/dist/features/slash-commands/commands/cancel-loop.d.ts +2 -0
- package/dist/features/slash-commands/commands/handoff.d.ts +2 -0
- package/dist/features/slash-commands/commands/init-deep.d.ts +2 -0
- package/dist/features/slash-commands/commands/loop.d.ts +2 -0
- package/dist/features/slash-commands/commands/start-work.d.ts +2 -0
- package/dist/features/slash-commands/commands/stop-continuation.d.ts +2 -0
- package/dist/features/slash-commands/index.d.ts +2 -0
- package/dist/features/slash-commands/types.d.ts +5 -0
- package/dist/hooks/anthropic-effort/handler.d.ts +5 -0
- package/dist/hooks/anthropic-effort/index.d.ts +3 -0
- package/dist/hooks/anthropic-effort/plugin.d.ts +1 -0
- package/dist/hooks/builtin-hooks.d.ts +2 -0
- package/dist/hooks/comment-checker/handler.d.ts +5 -0
- package/dist/hooks/comment-checker/index.d.ts +2 -0
- package/dist/hooks/comment-checker/plugin.d.ts +1 -0
- package/dist/hooks/compaction-context/handler.d.ts +2 -0
- package/dist/hooks/compaction-context/index.d.ts +2 -0
- package/dist/hooks/compaction-context/plugin.d.ts +1 -0
- package/dist/hooks/compaction-todo-preserver/handler.d.ts +4 -0
- package/dist/hooks/compaction-todo-preserver/index.d.ts +2 -0
- package/dist/hooks/compaction-todo-preserver/plugin.d.ts +1 -0
- package/dist/hooks/context-injector/handlers/agents.d.ts +1 -0
- package/dist/hooks/context-injector/handlers/readme.d.ts +1 -0
- package/dist/hooks/context-injector/handlers/rules.d.ts +1 -0
- package/dist/hooks/context-injector/index.d.ts +4 -0
- package/dist/hooks/context-injector/plugin.d.ts +1 -0
- package/dist/hooks/context-window-limit/handler.d.ts +6 -0
- package/dist/hooks/context-window-limit/index.d.ts +2 -0
- package/dist/hooks/context-window-limit/plugin.d.ts +1 -0
- package/dist/hooks/delegate-retry/handler.d.ts +16 -0
- package/dist/hooks/delegate-retry/index.d.ts +3 -0
- package/dist/hooks/delegate-retry/plugin.d.ts +1 -0
- package/dist/hooks/edit-error/handler.d.ts +6 -0
- package/dist/hooks/edit-error/index.d.ts +2 -0
- package/dist/hooks/edit-error/plugin.d.ts +1 -0
- package/dist/hooks/empty-response-detector/handler.d.ts +5 -0
- package/dist/hooks/empty-response-detector/index.d.ts +2 -0
- package/dist/hooks/empty-response-detector/plugin.d.ts +1 -0
- package/dist/hooks/error-diagnostics/handler.d.ts +6 -0
- package/dist/hooks/error-diagnostics/patterns.d.ts +3 -0
- package/dist/hooks/error-diagnostics/plugin.d.ts +1 -0
- package/dist/hooks/error-diagnostics/types.d.ts +14 -0
- package/dist/hooks/foreground-fallback/handler.d.ts +22 -0
- package/dist/hooks/foreground-fallback/index.d.ts +2 -0
- package/dist/hooks/foreground-fallback/plugin.d.ts +1 -0
- package/dist/hooks/hashline-diff-enhancer/handler.d.ts +28 -0
- package/dist/hooks/hashline-diff-enhancer/index.d.ts +2 -0
- package/dist/hooks/hashline-diff-enhancer/plugin.d.ts +1 -0
- package/dist/hooks/hashline-read-enhancer/handler.d.ts +4 -0
- package/dist/hooks/hashline-read-enhancer/index.d.ts +2 -0
- package/dist/hooks/hashline-read-enhancer/plugin.d.ts +1 -0
- package/dist/hooks/hook-composer.d.ts +4 -0
- package/dist/hooks/hook-ordering.d.ts +9 -0
- package/dist/hooks/hook-types.d.ts +3 -0
- package/dist/hooks/index.d.ts +6 -0
- package/dist/hooks/json-error/handler.d.ts +6 -0
- package/dist/hooks/json-error/index.d.ts +2 -0
- package/dist/hooks/json-error/plugin.d.ts +1 -0
- package/dist/hooks/keyword-detector/handler.d.ts +8 -0
- package/dist/hooks/keyword-detector/index.d.ts +3 -0
- package/dist/hooks/keyword-detector/plugin.d.ts +1 -0
- package/dist/hooks/model-fallback/handler.d.ts +21 -0
- package/dist/hooks/model-fallback/index.d.ts +2 -0
- package/dist/hooks/model-fallback/plugin.d.ts +1 -0
- package/dist/hooks/phase-reminder/handler.d.ts +5 -0
- package/dist/hooks/phase-reminder/index.d.ts +2 -0
- package/dist/hooks/phase-reminder/plugin.d.ts +1 -0
- package/dist/hooks/post-read-nudge/handler.d.ts +6 -0
- package/dist/hooks/post-read-nudge/index.d.ts +2 -0
- package/dist/hooks/post-read-nudge/plugin.d.ts +1 -0
- package/dist/hooks/preemptive-compaction/handler.d.ts +31 -0
- package/dist/hooks/preemptive-compaction/index.d.ts +2 -0
- package/dist/hooks/preemptive-compaction/plugin.d.ts +1 -0
- package/dist/hooks/runtime-fallback/handler.d.ts +21 -0
- package/dist/hooks/runtime-fallback/index.d.ts +2 -0
- package/dist/hooks/runtime-fallback/plugin.d.ts +1 -0
- package/dist/hooks/safe-hook-wrapper.d.ts +2 -0
- package/dist/hooks/session-recovery/handler.d.ts +6 -0
- package/dist/hooks/session-recovery/index.d.ts +2 -0
- package/dist/hooks/session-recovery/plugin.d.ts +1 -0
- package/dist/hooks/skill-discovery/plugin.d.ts +1 -0
- package/dist/hooks/stop-guard/handler.d.ts +4 -0
- package/dist/hooks/stop-guard/index.d.ts +2 -0
- package/dist/hooks/stop-guard/plugin.d.ts +1 -0
- package/dist/hooks/task-resume-info/handler.d.ts +4 -0
- package/dist/hooks/task-resume-info/index.d.ts +2 -0
- package/dist/hooks/task-resume-info/plugin.d.ts +1 -0
- package/dist/hooks/think-mode/handler.d.ts +4 -0
- package/dist/hooks/think-mode/index.d.ts +2 -0
- package/dist/hooks/think-mode/plugin.d.ts +1 -0
- package/dist/hooks/thinking-block-validator/handler.d.ts +4 -0
- package/dist/hooks/thinking-block-validator/index.d.ts +2 -0
- package/dist/hooks/thinking-block-validator/plugin.d.ts +1 -0
- package/dist/hooks/todo-enforcer/handler.d.ts +4 -0
- package/dist/hooks/todo-enforcer/index.d.ts +2 -0
- package/dist/hooks/todo-enforcer/plugin.d.ts +1 -0
- package/dist/hooks/todowrite-disabler/handler.d.ts +6 -0
- package/dist/hooks/todowrite-disabler/index.d.ts +2 -0
- package/dist/hooks/todowrite-disabler/plugin.d.ts +1 -0
- package/dist/hooks/tool-output-truncator/handler.d.ts +4 -0
- package/dist/hooks/tool-output-truncator/index.d.ts +2 -0
- package/dist/hooks/tool-output-truncator/plugin.d.ts +1 -0
- package/dist/hooks/write-file-guard/handler.d.ts +7 -0
- package/dist/hooks/write-file-guard/index.d.ts +2 -0
- package/dist/hooks/write-file-guard/plugin.d.ts +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.js +8623 -0
- package/dist/plugin/compositor.d.ts +9 -0
- package/dist/plugin/index.d.ts +1 -0
- package/dist/plugin-api/define-plugin.d.ts +33 -0
- package/dist/plugin-api/index.d.ts +3 -0
- package/dist/plugin-api/types.d.ts +10 -0
- package/dist/registry/agent-aggregator.d.ts +3 -0
- package/dist/registry/contribution-aggregator.d.ts +10 -0
- package/dist/registry/dependency-resolver.d.ts +3 -0
- package/dist/registry/hook-aggregator.d.ts +2 -0
- package/dist/registry/index.d.ts +6 -0
- package/dist/registry/plugin-registry.d.ts +16 -0
- package/dist/registry/tool-aggregator.d.ts +3 -0
- package/dist/registry/types.d.ts +9 -0
- package/dist/runtime/index.d.ts +7 -0
- package/dist/shared/data-path.d.ts +4 -0
- package/dist/shared/deep-merge.d.ts +13 -0
- package/dist/shared/fallback-chain.d.ts +1 -0
- package/dist/shared/index.d.ts +19 -0
- package/dist/shared/logger.d.ts +4 -0
- package/dist/shared/model-availability.d.ts +1 -0
- package/dist/shared/model-normalization.d.ts +6 -0
- package/dist/shared/model-prefix-map.d.ts +11 -0
- package/dist/shared/model-resolution-pipeline.d.ts +14 -0
- package/dist/shared/models-dev.d.ts +29 -0
- package/dist/shared/provider-discovery.d.ts +28 -0
- package/dist/shared/provider-registry.d.ts +16 -0
- package/dist/shared/safe-create-hook.d.ts +3 -0
- package/dist/shared/snake-case.d.ts +1 -0
- package/dist/shared/truncate-description.d.ts +1 -0
- package/dist/test-utils/index.d.ts +6 -0
- package/dist/test-utils/mock-agent-config.d.ts +5 -0
- package/dist/test-utils/mock-hook-inputs.d.ts +20 -0
- package/dist/test-utils/mock-hook-outputs.d.ts +20 -0
- package/dist/test-utils/mock-plugin-context.d.ts +6 -0
- package/dist/test-utils/mock-sdk-client.d.ts +41 -0
- package/dist/test-utils/mock-tool-context.d.ts +6 -0
- package/dist/tools/ast-grep/index.d.ts +4 -0
- package/dist/tools/ast-grep/replace/handler.d.ts +7 -0
- package/dist/tools/ast-grep/replace/plugin.d.ts +1 -0
- package/dist/tools/ast-grep/replace/types.d.ts +37 -0
- package/dist/tools/ast-grep/search/handler.d.ts +14 -0
- package/dist/tools/ast-grep/search/plugin.d.ts +1 -0
- package/dist/tools/ast-grep/search/types.d.ts +37 -0
- package/dist/tools/background-task/cancel/handler.d.ts +4 -0
- package/dist/tools/background-task/cancel/plugin.d.ts +2 -0
- package/dist/tools/background-task/cancel/types.d.ts +4 -0
- package/dist/tools/background-task/index.d.ts +2 -0
- package/dist/tools/background-task/output/handler.d.ts +3 -0
- package/dist/tools/background-task/output/plugin.d.ts +2 -0
- package/dist/tools/background-task/output/types.d.ts +11 -0
- package/dist/tools/bridge.d.ts +7 -0
- package/dist/tools/builtin-tools.d.ts +2 -0
- package/dist/tools/delegate-task/category-resolver.d.ts +4 -0
- package/dist/tools/delegate-task/constants.d.ts +3 -0
- package/dist/tools/delegate-task/executor.d.ts +10 -0
- package/dist/tools/delegate-task/handler.d.ts +4 -0
- package/dist/tools/delegate-task/index.d.ts +7 -0
- package/dist/tools/delegate-task/plugin.d.ts +4 -0
- package/dist/tools/delegate-task/types.d.ts +17 -0
- package/dist/tools/glob/handler.d.ts +7 -0
- package/dist/tools/glob/index.d.ts +2 -0
- package/dist/tools/glob/plugin.d.ts +1 -0
- package/dist/tools/glob/types.d.ts +7 -0
- package/dist/tools/grep/handler.d.ts +13 -0
- package/dist/tools/grep/index.d.ts +2 -0
- package/dist/tools/grep/plugin.d.ts +1 -0
- package/dist/tools/grep/types.d.ts +15 -0
- package/dist/tools/hashline-edit/constants.d.ts +4 -0
- package/dist/tools/hashline-edit/edit-operations.d.ts +4 -0
- package/dist/tools/hashline-edit/handler.d.ts +5 -0
- package/dist/tools/hashline-edit/hash-computation.d.ts +2 -0
- package/dist/tools/hashline-edit/index.d.ts +5 -0
- package/dist/tools/hashline-edit/plugin.d.ts +3 -0
- package/dist/tools/hashline-edit/types.d.ts +21 -0
- package/dist/tools/index.d.ts +4 -0
- package/dist/tools/look-at/handler.d.ts +6 -0
- package/dist/tools/look-at/index.d.ts +3 -0
- package/dist/tools/look-at/plugin.d.ts +1 -0
- package/dist/tools/look-at/types.d.ts +9 -0
- package/dist/tools/lsp/client.d.ts +7 -0
- package/dist/tools/lsp/diagnostics/handler.d.ts +2 -0
- package/dist/tools/lsp/diagnostics/plugin.d.ts +1 -0
- package/dist/tools/lsp/diagnostics/types.d.ts +13 -0
- package/dist/tools/lsp/find-references/handler.d.ts +2 -0
- package/dist/tools/lsp/find-references/plugin.d.ts +1 -0
- package/dist/tools/lsp/find-references/types.d.ts +8 -0
- package/dist/tools/lsp/goto-definition/handler.d.ts +2 -0
- package/dist/tools/lsp/goto-definition/plugin.d.ts +1 -0
- package/dist/tools/lsp/goto-definition/types.d.ts +7 -0
- package/dist/tools/lsp/index.d.ts +6 -0
- package/dist/tools/lsp/prepare-rename/handler.d.ts +2 -0
- package/dist/tools/lsp/prepare-rename/plugin.d.ts +1 -0
- package/dist/tools/lsp/prepare-rename/types.d.ts +7 -0
- package/dist/tools/lsp/rename/handler.d.ts +2 -0
- package/dist/tools/lsp/rename/plugin.d.ts +1 -0
- package/dist/tools/lsp/rename/types.d.ts +8 -0
- package/dist/tools/lsp/symbols/handler.d.ts +2 -0
- package/dist/tools/lsp/symbols/plugin.d.ts +1 -0
- package/dist/tools/lsp/symbols/types.d.ts +11 -0
- package/dist/tools/session-manager/client-context.d.ts +3 -0
- package/dist/tools/session-manager/index.d.ts +5 -0
- package/dist/tools/session-manager/info/handler.d.ts +3 -0
- package/dist/tools/session-manager/info/plugin.d.ts +1 -0
- package/dist/tools/session-manager/info/types.d.ts +3 -0
- package/dist/tools/session-manager/list/handler.d.ts +3 -0
- package/dist/tools/session-manager/list/plugin.d.ts +1 -0
- package/dist/tools/session-manager/list/types.d.ts +6 -0
- package/dist/tools/session-manager/read/handler.d.ts +3 -0
- package/dist/tools/session-manager/read/plugin.d.ts +1 -0
- package/dist/tools/session-manager/read/types.d.ts +6 -0
- package/dist/tools/session-manager/search/handler.d.ts +3 -0
- package/dist/tools/session-manager/search/plugin.d.ts +1 -0
- package/dist/tools/session-manager/search/types.d.ts +6 -0
- package/dist/tools/session-manager/session-formatter.d.ts +29 -0
- package/dist/tools/session-manager/types.d.ts +36 -0
- package/dist/tools/shared/constants.d.ts +3 -0
- package/dist/tools/skill/handler.d.ts +4 -0
- package/dist/tools/skill/index.d.ts +3 -0
- package/dist/tools/skill/plugin.d.ts +1 -0
- package/dist/tools/skill/types.d.ts +12 -0
- package/dist/tools/skill-mcp/handler.d.ts +5 -0
- package/dist/tools/skill-mcp/index.d.ts +3 -0
- package/dist/tools/skill-mcp/plugin.d.ts +1 -0
- package/dist/tools/skill-mcp/types.d.ts +13 -0
- package/dist/tools/task/create/handler.d.ts +2 -0
- package/dist/tools/task/create/plugin.d.ts +1 -0
- package/dist/tools/task/format-task.d.ts +2 -0
- package/dist/tools/task/get/handler.d.ts +2 -0
- package/dist/tools/task/get/plugin.d.ts +1 -0
- package/dist/tools/task/index.d.ts +4 -0
- package/dist/tools/task/list/handler.d.ts +2 -0
- package/dist/tools/task/list/plugin.d.ts +1 -0
- package/dist/tools/task/storage.d.ts +7 -0
- package/dist/tools/task/types.d.ts +84 -0
- package/dist/tools/task/update/handler.d.ts +2 -0
- package/dist/tools/task/update/plugin.d.ts +1 -0
- package/dist/tools/tool-builder.d.ts +7 -0
- package/dist/tools/tool-registry-adapter.d.ts +3 -0
- package/dist/types/agent.d.ts +40 -0
- package/dist/types/category.d.ts +22 -0
- package/dist/types/config.d.ts +23 -0
- package/dist/types/hook.d.ts +18 -0
- package/dist/types/index.d.ts +12 -0
- package/dist/types/plugin.d.ts +41 -0
- package/dist/types/tool.d.ts +7 -0
- package/eval/README.md +160 -0
- package/eval/ablation-config.yaml +43 -0
- package/eval/assertions/ablation-scorer.ts +81 -0
- package/eval/assertions/hook-impact.ts +152 -0
- package/eval/assertions/task-completion.ts +65 -0
- package/eval/assertions/tool-accuracy.ts +56 -0
- package/eval/promptfooconfig.yaml +42 -0
- package/eval/providers/opencode-baseline.ts +63 -0
- package/eval/providers/opencode-client.ts +112 -0
- package/eval/providers/opencode-provider.ts +66 -0
- package/eval/spike/config.yaml +13 -0
- package/eval/spike/provider.ts +15 -0
- package/npm-reserve/README.md +19 -0
- package/npm-reserve/package.json +24 -0
- package/opencode.json +6 -0
- package/package.json +47 -8
- package/src/agents/advisor/config.ts +6 -0
- package/src/agents/advisor/index.ts +2 -0
- package/src/agents/advisor/plugin.test.ts +48 -0
- package/src/agents/advisor/plugin.ts +17 -0
- package/src/agents/advisor/prompt-meta.ts +14 -0
- package/src/agents/advisor/prompt.ts +93 -0
- package/src/agents/agent-builder.test.ts +66 -0
- package/src/agents/agent-builder.ts +97 -0
- package/src/agents/agent-plugins.test.ts +98 -0
- package/src/agents/agent-registry.ts +25 -0
- package/src/agents/builtin-agents.ts +18 -0
- package/src/agents/deep-worker/config.ts +6 -0
- package/src/agents/deep-worker/index.ts +2 -0
- package/src/agents/deep-worker/plugin.test.ts +31 -0
- package/src/agents/deep-worker/plugin.ts +16 -0
- package/src/agents/deep-worker/prompt-meta.ts +14 -0
- package/src/agents/deep-worker/prompt.ts +121 -0
- package/src/agents/disabled/analyst/config.ts +6 -0
- package/src/agents/disabled/analyst/index.ts +2 -0
- package/src/agents/disabled/analyst/plugin.ts +16 -0
- package/src/agents/disabled/analyst/prompt.ts +1 -0
- package/src/agents/disabled/executor/config.ts +9 -0
- package/src/agents/disabled/executor/index.ts +2 -0
- package/src/agents/disabled/executor/plugin.ts +16 -0
- package/src/agents/disabled/executor/prompt.ts +1 -0
- package/src/agents/disabled/inspector/config.ts +6 -0
- package/src/agents/disabled/inspector/index.ts +2 -0
- package/src/agents/disabled/inspector/plugin.ts +18 -0
- package/src/agents/disabled/inspector/prompt.ts +1 -0
- package/src/agents/disabled/reviewer/config.ts +6 -0
- package/src/agents/disabled/reviewer/index.ts +2 -0
- package/src/agents/disabled/reviewer/plugin.ts +18 -0
- package/src/agents/disabled/reviewer/prompt.ts +1 -0
- package/src/agents/explorer/config.ts +6 -0
- package/src/agents/explorer/index.ts +2 -0
- package/src/agents/explorer/plugin.test.ts +36 -0
- package/src/agents/explorer/plugin.ts +15 -0
- package/src/agents/explorer/prompt-meta.ts +14 -0
- package/src/agents/explorer/prompt.ts +96 -0
- package/src/agents/fallback-chains.ts +13 -0
- package/src/agents/index.ts +18 -0
- package/src/agents/model-resolution.test.ts +79 -0
- package/src/agents/orchestrator/config.ts +10 -0
- package/src/agents/orchestrator/index.ts +2 -0
- package/src/agents/orchestrator/plugin.test.ts +31 -0
- package/src/agents/orchestrator/plugin.ts +16 -0
- package/src/agents/orchestrator/prompt-meta.ts +14 -0
- package/src/agents/orchestrator/prompt.ts +166 -0
- package/src/agents/planner/config.ts +6 -0
- package/src/agents/planner/index.ts +2 -0
- package/src/agents/planner/plugin.test.ts +31 -0
- package/src/agents/planner/plugin.ts +16 -0
- package/src/agents/planner/prompt-meta.ts +14 -0
- package/src/agents/planner/prompt.ts +138 -0
- package/src/agents/prompt-meta.ts +12 -0
- package/src/agents/prompt-registry.test.ts +98 -0
- package/src/agents/prompt-registry.ts +22 -0
- package/src/agents/researcher/config.ts +6 -0
- package/src/agents/researcher/index.ts +2 -0
- package/src/agents/researcher/plugin.test.ts +31 -0
- package/src/agents/researcher/plugin.ts +16 -0
- package/src/agents/researcher/prompt-meta.ts +14 -0
- package/src/agents/researcher/prompt.ts +116 -0
- package/src/agents/tool-restrictions.ts +87 -0
- package/src/agents/worker/config.ts +6 -0
- package/src/agents/worker/index.ts +2 -0
- package/src/agents/worker/plugin.test.ts +31 -0
- package/src/agents/worker/plugin.ts +15 -0
- package/src/agents/worker/prompt-meta.ts +14 -0
- package/src/agents/worker/prompt.ts +83 -0
- package/src/bootstrap.integration.test.ts +168 -0
- package/src/bootstrap.ts +171 -0
- package/src/cli/cli.ts +42 -0
- package/src/cli/commands/install.test.ts +40 -0
- package/src/cli/commands/install.ts +125 -0
- package/src/cli/commands/update.test.ts +84 -0
- package/src/cli/commands/update.ts +45 -0
- package/src/cli/config-generator.test.ts +178 -0
- package/src/cli/config-generator.ts +119 -0
- package/src/cli/index.test.ts +34 -0
- package/src/cli/index.ts +4 -0
- package/src/config/defaults.ts +24 -0
- package/src/config/define-config.ts +38 -0
- package/src/config/index.ts +6 -0
- package/src/config/loader.test.ts +218 -0
- package/src/config/loader.ts +89 -0
- package/src/config/paths.ts +30 -0
- package/src/config/schema.test.ts +69 -0
- package/src/config/schema.ts +57 -0
- package/src/config/validator.ts +24 -0
- package/src/features/auto-update/auto-update.test.ts +105 -0
- package/src/features/auto-update/index.ts +4 -0
- package/src/features/auto-update/plugin.ts +45 -0
- package/src/features/auto-update/update-checker.ts +66 -0
- package/src/features/background-agent/concurrency.test.ts +65 -0
- package/src/features/background-agent/concurrency.ts +44 -0
- package/src/features/background-agent/index.ts +12 -0
- package/src/features/background-agent/manager.ts +214 -0
- package/src/features/background-agent/poller.test.ts +33 -0
- package/src/features/background-agent/poller.ts +75 -0
- package/src/features/background-agent/singleton.ts +26 -0
- package/src/features/background-agent/spawner.ts +51 -0
- package/src/features/background-agent/types.ts +20 -0
- package/src/features/builtin-features.ts +5 -0
- package/src/features/categories/categories.test.ts +68 -0
- package/src/features/categories/category-config.ts +70 -0
- package/src/features/categories/category-resolver.ts +36 -0
- package/src/features/categories/index.ts +8 -0
- package/src/features/categories/prompt-appends.ts +38 -0
- package/src/features/loops/file-store.ts +151 -0
- package/src/features/loops/handler.ts +89 -0
- package/src/features/loops/index.ts +28 -0
- package/src/features/loops/loops.test.ts +175 -0
- package/src/features/loops/memory-store.ts +53 -0
- package/src/features/loops/plugin.ts +107 -0
- package/src/features/loops/shared/event-utils.ts +50 -0
- package/src/features/loops/state.ts +44 -0
- package/src/features/prompt-builder/agent-table-builder.ts +23 -0
- package/src/features/prompt-builder/category-section-builder.ts +21 -0
- package/src/features/prompt-builder/dynamic-prompt-builder.ts +42 -0
- package/src/features/prompt-builder/index.ts +7 -0
- package/src/features/prompt-builder/prompt-builder.test.ts +244 -0
- package/src/features/prompt-builder/skill-section-builder.ts +25 -0
- package/src/features/session-state/index.ts +17 -0
- package/src/features/session-state/session-cursor.test.ts +137 -0
- package/src/features/session-state/session-cursor.ts +80 -0
- package/src/features/session-state/session-store.test.ts +82 -0
- package/src/features/session-state/session-store.ts +37 -0
- package/src/features/session-state/session-tools-store.ts +18 -0
- package/src/features/skills/builtin/git-master.ts +109 -0
- package/src/features/skills/index.ts +97 -0
- package/src/features/skills/skill-loader.ts +133 -0
- package/src/features/skills/skill-merger.ts +15 -0
- package/src/features/skills/skills.test.ts +120 -0
- package/src/features/slash-commands/command-registry.ts +36 -0
- package/src/features/slash-commands/commands/cancel-loop.ts +17 -0
- package/src/features/slash-commands/commands/handoff.ts +59 -0
- package/src/features/slash-commands/commands/init-deep.ts +40 -0
- package/src/features/slash-commands/commands/loop.ts +39 -0
- package/src/features/slash-commands/commands/start-work.ts +39 -0
- package/src/features/slash-commands/commands/stop-continuation.ts +21 -0
- package/src/features/slash-commands/index.ts +2 -0
- package/src/features/slash-commands/slash-commands.test.ts +68 -0
- package/src/features/slash-commands/types.ts +5 -0
- package/src/hooks/anthropic-effort/handler.test.ts +156 -0
- package/src/hooks/anthropic-effort/handler.ts +64 -0
- package/src/hooks/anthropic-effort/index.ts +3 -0
- package/src/hooks/anthropic-effort/plugin.ts +17 -0
- package/src/hooks/builtin-hooks.ts +64 -0
- package/src/hooks/comment-checker/handler.test.ts +65 -0
- package/src/hooks/comment-checker/handler.ts +60 -0
- package/src/hooks/comment-checker/index.ts +2 -0
- package/src/hooks/comment-checker/plugin.ts +15 -0
- package/src/hooks/compaction-context/handler.test.ts +160 -0
- package/src/hooks/compaction-context/handler.ts +179 -0
- package/src/hooks/compaction-context/index.ts +5 -0
- package/src/hooks/compaction-context/plugin.ts +40 -0
- package/src/hooks/compaction-todo-preserver/handler.test.ts +155 -0
- package/src/hooks/compaction-todo-preserver/handler.ts +129 -0
- package/src/hooks/compaction-todo-preserver/index.ts +2 -0
- package/src/hooks/compaction-todo-preserver/plugin.ts +18 -0
- package/src/hooks/context-injection.test.ts +124 -0
- package/src/hooks/context-injector/handlers/agents.test.ts +140 -0
- package/src/hooks/context-injector/handlers/agents.ts +101 -0
- package/src/hooks/context-injector/handlers/readme.ts +55 -0
- package/src/hooks/context-injector/handlers/rules.ts +62 -0
- package/src/hooks/context-injector/index.ts +4 -0
- package/src/hooks/context-injector/plugin.ts +56 -0
- package/src/hooks/context-window-limit/handler.test.ts +103 -0
- package/src/hooks/context-window-limit/handler.ts +128 -0
- package/src/hooks/context-window-limit/index.ts +6 -0
- package/src/hooks/context-window-limit/plugin.ts +15 -0
- package/src/hooks/continuation.test.ts +103 -0
- package/src/hooks/delegate-retry/handler.test.ts +212 -0
- package/src/hooks/delegate-retry/handler.ts +137 -0
- package/src/hooks/delegate-retry/index.ts +8 -0
- package/src/hooks/delegate-retry/plugin.ts +15 -0
- package/src/hooks/edit-error/handler.test.ts +82 -0
- package/src/hooks/edit-error/handler.ts +50 -0
- package/src/hooks/edit-error/index.ts +6 -0
- package/src/hooks/edit-error/plugin.ts +15 -0
- package/src/hooks/empty-response-detector/handler.test.ts +133 -0
- package/src/hooks/empty-response-detector/handler.ts +62 -0
- package/src/hooks/empty-response-detector/index.ts +2 -0
- package/src/hooks/empty-response-detector/plugin.ts +18 -0
- package/src/hooks/error-diagnostics/error-diagnostics.test.ts +116 -0
- package/src/hooks/error-diagnostics/handler.test.ts +147 -0
- package/src/hooks/error-diagnostics/handler.ts +135 -0
- package/src/hooks/error-diagnostics/patterns.ts +93 -0
- package/src/hooks/error-diagnostics/plugin.ts +11 -0
- package/src/hooks/error-diagnostics/types.ts +26 -0
- package/src/hooks/error-recovery.test.ts +85 -0
- package/src/hooks/foreground-fallback/handler.test.ts +229 -0
- package/src/hooks/foreground-fallback/handler.ts +294 -0
- package/src/hooks/foreground-fallback/index.ts +2 -0
- package/src/hooks/foreground-fallback/plugin.ts +18 -0
- package/src/hooks/hashline-diff-enhancer/handler.test.ts +166 -0
- package/src/hooks/hashline-diff-enhancer/handler.ts +186 -0
- package/src/hooks/hashline-diff-enhancer/index.ts +6 -0
- package/src/hooks/hashline-diff-enhancer/plugin.ts +24 -0
- package/src/hooks/hashline-read-enhancer/handler.test.ts +121 -0
- package/src/hooks/hashline-read-enhancer/handler.ts +165 -0
- package/src/hooks/hashline-read-enhancer/index.ts +2 -0
- package/src/hooks/hashline-read-enhancer/plugin.ts +18 -0
- package/src/hooks/hook-composer.test.ts +52 -0
- package/src/hooks/hook-composer.ts +17 -0
- package/src/hooks/hook-composition.integration.test.ts +274 -0
- package/src/hooks/hook-ordering.ts +41 -0
- package/src/hooks/hook-types.ts +22 -0
- package/src/hooks/index.ts +6 -0
- package/src/hooks/json-error/handler.test.ts +95 -0
- package/src/hooks/json-error/handler.ts +82 -0
- package/src/hooks/json-error/index.ts +6 -0
- package/src/hooks/json-error/plugin.ts +15 -0
- package/src/hooks/keyword-detector/handler.test.ts +113 -0
- package/src/hooks/keyword-detector/handler.ts +73 -0
- package/src/hooks/keyword-detector/index.ts +8 -0
- package/src/hooks/keyword-detector/plugin.ts +24 -0
- package/src/hooks/model-fallback/handler.test.ts +163 -0
- package/src/hooks/model-fallback/handler.ts +178 -0
- package/src/hooks/model-fallback/index.ts +2 -0
- package/src/hooks/model-fallback/plugin.ts +11 -0
- package/src/hooks/model-management.test.ts +121 -0
- package/src/hooks/phase-reminder/handler.test.ts +105 -0
- package/src/hooks/phase-reminder/handler.ts +54 -0
- package/src/hooks/phase-reminder/index.ts +2 -0
- package/src/hooks/phase-reminder/plugin.ts +18 -0
- package/src/hooks/post-read-nudge/handler.test.ts +159 -0
- package/src/hooks/post-read-nudge/handler.ts +64 -0
- package/src/hooks/post-read-nudge/index.ts +6 -0
- package/src/hooks/post-read-nudge/plugin.ts +18 -0
- package/src/hooks/preemptive-compaction/handler.test.ts +130 -0
- package/src/hooks/preemptive-compaction/handler.ts +84 -0
- package/src/hooks/preemptive-compaction/index.ts +2 -0
- package/src/hooks/preemptive-compaction/plugin.ts +15 -0
- package/src/hooks/productivity.test.ts +332 -0
- package/src/hooks/quality.test.ts +330 -0
- package/src/hooks/runtime-fallback/handler.test.ts +142 -0
- package/src/hooks/runtime-fallback/handler.ts +171 -0
- package/src/hooks/runtime-fallback/index.ts +2 -0
- package/src/hooks/runtime-fallback/plugin.ts +13 -0
- package/src/hooks/safe-hook-wrapper.test.ts +35 -0
- package/src/hooks/safe-hook-wrapper.ts +12 -0
- package/src/hooks/session-recovery/handler.test.ts +88 -0
- package/src/hooks/session-recovery/handler.ts +87 -0
- package/src/hooks/session-recovery/index.ts +6 -0
- package/src/hooks/session-recovery/plugin.ts +15 -0
- package/src/hooks/skill-discovery/plugin.ts +45 -0
- package/src/hooks/stop-guard/handler.test.ts +147 -0
- package/src/hooks/stop-guard/handler.ts +127 -0
- package/src/hooks/stop-guard/index.ts +2 -0
- package/src/hooks/stop-guard/plugin.ts +15 -0
- package/src/hooks/task-hooks.test.ts +324 -0
- package/src/hooks/task-resume-info/handler.test.ts +180 -0
- package/src/hooks/task-resume-info/handler.ts +61 -0
- package/src/hooks/task-resume-info/index.ts +2 -0
- package/src/hooks/task-resume-info/plugin.ts +15 -0
- package/src/hooks/think-mode/handler.test.ts +139 -0
- package/src/hooks/think-mode/handler.ts +50 -0
- package/src/hooks/think-mode/index.ts +2 -0
- package/src/hooks/think-mode/plugin.ts +15 -0
- package/src/hooks/thinking-block-validator/handler.test.ts +79 -0
- package/src/hooks/thinking-block-validator/handler.ts +93 -0
- package/src/hooks/thinking-block-validator/index.ts +2 -0
- package/src/hooks/thinking-block-validator/plugin.ts +18 -0
- package/src/hooks/todo-enforcer/handler.test.ts +153 -0
- package/src/hooks/todo-enforcer/handler.ts +100 -0
- package/src/hooks/todo-enforcer/index.ts +2 -0
- package/src/hooks/todo-enforcer/plugin.ts +15 -0
- package/src/hooks/todowrite-disabler/handler.test.ts +119 -0
- package/src/hooks/todowrite-disabler/handler.ts +50 -0
- package/src/hooks/todowrite-disabler/index.ts +6 -0
- package/src/hooks/todowrite-disabler/plugin.ts +46 -0
- package/src/hooks/tool-output-truncator/handler.test.ts +113 -0
- package/src/hooks/tool-output-truncator/handler.ts +83 -0
- package/src/hooks/tool-output-truncator/index.ts +2 -0
- package/src/hooks/tool-output-truncator/plugin.ts +18 -0
- package/src/hooks/tool-output.test.ts +238 -0
- package/src/hooks/workflow-reminders.test.ts +187 -0
- package/src/hooks/write-file-guard/handler.test.ts +107 -0
- package/src/hooks/write-file-guard/handler.ts +166 -0
- package/src/hooks/write-file-guard/index.ts +2 -0
- package/src/hooks/write-file-guard/plugin.ts +23 -0
- package/src/index.ts +8 -0
- package/src/plugin/compositor.ts +99 -0
- package/src/plugin/index.ts +1 -0
- package/src/plugin-api/define-plugin.test.ts +66 -0
- package/src/plugin-api/define-plugin.ts +36 -0
- package/src/plugin-api/index.ts +26 -0
- package/src/plugin-api/types.ts +28 -0
- package/src/registry/agent-aggregator.ts +13 -0
- package/src/registry/contribution-aggregator.test.ts +62 -0
- package/src/registry/contribution-aggregator.ts +114 -0
- package/src/registry/contribution-conflicts.integration.test.ts +186 -0
- package/src/registry/dependency-resolver.test.ts +35 -0
- package/src/registry/dependency-resolver.ts +64 -0
- package/src/registry/hook-aggregator.test.ts +78 -0
- package/src/registry/hook-aggregator.ts +63 -0
- package/src/registry/index.ts +6 -0
- package/src/registry/plugin-lifecycle.integration.test.ts +94 -0
- package/src/registry/plugin-overrides.integration.test.ts +140 -0
- package/src/registry/plugin-registry.test.ts +56 -0
- package/src/registry/plugin-registry.ts +82 -0
- package/src/registry/tool-aggregator.ts +13 -0
- package/src/registry/types.ts +11 -0
- package/src/runtime/index.ts +43 -0
- package/src/shared/data-path.ts +18 -0
- package/src/shared/deep-merge.test.ts +36 -0
- package/src/shared/deep-merge.ts +61 -0
- package/src/shared/fallback-chain.ts +8 -0
- package/src/shared/index.ts +59 -0
- package/src/shared/logger.ts +54 -0
- package/src/shared/model-availability.ts +18 -0
- package/src/shared/model-normalization.test.ts +75 -0
- package/src/shared/model-normalization.ts +28 -0
- package/src/shared/model-prefix-map.test.ts +75 -0
- package/src/shared/model-prefix-map.ts +58 -0
- package/src/shared/model-resolution-pipeline.test.ts +111 -0
- package/src/shared/model-resolution-pipeline.ts +55 -0
- package/src/shared/models-dev.test.ts +277 -0
- package/src/shared/models-dev.ts +176 -0
- package/src/shared/provider-discovery.test.ts +97 -0
- package/src/shared/provider-discovery.ts +73 -0
- package/src/shared/provider-registry.test.ts +212 -0
- package/src/shared/provider-registry.ts +157 -0
- package/src/shared/safe-create-hook.ts +15 -0
- package/src/shared/snake-case.ts +7 -0
- package/src/shared/truncate-description.ts +6 -0
- package/src/test-utils/index.ts +6 -0
- package/src/test-utils/mock-agent-config.ts +13 -0
- package/src/test-utils/mock-hook-inputs.ts +148 -0
- package/src/test-utils/mock-hook-outputs.ts +153 -0
- package/src/test-utils/mock-plugin-context.test.ts +32 -0
- package/src/test-utils/mock-plugin-context.ts +21 -0
- package/src/test-utils/mock-sdk-client.ts +52 -0
- package/src/test-utils/mock-tool-context.ts +24 -0
- package/src/tools/ast-grep/index.ts +4 -0
- package/src/tools/ast-grep/replace/handler.test.ts +93 -0
- package/src/tools/ast-grep/replace/handler.ts +89 -0
- package/src/tools/ast-grep/replace/plugin.ts +10 -0
- package/src/tools/ast-grep/replace/types.ts +14 -0
- package/src/tools/ast-grep/search/handler.test.ts +94 -0
- package/src/tools/ast-grep/search/handler.ts +93 -0
- package/src/tools/ast-grep/search/plugin.ts +10 -0
- package/src/tools/ast-grep/search/types.ts +42 -0
- package/src/tools/background-task/background-task.test.ts +185 -0
- package/src/tools/background-task/cancel/handler.test.ts +141 -0
- package/src/tools/background-task/cancel/handler.ts +52 -0
- package/src/tools/background-task/cancel/plugin.ts +30 -0
- package/src/tools/background-task/cancel/types.ts +4 -0
- package/src/tools/background-task/index.ts +2 -0
- package/src/tools/background-task/output/handler.test.ts +142 -0
- package/src/tools/background-task/output/handler.ts +93 -0
- package/src/tools/background-task/output/plugin.ts +60 -0
- package/src/tools/background-task/output/types.ts +11 -0
- package/src/tools/bridge.test.ts +55 -0
- package/src/tools/bridge.ts +13 -0
- package/src/tools/builtin-tools.ts +54 -0
- package/src/tools/code-search.test.ts +203 -0
- package/src/tools/delegate-task/category-resolver.ts +18 -0
- package/src/tools/delegate-task/constants.ts +43 -0
- package/src/tools/delegate-task/delegate-task.test.ts +245 -0
- package/src/tools/delegate-task/executor.ts +157 -0
- package/src/tools/delegate-task/handler.ts +107 -0
- package/src/tools/delegate-task/index.ts +7 -0
- package/src/tools/delegate-task/plugin.ts +30 -0
- package/src/tools/delegate-task/types.ts +19 -0
- package/src/tools/glob/handler.test.ts +80 -0
- package/src/tools/glob/handler.ts +74 -0
- package/src/tools/glob/index.ts +2 -0
- package/src/tools/glob/plugin.ts +10 -0
- package/src/tools/glob/types.ts +14 -0
- package/src/tools/grep/handler.test.ts +79 -0
- package/src/tools/grep/handler.ts +104 -0
- package/src/tools/grep/index.ts +2 -0
- package/src/tools/grep/plugin.ts +10 -0
- package/src/tools/grep/types.ts +28 -0
- package/src/tools/hashline-edit/constants.ts +10 -0
- package/src/tools/hashline-edit/edit-operations.ts +115 -0
- package/src/tools/hashline-edit/handler.test.ts +105 -0
- package/src/tools/hashline-edit/handler.ts +33 -0
- package/src/tools/hashline-edit/hash-computation.ts +20 -0
- package/src/tools/hashline-edit/hashline-edit.test.ts +62 -0
- package/src/tools/hashline-edit/index.ts +5 -0
- package/src/tools/hashline-edit/plugin.ts +28 -0
- package/src/tools/hashline-edit/types.ts +42 -0
- package/src/tools/index.ts +4 -0
- package/src/tools/look-at/handler.test.ts +189 -0
- package/src/tools/look-at/handler.ts +232 -0
- package/src/tools/look-at/index.ts +3 -0
- package/src/tools/look-at/look-at.test.ts +200 -0
- package/src/tools/look-at/plugin.ts +10 -0
- package/src/tools/look-at/types.ts +17 -0
- package/src/tools/lsp/client.ts +145 -0
- package/src/tools/lsp/diagnostics/handler.test.ts +94 -0
- package/src/tools/lsp/diagnostics/handler.ts +39 -0
- package/src/tools/lsp/diagnostics/plugin.ts +10 -0
- package/src/tools/lsp/diagnostics/types.ts +15 -0
- package/src/tools/lsp/find-references/handler.test.ts +79 -0
- package/src/tools/lsp/find-references/handler.ts +38 -0
- package/src/tools/lsp/find-references/plugin.ts +10 -0
- package/src/tools/lsp/find-references/types.ts +10 -0
- package/src/tools/lsp/goto-definition/handler.test.ts +80 -0
- package/src/tools/lsp/goto-definition/handler.ts +38 -0
- package/src/tools/lsp/goto-definition/plugin.ts +10 -0
- package/src/tools/lsp/goto-definition/types.ts +9 -0
- package/src/tools/lsp/index.ts +6 -0
- package/src/tools/lsp/lsp-tools.test.ts +150 -0
- package/src/tools/lsp/prepare-rename/handler.test.ts +81 -0
- package/src/tools/lsp/prepare-rename/handler.ts +34 -0
- package/src/tools/lsp/prepare-rename/plugin.ts +10 -0
- package/src/tools/lsp/prepare-rename/types.ts +9 -0
- package/src/tools/lsp/rename/handler.test.ts +87 -0
- package/src/tools/lsp/rename/handler.ts +34 -0
- package/src/tools/lsp/rename/plugin.ts +10 -0
- package/src/tools/lsp/rename/types.ts +10 -0
- package/src/tools/lsp/symbols/handler.test.ts +108 -0
- package/src/tools/lsp/symbols/handler.ts +43 -0
- package/src/tools/lsp/symbols/plugin.ts +10 -0
- package/src/tools/lsp/symbols/types.ts +13 -0
- package/src/tools/session-manager/client-context.ts +16 -0
- package/src/tools/session-manager/index.ts +5 -0
- package/src/tools/session-manager/info/handler.test.ts +100 -0
- package/src/tools/session-manager/info/handler.ts +27 -0
- package/src/tools/session-manager/info/plugin.ts +40 -0
- package/src/tools/session-manager/info/types.ts +3 -0
- package/src/tools/session-manager/list/handler.test.ts +122 -0
- package/src/tools/session-manager/list/handler.ts +56 -0
- package/src/tools/session-manager/list/plugin.ts +52 -0
- package/src/tools/session-manager/list/types.ts +6 -0
- package/src/tools/session-manager/read/handler.test.ts +114 -0
- package/src/tools/session-manager/read/handler.ts +36 -0
- package/src/tools/session-manager/read/plugin.ts +57 -0
- package/src/tools/session-manager/read/types.ts +6 -0
- package/src/tools/session-manager/search/handler.test.ts +115 -0
- package/src/tools/session-manager/search/handler.ts +72 -0
- package/src/tools/session-manager/search/plugin.ts +57 -0
- package/src/tools/session-manager/search/types.ts +6 -0
- package/src/tools/session-manager/session-formatter.ts +315 -0
- package/src/tools/session-manager/session-manager.test.ts +254 -0
- package/src/tools/session-manager/types.ts +41 -0
- package/src/tools/shared/constants.ts +3 -0
- package/src/tools/skill/handler.test.ts +57 -0
- package/src/tools/skill/handler.ts +27 -0
- package/src/tools/skill/index.ts +3 -0
- package/src/tools/skill/plugin.ts +41 -0
- package/src/tools/skill/types.ts +14 -0
- package/src/tools/skill-mcp/handler.test.ts +68 -0
- package/src/tools/skill-mcp/handler.ts +84 -0
- package/src/tools/skill-mcp/index.ts +3 -0
- package/src/tools/skill-mcp/plugin.ts +37 -0
- package/src/tools/skill-mcp/types.ts +15 -0
- package/src/tools/skill-tools.test.ts +172 -0
- package/src/tools/task/create/handler.test.ts +64 -0
- package/src/tools/task/create/handler.ts +43 -0
- package/src/tools/task/create/plugin.ts +10 -0
- package/src/tools/task/format-task.test.ts +37 -0
- package/src/tools/task/format-task.ts +19 -0
- package/src/tools/task/get/handler.test.ts +76 -0
- package/src/tools/task/get/handler.ts +35 -0
- package/src/tools/task/get/plugin.ts +10 -0
- package/src/tools/task/index.ts +4 -0
- package/src/tools/task/list/handler.test.ts +70 -0
- package/src/tools/task/list/handler.ts +48 -0
- package/src/tools/task/list/plugin.ts +10 -0
- package/src/tools/task/storage.ts +14 -0
- package/src/tools/task/task.test.ts +165 -0
- package/src/tools/task/types.ts +51 -0
- package/src/tools/task/update/handler.test.ts +86 -0
- package/src/tools/task/update/handler.ts +54 -0
- package/src/tools/task/update/plugin.ts +10 -0
- package/src/tools/tool-builder.test.ts +32 -0
- package/src/tools/tool-builder.ts +24 -0
- package/src/tools/tool-registry-adapter.test.ts +51 -0
- package/src/tools/tool-registry-adapter.ts +19 -0
- package/src/types/agent.ts +53 -0
- package/src/types/category.ts +32 -0
- package/src/types/config.ts +26 -0
- package/src/types/hook.ts +44 -0
- package/src/types/index.ts +12 -0
- package/src/types/plugin.ts +47 -0
- package/src/types/tool.ts +10 -0
- package/test-setup.ts +8 -0
- package/tsconfig.json +20 -0
- /package/{index.js → npm-reserve/index.js} +0 -0
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
// IMPORTANT: No bun:* imports — this file runs under Node.js via npx promptfoo eval
|
|
2
|
+
|
|
3
|
+
interface HookGroupSignals {
|
|
4
|
+
keywords: string[];
|
|
5
|
+
description: string;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
const HOOK_GROUPS: Record<string, HookGroupSignals> = {
|
|
9
|
+
"no-recovery-hooks": {
|
|
10
|
+
keywords: [
|
|
11
|
+
"fix",
|
|
12
|
+
"retry",
|
|
13
|
+
"recover",
|
|
14
|
+
"fallback",
|
|
15
|
+
"error",
|
|
16
|
+
"catch",
|
|
17
|
+
"handle",
|
|
18
|
+
"repair",
|
|
19
|
+
"corrected",
|
|
20
|
+
"resolved",
|
|
21
|
+
],
|
|
22
|
+
description: "error-recovery signals",
|
|
23
|
+
},
|
|
24
|
+
"no-quality-hooks": {
|
|
25
|
+
keywords: [
|
|
26
|
+
"lint",
|
|
27
|
+
"guard",
|
|
28
|
+
"validate",
|
|
29
|
+
"quality",
|
|
30
|
+
"check",
|
|
31
|
+
"comment",
|
|
32
|
+
"block",
|
|
33
|
+
"catch",
|
|
34
|
+
"empty",
|
|
35
|
+
"verified",
|
|
36
|
+
],
|
|
37
|
+
description: "code quality signals",
|
|
38
|
+
},
|
|
39
|
+
"no-context-hooks": {
|
|
40
|
+
keywords: [
|
|
41
|
+
"context",
|
|
42
|
+
"phase",
|
|
43
|
+
"inject",
|
|
44
|
+
"reminder",
|
|
45
|
+
"current",
|
|
46
|
+
"project",
|
|
47
|
+
"state",
|
|
48
|
+
"summary",
|
|
49
|
+
"scope",
|
|
50
|
+
"awareness",
|
|
51
|
+
],
|
|
52
|
+
description: "context injection signals",
|
|
53
|
+
},
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
const ALL_SIGNALS = [
|
|
57
|
+
...new Set(
|
|
58
|
+
Object.values(HOOK_GROUPS).flatMap((group) => group.keywords),
|
|
59
|
+
),
|
|
60
|
+
];
|
|
61
|
+
|
|
62
|
+
export default function assertHookImpact(
|
|
63
|
+
output: string,
|
|
64
|
+
context: {
|
|
65
|
+
prompt: string;
|
|
66
|
+
vars: Record<string, string>;
|
|
67
|
+
provider?: { id?: string; label?: string };
|
|
68
|
+
},
|
|
69
|
+
): { pass: boolean; score: number; reason: string; namedScores: { hook_impact: number } } {
|
|
70
|
+
if (!output || output.trim().length === 0) {
|
|
71
|
+
return { pass: false, score: 0, reason: "Output is empty", namedScores: { hook_impact: 0 } };
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
if (output.startsWith("[MOCK]")) {
|
|
75
|
+
return {
|
|
76
|
+
pass: true,
|
|
77
|
+
score: 0,
|
|
78
|
+
reason: `Mock/skipped — no live server. Provider: ${context.provider?.label ?? "unknown"}`,
|
|
79
|
+
namedScores: { hook_impact: 0 },
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
const lowerOutput = output.toLowerCase();
|
|
84
|
+
const providerLabel = context.provider?.label ?? "unknown";
|
|
85
|
+
|
|
86
|
+
if (providerLabel === "full") {
|
|
87
|
+
return scoreFullProvider(lowerOutput);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
const hookGroup = HOOK_GROUPS[providerLabel];
|
|
91
|
+
if (hookGroup) {
|
|
92
|
+
return scoreAblatedProvider(lowerOutput, providerLabel, hookGroup);
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
return scoreGeneric(lowerOutput, providerLabel);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
function scoreFullProvider(
|
|
99
|
+
lowerOutput: string,
|
|
100
|
+
): { pass: boolean; score: number; reason: string; namedScores: { hook_impact: number } } {
|
|
101
|
+
const matched = ALL_SIGNALS.filter((kw) => lowerOutput.includes(kw));
|
|
102
|
+
const score = Number(Math.min(matched.length / 8, 1.0).toFixed(2));
|
|
103
|
+
const pass = matched.length >= 2;
|
|
104
|
+
|
|
105
|
+
return {
|
|
106
|
+
pass,
|
|
107
|
+
score,
|
|
108
|
+
reason: pass
|
|
109
|
+
? `Full provider shows broad hook signals (score: ${score}). Matched: ${matched.slice(0, 8).join(", ")}`
|
|
110
|
+
: `Full provider lacks hook signals (score: ${score}). Matched: ${matched.length}`,
|
|
111
|
+
namedScores: { hook_impact: score },
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
function scoreAblatedProvider(
|
|
116
|
+
lowerOutput: string,
|
|
117
|
+
label: string,
|
|
118
|
+
group: HookGroupSignals,
|
|
119
|
+
): { pass: boolean; score: number; reason: string; namedScores: { hook_impact: number } } {
|
|
120
|
+
const matchedGroupSignals = group.keywords.filter((kw) =>
|
|
121
|
+
lowerOutput.includes(kw),
|
|
122
|
+
);
|
|
123
|
+
|
|
124
|
+
const disabledGroupPresence = matchedGroupSignals.length / group.keywords.length;
|
|
125
|
+
|
|
126
|
+
const impactScore = Number((1.0 - disabledGroupPresence).toFixed(2));
|
|
127
|
+
const pass = impactScore >= 0.5;
|
|
128
|
+
|
|
129
|
+
return {
|
|
130
|
+
pass,
|
|
131
|
+
score: impactScore,
|
|
132
|
+
reason: pass
|
|
133
|
+
? `Ablated [${label}] shows measurable hook impact (score: ${impactScore}). ${matchedGroupSignals.length}/${group.keywords.length} ${group.description} present.`
|
|
134
|
+
: `Ablated [${label}] shows weak hook impact (score: ${impactScore}). ${matchedGroupSignals.length}/${group.keywords.length} ${group.description} present.`,
|
|
135
|
+
namedScores: { hook_impact: impactScore },
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
function scoreGeneric(
|
|
140
|
+
lowerOutput: string,
|
|
141
|
+
label: string,
|
|
142
|
+
): { pass: boolean; score: number; reason: string; namedScores: { hook_impact: number } } {
|
|
143
|
+
const matched = ALL_SIGNALS.filter((kw) => lowerOutput.includes(kw));
|
|
144
|
+
const score = Number(Math.min(matched.length / 6, 1.0).toFixed(2));
|
|
145
|
+
|
|
146
|
+
return {
|
|
147
|
+
pass: true,
|
|
148
|
+
score,
|
|
149
|
+
reason: `Generic scoring for [${label}] (score: ${score}). Signals: ${matched.length}`,
|
|
150
|
+
namedScores: { hook_impact: score },
|
|
151
|
+
};
|
|
152
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
// IMPORTANT: No bun:* imports — this file runs under Node.js via npx promptfoo eval
|
|
2
|
+
|
|
3
|
+
const CONTENT_INDICATORS = [
|
|
4
|
+
"found",
|
|
5
|
+
"result",
|
|
6
|
+
"file",
|
|
7
|
+
"function",
|
|
8
|
+
"usage",
|
|
9
|
+
"reference",
|
|
10
|
+
"line",
|
|
11
|
+
"match",
|
|
12
|
+
"complete",
|
|
13
|
+
"done",
|
|
14
|
+
"created",
|
|
15
|
+
"updated",
|
|
16
|
+
"error",
|
|
17
|
+
"fixed",
|
|
18
|
+
"plan",
|
|
19
|
+
"step",
|
|
20
|
+
];
|
|
21
|
+
|
|
22
|
+
export default function assertTaskCompletion(
|
|
23
|
+
output: string,
|
|
24
|
+
context: {
|
|
25
|
+
prompt: string;
|
|
26
|
+
vars: Record<string, string>;
|
|
27
|
+
provider?: { id?: string };
|
|
28
|
+
},
|
|
29
|
+
): { pass: boolean; score: number; reason: string; namedScores: { completion: number } } {
|
|
30
|
+
if (!output || output.trim().length === 0) {
|
|
31
|
+
return { pass: false, score: 0, reason: "Output is empty", namedScores: { completion: 0 } };
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
if (output.startsWith("[MOCK]")) {
|
|
35
|
+
return {
|
|
36
|
+
pass: true,
|
|
37
|
+
score: 0,
|
|
38
|
+
reason: `Mock response — assertion skipped. Output: ${output.slice(0, 100)}`,
|
|
39
|
+
namedScores: { completion: 0 },
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const lowerOutput = output.toLowerCase();
|
|
44
|
+
|
|
45
|
+
const matchedIndicators = CONTENT_INDICATORS.filter((word) =>
|
|
46
|
+
lowerOutput.includes(word),
|
|
47
|
+
);
|
|
48
|
+
|
|
49
|
+
// Weighted score: content presence (0.3) + output length (0.3) + indicator matches (0.4)
|
|
50
|
+
const hasContent = output.trim().length > 20 ? 0.3 : 0.1;
|
|
51
|
+
const lengthScore = Math.min(output.length / 500, 1.0) * 0.3;
|
|
52
|
+
const indicatorScore = Math.min(matchedIndicators.length / 4, 1.0) * 0.4;
|
|
53
|
+
|
|
54
|
+
const score = Number((hasContent + lengthScore + indicatorScore).toFixed(2));
|
|
55
|
+
const pass = score >= 0.3 && matchedIndicators.length >= 1;
|
|
56
|
+
|
|
57
|
+
return {
|
|
58
|
+
pass,
|
|
59
|
+
score,
|
|
60
|
+
reason: pass
|
|
61
|
+
? `Task completion detected (score: ${score}). Indicators: ${matchedIndicators.join(", ")}`
|
|
62
|
+
: `Insufficient task completion indicators (score: ${score}). Found: ${matchedIndicators.length} indicators`,
|
|
63
|
+
namedScores: { completion: score },
|
|
64
|
+
};
|
|
65
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
// IMPORTANT: No bun:* imports — this file runs under Node.js via npx promptfoo eval
|
|
2
|
+
|
|
3
|
+
const TOOL_KEYWORDS = [
|
|
4
|
+
"lsp",
|
|
5
|
+
"goto_definition",
|
|
6
|
+
"find_references",
|
|
7
|
+
"diagnostics",
|
|
8
|
+
"symbols",
|
|
9
|
+
"grep",
|
|
10
|
+
"glob",
|
|
11
|
+
"ast_grep",
|
|
12
|
+
"search",
|
|
13
|
+
"edit",
|
|
14
|
+
"hashline_edit",
|
|
15
|
+
"rename",
|
|
16
|
+
"bash",
|
|
17
|
+
];
|
|
18
|
+
|
|
19
|
+
export default function assertToolAccuracy(
|
|
20
|
+
output: string,
|
|
21
|
+
context: {
|
|
22
|
+
prompt: string;
|
|
23
|
+
vars: Record<string, string>;
|
|
24
|
+
provider?: { id?: string };
|
|
25
|
+
},
|
|
26
|
+
): { pass: boolean; score: number; reason: string; namedScores: { tool_accuracy: number } } {
|
|
27
|
+
if (!output || output.trim().length === 0) {
|
|
28
|
+
return { pass: false, score: 0, reason: "Output is empty", namedScores: { tool_accuracy: 0 } };
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
if (output.startsWith("[MOCK]") || output.startsWith("[BASELINE]")) {
|
|
32
|
+
return {
|
|
33
|
+
pass: true,
|
|
34
|
+
score: 0,
|
|
35
|
+
reason: `Mock/baseline response — assertion skipped. Output: ${output.slice(0, 100)}`,
|
|
36
|
+
namedScores: { tool_accuracy: 0 },
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const lowerOutput = output.toLowerCase();
|
|
41
|
+
const matchedTools = TOOL_KEYWORDS.filter((kw) =>
|
|
42
|
+
lowerOutput.includes(kw),
|
|
43
|
+
);
|
|
44
|
+
|
|
45
|
+
const score = Math.min(matchedTools.length / 3, 1.0);
|
|
46
|
+
const pass = matchedTools.length >= 1;
|
|
47
|
+
|
|
48
|
+
return {
|
|
49
|
+
pass,
|
|
50
|
+
score,
|
|
51
|
+
reason: pass
|
|
52
|
+
? `Found ${matchedTools.length} tool references: ${matchedTools.join(", ")}`
|
|
53
|
+
: "No tool references found in output",
|
|
54
|
+
namedScores: { tool_accuracy: score },
|
|
55
|
+
};
|
|
56
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
description: "GoatCode A/B Evaluation — With vs Without Plugin"
|
|
2
|
+
|
|
3
|
+
providers:
|
|
4
|
+
- id: file://providers/opencode-provider.ts
|
|
5
|
+
label: with-goatcode
|
|
6
|
+
config:
|
|
7
|
+
enablePlugin: true
|
|
8
|
+
model: "anthropic/claude-sonnet-4-20250514"
|
|
9
|
+
- id: file://providers/opencode-baseline.ts
|
|
10
|
+
label: baseline
|
|
11
|
+
|
|
12
|
+
defaultTest:
|
|
13
|
+
assert:
|
|
14
|
+
- type: javascript
|
|
15
|
+
value: "output.length > 0"
|
|
16
|
+
- type: latency
|
|
17
|
+
threshold: 30000
|
|
18
|
+
- type: cost
|
|
19
|
+
threshold: 0.10
|
|
20
|
+
|
|
21
|
+
prompts:
|
|
22
|
+
- "{{task}}"
|
|
23
|
+
|
|
24
|
+
tests:
|
|
25
|
+
- vars:
|
|
26
|
+
task: "Find all usages of the function 'bootstrap'"
|
|
27
|
+
assert:
|
|
28
|
+
- type: javascript
|
|
29
|
+
value: "file://assertions/task-completion.ts"
|
|
30
|
+
threshold: 0.5
|
|
31
|
+
- vars:
|
|
32
|
+
task: "Fix the edit error and retry the write"
|
|
33
|
+
assert:
|
|
34
|
+
- type: javascript
|
|
35
|
+
value: "file://assertions/tool-accuracy.ts"
|
|
36
|
+
threshold: 0.5
|
|
37
|
+
- vars:
|
|
38
|
+
task: "Create a plan for refactoring the hooks module"
|
|
39
|
+
assert:
|
|
40
|
+
- type: javascript
|
|
41
|
+
value: "file://assertions/task-completion.ts"
|
|
42
|
+
threshold: 0.5
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
// IMPORTANT: No bun:* imports — this file runs under Node.js via npx promptfoo eval
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
callLive,
|
|
5
|
+
type OpenCodeProviderConfig,
|
|
6
|
+
type ProviderResponse,
|
|
7
|
+
} from "./opencode-client.ts";
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Baseline provider for A/B comparison — simulates OpenCode WITHOUT GoatCode.
|
|
11
|
+
*
|
|
12
|
+
* promptfoo config example:
|
|
13
|
+
* providers:
|
|
14
|
+
* - id: file://eval/providers/opencode-baseline.ts
|
|
15
|
+
* config:
|
|
16
|
+
* model: "anthropic/claude-sonnet-4-20250514"
|
|
17
|
+
*/
|
|
18
|
+
export default class OpenCodeBaselineProvider {
|
|
19
|
+
id() {
|
|
20
|
+
return "goatcode-opencode-baseline";
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
async callApi(
|
|
24
|
+
prompt: string,
|
|
25
|
+
context?: { config?: { config?: { model?: string } } },
|
|
26
|
+
): Promise<ProviderResponse> {
|
|
27
|
+
const startTime = Date.now();
|
|
28
|
+
const model = context?.config?.config?.model ?? "anthropic/claude-sonnet-4-20250514";
|
|
29
|
+
const cfg: OpenCodeProviderConfig = {
|
|
30
|
+
enablePlugin: false,
|
|
31
|
+
disabledHooks: ["*"],
|
|
32
|
+
disabledTools: ["*"],
|
|
33
|
+
model,
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
try {
|
|
37
|
+
return await callLive(prompt, cfg, startTime);
|
|
38
|
+
} catch (err) {
|
|
39
|
+
const errMsg = err instanceof Error ? err.message : String(err);
|
|
40
|
+
|
|
41
|
+
return {
|
|
42
|
+
output: `[BASELINE] GoatCode plugin DISABLED. No hooks, no tools, no agents. Model: ${model}. Task: ${prompt}`,
|
|
43
|
+
tokenUsage: { total: 0, prompt: 0, completion: 0 },
|
|
44
|
+
cost: 0,
|
|
45
|
+
metadata: {
|
|
46
|
+
mock: true,
|
|
47
|
+
baseline: true,
|
|
48
|
+
error: errMsg,
|
|
49
|
+
// NOTE: The OpenCode SDK does not support per-session plugin configuration.
|
|
50
|
+
// enablePlugin: false is stored in metadata only. In a production setup,
|
|
51
|
+
// this would require modifying opencode.json and restarting the server.
|
|
52
|
+
pluginEnabled: false,
|
|
53
|
+
disabledHooks: ["*"],
|
|
54
|
+
disabledTools: ["*"],
|
|
55
|
+
model,
|
|
56
|
+
toolsUsed: [],
|
|
57
|
+
hooksFired: [],
|
|
58
|
+
sessionDuration: Date.now() - startTime,
|
|
59
|
+
},
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
// IMPORTANT: No bun:* imports — this file runs under Node.js via npx promptfoo eval
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
createOpencodeClient,
|
|
5
|
+
type Part,
|
|
6
|
+
type Session,
|
|
7
|
+
type TextPart,
|
|
8
|
+
type ToolPart,
|
|
9
|
+
} from "@opencode-ai/sdk";
|
|
10
|
+
|
|
11
|
+
export interface OpenCodeProviderConfig {
|
|
12
|
+
enablePlugin: boolean;
|
|
13
|
+
disabledHooks: string[];
|
|
14
|
+
disabledTools: string[];
|
|
15
|
+
model: string;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export interface ProviderResponse {
|
|
19
|
+
output: string;
|
|
20
|
+
tokenUsage: { total: number; prompt: number; completion: number };
|
|
21
|
+
cost: number;
|
|
22
|
+
metadata: Record<string, unknown>;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
interface SdkResult<T> {
|
|
26
|
+
data?: T;
|
|
27
|
+
error?: unknown;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
interface PromptInfo {
|
|
31
|
+
tokens?: { input: number; output: number; reasoning?: number };
|
|
32
|
+
cost?: number;
|
|
33
|
+
finish?: string;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
interface PromptData {
|
|
37
|
+
parts?: Part[];
|
|
38
|
+
info?: PromptInfo;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export async function callLive(
|
|
42
|
+
prompt: string,
|
|
43
|
+
cfg: OpenCodeProviderConfig,
|
|
44
|
+
startTime: number,
|
|
45
|
+
): Promise<ProviderResponse> {
|
|
46
|
+
const client = createOpencodeClient();
|
|
47
|
+
|
|
48
|
+
const createResult = (await client.session.create({
|
|
49
|
+
body: { title: `eval-${Date.now()}` },
|
|
50
|
+
query: { directory: process.cwd() },
|
|
51
|
+
})) as SdkResult<Session>;
|
|
52
|
+
|
|
53
|
+
const session = createResult.data;
|
|
54
|
+
if (!session?.id) {
|
|
55
|
+
throw new Error(
|
|
56
|
+
`Session creation failed: ${JSON.stringify(createResult.error ?? createResult)}`,
|
|
57
|
+
);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
const sessionId = session.id;
|
|
61
|
+
|
|
62
|
+
const promptResult = (await client.session.prompt({
|
|
63
|
+
body: {
|
|
64
|
+
parts: [{ type: "text" as const, text: prompt }],
|
|
65
|
+
},
|
|
66
|
+
path: { id: sessionId },
|
|
67
|
+
query: { directory: process.cwd() },
|
|
68
|
+
})) as SdkResult<PromptData>;
|
|
69
|
+
|
|
70
|
+
const response = promptResult.data;
|
|
71
|
+
if (!response) {
|
|
72
|
+
throw new Error(
|
|
73
|
+
`Prompt failed: ${JSON.stringify(promptResult.error ?? promptResult)}`,
|
|
74
|
+
);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
const parts: Part[] = response.parts ?? [];
|
|
78
|
+
const textParts = parts.filter((p): p is TextPart => p.type === "text");
|
|
79
|
+
const outputText = textParts.map((p) => p.text).join("\n") || "[No text output]";
|
|
80
|
+
|
|
81
|
+
const toolParts = parts.filter((p): p is ToolPart => p.type === "tool");
|
|
82
|
+
const toolsUsed = toolParts.map((p) => p.tool);
|
|
83
|
+
|
|
84
|
+
const info = response.info;
|
|
85
|
+
const tokens = info?.tokens ?? { input: 0, output: 0, reasoning: 0 };
|
|
86
|
+
const totalTokens = tokens.input + tokens.output + (tokens.reasoning ?? 0);
|
|
87
|
+
|
|
88
|
+
return {
|
|
89
|
+
output: outputText,
|
|
90
|
+
tokenUsage: {
|
|
91
|
+
total: totalTokens,
|
|
92
|
+
prompt: tokens.input,
|
|
93
|
+
completion: tokens.output,
|
|
94
|
+
},
|
|
95
|
+
cost: info?.cost ?? 0,
|
|
96
|
+
metadata: {
|
|
97
|
+
mock: false,
|
|
98
|
+
toolsUsed,
|
|
99
|
+
hooksFired: [],
|
|
100
|
+
sessionDuration: Date.now() - startTime,
|
|
101
|
+
sessionId,
|
|
102
|
+
// NOTE: The OpenCode SDK does not support per-session plugin configuration.
|
|
103
|
+
// enablePlugin/disabledHooks/disabledTools are stored in metadata only.
|
|
104
|
+
// In a production setup, this would require modifying opencode.json and restarting the server.
|
|
105
|
+
pluginEnabled: cfg.enablePlugin,
|
|
106
|
+
disabledHooks: cfg.disabledHooks,
|
|
107
|
+
disabledTools: cfg.disabledTools,
|
|
108
|
+
model: cfg.model,
|
|
109
|
+
finishReason: info?.finish,
|
|
110
|
+
},
|
|
111
|
+
};
|
|
112
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
// IMPORTANT: No bun:* imports — this file runs under Node.js via npx promptfoo eval
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
callLive,
|
|
5
|
+
type OpenCodeProviderConfig,
|
|
6
|
+
type ProviderResponse,
|
|
7
|
+
} from "./opencode-client.ts";
|
|
8
|
+
|
|
9
|
+
const DEFAULT_CONFIG: OpenCodeProviderConfig = {
|
|
10
|
+
enablePlugin: true,
|
|
11
|
+
disabledHooks: [],
|
|
12
|
+
disabledTools: [],
|
|
13
|
+
model: "anthropic/claude-sonnet-4-20250514",
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* promptfoo custom provider — uses @opencode-ai/sdk to spawn a real session.
|
|
18
|
+
* Falls back to a structured mock response if the server isn't running.
|
|
19
|
+
*
|
|
20
|
+
* promptfoo config example:
|
|
21
|
+
* providers:
|
|
22
|
+
* - id: file://eval/providers/opencode-provider.ts
|
|
23
|
+
* config:
|
|
24
|
+
* enablePlugin: true
|
|
25
|
+
* disabledHooks: []
|
|
26
|
+
* disabledTools: []
|
|
27
|
+
* model: "anthropic/claude-sonnet-4-20250514"
|
|
28
|
+
*/
|
|
29
|
+
export default class OpenCodeProvider {
|
|
30
|
+
id() {
|
|
31
|
+
return "goatcode-opencode-provider";
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
async callApi(
|
|
35
|
+
prompt: string,
|
|
36
|
+
context?: { config?: { config?: Partial<OpenCodeProviderConfig> } },
|
|
37
|
+
): Promise<ProviderResponse> {
|
|
38
|
+
const cfg: OpenCodeProviderConfig = {
|
|
39
|
+
...DEFAULT_CONFIG,
|
|
40
|
+
...(context?.config?.config ?? {}),
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
const startTime = Date.now();
|
|
44
|
+
|
|
45
|
+
try {
|
|
46
|
+
return await callLive(prompt, cfg, startTime);
|
|
47
|
+
} catch (err) {
|
|
48
|
+
const label = cfg.enablePlugin ? "ENABLED" : "DISABLED";
|
|
49
|
+
const errMsg = err instanceof Error ? err.message : String(err);
|
|
50
|
+
return {
|
|
51
|
+
output: `[MOCK] No OpenCode server available. GoatCode plugin would be: ${label}. Task: ${prompt}`,
|
|
52
|
+
tokenUsage: { total: 0, prompt: 0, completion: 0 },
|
|
53
|
+
cost: 0,
|
|
54
|
+
metadata: {
|
|
55
|
+
mock: true,
|
|
56
|
+
error: errMsg,
|
|
57
|
+
pluginEnabled: cfg.enablePlugin,
|
|
58
|
+
disabledHooks: cfg.disabledHooks,
|
|
59
|
+
disabledTools: cfg.disabledTools,
|
|
60
|
+
model: cfg.model,
|
|
61
|
+
sessionDuration: Date.now() - startTime,
|
|
62
|
+
},
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
// IMPORTANT: No bun:* imports — this file runs under Node.js via npx promptfoo eval
|
|
2
|
+
|
|
3
|
+
export default class SpikeProvider {
|
|
4
|
+
id() {
|
|
5
|
+
return "goatcode-spike-provider";
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
async callApi(prompt: string) {
|
|
9
|
+
return {
|
|
10
|
+
output: `Spike response for: ${prompt}`,
|
|
11
|
+
tokenUsage: { total: 10, prompt: 5, completion: 5 },
|
|
12
|
+
cost: 0,
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
# goatcode
|
|
2
|
+
|
|
3
|
+
Enterprise-grade OpenCode plugin with micro-plugin architecture and multi-agent orchestration.
|
|
4
|
+
|
|
5
|
+
> **This package is under active development.** This is a name reservation. Full implementation coming soon.
|
|
6
|
+
|
|
7
|
+
## What is goatcode?
|
|
8
|
+
|
|
9
|
+
goatcode is a professionally engineered OpenCode plugin that provides:
|
|
10
|
+
|
|
11
|
+
- Multi-agent orchestration with 11 specialized agents
|
|
12
|
+
- Micro-plugin architecture where every feature is independently composable
|
|
13
|
+
- TypeScript-native configuration (`goatcode.config.ts`)
|
|
14
|
+
- Zero built-in external service connections (enterprise-secure by default)
|
|
15
|
+
- Background agent parallelism with concurrency management
|
|
16
|
+
|
|
17
|
+
## Links
|
|
18
|
+
|
|
19
|
+
- [GitHub](https://github.com/ryanskidmore/goatcode)
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "goatcode-sh",
|
|
3
|
+
"version": "0.0.1",
|
|
4
|
+
"description": "Enterprise-grade OpenCode plugin with micro-plugin architecture and multi-agent orchestration",
|
|
5
|
+
"main": "index.js",
|
|
6
|
+
"type": "module",
|
|
7
|
+
"keywords": [
|
|
8
|
+
"opencode",
|
|
9
|
+
"plugin",
|
|
10
|
+
"agents",
|
|
11
|
+
"orchestration",
|
|
12
|
+
"ai"
|
|
13
|
+
],
|
|
14
|
+
"author": "ryanskidmore",
|
|
15
|
+
"license": "MIT",
|
|
16
|
+
"repository": {
|
|
17
|
+
"type": "git",
|
|
18
|
+
"url": "git+https://github.com/ryanskidmore/goatcode.git"
|
|
19
|
+
},
|
|
20
|
+
"homepage": "https://github.com/ryanskidmore/goatcode#readme",
|
|
21
|
+
"bugs": {
|
|
22
|
+
"url": "https://github.com/ryanskidmore/goatcode/issues"
|
|
23
|
+
}
|
|
24
|
+
}
|