@roackb2/heddle 0.0.37 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +11 -0
- package/dist/examples/conversation-engine.d.ts +2 -0
- package/dist/examples/conversation-engine.d.ts.map +1 -0
- package/dist/examples/conversation-engine.js +127 -0
- package/dist/examples/conversation-engine.js.map +1 -0
- package/dist/examples/repo-investigator.js +1 -2
- package/dist/examples/repo-investigator.js.map +1 -1
- package/dist/src/cli/ask.d.ts.map +1 -1
- package/dist/src/cli/ask.js +22 -3
- package/dist/src/cli/ask.js.map +1 -1
- package/dist/src/cli/chat/App.js +43 -27
- package/dist/src/cli/chat/App.js.map +1 -1
- package/dist/src/cli/chat/adapters/conversation-activity-adapter.d.ts +5 -0
- package/dist/src/cli/chat/adapters/conversation-activity-adapter.d.ts.map +1 -0
- package/dist/src/cli/chat/adapters/conversation-activity-adapter.js +43 -0
- package/dist/src/cli/chat/adapters/conversation-activity-adapter.js.map +1 -0
- package/dist/src/cli/chat/adapters/slash-command-context.d.ts +4 -0
- package/dist/src/cli/chat/adapters/slash-command-context.d.ts.map +1 -0
- package/dist/src/cli/chat/adapters/slash-command-context.js +48 -0
- package/dist/src/cli/chat/adapters/slash-command-context.js.map +1 -0
- package/dist/src/cli/chat/commands/debug-snapshot-command.d.ts +7 -0
- package/dist/src/cli/chat/commands/debug-snapshot-command.d.ts.map +1 -0
- package/dist/src/cli/chat/commands/debug-snapshot-command.js +25 -0
- package/dist/src/cli/chat/commands/debug-snapshot-command.js.map +1 -0
- package/dist/src/cli/chat/components/ApprovalComposer.js.map +1 -1
- package/dist/src/cli/chat/components/ConversationPanel.d.ts +42 -1
- package/dist/src/cli/chat/components/ConversationPanel.d.ts.map +1 -1
- package/dist/src/cli/chat/components/ConversationPanel.js +114 -67
- package/dist/src/cli/chat/components/ConversationPanel.js.map +1 -1
- package/dist/src/cli/chat/components/ModelPickerPanel.d.ts +2 -1
- package/dist/src/cli/chat/components/ModelPickerPanel.d.ts.map +1 -1
- package/dist/src/cli/chat/components/ModelPickerPanel.js +8 -4
- package/dist/src/cli/chat/components/ModelPickerPanel.js.map +1 -1
- package/dist/src/cli/chat/debug/tui-debug-snapshot.d.ts +2 -1
- package/dist/src/cli/chat/debug/tui-debug-snapshot.d.ts.map +1 -1
- package/dist/src/cli/chat/debug/tui-debug-snapshot.js +14 -1
- package/dist/src/cli/chat/debug/tui-debug-snapshot.js.map +1 -1
- package/dist/src/cli/chat/hooks/tui-agent-turn-result.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/tui-agent-turn-result.js +3 -2
- package/dist/src/cli/chat/hooks/tui-agent-turn-result.js.map +1 -1
- package/dist/src/cli/chat/hooks/tui-compaction-status.d.ts +1 -1
- package/dist/src/cli/chat/hooks/tui-compaction-status.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/tui-compaction-status.js.map +1 -1
- package/dist/src/cli/chat/hooks/tui-direct-shell-result.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/tui-direct-shell-result.js +2 -1
- package/dist/src/cli/chat/hooks/tui-direct-shell-result.js.map +1 -1
- package/dist/src/cli/chat/hooks/tui-direct-shell.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/tui-direct-shell.js +21 -7
- package/dist/src/cli/chat/hooks/tui-direct-shell.js.map +1 -1
- package/dist/src/cli/chat/hooks/tui-ordinary-turn.d.ts +2 -2
- package/dist/src/cli/chat/hooks/tui-ordinary-turn.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/tui-ordinary-turn.js +6 -5
- package/dist/src/cli/chat/hooks/tui-ordinary-turn.js.map +1 -1
- package/dist/src/cli/chat/hooks/tui-run-loop-events.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/tui-run-loop-events.js +13 -9
- package/dist/src/cli/chat/hooks/tui-run-loop-events.js.map +1 -1
- package/dist/src/cli/chat/hooks/tui-tool-approval.d.ts +8 -3
- package/dist/src/cli/chat/hooks/tui-tool-approval.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/tui-tool-approval.js +33 -25
- package/dist/src/cli/chat/hooks/tui-tool-approval.js.map +1 -1
- package/dist/src/cli/chat/hooks/useAgentRun.d.ts +2 -2
- package/dist/src/cli/chat/hooks/useAgentRun.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/useAgentRun.js +2 -2
- package/dist/src/cli/chat/hooks/useAgentRun.js.map +1 -1
- package/dist/src/cli/chat/hooks/useApprovalFlow.d.ts +2 -2
- package/dist/src/cli/chat/hooks/useApprovalFlow.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/useApprovalFlow.js +3 -3
- package/dist/src/cli/chat/hooks/useApprovalFlow.js.map +1 -1
- package/dist/src/cli/chat/hooks/useChatPickers.d.ts +6 -3
- package/dist/src/cli/chat/hooks/useChatPickers.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/useChatPickers.js +17 -4
- package/dist/src/cli/chat/hooks/useChatPickers.js.map +1 -1
- package/dist/src/cli/chat/hooks/useChatSessions.d.ts +1 -1
- package/dist/src/cli/chat/hooks/useChatSessions.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/useChatSessions.js +25 -22
- package/dist/src/cli/chat/hooks/useChatSessions.js.map +1 -1
- package/dist/src/cli/chat/hooks/useChatStatusSummary.d.ts +1 -1
- package/dist/src/cli/chat/hooks/useChatStatusSummary.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/usePromptSubmission.d.ts +2 -1
- package/dist/src/cli/chat/hooks/usePromptSubmission.d.ts.map +1 -1
- package/dist/src/cli/chat/hooks/usePromptSubmission.js +4 -1
- package/dist/src/cli/chat/hooks/usePromptSubmission.js.map +1 -1
- package/dist/src/cli/chat/state/approval-rules.d.ts +2 -20
- package/dist/src/cli/chat/state/approval-rules.d.ts.map +1 -1
- package/dist/src/cli/chat/state/approval-rules.js +1 -256
- package/dist/src/cli/chat/state/approval-rules.js.map +1 -1
- package/dist/src/cli/chat/state/compaction.d.ts +1 -1
- package/dist/src/cli/chat/state/compaction.d.ts.map +1 -1
- package/dist/src/cli/chat/state/compaction.js +1 -1
- package/dist/src/cli/chat/state/compaction.js.map +1 -1
- package/dist/src/cli/chat/state/local-commands.d.ts +5 -2
- package/dist/src/cli/chat/state/local-commands.d.ts.map +1 -1
- package/dist/src/cli/chat/state/local-commands.js +35 -410
- package/dist/src/cli/chat/state/local-commands.js.map +1 -1
- package/dist/src/cli/chat/state/storage.d.ts +1 -1
- package/dist/src/cli/chat/state/storage.d.ts.map +1 -1
- package/dist/src/cli/chat/state/storage.js +1 -1
- package/dist/src/cli/chat/state/storage.js.map +1 -1
- package/dist/src/cli/chat/state/types.d.ts +2 -1
- package/dist/src/cli/chat/state/types.d.ts.map +1 -1
- package/dist/src/cli/chat/submit.d.ts.map +1 -1
- package/dist/src/cli/chat/submit.js +13 -1
- package/dist/src/cli/chat/submit.js.map +1 -1
- package/dist/src/cli/chat/utils/file-mentions.js +1 -1
- package/dist/src/cli/chat/utils/file-mentions.js.map +1 -1
- package/dist/src/cli/chat/utils/format.d.ts +4 -12
- package/dist/src/cli/chat/utils/format.d.ts.map +1 -1
- package/dist/src/cli/chat/utils/format.js +12 -167
- package/dist/src/cli/chat/utils/format.js.map +1 -1
- package/dist/src/cli/chat/utils/runtime.d.ts +1 -1
- package/dist/src/cli/chat/utils/runtime.d.ts.map +1 -1
- package/dist/src/cli/chat/utils/runtime.js +1 -1
- package/dist/src/cli/chat/utils/runtime.js.map +1 -1
- package/dist/src/cli/eval/index.d.ts +24 -0
- package/dist/src/cli/eval/index.d.ts.map +1 -0
- package/dist/src/cli/eval/index.js +232 -0
- package/dist/src/cli/eval/index.js.map +1 -0
- package/dist/src/cli/main.js +25 -3
- package/dist/src/cli/main.js.map +1 -1
- package/dist/src/cli/remote/control-plane-client.d.ts +5 -1
- package/dist/src/cli/remote/control-plane-client.d.ts.map +1 -1
- package/dist/src/cli/session.js +1 -1
- package/dist/src/cli/session.js.map +1 -1
- package/dist/src/core/agent/mutation-tracking.d.ts +0 -7
- package/dist/src/core/agent/mutation-tracking.d.ts.map +1 -1
- package/dist/src/core/agent/mutation-tracking.js +5 -63
- package/dist/src/core/agent/mutation-tracking.js.map +1 -1
- package/dist/src/core/agent/post-mutation.d.ts +2 -2
- package/dist/src/core/agent/post-mutation.d.ts.map +1 -1
- package/dist/src/core/agent/post-mutation.js +5 -20
- package/dist/src/core/agent/post-mutation.js.map +1 -1
- package/dist/src/core/agent/progress-reminders.d.ts +1 -4
- package/dist/src/core/agent/progress-reminders.d.ts.map +1 -1
- package/dist/src/core/agent/progress-reminders.js +4 -56
- package/dist/src/core/agent/progress-reminders.js.map +1 -1
- package/dist/src/core/agent/run-agent.d.ts +2 -0
- package/dist/src/core/agent/run-agent.d.ts.map +1 -1
- package/dist/src/core/agent/run-agent.js +6 -103
- package/dist/src/core/agent/run-agent.js.map +1 -1
- package/dist/src/core/agent/tool-dispatch.d.ts +3 -0
- package/dist/src/core/agent/tool-dispatch.d.ts.map +1 -1
- package/dist/src/core/agent/tool-dispatch.js +24 -50
- package/dist/src/core/agent/tool-dispatch.js.map +1 -1
- package/dist/src/core/approvals/default-policies.d.ts +10 -0
- package/dist/src/core/approvals/default-policies.d.ts.map +1 -0
- package/dist/src/core/approvals/default-policies.js +37 -0
- package/dist/src/core/approvals/default-policies.js.map +1 -0
- package/dist/src/core/approvals/policy-chain.d.ts +9 -0
- package/dist/src/core/approvals/policy-chain.d.ts.map +1 -0
- package/dist/src/core/approvals/policy-chain.js +36 -0
- package/dist/src/core/approvals/policy-chain.js.map +1 -0
- package/dist/src/core/approvals/remembered-rules.d.ts +21 -0
- package/dist/src/core/approvals/remembered-rules.d.ts.map +1 -0
- package/dist/src/core/approvals/remembered-rules.js +257 -0
- package/dist/src/core/approvals/remembered-rules.js.map +1 -0
- package/dist/src/core/{chat/tool-approval-host.d.ts → approvals/surface.d.ts} +4 -6
- package/dist/src/core/approvals/surface.d.ts.map +1 -0
- package/dist/src/core/{chat/tool-approval-host.js → approvals/surface.js} +9 -1
- package/dist/src/core/approvals/surface.js.map +1 -0
- package/dist/src/core/approvals/types.d.ts +23 -0
- package/dist/src/core/approvals/types.d.ts.map +1 -0
- package/dist/src/core/approvals/types.js +2 -0
- package/dist/src/core/approvals/types.js.map +1 -0
- package/dist/src/core/chat/engine/config.d.ts +22 -0
- package/dist/src/core/chat/engine/config.d.ts.map +1 -0
- package/dist/src/core/chat/engine/config.js +27 -0
- package/dist/src/core/chat/engine/config.js.map +1 -0
- package/dist/src/core/chat/engine/conversation-engine.d.ts +3 -0
- package/dist/src/core/chat/engine/conversation-engine.d.ts.map +1 -0
- package/dist/src/core/chat/engine/conversation-engine.js +15 -0
- package/dist/src/core/chat/engine/conversation-engine.js.map +1 -0
- package/dist/src/core/chat/{compaction.d.ts → engine/history/compaction.d.ts} +3 -3
- package/dist/src/core/chat/engine/history/compaction.d.ts.map +1 -0
- package/dist/src/core/chat/{compaction.js → engine/history/compaction.js} +5 -5
- package/dist/src/core/chat/engine/history/compaction.js.map +1 -0
- package/dist/src/core/chat/engine/index.d.ts +5 -0
- package/dist/src/core/chat/engine/index.d.ts.map +1 -0
- package/dist/src/core/chat/engine/index.js +3 -0
- package/dist/src/core/chat/engine/index.js.map +1 -0
- package/dist/src/core/chat/{archive.d.ts → engine/sessions/archive.d.ts} +2 -2
- package/dist/src/core/chat/engine/sessions/archive.d.ts.map +1 -0
- package/dist/src/core/chat/engine/sessions/archive.js.map +1 -0
- package/dist/src/core/chat/engine/sessions/conversation-lines.d.ts +4 -0
- package/dist/src/core/chat/engine/sessions/conversation-lines.d.ts.map +1 -0
- package/dist/src/core/chat/{conversation-lines.js → engine/sessions/conversation-lines.js} +1 -1
- package/dist/src/core/chat/engine/sessions/conversation-lines.js.map +1 -0
- package/dist/src/core/chat/{session-lease.d.ts → engine/sessions/lease.d.ts} +2 -2
- package/dist/src/core/chat/engine/sessions/lease.d.ts.map +1 -0
- package/dist/src/core/chat/{session-lease.js → engine/sessions/lease.js} +1 -1
- package/dist/src/core/chat/engine/sessions/lease.js.map +1 -0
- package/dist/src/core/chat/engine/sessions/service.d.ts +6 -0
- package/dist/src/core/chat/engine/sessions/service.d.ts.map +1 -0
- package/dist/src/core/chat/engine/sessions/service.js +50 -0
- package/dist/src/core/chat/engine/sessions/service.js.map +1 -0
- package/dist/src/core/chat/{storage.d.ts → engine/sessions/storage.d.ts} +1 -1
- package/dist/src/core/chat/engine/sessions/storage.d.ts.map +1 -0
- package/dist/src/core/chat/{storage.js → engine/sessions/storage.js} +1 -1
- package/dist/src/core/chat/engine/sessions/storage.js.map +1 -0
- package/dist/src/core/chat/{session-title.d.ts → engine/sessions/title.d.ts} +2 -2
- package/dist/src/core/chat/engine/sessions/title.d.ts.map +1 -0
- package/dist/src/core/chat/{session-title.js → engine/sessions/title.js} +1 -1
- package/dist/src/core/chat/engine/sessions/title.js.map +1 -0
- package/dist/src/core/chat/engine/turns/context.d.ts +25 -0
- package/dist/src/core/chat/engine/turns/context.d.ts.map +1 -0
- package/dist/src/core/chat/engine/turns/context.js +41 -0
- package/dist/src/core/chat/engine/turns/context.js.map +1 -0
- package/dist/src/core/chat/engine/turns/host-bridge.d.ts +37 -0
- package/dist/src/core/chat/engine/turns/host-bridge.d.ts.map +1 -0
- package/dist/src/core/chat/engine/turns/host-bridge.js +20 -0
- package/dist/src/core/chat/engine/turns/host-bridge.js.map +1 -0
- package/dist/src/core/chat/engine/turns/host.d.ts +3 -0
- package/dist/src/core/chat/engine/turns/host.d.ts.map +1 -0
- package/dist/src/core/chat/engine/turns/host.js +42 -0
- package/dist/src/core/chat/engine/turns/host.js.map +1 -0
- package/dist/src/core/chat/engine/turns/memory-maintenance.d.ts +33 -0
- package/dist/src/core/chat/engine/turns/memory-maintenance.d.ts.map +1 -0
- package/dist/src/core/chat/engine/turns/memory-maintenance.js +120 -0
- package/dist/src/core/chat/engine/turns/memory-maintenance.js.map +1 -0
- package/dist/src/core/chat/engine/turns/persistence.d.ts +25 -0
- package/dist/src/core/chat/engine/turns/persistence.d.ts.map +1 -0
- package/dist/src/core/chat/engine/turns/persistence.js +45 -0
- package/dist/src/core/chat/engine/turns/persistence.js.map +1 -0
- package/dist/src/core/chat/{session-turn-preflight.d.ts → engine/turns/preflight.d.ts} +25 -6
- package/dist/src/core/chat/engine/turns/preflight.d.ts.map +1 -0
- package/dist/src/core/chat/engine/turns/preflight.js +96 -0
- package/dist/src/core/chat/engine/turns/preflight.js.map +1 -0
- package/dist/src/core/chat/{session-turn-result.d.ts → engine/turns/result.d.ts} +7 -5
- package/dist/src/core/chat/engine/turns/result.d.ts.map +1 -0
- package/dist/src/core/chat/{session-turn-result.js → engine/turns/result.js} +11 -9
- package/dist/src/core/chat/engine/turns/result.js.map +1 -0
- package/dist/src/core/chat/engine/turns/run-conversation-turn.d.ts +37 -0
- package/dist/src/core/chat/engine/turns/run-conversation-turn.d.ts.map +1 -0
- package/dist/src/core/chat/engine/turns/run-conversation-turn.js +125 -0
- package/dist/src/core/chat/engine/turns/run-conversation-turn.js.map +1 -0
- package/dist/src/core/chat/engine/turns/runtime.d.ts +26 -0
- package/dist/src/core/chat/engine/turns/runtime.d.ts.map +1 -0
- package/dist/src/core/chat/engine/turns/runtime.js +55 -0
- package/dist/src/core/chat/engine/turns/runtime.js.map +1 -0
- package/dist/src/core/chat/engine/turns/service.d.ts +6 -0
- package/dist/src/core/chat/engine/turns/service.d.ts.map +1 -0
- package/dist/src/core/chat/engine/turns/service.js +51 -0
- package/dist/src/core/chat/engine/turns/service.js.map +1 -0
- package/dist/src/core/chat/engine/turns/trace.d.ts +3 -0
- package/dist/src/core/chat/engine/turns/trace.d.ts.map +1 -0
- package/dist/src/core/chat/engine/turns/trace.js.map +1 -0
- package/dist/src/core/chat/engine/types.d.ts +111 -0
- package/dist/src/core/chat/engine/types.d.ts.map +1 -0
- package/dist/src/core/chat/engine/types.js +2 -0
- package/dist/src/core/chat/engine/types.js.map +1 -0
- package/dist/src/core/chat/types.d.ts +3 -20
- package/dist/src/core/chat/types.d.ts.map +1 -1
- package/dist/src/core/commands/slash/autocomplete.d.ts +6 -0
- package/dist/src/core/commands/slash/autocomplete.d.ts.map +1 -0
- package/dist/src/core/commands/slash/autocomplete.js +56 -0
- package/dist/src/core/commands/slash/autocomplete.js.map +1 -0
- package/dist/src/core/commands/slash/modules/auth/auth-commands.d.ts +5 -0
- package/dist/src/core/commands/slash/modules/auth/auth-commands.d.ts.map +1 -0
- package/dist/src/core/commands/slash/modules/auth/auth-commands.js +67 -0
- package/dist/src/core/commands/slash/modules/auth/auth-commands.js.map +1 -0
- package/dist/src/core/commands/slash/modules/compaction/compaction-commands.d.ts +5 -0
- package/dist/src/core/commands/slash/modules/compaction/compaction-commands.d.ts.map +1 -0
- package/dist/src/core/commands/slash/modules/compaction/compaction-commands.js +20 -0
- package/dist/src/core/commands/slash/modules/compaction/compaction-commands.js.map +1 -0
- package/dist/src/core/commands/slash/modules/context.d.ts +48 -0
- package/dist/src/core/commands/slash/modules/context.d.ts.map +1 -0
- package/dist/src/core/commands/slash/modules/context.js +2 -0
- package/dist/src/core/commands/slash/modules/context.js.map +1 -0
- package/dist/src/core/commands/slash/modules/core-command-modules.d.ts +5 -0
- package/dist/src/core/commands/slash/modules/core-command-modules.d.ts.map +1 -0
- package/dist/src/core/commands/slash/modules/core-command-modules.js +17 -0
- package/dist/src/core/commands/slash/modules/core-command-modules.js.map +1 -0
- package/dist/src/core/commands/slash/modules/drift/drift-commands.d.ts +6 -0
- package/dist/src/core/commands/slash/modules/drift/drift-commands.d.ts.map +1 -0
- package/dist/src/core/commands/slash/modules/drift/drift-commands.js +54 -0
- package/dist/src/core/commands/slash/modules/drift/drift-commands.js.map +1 -0
- package/dist/src/core/commands/slash/modules/heartbeat/heartbeat-commands.d.ts +12 -0
- package/dist/src/core/commands/slash/modules/heartbeat/heartbeat-commands.d.ts.map +1 -0
- package/dist/src/core/commands/slash/modules/heartbeat/heartbeat-commands.js +199 -0
- package/dist/src/core/commands/slash/modules/heartbeat/heartbeat-commands.js.map +1 -0
- package/dist/src/core/commands/slash/modules/model/model-commands.d.ts +7 -0
- package/dist/src/core/commands/slash/modules/model/model-commands.d.ts.map +1 -0
- package/dist/src/core/commands/slash/modules/model/model-commands.js +77 -0
- package/dist/src/core/commands/slash/modules/model/model-commands.js.map +1 -0
- package/dist/src/core/commands/slash/modules/results.d.ts +6 -0
- package/dist/src/core/commands/slash/modules/results.d.ts.map +1 -0
- package/dist/src/core/commands/slash/modules/results.js +15 -0
- package/dist/src/core/commands/slash/modules/results.js.map +1 -0
- package/dist/src/core/commands/slash/modules/session/session-commands.d.ts +11 -0
- package/dist/src/core/commands/slash/modules/session/session-commands.d.ts.map +1 -0
- package/dist/src/core/commands/slash/modules/session/session-commands.js +146 -0
- package/dist/src/core/commands/slash/modules/session/session-commands.js.map +1 -0
- package/dist/src/core/commands/slash/parser.d.ts +7 -0
- package/dist/src/core/commands/slash/parser.d.ts.map +1 -0
- package/dist/src/core/commands/slash/parser.js +44 -0
- package/dist/src/core/commands/slash/parser.js.map +1 -0
- package/dist/src/core/commands/slash/registry.d.ts +9 -0
- package/dist/src/core/commands/slash/registry.d.ts.map +1 -0
- package/dist/src/core/commands/slash/registry.js +50 -0
- package/dist/src/core/commands/slash/registry.js.map +1 -0
- package/dist/src/core/commands/slash/result-types.d.ts +20 -0
- package/dist/src/core/commands/slash/result-types.d.ts.map +1 -0
- package/dist/src/core/commands/slash/result-types.js +2 -0
- package/dist/src/core/commands/slash/result-types.js.map +1 -0
- package/dist/src/core/commands/slash/types.d.ts +28 -0
- package/dist/src/core/commands/slash/types.d.ts.map +1 -0
- package/dist/src/core/commands/slash/types.js +2 -0
- package/dist/src/core/commands/slash/types.js.map +1 -0
- package/dist/src/core/config.d.ts +1 -1
- package/dist/src/core/config.d.ts.map +1 -1
- package/dist/src/core/config.js +1 -1
- package/dist/src/core/config.js.map +1 -1
- package/dist/src/core/eval/agent-runner.d.ts +24 -0
- package/dist/src/core/eval/agent-runner.d.ts.map +1 -0
- package/dist/src/core/eval/agent-runner.js +151 -0
- package/dist/src/core/eval/agent-runner.js.map +1 -0
- package/dist/src/core/eval/case-loader.d.ts +7 -0
- package/dist/src/core/eval/case-loader.d.ts.map +1 -0
- package/dist/src/core/eval/case-loader.js +34 -0
- package/dist/src/core/eval/case-loader.js.map +1 -0
- package/dist/src/core/eval/check-runner.d.ts +8 -0
- package/dist/src/core/eval/check-runner.d.ts.map +1 -0
- package/dist/src/core/eval/check-runner.js +33 -0
- package/dist/src/core/eval/check-runner.js.map +1 -0
- package/dist/src/core/eval/cleanup.d.ts +20 -0
- package/dist/src/core/eval/cleanup.d.ts.map +1 -0
- package/dist/src/core/eval/cleanup.js +42 -0
- package/dist/src/core/eval/cleanup.js.map +1 -0
- package/dist/src/core/eval/git-artifacts.d.ts +26 -0
- package/dist/src/core/eval/git-artifacts.d.ts.map +1 -0
- package/dist/src/core/eval/git-artifacts.js +211 -0
- package/dist/src/core/eval/git-artifacts.js.map +1 -0
- package/dist/src/core/eval/process.d.ts +22 -0
- package/dist/src/core/eval/process.d.ts.map +1 -0
- package/dist/src/core/eval/process.js +65 -0
- package/dist/src/core/eval/process.js.map +1 -0
- package/dist/src/core/eval/progress.d.ts +28 -0
- package/dist/src/core/eval/progress.d.ts.map +1 -0
- package/dist/src/core/eval/progress.js +94 -0
- package/dist/src/core/eval/progress.js.map +1 -0
- package/dist/src/core/eval/report-writer.d.ts +7 -0
- package/dist/src/core/eval/report-writer.d.ts.map +1 -0
- package/dist/src/core/eval/report-writer.js +159 -0
- package/dist/src/core/eval/report-writer.js.map +1 -0
- package/dist/src/core/eval/schema.d.ts +206 -0
- package/dist/src/core/eval/schema.d.ts.map +1 -0
- package/dist/src/core/eval/schema.js +104 -0
- package/dist/src/core/eval/schema.js.map +1 -0
- package/dist/src/core/eval/trace-analyzer.d.ts +6 -0
- package/dist/src/core/eval/trace-analyzer.d.ts.map +1 -0
- package/dist/src/core/eval/trace-analyzer.js +106 -0
- package/dist/src/core/eval/trace-analyzer.js.map +1 -0
- package/dist/src/core/eval/workspace-fixture.d.ts +14 -0
- package/dist/src/core/eval/workspace-fixture.d.ts.map +1 -0
- package/dist/src/core/eval/workspace-fixture.js +235 -0
- package/dist/src/core/eval/workspace-fixture.js.map +1 -0
- package/dist/src/core/llm/model-policy.d.ts +26 -0
- package/dist/src/core/llm/model-policy.d.ts.map +1 -1
- package/dist/src/core/llm/model-policy.js +47 -0
- package/dist/src/core/llm/model-policy.js.map +1 -1
- package/dist/src/core/memory/maintainer-tools.js +1 -1
- package/dist/src/core/memory/maintainer-tools.js.map +1 -1
- package/dist/src/core/memory/visibility.js +1 -1
- package/dist/src/core/memory/visibility.js.map +1 -1
- package/dist/src/core/observability/conversation-activity.d.ts +114 -0
- package/dist/src/core/observability/conversation-activity.d.ts.map +1 -0
- package/dist/src/core/observability/conversation-activity.js +249 -0
- package/dist/src/core/observability/conversation-activity.js.map +1 -0
- package/dist/src/core/observability/semantic-conventions.d.ts +33 -0
- package/dist/src/core/observability/semantic-conventions.d.ts.map +1 -0
- package/dist/src/core/observability/semantic-conventions.js +33 -0
- package/dist/src/core/observability/semantic-conventions.js.map +1 -0
- package/dist/src/core/observability/trace-summarizers.d.ts +23 -0
- package/dist/src/core/observability/trace-summarizers.d.ts.map +1 -0
- package/dist/src/core/observability/trace-summarizers.js +60 -0
- package/dist/src/core/observability/trace-summarizers.js.map +1 -0
- package/dist/src/core/prompts/system-prompt.d.ts +1 -1
- package/dist/src/core/prompts/system-prompt.d.ts.map +1 -1
- package/dist/src/core/prompts/system-prompt.js +19 -100
- package/dist/src/core/prompts/system-prompt.js.map +1 -1
- package/dist/src/core/runtime/agent-loop.d.ts +2 -0
- package/dist/src/core/runtime/agent-loop.d.ts.map +1 -1
- package/dist/src/core/runtime/agent-loop.js +1 -0
- package/dist/src/core/runtime/agent-loop.js.map +1 -1
- package/dist/src/core/runtime/default-tools.d.ts.map +1 -1
- package/dist/src/core/runtime/default-tools.js +33 -54
- package/dist/src/core/runtime/default-tools.js.map +1 -1
- package/dist/src/core/runtime/heartbeat.d.ts +2 -0
- package/dist/src/core/runtime/heartbeat.d.ts.map +1 -1
- package/dist/src/core/runtime/heartbeat.js +1 -0
- package/dist/src/core/runtime/heartbeat.js.map +1 -1
- package/dist/src/core/tools/toolkit.d.ts +20 -0
- package/dist/src/core/tools/toolkit.d.ts.map +1 -0
- package/dist/src/core/tools/toolkit.js +21 -0
- package/dist/src/core/tools/toolkit.js.map +1 -0
- package/dist/src/core/tools/{delete-file.d.ts → toolkits/coding-files/delete-file.d.ts} +1 -1
- package/dist/src/core/tools/toolkits/coding-files/delete-file.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/coding-files/delete-file.js.map +1 -0
- package/dist/src/core/tools/{edit-file.d.ts → toolkits/coding-files/edit-file.d.ts} +1 -1
- package/dist/src/core/tools/toolkits/coding-files/edit-file.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/coding-files/edit-file.js.map +1 -0
- package/dist/src/core/tools/{file-edit-core.d.ts → toolkits/coding-files/file-edit-core.d.ts} +1 -1
- package/dist/src/core/tools/toolkits/coding-files/file-edit-core.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/coding-files/file-edit-core.js.map +1 -0
- package/dist/src/core/tools/toolkits/coding-files/index.d.ts +8 -0
- package/dist/src/core/tools/toolkits/coding-files/index.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/coding-files/index.js +8 -0
- package/dist/src/core/tools/toolkits/coding-files/index.js.map +1 -0
- package/dist/src/core/tools/{list-files.d.ts → toolkits/coding-files/list-files.d.ts} +1 -1
- package/dist/src/core/tools/toolkits/coding-files/list-files.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/coding-files/list-files.js.map +1 -0
- package/dist/src/core/tools/{move-file.d.ts → toolkits/coding-files/move-file.d.ts} +1 -1
- package/dist/src/core/tools/toolkits/coding-files/move-file.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/coding-files/move-file.js.map +1 -0
- package/dist/src/core/tools/{read-file.d.ts → toolkits/coding-files/read-file.d.ts} +1 -1
- package/dist/src/core/tools/toolkits/coding-files/read-file.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/coding-files/read-file.js.map +1 -0
- package/dist/src/core/tools/{search-files.d.ts → toolkits/coding-files/search-files.d.ts} +1 -1
- package/dist/src/core/tools/toolkits/coding-files/search-files.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/coding-files/search-files.js.map +1 -0
- package/dist/src/core/tools/toolkits/coding-files/toolkit.d.ts +3 -0
- package/dist/src/core/tools/toolkits/coding-files/toolkit.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/coding-files/toolkit.js +23 -0
- package/dist/src/core/tools/toolkits/coding-files/toolkit.js.map +1 -0
- package/dist/src/core/tools/toolkits/external-context/toolkit.d.ts +3 -0
- package/dist/src/core/tools/toolkits/external-context/toolkit.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/external-context/toolkit.js +23 -0
- package/dist/src/core/tools/toolkits/external-context/toolkit.js.map +1 -0
- package/dist/src/core/tools/{view-image.d.ts → toolkits/external-context/view-image.d.ts} +3 -3
- package/dist/src/core/tools/toolkits/external-context/view-image.d.ts.map +1 -0
- package/dist/src/core/tools/{view-image.js → toolkits/external-context/view-image.js} +5 -5
- package/dist/src/core/tools/toolkits/external-context/view-image.js.map +1 -0
- package/dist/src/core/tools/{web-search.d.ts → toolkits/external-context/web-search.d.ts} +3 -3
- package/dist/src/core/tools/toolkits/external-context/web-search.d.ts.map +1 -0
- package/dist/src/core/tools/{web-search.js → toolkits/external-context/web-search.js} +5 -5
- package/dist/src/core/tools/toolkits/external-context/web-search.js.map +1 -0
- package/dist/src/core/tools/toolkits/internal/toolkit.d.ts +3 -0
- package/dist/src/core/tools/toolkits/internal/toolkit.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/internal/toolkit.js +8 -0
- package/dist/src/core/tools/toolkits/internal/toolkit.js.map +1 -0
- package/dist/src/core/tools/{update-plan.d.ts → toolkits/internal/update-plan.d.ts} +1 -1
- package/dist/src/core/tools/toolkits/internal/update-plan.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/internal/update-plan.js.map +1 -0
- package/dist/src/core/tools/{memory-checkpoint.d.ts → toolkits/knowledge/memory-checkpoint.d.ts} +1 -1
- package/dist/src/core/tools/toolkits/knowledge/memory-checkpoint.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/knowledge/memory-checkpoint.js.map +1 -0
- package/dist/src/core/tools/{memory-notes.d.ts → toolkits/knowledge/memory-notes.d.ts} +1 -1
- package/dist/src/core/tools/toolkits/knowledge/memory-notes.d.ts.map +1 -0
- package/dist/src/core/tools/{memory-notes.js → toolkits/knowledge/memory-notes.js} +1 -1
- package/dist/src/core/tools/toolkits/knowledge/memory-notes.js.map +1 -0
- package/dist/src/core/tools/{record-knowledge.d.ts → toolkits/knowledge/record-knowledge.d.ts} +1 -1
- package/dist/src/core/tools/toolkits/knowledge/record-knowledge.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/knowledge/record-knowledge.js.map +1 -0
- package/dist/src/core/tools/toolkits/knowledge/toolkit.d.ts +3 -0
- package/dist/src/core/tools/toolkits/knowledge/toolkit.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/knowledge/toolkit.js +29 -0
- package/dist/src/core/tools/toolkits/knowledge/toolkit.js.map +1 -0
- package/dist/src/core/tools/toolkits/shell-process/index.d.ts +4 -0
- package/dist/src/core/tools/toolkits/shell-process/index.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/shell-process/index.js +3 -0
- package/dist/src/core/tools/toolkits/shell-process/index.js.map +1 -0
- package/dist/src/core/tools/toolkits/shell-process/run-shell.d.ts +18 -0
- package/dist/src/core/tools/toolkits/shell-process/run-shell.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/shell-process/run-shell.js +210 -0
- package/dist/src/core/tools/toolkits/shell-process/run-shell.js.map +1 -0
- package/dist/src/core/tools/{run-shell.d.ts → toolkits/shell-process/shell-policy.d.ts} +4 -17
- package/dist/src/core/tools/toolkits/shell-process/shell-policy.d.ts.map +1 -0
- package/dist/src/core/tools/{run-shell.js → toolkits/shell-process/shell-policy.js} +41 -238
- package/dist/src/core/tools/toolkits/shell-process/shell-policy.js.map +1 -0
- package/dist/src/core/tools/toolkits/shell-process/toolkit.d.ts +3 -0
- package/dist/src/core/tools/toolkits/shell-process/toolkit.d.ts.map +1 -0
- package/dist/src/core/tools/toolkits/shell-process/toolkit.js +11 -0
- package/dist/src/core/tools/toolkits/shell-process/toolkit.js.map +1 -0
- package/dist/src/index.d.ts +37 -25
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +24 -15
- package/dist/src/index.js.map +1 -1
- package/dist/src/server/features/control-plane/router.d.ts +5 -1
- package/dist/src/server/features/control-plane/router.d.ts.map +1 -1
- package/dist/src/server/features/control-plane/router.js +17 -2
- package/dist/src/server/features/control-plane/router.js.map +1 -1
- package/dist/src/server/features/control-plane/services/chat-session-events.d.ts +1 -1
- package/dist/src/server/features/control-plane/services/chat-session-events.d.ts.map +1 -1
- package/dist/src/server/features/control-plane/services/chat-sessions.d.ts +5 -2
- package/dist/src/server/features/control-plane/services/chat-sessions.d.ts.map +1 -1
- package/dist/src/server/features/control-plane/services/chat-sessions.js +67 -29
- package/dist/src/server/features/control-plane/services/chat-sessions.js.map +1 -1
- package/dist/src/server/router.d.ts +5 -1
- package/dist/src/server/router.d.ts.map +1 -1
- package/dist/src/web/assets/{MonacoDiffViewer-DM8Cy5Xf.js → MonacoDiffViewer-tvXEFlgh.js} +1 -1
- package/dist/src/web/assets/index-CYd4sslC.css +2 -0
- package/dist/src/web/assets/index-WQmlPSO9.js +56 -0
- package/dist/src/web/index.html +2 -2
- package/package.json +8 -2
- package/dist/src/core/chat/archive.d.ts.map +0 -1
- package/dist/src/core/chat/archive.js.map +0 -1
- package/dist/src/core/chat/compaction.d.ts.map +0 -1
- package/dist/src/core/chat/compaction.js.map +0 -1
- package/dist/src/core/chat/conversation-lines.d.ts +0 -4
- package/dist/src/core/chat/conversation-lines.d.ts.map +0 -1
- package/dist/src/core/chat/conversation-lines.js.map +0 -1
- package/dist/src/core/chat/ordinary-turn.d.ts +0 -34
- package/dist/src/core/chat/ordinary-turn.d.ts.map +0 -1
- package/dist/src/core/chat/ordinary-turn.js +0 -274
- package/dist/src/core/chat/ordinary-turn.js.map +0 -1
- package/dist/src/core/chat/session-lease.d.ts.map +0 -1
- package/dist/src/core/chat/session-lease.js.map +0 -1
- package/dist/src/core/chat/session-submit.d.ts +0 -35
- package/dist/src/core/chat/session-submit.d.ts.map +0 -1
- package/dist/src/core/chat/session-submit.js +0 -30
- package/dist/src/core/chat/session-submit.js.map +0 -1
- package/dist/src/core/chat/session-title.d.ts.map +0 -1
- package/dist/src/core/chat/session-title.js.map +0 -1
- package/dist/src/core/chat/session-turn-preflight.d.ts.map +0 -1
- package/dist/src/core/chat/session-turn-preflight.js +0 -43
- package/dist/src/core/chat/session-turn-preflight.js.map +0 -1
- package/dist/src/core/chat/session-turn-result.d.ts.map +0 -1
- package/dist/src/core/chat/session-turn-result.js.map +0 -1
- package/dist/src/core/chat/storage.d.ts.map +0 -1
- package/dist/src/core/chat/storage.js.map +0 -1
- package/dist/src/core/chat/tool-approval-host.d.ts.map +0 -1
- package/dist/src/core/chat/tool-approval-host.js.map +0 -1
- package/dist/src/core/chat/trace-summary.d.ts +0 -4
- package/dist/src/core/chat/trace-summary.d.ts.map +0 -1
- package/dist/src/core/chat/trace-summary.js +0 -76
- package/dist/src/core/chat/trace-summary.js.map +0 -1
- package/dist/src/core/chat/trace.d.ts +0 -3
- package/dist/src/core/chat/trace.d.ts.map +0 -1
- package/dist/src/core/chat/trace.js.map +0 -1
- package/dist/src/core/chat/turn-host.d.ts +0 -25
- package/dist/src/core/chat/turn-host.d.ts.map +0 -1
- package/dist/src/core/chat/turn-host.js +0 -2
- package/dist/src/core/chat/turn-host.js.map +0 -1
- package/dist/src/core/tools/delete-file.d.ts.map +0 -1
- package/dist/src/core/tools/delete-file.js.map +0 -1
- package/dist/src/core/tools/edit-file.d.ts.map +0 -1
- package/dist/src/core/tools/edit-file.js.map +0 -1
- package/dist/src/core/tools/file-edit-core.d.ts.map +0 -1
- package/dist/src/core/tools/file-edit-core.js.map +0 -1
- package/dist/src/core/tools/list-files.d.ts.map +0 -1
- package/dist/src/core/tools/list-files.js.map +0 -1
- package/dist/src/core/tools/memory-checkpoint.d.ts.map +0 -1
- package/dist/src/core/tools/memory-checkpoint.js.map +0 -1
- package/dist/src/core/tools/memory-notes.d.ts.map +0 -1
- package/dist/src/core/tools/memory-notes.js.map +0 -1
- package/dist/src/core/tools/move-file.d.ts.map +0 -1
- package/dist/src/core/tools/move-file.js.map +0 -1
- package/dist/src/core/tools/read-file.d.ts.map +0 -1
- package/dist/src/core/tools/read-file.js.map +0 -1
- package/dist/src/core/tools/record-knowledge.d.ts.map +0 -1
- package/dist/src/core/tools/record-knowledge.js.map +0 -1
- package/dist/src/core/tools/report-state.d.ts +0 -3
- package/dist/src/core/tools/report-state.d.ts.map +0 -1
- package/dist/src/core/tools/report-state.js +0 -63
- package/dist/src/core/tools/report-state.js.map +0 -1
- package/dist/src/core/tools/run-shell.d.ts.map +0 -1
- package/dist/src/core/tools/run-shell.js.map +0 -1
- package/dist/src/core/tools/search-files.d.ts.map +0 -1
- package/dist/src/core/tools/search-files.js.map +0 -1
- package/dist/src/core/tools/update-plan.d.ts.map +0 -1
- package/dist/src/core/tools/update-plan.js.map +0 -1
- package/dist/src/core/tools/view-image.d.ts.map +0 -1
- package/dist/src/core/tools/view-image.js.map +0 -1
- package/dist/src/core/tools/web-search.d.ts.map +0 -1
- package/dist/src/core/tools/web-search.js.map +0 -1
- package/dist/src/web/assets/index-BEeN-RT5.css +0 -2
- package/dist/src/web/assets/index-BKDg9H_-.js +0 -56
- /package/dist/src/core/chat/{archive.js → engine/sessions/archive.js} +0 -0
- /package/dist/src/core/chat/{trace.js → engine/turns/trace.js} +0 -0
- /package/dist/src/core/tools/{delete-file.js → toolkits/coding-files/delete-file.js} +0 -0
- /package/dist/src/core/tools/{edit-file.js → toolkits/coding-files/edit-file.js} +0 -0
- /package/dist/src/core/tools/{file-edit-core.js → toolkits/coding-files/file-edit-core.js} +0 -0
- /package/dist/src/core/tools/{list-files.js → toolkits/coding-files/list-files.js} +0 -0
- /package/dist/src/core/tools/{move-file.js → toolkits/coding-files/move-file.js} +0 -0
- /package/dist/src/core/tools/{read-file.js → toolkits/coding-files/read-file.js} +0 -0
- /package/dist/src/core/tools/{search-files.js → toolkits/coding-files/search-files.js} +0 -0
- /package/dist/src/core/tools/{update-plan.js → toolkits/internal/update-plan.js} +0 -0
- /package/dist/src/core/tools/{memory-checkpoint.js → toolkits/knowledge/memory-checkpoint.js} +0 -0
- /package/dist/src/core/tools/{record-knowledge.js → toolkits/knowledge/record-knowledge.js} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-commands.js","sourceRoot":"","sources":["../../../../../../../src/core/commands/slash/modules/session/session-commands.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ParsedSlashCommand } from './types.js';
|
|
2
|
+
export declare function parseSlashCommand(input: string): ParsedSlashCommand | undefined;
|
|
3
|
+
export declare function isSlashCommandInput(input: string): boolean;
|
|
4
|
+
export declare function matchesExactSlashCommand(command: string): (input: ParsedSlashCommand) => boolean;
|
|
5
|
+
export declare function matchesAnyExactSlashCommand(commands: string[]): (input: ParsedSlashCommand) => boolean;
|
|
6
|
+
export declare function matchesSlashCommandPrefix(prefix: string): (input: ParsedSlashCommand) => boolean;
|
|
7
|
+
//# sourceMappingURL=parser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parser.d.ts","sourceRoot":"","sources":["../../../../../src/core/commands/slash/parser.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAErD,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,kBAAkB,GAAG,SAAS,CA8B/E;AAED,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAE1D;AAED,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,MAAM,GAAG,CAAC,KAAK,EAAE,kBAAkB,KAAK,OAAO,CAEhG;AAED,wBAAgB,2BAA2B,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,CAAC,KAAK,EAAE,kBAAkB,KAAK,OAAO,CAGtG;AAED,wBAAgB,yBAAyB,CAAC,MAAM,EAAE,MAAM,GAAG,CAAC,KAAK,EAAE,kBAAkB,KAAK,OAAO,CAIhG"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
export function parseSlashCommand(input) {
|
|
2
|
+
const raw = input.trim();
|
|
3
|
+
if (!raw.startsWith('/')) {
|
|
4
|
+
return undefined;
|
|
5
|
+
}
|
|
6
|
+
const body = raw.slice(1).trim();
|
|
7
|
+
if (!body) {
|
|
8
|
+
return {
|
|
9
|
+
raw,
|
|
10
|
+
root: '',
|
|
11
|
+
tokens: [],
|
|
12
|
+
rest: '',
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
const firstToken = body.split(/\s+/, 1)[0] ?? '';
|
|
16
|
+
if (firstToken.includes('/')) {
|
|
17
|
+
return undefined;
|
|
18
|
+
}
|
|
19
|
+
const tokens = body.split(/\s+/).filter(Boolean);
|
|
20
|
+
const root = tokens[0] ?? '';
|
|
21
|
+
const rest = body.slice(root.length).trimStart();
|
|
22
|
+
return {
|
|
23
|
+
raw,
|
|
24
|
+
root,
|
|
25
|
+
tokens,
|
|
26
|
+
rest,
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
export function isSlashCommandInput(input) {
|
|
30
|
+
return parseSlashCommand(input) !== undefined;
|
|
31
|
+
}
|
|
32
|
+
export function matchesExactSlashCommand(command) {
|
|
33
|
+
return (input) => input.raw === command;
|
|
34
|
+
}
|
|
35
|
+
export function matchesAnyExactSlashCommand(commands) {
|
|
36
|
+
const normalized = new Set(commands);
|
|
37
|
+
return (input) => normalized.has(input.raw);
|
|
38
|
+
}
|
|
39
|
+
export function matchesSlashCommandPrefix(prefix) {
|
|
40
|
+
const normalizedPrefix = prefix.endsWith(' ') ? prefix : `${prefix} `;
|
|
41
|
+
const exactPrefix = normalizedPrefix.trimEnd();
|
|
42
|
+
return (input) => input.raw === exactPrefix || input.raw.startsWith(normalizedPrefix);
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parser.js","sourceRoot":"","sources":["../../../../../src/core/commands/slash/parser.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,iBAAiB,CAAC,KAAa;IAC7C,MAAM,GAAG,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC;IACzB,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;QACzB,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,IAAI,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;IACjC,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,OAAO;YACL,GAAG;YACH,IAAI,EAAE,EAAE;YACR,MAAM,EAAE,EAAE;YACV,IAAI,EAAE,EAAE;SACT,CAAC;IACJ,CAAC;IAED,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;IACjD,IAAI,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;QAC7B,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACjD,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;IAC7B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC;IACjD,OAAO;QACL,GAAG;QACH,IAAI;QACJ,MAAM;QACN,IAAI;KACL,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,KAAa;IAC/C,OAAO,iBAAiB,CAAC,KAAK,CAAC,KAAK,SAAS,CAAC;AAChD,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,OAAe;IACtD,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,KAAK,OAAO,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,2BAA2B,CAAC,QAAkB;IAC5D,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,CAAC;IACrC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,yBAAyB,CAAC,MAAc;IACtD,MAAM,gBAAgB,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,CAAC;IACtE,MAAM,WAAW,GAAG,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAC/C,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,KAAK,WAAW,IAAI,KAAK,CAAC,GAAG,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;AACxF,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ParsedSlashCommand, SlashCommand, SlashCommandHint, SlashCommandMatch, SlashCommandModule } from './types.js';
|
|
2
|
+
export type SlashCommandRegistry<Result, Context> = {
|
|
3
|
+
commands(): SlashCommand<Result, Context>[];
|
|
4
|
+
hints(): SlashCommandHint[];
|
|
5
|
+
find(input: string | ParsedSlashCommand): SlashCommandMatch<Result, Context> | undefined;
|
|
6
|
+
run(context: Context, input: string | ParsedSlashCommand): Promise<Result | undefined>;
|
|
7
|
+
};
|
|
8
|
+
export declare function createSlashCommandRegistry<Result, Context>(modules: SlashCommandModule<Result, Context>[]): SlashCommandRegistry<Result, Context>;
|
|
9
|
+
//# sourceMappingURL=registry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../../../../src/core/commands/slash/registry.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,kBAAkB,EAClB,YAAY,EACZ,gBAAgB,EAChB,iBAAiB,EACjB,kBAAkB,EACnB,MAAM,YAAY,CAAC;AAEpB,MAAM,MAAM,oBAAoB,CAAC,MAAM,EAAE,OAAO,IAAI;IAClD,QAAQ,IAAI,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;IAC5C,KAAK,IAAI,gBAAgB,EAAE,CAAC;IAC5B,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,kBAAkB,GAAG,iBAAiB,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS,CAAC;IACzF,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,GAAG,kBAAkB,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC;CACxF,CAAC;AAEF,wBAAgB,0BAA0B,CAAC,MAAM,EAAE,OAAO,EACxD,OAAO,EAAE,kBAAkB,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAC7C,oBAAoB,CAAC,MAAM,EAAE,OAAO,CAAC,CA6BvC"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { parseSlashCommand } from './parser.js';
|
|
2
|
+
export function createSlashCommandRegistry(modules) {
|
|
3
|
+
const commands = flattenModules(modules);
|
|
4
|
+
const hints = flattenModuleHints(modules);
|
|
5
|
+
validateSlashCommandRegistry(modules, commands);
|
|
6
|
+
return {
|
|
7
|
+
commands() {
|
|
8
|
+
return [...commands];
|
|
9
|
+
},
|
|
10
|
+
hints() {
|
|
11
|
+
return [...hints];
|
|
12
|
+
},
|
|
13
|
+
find(input) {
|
|
14
|
+
const parsed = typeof input === 'string' ? parseSlashCommand(input) : input;
|
|
15
|
+
if (!parsed) {
|
|
16
|
+
return undefined;
|
|
17
|
+
}
|
|
18
|
+
const command = commands.find((candidate) => candidate.match(parsed));
|
|
19
|
+
return command ? { command, input: parsed } : undefined;
|
|
20
|
+
},
|
|
21
|
+
async run(context, input) {
|
|
22
|
+
const matched = this.find(input);
|
|
23
|
+
return matched ? await matched.command.run(context, matched.input) : undefined;
|
|
24
|
+
},
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
function flattenModuleHints(modules) {
|
|
28
|
+
return modules.flatMap((module) => module.hints ?? module.commands.map((command) => ({
|
|
29
|
+
command: command.syntax,
|
|
30
|
+
description: command.description,
|
|
31
|
+
})));
|
|
32
|
+
}
|
|
33
|
+
function flattenModules(modules) {
|
|
34
|
+
return modules.flatMap((module) => module.commands);
|
|
35
|
+
}
|
|
36
|
+
function validateSlashCommandRegistry(modules, commands) {
|
|
37
|
+
assertUnique('slash command module id', modules.map((module) => module.id));
|
|
38
|
+
assertUnique('slash command id', commands.map((command) => command.id));
|
|
39
|
+
assertUnique('slash command syntax', commands.flatMap((command) => [command.syntax, ...(command.aliases ?? [])]));
|
|
40
|
+
}
|
|
41
|
+
function assertUnique(label, values) {
|
|
42
|
+
const seen = new Set();
|
|
43
|
+
for (const value of values) {
|
|
44
|
+
if (seen.has(value)) {
|
|
45
|
+
throw new Error(`Duplicate ${label}: ${value}`);
|
|
46
|
+
}
|
|
47
|
+
seen.add(value);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../../../../src/core/commands/slash/registry.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAgBhD,MAAM,UAAU,0BAA0B,CACxC,OAA8C;IAE9C,MAAM,QAAQ,GAAG,cAAc,CAAC,OAAO,CAAC,CAAC;IACzC,MAAM,KAAK,GAAG,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAC1C,4BAA4B,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;IAEhD,OAAO;QACL,QAAQ;YACN,OAAO,CAAC,GAAG,QAAQ,CAAC,CAAC;QACvB,CAAC;QAED,KAAK;YACH,OAAO,CAAC,GAAG,KAAK,CAAC,CAAC;QACpB,CAAC;QAED,IAAI,CAAC,KAAK;YACR,MAAM,MAAM,GAAG,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YAC5E,IAAI,CAAC,MAAM,EAAE,CAAC;gBACZ,OAAO,SAAS,CAAC;YACnB,CAAC;YAED,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;YACtE,OAAO,OAAO,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;QAC1D,CAAC;QAED,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK;YACtB,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACjC,OAAO,OAAO,CAAC,CAAC,CAAC,MAAM,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QACjF,CAAC;KACF,CAAC;AACJ,CAAC;AAED,SAAS,kBAAkB,CACzB,OAA8C;IAE9C,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAChC,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QAChD,OAAO,EAAE,OAAO,CAAC,MAAM;QACvB,WAAW,EAAE,OAAO,CAAC,WAAW;KACjC,CAAC,CAAC,CACJ,CAAC;AACJ,CAAC;AAED,SAAS,cAAc,CACrB,OAA8C;IAE9C,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;AACtD,CAAC;AAED,SAAS,4BAA4B,CACnC,OAA8C,EAC9C,QAAyC;IAEzC,YAAY,CAAC,yBAAyB,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5E,YAAY,CAAC,kBAAkB,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;IACxE,YAAY,CACV,sBAAsB,EACtB,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,CAAC,CAC5E,CAAC;AACJ,CAAC;AAED,SAAS,YAAY,CAAC,KAAa,EAAE,MAAgB;IACnD,MAAM,IAAI,GAAG,IAAI,GAAG,EAAU,CAAC;IAC/B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,aAAa,KAAK,KAAK,KAAK,EAAE,CAAC,CAAC;QAClD,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAClB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export type SlashCommandResult = {
|
|
2
|
+
handled: false;
|
|
3
|
+
} | {
|
|
4
|
+
handled: true;
|
|
5
|
+
kind: 'message';
|
|
6
|
+
message: string;
|
|
7
|
+
sessionId?: string;
|
|
8
|
+
} | {
|
|
9
|
+
handled: true;
|
|
10
|
+
kind: 'continue';
|
|
11
|
+
sessionId?: string;
|
|
12
|
+
message?: string;
|
|
13
|
+
} | {
|
|
14
|
+
handled: true;
|
|
15
|
+
kind: 'execute';
|
|
16
|
+
prompt: string;
|
|
17
|
+
displayText: string;
|
|
18
|
+
message?: string;
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=result-types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"result-types.d.ts","sourceRoot":"","sources":["../../../../../src/core/commands/slash/result-types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,kBAAkB,GAC1B;IAAE,OAAO,EAAE,KAAK,CAAA;CAAE,GAClB;IAAE,OAAO,EAAE,IAAI,CAAC;IAAC,IAAI,EAAE,SAAS,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,GACvE;IAAE,OAAO,EAAE,IAAI,CAAC;IAAC,IAAI,EAAE,UAAU,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,GACzE;IAAE,OAAO,EAAE,IAAI,CAAC;IAAC,IAAI,EAAE,SAAS,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,WAAW,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"result-types.js","sourceRoot":"","sources":["../../../../../src/core/commands/slash/result-types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export type ParsedSlashCommand = {
|
|
2
|
+
raw: string;
|
|
3
|
+
root: string;
|
|
4
|
+
tokens: string[];
|
|
5
|
+
rest: string;
|
|
6
|
+
};
|
|
7
|
+
export type SlashCommandHint = {
|
|
8
|
+
command: string;
|
|
9
|
+
description: string;
|
|
10
|
+
};
|
|
11
|
+
export type SlashCommand<Result, Context> = {
|
|
12
|
+
id: string;
|
|
13
|
+
syntax: string;
|
|
14
|
+
description: string;
|
|
15
|
+
aliases?: string[];
|
|
16
|
+
match: (input: ParsedSlashCommand) => boolean;
|
|
17
|
+
run: (context: Context, input: ParsedSlashCommand) => Promise<Result> | Result;
|
|
18
|
+
};
|
|
19
|
+
export type SlashCommandModule<Result, Context> = {
|
|
20
|
+
id: string;
|
|
21
|
+
hints?: SlashCommandHint[];
|
|
22
|
+
commands: SlashCommand<Result, Context>[];
|
|
23
|
+
};
|
|
24
|
+
export type SlashCommandMatch<Result, Context> = {
|
|
25
|
+
command: SlashCommand<Result, Context>;
|
|
26
|
+
input: ParsedSlashCommand;
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../src/core/commands/slash/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,kBAAkB,GAAG;IAC/B,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,YAAY,CAAC,MAAM,EAAE,OAAO,IAAI;IAC1C,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,KAAK,EAAE,CAAC,KAAK,EAAE,kBAAkB,KAAK,OAAO,CAAC;IAC9C,GAAG,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,kBAAkB,KAAK,OAAO,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC;CAChF,CAAC;AAEF,MAAM,MAAM,kBAAkB,CAAC,MAAM,EAAE,OAAO,IAAI;IAChD,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,CAAC,EAAE,gBAAgB,EAAE,CAAC;IAC3B,QAAQ,EAAE,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;CAC3C,CAAC;AAEF,MAAM,MAAM,iBAAiB,CAAC,MAAM,EAAE,OAAO,IAAI;IAC/C,OAAO,EAAE,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACvC,KAAK,EAAE,kBAAkB,CAAC;CAC3B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/core/commands/slash/types.ts"],"names":[],"mappings":""}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
export declare const DEFAULT_LLM_PROVIDER = "openai";
|
|
2
|
-
export declare const DEFAULT_OPENAI_MODEL = "gpt-5.
|
|
2
|
+
export declare const DEFAULT_OPENAI_MODEL = "gpt-5.4";
|
|
3
3
|
export declare const DEFAULT_ANTHROPIC_MODEL = "claude-sonnet-4-6";
|
|
4
4
|
//# sourceMappingURL=config.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../../src/core/config.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,oBAAoB,WAAW,CAAC;AAC7C,eAAO,MAAM,oBAAoB,
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../../src/core/config.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,oBAAoB,WAAW,CAAC;AAC7C,eAAO,MAAM,oBAAoB,YAAY,CAAC;AAC9C,eAAO,MAAM,uBAAuB,sBAAsB,CAAC"}
|
package/dist/src/core/config.js
CHANGED
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
// Shared runtime configuration
|
|
3
3
|
// ---------------------------------------------------------------------------
|
|
4
4
|
export const DEFAULT_LLM_PROVIDER = 'openai';
|
|
5
|
-
export const DEFAULT_OPENAI_MODEL = 'gpt-5.
|
|
5
|
+
export const DEFAULT_OPENAI_MODEL = 'gpt-5.4';
|
|
6
6
|
export const DEFAULT_ANTHROPIC_MODEL = 'claude-sonnet-4-6';
|
|
7
7
|
//# sourceMappingURL=config.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/core/config.ts"],"names":[],"mappings":"AAAA,8EAA8E;AAC9E,+BAA+B;AAC/B,8EAA8E;AAE9E,MAAM,CAAC,MAAM,oBAAoB,GAAG,QAAQ,CAAC;AAC7C,MAAM,CAAC,MAAM,oBAAoB,GAAG,
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/core/config.ts"],"names":[],"mappings":"AAAA,8EAA8E;AAC9E,+BAA+B;AAC/B,8EAA8E;AAE9E,MAAM,CAAC,MAAM,oBAAoB,GAAG,QAAQ,CAAC;AAC7C,MAAM,CAAC,MAAM,oBAAoB,GAAG,SAAS,CAAC;AAC9C,MAAM,CAAC,MAAM,uBAAuB,GAAG,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { AgentEvalCase, EvalRunResult } from './schema.js';
|
|
2
|
+
export type RunAgentEvalCaseArgs = {
|
|
3
|
+
testCase: AgentEvalCase;
|
|
4
|
+
repoRoot: string;
|
|
5
|
+
resultsRoot: string;
|
|
6
|
+
target?: string;
|
|
7
|
+
model?: string;
|
|
8
|
+
maxSteps?: number;
|
|
9
|
+
timeoutMs?: number;
|
|
10
|
+
stateDir?: string;
|
|
11
|
+
workRoot?: string;
|
|
12
|
+
preferApiKey?: boolean;
|
|
13
|
+
dryRun?: boolean;
|
|
14
|
+
};
|
|
15
|
+
export declare function runAgentEvalCase(args: RunAgentEvalCaseArgs): Promise<EvalRunResult>;
|
|
16
|
+
export declare function buildHeddleAskCommand(args: {
|
|
17
|
+
workspaceRoot: string;
|
|
18
|
+
model?: string;
|
|
19
|
+
maxSteps?: number;
|
|
20
|
+
prompt: string;
|
|
21
|
+
sessionName: string;
|
|
22
|
+
preferApiKey?: boolean;
|
|
23
|
+
}): string[];
|
|
24
|
+
//# sourceMappingURL=agent-runner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-runner.d.ts","sourceRoot":"","sources":["../../../../src/core/eval/agent-runner.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAEhE,MAAM,MAAM,oBAAoB,GAAG;IACjC,QAAQ,EAAE,aAAa,CAAC;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF,wBAAsB,gBAAgB,CAAC,IAAI,EAAE,oBAAoB,GAAG,OAAO,CAAC,aAAa,CAAC,CAkIzF;AAED,wBAAgB,qBAAqB,CAAC,IAAI,EAAE;IAC1C,aAAa,EAAE,MAAM,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB,GAAG,MAAM,EAAE,CAeX"}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { mkdirSync } from 'node:fs';
|
|
2
|
+
import { join, resolve } from 'node:path';
|
|
3
|
+
import { collectEvalArtifacts, writeTextArtifact } from './git-artifacts.js';
|
|
4
|
+
import { prepareEvalWorkspace } from './workspace-fixture.js';
|
|
5
|
+
import { runEvalChecks } from './check-runner.js';
|
|
6
|
+
import { runCommand } from './process.js';
|
|
7
|
+
import { EvalProgressReporter } from './progress.js';
|
|
8
|
+
import { analyzeTraceFiles } from './trace-analyzer.js';
|
|
9
|
+
export async function runAgentEvalCase(args) {
|
|
10
|
+
const startedAtMs = Date.now();
|
|
11
|
+
const startedAt = new Date(startedAtMs).toISOString();
|
|
12
|
+
const target = args.target ?? 'current';
|
|
13
|
+
const outputDir = join(args.resultsRoot, target, args.testCase.id);
|
|
14
|
+
mkdirSync(outputDir, { recursive: true });
|
|
15
|
+
const progress = new EvalProgressReporter({
|
|
16
|
+
caseId: args.testCase.id,
|
|
17
|
+
progressPath: join(outputDir, 'progress.jsonl'),
|
|
18
|
+
});
|
|
19
|
+
progress.info('case', 'starting eval case');
|
|
20
|
+
try {
|
|
21
|
+
const prepared = await progress.track({
|
|
22
|
+
phase: 'workspace.prepare',
|
|
23
|
+
message: 'prepare eval workspace',
|
|
24
|
+
heartbeatMessage: 'still preparing eval workspace',
|
|
25
|
+
run: () => prepareEvalWorkspace({
|
|
26
|
+
testCase: args.testCase,
|
|
27
|
+
repoRoot: args.repoRoot,
|
|
28
|
+
workRoot: args.workRoot ? resolve(args.workRoot) : undefined,
|
|
29
|
+
progress,
|
|
30
|
+
}),
|
|
31
|
+
});
|
|
32
|
+
const workspaceRoot = prepared.workspaceRoot;
|
|
33
|
+
const model = args.model ?? args.testCase.model;
|
|
34
|
+
const maxSteps = args.maxSteps ?? args.testCase.maxSteps;
|
|
35
|
+
const command = buildHeddleAskCommand({
|
|
36
|
+
workspaceRoot,
|
|
37
|
+
model,
|
|
38
|
+
maxSteps,
|
|
39
|
+
prompt: args.testCase.prompt,
|
|
40
|
+
sessionName: `eval-${args.testCase.id}`,
|
|
41
|
+
preferApiKey: args.preferApiKey,
|
|
42
|
+
});
|
|
43
|
+
const stdoutPath = join(outputDir, 'stdout.txt');
|
|
44
|
+
const stderrPath = join(outputDir, 'stderr.txt');
|
|
45
|
+
const agentResult = args.dryRun ?
|
|
46
|
+
{
|
|
47
|
+
command,
|
|
48
|
+
exitCode: 0,
|
|
49
|
+
stdout: `Dry run: ${command.join(' ')}\n`,
|
|
50
|
+
stderr: '',
|
|
51
|
+
durationMs: 0,
|
|
52
|
+
timedOut: false,
|
|
53
|
+
}
|
|
54
|
+
: await progress.track({
|
|
55
|
+
phase: 'agent.run',
|
|
56
|
+
message: 'run Heddle agent',
|
|
57
|
+
heartbeatMessage: 'still running Heddle agent',
|
|
58
|
+
run: () => runCommand({
|
|
59
|
+
command: command[0] ?? 'yarn',
|
|
60
|
+
args: command.slice(1),
|
|
61
|
+
cwd: args.repoRoot,
|
|
62
|
+
env: {
|
|
63
|
+
...process.env,
|
|
64
|
+
HEDDLE_EVAL_AUTO_APPROVE: '1',
|
|
65
|
+
},
|
|
66
|
+
timeoutMs: args.timeoutMs ?? 15 * 60_000,
|
|
67
|
+
}),
|
|
68
|
+
});
|
|
69
|
+
progress.info('agent.stdout', `write agent stdout to ${stdoutPath}`);
|
|
70
|
+
writeTextArtifact(stdoutPath, agentResult.stdout);
|
|
71
|
+
progress.info('agent.stderr', `write agent stderr to ${stderrPath}`);
|
|
72
|
+
writeTextArtifact(stderrPath, agentResult.stderr);
|
|
73
|
+
const checks = args.dryRun ? [] : await progress.track({
|
|
74
|
+
phase: 'checks',
|
|
75
|
+
message: 'run deterministic checks',
|
|
76
|
+
heartbeatMessage: 'still running deterministic checks',
|
|
77
|
+
run: () => runEvalChecks({
|
|
78
|
+
checks: args.testCase.checks,
|
|
79
|
+
workspaceRoot,
|
|
80
|
+
progress,
|
|
81
|
+
}),
|
|
82
|
+
});
|
|
83
|
+
const artifacts = await progress.track({
|
|
84
|
+
phase: 'artifacts',
|
|
85
|
+
message: 'collect eval artifacts',
|
|
86
|
+
run: () => collectEvalArtifacts({
|
|
87
|
+
workspaceRoot,
|
|
88
|
+
outputDir,
|
|
89
|
+
stateDir: args.stateDir,
|
|
90
|
+
}),
|
|
91
|
+
});
|
|
92
|
+
const metrics = analyzeTraceFiles(artifacts.traceFiles);
|
|
93
|
+
const finishedAtMs = Date.now();
|
|
94
|
+
const status = agentResult.exitCode === 0
|
|
95
|
+
&& !agentResult.timedOut
|
|
96
|
+
&& checks.every((check) => check.passed) ?
|
|
97
|
+
'passed'
|
|
98
|
+
: 'failed';
|
|
99
|
+
const result = {
|
|
100
|
+
caseId: args.testCase.id,
|
|
101
|
+
target,
|
|
102
|
+
status,
|
|
103
|
+
workspaceRoot,
|
|
104
|
+
outputDir,
|
|
105
|
+
fixture: prepared.fixture,
|
|
106
|
+
startedAt,
|
|
107
|
+
finishedAt: new Date(finishedAtMs).toISOString(),
|
|
108
|
+
durationMs: finishedAtMs - startedAtMs,
|
|
109
|
+
agent: {
|
|
110
|
+
command,
|
|
111
|
+
exitCode: agentResult.exitCode,
|
|
112
|
+
stdoutPath,
|
|
113
|
+
stderrPath,
|
|
114
|
+
timedOut: agentResult.timedOut,
|
|
115
|
+
},
|
|
116
|
+
artifacts: {
|
|
117
|
+
...artifacts,
|
|
118
|
+
progressPath: progress.progressPath,
|
|
119
|
+
},
|
|
120
|
+
checks,
|
|
121
|
+
metrics,
|
|
122
|
+
review: args.testCase.review,
|
|
123
|
+
model,
|
|
124
|
+
maxSteps,
|
|
125
|
+
};
|
|
126
|
+
progress.info('case', `completed eval case with status ${status}`);
|
|
127
|
+
writeTextArtifact(join(outputDir, 'result.json'), `${JSON.stringify(result, null, 2)}\n`);
|
|
128
|
+
return result;
|
|
129
|
+
}
|
|
130
|
+
catch (error) {
|
|
131
|
+
progress.info('case', `eval case failed: ${error instanceof Error ? error.message : String(error)}`);
|
|
132
|
+
throw error;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
export function buildHeddleAskCommand(args) {
|
|
136
|
+
return [
|
|
137
|
+
'yarn',
|
|
138
|
+
'cli:dev',
|
|
139
|
+
'--cwd',
|
|
140
|
+
args.workspaceRoot,
|
|
141
|
+
'--force-owner-conflict',
|
|
142
|
+
...(args.model ? ['--model', args.model] : []),
|
|
143
|
+
...(args.maxSteps ? ['--max-steps', String(args.maxSteps)] : []),
|
|
144
|
+
...(args.preferApiKey ? ['--prefer-api-key'] : []),
|
|
145
|
+
'ask',
|
|
146
|
+
'--new-session',
|
|
147
|
+
args.sessionName,
|
|
148
|
+
args.prompt,
|
|
149
|
+
];
|
|
150
|
+
}
|
|
151
|
+
//# sourceMappingURL=agent-runner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-runner.js","sourceRoot":"","sources":["../../../../src/core/eval/agent-runner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"case-loader.d.ts","sourceRoot":"","sources":["../../../../src/core/eval/case-loader.ts"],"names":[],"mappings":"AAEA,OAAO,EAAkB,KAAK,QAAQ,EAAE,MAAM,aAAa,CAAC;AAE5D,wBAAgB,aAAa,CAAC,IAAI,EAAE;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC;CAChB,GAAG,QAAQ,EAAE,CAUb;AAED,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAOnD"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { readdirSync, readFileSync, statSync } from 'node:fs';
|
|
2
|
+
import { extname, join, resolve } from 'node:path';
|
|
3
|
+
import { evalCaseSchema } from './schema.js';
|
|
4
|
+
export function loadEvalCases(args) {
|
|
5
|
+
const selectedIds = new Set(args.ids?.filter(Boolean));
|
|
6
|
+
const files = listCaseFiles(resolve(args.casesDir));
|
|
7
|
+
const cases = files.map((file) => loadEvalCase(file));
|
|
8
|
+
const filtered = selectedIds.size > 0 ? cases.filter((testCase) => selectedIds.has(testCase.id)) : cases;
|
|
9
|
+
const missing = [...selectedIds].filter((id) => !filtered.some((testCase) => testCase.id === id));
|
|
10
|
+
if (missing.length > 0) {
|
|
11
|
+
throw new Error(`Eval case not found: ${missing.join(', ')}`);
|
|
12
|
+
}
|
|
13
|
+
return filtered.sort((left, right) => left.id.localeCompare(right.id));
|
|
14
|
+
}
|
|
15
|
+
export function loadEvalCase(path) {
|
|
16
|
+
const parsed = JSON.parse(readFileSync(path, 'utf8'));
|
|
17
|
+
const result = evalCaseSchema.safeParse(parsed);
|
|
18
|
+
if (!result.success) {
|
|
19
|
+
throw new Error(`Invalid eval case ${path}: ${result.error.issues.map((issue) => `${issue.path.join('.')}: ${issue.message}`).join('; ')}`);
|
|
20
|
+
}
|
|
21
|
+
return result.data;
|
|
22
|
+
}
|
|
23
|
+
function listCaseFiles(dir) {
|
|
24
|
+
const entries = readdirSync(dir);
|
|
25
|
+
return entries.flatMap((entry) => {
|
|
26
|
+
const path = join(dir, entry);
|
|
27
|
+
const stat = statSync(path);
|
|
28
|
+
if (stat.isDirectory()) {
|
|
29
|
+
return listCaseFiles(path);
|
|
30
|
+
}
|
|
31
|
+
return extname(path) === '.json' ? [path] : [];
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=case-loader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"case-loader.js","sourceRoot":"","sources":["../../../../src/core/eval/case-loader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAC9D,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACnD,OAAO,EAAE,cAAc,EAAiB,MAAM,aAAa,CAAC;AAE5D,MAAM,UAAU,aAAa,CAAC,IAG7B;IACC,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;IACvD,MAAM,KAAK,GAAG,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IACpD,MAAM,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC;IACtD,MAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IACzG,MAAM,OAAO,GAAG,CAAC,GAAG,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;IAClG,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACvB,MAAM,IAAI,KAAK,CAAC,wBAAwB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChE,CAAC;IACD,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;AACzE,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,IAAY;IACvC,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAY,CAAC;IACjE,MAAM,MAAM,GAAG,cAAc,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IAChD,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QACpB,MAAM,IAAI,KAAK,CAAC,qBAAqB,IAAI,KAAK,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9I,CAAC;IACD,OAAO,MAAM,CAAC,IAAI,CAAC;AACrB,CAAC;AAED,SAAS,aAAa,CAAC,GAAW;IAChC,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC;IACjC,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;QAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAC9B,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;YACvB,OAAO,aAAa,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC;QACD,OAAO,OAAO,CAAC,IAAI,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACjD,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { EvalProgressReporter } from './progress.js';
|
|
2
|
+
import type { EvalCheck, EvalCheckResult } from './schema.js';
|
|
3
|
+
export declare function runEvalChecks(args: {
|
|
4
|
+
checks: EvalCheck[];
|
|
5
|
+
workspaceRoot: string;
|
|
6
|
+
progress?: EvalProgressReporter;
|
|
7
|
+
}): Promise<EvalCheckResult[]>;
|
|
8
|
+
//# sourceMappingURL=check-runner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check-runner.d.ts","sourceRoot":"","sources":["../../../../src/core/eval/check-runner.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAC1D,OAAO,KAAK,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAE9D,wBAAsB,aAAa,CAAC,IAAI,EAAE;IACxC,MAAM,EAAE,SAAS,EAAE,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,oBAAoB,CAAC;CACjC,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC,CA8B7B"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { runShellCommand } from './process.js';
|
|
2
|
+
export async function runEvalChecks(args) {
|
|
3
|
+
const results = [];
|
|
4
|
+
for (const check of args.checks) {
|
|
5
|
+
const name = check.name ?? check.command;
|
|
6
|
+
const result = await args.progress?.track({
|
|
7
|
+
phase: 'checks.command',
|
|
8
|
+
message: `run check: ${name}`,
|
|
9
|
+
heartbeatMessage: `still running check: ${name}`,
|
|
10
|
+
run: () => runShellCommand({
|
|
11
|
+
command: check.command,
|
|
12
|
+
cwd: args.workspaceRoot,
|
|
13
|
+
timeoutMs: check.timeoutMs,
|
|
14
|
+
}),
|
|
15
|
+
}) ?? await runShellCommand({
|
|
16
|
+
command: check.command,
|
|
17
|
+
cwd: args.workspaceRoot,
|
|
18
|
+
timeoutMs: check.timeoutMs,
|
|
19
|
+
});
|
|
20
|
+
results.push({
|
|
21
|
+
name,
|
|
22
|
+
command: check.command,
|
|
23
|
+
exitCode: result.exitCode,
|
|
24
|
+
stdout: result.stdout,
|
|
25
|
+
stderr: result.stderr,
|
|
26
|
+
durationMs: result.durationMs,
|
|
27
|
+
passed: result.exitCode === 0 && !result.timedOut,
|
|
28
|
+
timedOut: result.timedOut,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
return results;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=check-runner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check-runner.js","sourceRoot":"","sources":["../../../../src/core/eval/check-runner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAI/C,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,IAInC;IACC,MAAM,OAAO,GAAsB,EAAE,CAAC;IACtC,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;QAChC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC;QACzC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC;YACxC,KAAK,EAAE,gBAAgB;YACvB,OAAO,EAAE,cAAc,IAAI,EAAE;YAC7B,gBAAgB,EAAE,wBAAwB,IAAI,EAAE;YAChD,GAAG,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC;gBACzB,OAAO,EAAE,KAAK,CAAC,OAAO;gBACtB,GAAG,EAAE,IAAI,CAAC,aAAa;gBACvB,SAAS,EAAE,KAAK,CAAC,SAAS;aAC3B,CAAC;SACH,CAAC,IAAI,MAAM,eAAe,CAAC;YAC1B,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,GAAG,EAAE,IAAI,CAAC,aAAa;YACvB,SAAS,EAAE,KAAK,CAAC,SAAS;SAC3B,CAAC,CAAC;QACH,OAAO,CAAC,IAAI,CAAC;YACX,IAAI;YACJ,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,MAAM,EAAE,MAAM,CAAC,QAAQ,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ;YACjD,QAAQ,EAAE,MAAM,CAAC,QAAQ;SAC1B,CAAC,CAAC;IACL,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export type EvalCleanupCandidate = {
|
|
2
|
+
path: string;
|
|
3
|
+
name: string;
|
|
4
|
+
modifiedAt: string;
|
|
5
|
+
modifiedAtMs: number;
|
|
6
|
+
};
|
|
7
|
+
export type EvalCleanupResult = {
|
|
8
|
+
resultsDir: string;
|
|
9
|
+
before?: string;
|
|
10
|
+
dryRun: boolean;
|
|
11
|
+
candidates: EvalCleanupCandidate[];
|
|
12
|
+
removed: EvalCleanupCandidate[];
|
|
13
|
+
};
|
|
14
|
+
export declare function cleanupEvalResults(args: {
|
|
15
|
+
resultsDir: string;
|
|
16
|
+
before?: Date;
|
|
17
|
+
dryRun?: boolean;
|
|
18
|
+
}): EvalCleanupResult;
|
|
19
|
+
export declare function listEvalResultDirs(resultsDir: string): EvalCleanupCandidate[];
|
|
20
|
+
//# sourceMappingURL=cleanup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleanup.d.ts","sourceRoot":"","sources":["../../../../src/core/eval/cleanup.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,oBAAoB,GAAG;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,OAAO,CAAC;IAChB,UAAU,EAAE,oBAAoB,EAAE,CAAC;IACnC,OAAO,EAAE,oBAAoB,EAAE,CAAC;CACjC,CAAC;AAEF,wBAAgB,kBAAkB,CAAC,IAAI,EAAE;IACvC,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,IAAI,CAAC;IACd,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,GAAG,iBAAiB,CAsBpB;AAED,wBAAgB,kBAAkB,CAAC,UAAU,EAAE,MAAM,GAAG,oBAAoB,EAAE,CAkB7E"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { existsSync, readdirSync, rmSync, statSync } from 'node:fs';
|
|
2
|
+
import { join, resolve } from 'node:path';
|
|
3
|
+
export function cleanupEvalResults(args) {
|
|
4
|
+
const resultsDir = resolve(args.resultsDir);
|
|
5
|
+
const candidates = listEvalResultDirs(resultsDir)
|
|
6
|
+
.filter((candidate) => !args.before || candidate.modifiedAtMs < args.before.getTime())
|
|
7
|
+
.sort((left, right) => left.modifiedAtMs - right.modifiedAtMs);
|
|
8
|
+
const dryRun = args.dryRun ?? true;
|
|
9
|
+
const removed = [];
|
|
10
|
+
if (!dryRun) {
|
|
11
|
+
for (const candidate of candidates) {
|
|
12
|
+
rmSync(candidate.path, { recursive: true, force: true });
|
|
13
|
+
removed.push(candidate);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
return {
|
|
17
|
+
resultsDir,
|
|
18
|
+
before: args.before?.toISOString(),
|
|
19
|
+
dryRun,
|
|
20
|
+
candidates,
|
|
21
|
+
removed,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
export function listEvalResultDirs(resultsDir) {
|
|
25
|
+
const resolved = resolve(resultsDir);
|
|
26
|
+
if (!existsSync(resolved)) {
|
|
27
|
+
return [];
|
|
28
|
+
}
|
|
29
|
+
return readdirSync(resolved, { withFileTypes: true })
|
|
30
|
+
.filter((entry) => entry.isDirectory())
|
|
31
|
+
.map((entry) => {
|
|
32
|
+
const path = join(resolved, entry.name);
|
|
33
|
+
const stat = statSync(path);
|
|
34
|
+
return {
|
|
35
|
+
path,
|
|
36
|
+
name: entry.name,
|
|
37
|
+
modifiedAt: stat.mtime.toISOString(),
|
|
38
|
+
modifiedAtMs: stat.mtimeMs,
|
|
39
|
+
};
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=cleanup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleanup.js","sourceRoot":"","sources":["../../../../src/core/eval/cleanup.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACpE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAiB1C,MAAM,UAAU,kBAAkB,CAAC,IAIlC;IACC,MAAM,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC5C,MAAM,UAAU,GAAG,kBAAkB,CAAC,UAAU,CAAC;SAC9C,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,IAAI,SAAS,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;SACrF,IAAI,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC;IACjE,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC;IACnC,MAAM,OAAO,GAA2B,EAAE,CAAC;IAE3C,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;YACnC,MAAM,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;YACzD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,OAAO;QACL,UAAU;QACV,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,WAAW,EAAE;QAClC,MAAM;QACN,UAAU;QACV,OAAO;KACR,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,UAAkB;IACnD,MAAM,QAAQ,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IACrC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC1B,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,OAAO,WAAW,CAAC,QAAQ,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;SAClD,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;SACtC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACb,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QACxC,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC5B,OAAO;YACL,IAAI;YACJ,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE;YACpC,YAAY,EAAE,IAAI,CAAC,OAAO;SAC3B,CAAC;IACJ,CAAC,CAAC,CAAC;AACP,CAAC"}
|