universal-agent-protocol 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +462 -0
- package/dist/analyzers/index.d.ts +3 -0
- package/dist/analyzers/index.d.ts.map +1 -0
- package/dist/analyzers/index.js +656 -0
- package/dist/analyzers/index.js.map +1 -0
- package/dist/bin/cli.d.ts +3 -0
- package/dist/bin/cli.d.ts.map +1 -0
- package/dist/bin/cli.js +506 -0
- package/dist/bin/cli.js.map +1 -0
- package/dist/bin/tool-calls.d.ts +3 -0
- package/dist/bin/tool-calls.d.ts.map +1 -0
- package/dist/bin/tool-calls.js +4 -0
- package/dist/bin/tool-calls.js.map +1 -0
- package/dist/cli/agent.d.ts +20 -0
- package/dist/cli/agent.d.ts.map +1 -0
- package/dist/cli/agent.js +434 -0
- package/dist/cli/agent.js.map +1 -0
- package/dist/cli/analyze.d.ts +7 -0
- package/dist/cli/analyze.d.ts.map +1 -0
- package/dist/cli/analyze.js +103 -0
- package/dist/cli/analyze.js.map +1 -0
- package/dist/cli/coord.d.ts +7 -0
- package/dist/cli/coord.d.ts.map +1 -0
- package/dist/cli/coord.js +138 -0
- package/dist/cli/coord.js.map +1 -0
- package/dist/cli/dashboard.d.ts +8 -0
- package/dist/cli/dashboard.d.ts.map +1 -0
- package/dist/cli/dashboard.js +704 -0
- package/dist/cli/dashboard.js.map +1 -0
- package/dist/cli/deploy.d.ts +19 -0
- package/dist/cli/deploy.d.ts.map +1 -0
- package/dist/cli/deploy.js +267 -0
- package/dist/cli/deploy.js.map +1 -0
- package/dist/cli/droids.d.ts +9 -0
- package/dist/cli/droids.d.ts.map +1 -0
- package/dist/cli/droids.js +227 -0
- package/dist/cli/droids.js.map +1 -0
- package/dist/cli/generate.d.ts +17 -0
- package/dist/cli/generate.d.ts.map +1 -0
- package/dist/cli/generate.js +432 -0
- package/dist/cli/generate.js.map +1 -0
- package/dist/cli/hooks.d.ts +9 -0
- package/dist/cli/hooks.d.ts.map +1 -0
- package/dist/cli/hooks.js +374 -0
- package/dist/cli/hooks.js.map +1 -0
- package/dist/cli/init.d.ts +11 -0
- package/dist/cli/init.d.ts.map +1 -0
- package/dist/cli/init.js +316 -0
- package/dist/cli/init.js.map +1 -0
- package/dist/cli/mcp-router.d.ts +16 -0
- package/dist/cli/mcp-router.d.ts.map +1 -0
- package/dist/cli/mcp-router.js +143 -0
- package/dist/cli/mcp-router.js.map +1 -0
- package/dist/cli/memory.d.ts +24 -0
- package/dist/cli/memory.d.ts.map +1 -0
- package/dist/cli/memory.js +877 -0
- package/dist/cli/memory.js.map +1 -0
- package/dist/cli/model.d.ts +15 -0
- package/dist/cli/model.d.ts.map +1 -0
- package/dist/cli/model.js +270 -0
- package/dist/cli/model.js.map +1 -0
- package/dist/cli/patterns.d.ts +26 -0
- package/dist/cli/patterns.d.ts.map +1 -0
- package/dist/cli/patterns.js +587 -0
- package/dist/cli/patterns.js.map +1 -0
- package/dist/cli/setup-mcp-router.d.ts +8 -0
- package/dist/cli/setup-mcp-router.d.ts.map +1 -0
- package/dist/cli/setup-mcp-router.js +163 -0
- package/dist/cli/setup-mcp-router.js.map +1 -0
- package/dist/cli/setup.d.ts +13 -0
- package/dist/cli/setup.d.ts.map +1 -0
- package/dist/cli/setup.js +146 -0
- package/dist/cli/setup.js.map +1 -0
- package/dist/cli/sync.d.ts +7 -0
- package/dist/cli/sync.d.ts.map +1 -0
- package/dist/cli/sync.js +26 -0
- package/dist/cli/sync.js.map +1 -0
- package/dist/cli/task.d.ts +33 -0
- package/dist/cli/task.d.ts.map +1 -0
- package/dist/cli/task.js +616 -0
- package/dist/cli/task.js.map +1 -0
- package/dist/cli/tool-calls.d.ts +8 -0
- package/dist/cli/tool-calls.d.ts.map +1 -0
- package/dist/cli/tool-calls.js +239 -0
- package/dist/cli/tool-calls.js.map +1 -0
- package/dist/cli/update.d.ts +10 -0
- package/dist/cli/update.d.ts.map +1 -0
- package/dist/cli/update.js +300 -0
- package/dist/cli/update.js.map +1 -0
- package/dist/cli/visualize.d.ts +77 -0
- package/dist/cli/visualize.d.ts.map +1 -0
- package/dist/cli/visualize.js +287 -0
- package/dist/cli/visualize.js.map +1 -0
- package/dist/cli/worktree.d.ts +9 -0
- package/dist/cli/worktree.d.ts.map +1 -0
- package/dist/cli/worktree.js +175 -0
- package/dist/cli/worktree.js.map +1 -0
- package/dist/coordination/capability-router.d.ts +79 -0
- package/dist/coordination/capability-router.d.ts.map +1 -0
- package/dist/coordination/capability-router.js +324 -0
- package/dist/coordination/capability-router.js.map +1 -0
- package/dist/coordination/database.d.ts +13 -0
- package/dist/coordination/database.d.ts.map +1 -0
- package/dist/coordination/database.js +131 -0
- package/dist/coordination/database.js.map +1 -0
- package/dist/coordination/deploy-batcher.d.ts +101 -0
- package/dist/coordination/deploy-batcher.d.ts.map +1 -0
- package/dist/coordination/deploy-batcher.js +565 -0
- package/dist/coordination/deploy-batcher.js.map +1 -0
- package/dist/coordination/index.d.ts +5 -0
- package/dist/coordination/index.d.ts.map +1 -0
- package/dist/coordination/index.js +5 -0
- package/dist/coordination/index.js.map +1 -0
- package/dist/coordination/service.d.ts +81 -0
- package/dist/coordination/service.d.ts.map +1 -0
- package/dist/coordination/service.js +603 -0
- package/dist/coordination/service.js.map +1 -0
- package/dist/generators/claude-md.d.ts +3 -0
- package/dist/generators/claude-md.d.ts.map +1 -0
- package/dist/generators/claude-md.js +977 -0
- package/dist/generators/claude-md.js.map +1 -0
- package/dist/generators/template-loader.d.ts +105 -0
- package/dist/generators/template-loader.d.ts.map +1 -0
- package/dist/generators/template-loader.js +291 -0
- package/dist/generators/template-loader.js.map +1 -0
- package/dist/index.d.ts +47 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +59 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp-router/config/parser.d.ts +9 -0
- package/dist/mcp-router/config/parser.d.ts.map +1 -0
- package/dist/mcp-router/config/parser.js +174 -0
- package/dist/mcp-router/config/parser.js.map +1 -0
- package/dist/mcp-router/executor/client.d.ts +31 -0
- package/dist/mcp-router/executor/client.d.ts.map +1 -0
- package/dist/mcp-router/executor/client.js +187 -0
- package/dist/mcp-router/executor/client.js.map +1 -0
- package/dist/mcp-router/index.d.ts +22 -0
- package/dist/mcp-router/index.d.ts.map +1 -0
- package/dist/mcp-router/index.js +18 -0
- package/dist/mcp-router/index.js.map +1 -0
- package/dist/mcp-router/output-compressor.d.ts +26 -0
- package/dist/mcp-router/output-compressor.d.ts.map +1 -0
- package/dist/mcp-router/output-compressor.js +236 -0
- package/dist/mcp-router/output-compressor.js.map +1 -0
- package/dist/mcp-router/search/fuzzy.d.ts +26 -0
- package/dist/mcp-router/search/fuzzy.d.ts.map +1 -0
- package/dist/mcp-router/search/fuzzy.js +94 -0
- package/dist/mcp-router/search/fuzzy.js.map +1 -0
- package/dist/mcp-router/server.d.ts +50 -0
- package/dist/mcp-router/server.d.ts.map +1 -0
- package/dist/mcp-router/server.js +229 -0
- package/dist/mcp-router/server.js.map +1 -0
- package/dist/mcp-router/session-stats.d.ts +37 -0
- package/dist/mcp-router/session-stats.d.ts.map +1 -0
- package/dist/mcp-router/session-stats.js +56 -0
- package/dist/mcp-router/session-stats.js.map +1 -0
- package/dist/mcp-router/tools/discover.d.ts +37 -0
- package/dist/mcp-router/tools/discover.d.ts.map +1 -0
- package/dist/mcp-router/tools/discover.js +65 -0
- package/dist/mcp-router/tools/discover.js.map +1 -0
- package/dist/mcp-router/tools/execute.d.ts +43 -0
- package/dist/mcp-router/tools/execute.d.ts.map +1 -0
- package/dist/mcp-router/tools/execute.js +103 -0
- package/dist/mcp-router/tools/execute.js.map +1 -0
- package/dist/mcp-router/types.d.ts +62 -0
- package/dist/mcp-router/types.d.ts.map +1 -0
- package/dist/mcp-router/types.js +6 -0
- package/dist/mcp-router/types.js.map +1 -0
- package/dist/memory/adaptive-context.d.ts +146 -0
- package/dist/memory/adaptive-context.d.ts.map +1 -0
- package/dist/memory/adaptive-context.js +1022 -0
- package/dist/memory/adaptive-context.js.map +1 -0
- package/dist/memory/agent-scoped-memory.d.ts +67 -0
- package/dist/memory/agent-scoped-memory.d.ts.map +1 -0
- package/dist/memory/agent-scoped-memory.js +126 -0
- package/dist/memory/agent-scoped-memory.js.map +1 -0
- package/dist/memory/backends/base.d.ts +18 -0
- package/dist/memory/backends/base.d.ts.map +1 -0
- package/dist/memory/backends/base.js +2 -0
- package/dist/memory/backends/base.js.map +1 -0
- package/dist/memory/backends/factory.d.ts +4 -0
- package/dist/memory/backends/factory.d.ts.map +1 -0
- package/dist/memory/backends/factory.js +53 -0
- package/dist/memory/backends/factory.js.map +1 -0
- package/dist/memory/backends/github.d.ts +22 -0
- package/dist/memory/backends/github.d.ts.map +1 -0
- package/dist/memory/backends/github.js +118 -0
- package/dist/memory/backends/github.js.map +1 -0
- package/dist/memory/backends/qdrant-cloud.d.ts +32 -0
- package/dist/memory/backends/qdrant-cloud.d.ts.map +1 -0
- package/dist/memory/backends/qdrant-cloud.js +168 -0
- package/dist/memory/backends/qdrant-cloud.js.map +1 -0
- package/dist/memory/context-compressor.d.ts +74 -0
- package/dist/memory/context-compressor.d.ts.map +1 -0
- package/dist/memory/context-compressor.js +289 -0
- package/dist/memory/context-compressor.js.map +1 -0
- package/dist/memory/correction-propagator.d.ts +44 -0
- package/dist/memory/correction-propagator.d.ts.map +1 -0
- package/dist/memory/correction-propagator.js +156 -0
- package/dist/memory/correction-propagator.js.map +1 -0
- package/dist/memory/daily-log.d.ts +67 -0
- package/dist/memory/daily-log.d.ts.map +1 -0
- package/dist/memory/daily-log.js +143 -0
- package/dist/memory/daily-log.js.map +1 -0
- package/dist/memory/dynamic-retrieval.d.ts +110 -0
- package/dist/memory/dynamic-retrieval.d.ts.map +1 -0
- package/dist/memory/dynamic-retrieval.js +688 -0
- package/dist/memory/dynamic-retrieval.js.map +1 -0
- package/dist/memory/embeddings.d.ts +116 -0
- package/dist/memory/embeddings.d.ts.map +1 -0
- package/dist/memory/embeddings.js +461 -0
- package/dist/memory/embeddings.js.map +1 -0
- package/dist/memory/hierarchical-memory.d.ts +141 -0
- package/dist/memory/hierarchical-memory.d.ts.map +1 -0
- package/dist/memory/hierarchical-memory.js +477 -0
- package/dist/memory/hierarchical-memory.js.map +1 -0
- package/dist/memory/memory-consolidator.d.ts +124 -0
- package/dist/memory/memory-consolidator.d.ts.map +1 -0
- package/dist/memory/memory-consolidator.js +514 -0
- package/dist/memory/memory-consolidator.js.map +1 -0
- package/dist/memory/memory-maintenance.d.ts +39 -0
- package/dist/memory/memory-maintenance.d.ts.map +1 -0
- package/dist/memory/memory-maintenance.js +305 -0
- package/dist/memory/memory-maintenance.js.map +1 -0
- package/dist/memory/model-router.d.ts +102 -0
- package/dist/memory/model-router.d.ts.map +1 -0
- package/dist/memory/model-router.js +448 -0
- package/dist/memory/model-router.js.map +1 -0
- package/dist/memory/multi-view-memory.d.ts +134 -0
- package/dist/memory/multi-view-memory.d.ts.map +1 -0
- package/dist/memory/multi-view-memory.js +420 -0
- package/dist/memory/multi-view-memory.js.map +1 -0
- package/dist/memory/prepopulate.d.ts +76 -0
- package/dist/memory/prepopulate.d.ts.map +1 -0
- package/dist/memory/prepopulate.js +815 -0
- package/dist/memory/prepopulate.js.map +1 -0
- package/dist/memory/semantic-compression.d.ts +77 -0
- package/dist/memory/semantic-compression.d.ts.map +1 -0
- package/dist/memory/semantic-compression.js +348 -0
- package/dist/memory/semantic-compression.js.map +1 -0
- package/dist/memory/serverless-qdrant.d.ts +102 -0
- package/dist/memory/serverless-qdrant.d.ts.map +1 -0
- package/dist/memory/serverless-qdrant.js +369 -0
- package/dist/memory/serverless-qdrant.js.map +1 -0
- package/dist/memory/short-term/factory.d.ts +26 -0
- package/dist/memory/short-term/factory.d.ts.map +1 -0
- package/dist/memory/short-term/factory.js +28 -0
- package/dist/memory/short-term/factory.js.map +1 -0
- package/dist/memory/short-term/indexeddb.d.ts +25 -0
- package/dist/memory/short-term/indexeddb.d.ts.map +1 -0
- package/dist/memory/short-term/indexeddb.js +64 -0
- package/dist/memory/short-term/indexeddb.js.map +1 -0
- package/dist/memory/short-term/schema.d.ts +6 -0
- package/dist/memory/short-term/schema.d.ts.map +1 -0
- package/dist/memory/short-term/schema.js +119 -0
- package/dist/memory/short-term/schema.js.map +1 -0
- package/dist/memory/short-term/sqlite.d.ts +50 -0
- package/dist/memory/short-term/sqlite.d.ts.map +1 -0
- package/dist/memory/short-term/sqlite.js +221 -0
- package/dist/memory/short-term/sqlite.js.map +1 -0
- package/dist/memory/speculative-cache.d.ts +111 -0
- package/dist/memory/speculative-cache.d.ts.map +1 -0
- package/dist/memory/speculative-cache.js +409 -0
- package/dist/memory/speculative-cache.js.map +1 -0
- package/dist/memory/task-classifier.d.ts +34 -0
- package/dist/memory/task-classifier.d.ts.map +1 -0
- package/dist/memory/task-classifier.js +300 -0
- package/dist/memory/task-classifier.js.map +1 -0
- package/dist/memory/terminal-bench-knowledge.d.ts +48 -0
- package/dist/memory/terminal-bench-knowledge.d.ts.map +1 -0
- package/dist/memory/terminal-bench-knowledge.js +399 -0
- package/dist/memory/terminal-bench-knowledge.js.map +1 -0
- package/dist/memory/write-gate.d.ts +39 -0
- package/dist/memory/write-gate.d.ts.map +1 -0
- package/dist/memory/write-gate.js +190 -0
- package/dist/memory/write-gate.js.map +1 -0
- package/dist/models/executor.d.ts +130 -0
- package/dist/models/executor.d.ts.map +1 -0
- package/dist/models/executor.js +383 -0
- package/dist/models/executor.js.map +1 -0
- package/dist/models/index.d.ts +15 -0
- package/dist/models/index.d.ts.map +1 -0
- package/dist/models/index.js +17 -0
- package/dist/models/index.js.map +1 -0
- package/dist/models/planner.d.ts +71 -0
- package/dist/models/planner.d.ts.map +1 -0
- package/dist/models/planner.js +344 -0
- package/dist/models/planner.js.map +1 -0
- package/dist/models/router.d.ts +75 -0
- package/dist/models/router.d.ts.map +1 -0
- package/dist/models/router.js +344 -0
- package/dist/models/router.js.map +1 -0
- package/dist/models/types.d.ts +370 -0
- package/dist/models/types.d.ts.map +1 -0
- package/dist/models/types.js +181 -0
- package/dist/models/types.js.map +1 -0
- package/dist/tasks/coordination.d.ts +74 -0
- package/dist/tasks/coordination.d.ts.map +1 -0
- package/dist/tasks/coordination.js +237 -0
- package/dist/tasks/coordination.js.map +1 -0
- package/dist/tasks/database.d.ts +14 -0
- package/dist/tasks/database.d.ts.map +1 -0
- package/dist/tasks/database.js +128 -0
- package/dist/tasks/database.js.map +1 -0
- package/dist/tasks/index.d.ts +5 -0
- package/dist/tasks/index.d.ts.map +1 -0
- package/dist/tasks/index.js +5 -0
- package/dist/tasks/index.js.map +1 -0
- package/dist/tasks/service.d.ts +39 -0
- package/dist/tasks/service.d.ts.map +1 -0
- package/dist/tasks/service.js +582 -0
- package/dist/tasks/service.js.map +1 -0
- package/dist/tasks/types.d.ts +224 -0
- package/dist/tasks/types.d.ts.map +1 -0
- package/dist/tasks/types.js +64 -0
- package/dist/tasks/types.js.map +1 -0
- package/dist/types/analysis.d.ts +82 -0
- package/dist/types/analysis.d.ts.map +1 -0
- package/dist/types/analysis.js +2 -0
- package/dist/types/analysis.js.map +1 -0
- package/dist/types/config.d.ts +3023 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +292 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/coordination.d.ts +240 -0
- package/dist/types/coordination.d.ts.map +1 -0
- package/dist/types/coordination.js +43 -0
- package/dist/types/coordination.js.map +1 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +4 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/calculate-average.d.ts +15 -0
- package/dist/utils/calculate-average.d.ts.map +1 -0
- package/dist/utils/calculate-average.js +21 -0
- package/dist/utils/calculate-average.js.map +1 -0
- package/dist/utils/config-manager.d.ts +30 -0
- package/dist/utils/config-manager.d.ts.map +1 -0
- package/dist/utils/config-manager.js +41 -0
- package/dist/utils/config-manager.js.map +1 -0
- package/dist/utils/dijkstra.d.ts +17 -0
- package/dist/utils/dijkstra.d.ts.map +1 -0
- package/dist/utils/dijkstra.js +91 -0
- package/dist/utils/dijkstra.js.map +1 -0
- package/dist/utils/fetch-with-retry.d.ts +5 -0
- package/dist/utils/fetch-with-retry.d.ts.map +1 -0
- package/dist/utils/fetch-with-retry.js +61 -0
- package/dist/utils/fetch-with-retry.js.map +1 -0
- package/dist/utils/merge-claude-md.d.ts +28 -0
- package/dist/utils/merge-claude-md.d.ts.map +1 -0
- package/dist/utils/merge-claude-md.js +342 -0
- package/dist/utils/merge-claude-md.js.map +1 -0
- package/dist/utils/order-processor-refactored.d.ts +126 -0
- package/dist/utils/order-processor-refactored.d.ts.map +1 -0
- package/dist/utils/order-processor-refactored.js +165 -0
- package/dist/utils/order-processor-refactored.js.map +1 -0
- package/dist/utils/order-processor-strategy.d.ts +72 -0
- package/dist/utils/order-processor-strategy.d.ts.map +1 -0
- package/dist/utils/order-processor-strategy.js +158 -0
- package/dist/utils/order-processor-strategy.js.map +1 -0
- package/dist/utils/order-processor.d.ts +242 -0
- package/dist/utils/order-processor.d.ts.map +1 -0
- package/dist/utils/order-processor.js +370 -0
- package/dist/utils/order-processor.js.map +1 -0
- package/dist/utils/rate-limiter-simple.d.ts +58 -0
- package/dist/utils/rate-limiter-simple.d.ts.map +1 -0
- package/dist/utils/rate-limiter-simple.js +100 -0
- package/dist/utils/rate-limiter-simple.js.map +1 -0
- package/dist/utils/rate-limiter.d.ts +62 -0
- package/dist/utils/rate-limiter.d.ts.map +1 -0
- package/dist/utils/rate-limiter.js +150 -0
- package/dist/utils/rate-limiter.js.map +1 -0
- package/dist/utils/string-similarity.d.ts +37 -0
- package/dist/utils/string-similarity.d.ts.map +1 -0
- package/dist/utils/string-similarity.js +114 -0
- package/dist/utils/string-similarity.js.map +1 -0
- package/dist/utils/validate-json.d.ts +51 -0
- package/dist/utils/validate-json.d.ts.map +1 -0
- package/dist/utils/validate-json.js +99 -0
- package/dist/utils/validate-json.js.map +1 -0
- package/package.json +96 -0
- package/templates/CLAUDE.template.md +11 -0
- package/templates/CLAUDE_ARCHITECTURE.template.md +103 -0
- package/templates/CLAUDE_CODING.template.md +125 -0
- package/templates/CLAUDE_DROIDS.template.md +109 -0
- package/templates/CLAUDE_MEMORY.template.md +130 -0
- package/templates/CLAUDE_WORKFLOWS.template.md +136 -0
- package/templates/PROJECT.template.md +209 -0
- package/templates/SCHEMA.md +57 -0
- package/templates/archive/CLAUDE.template.root-v6.md +762 -0
- package/templates/archive/CLAUDE.template.v6.md +762 -0
- package/templates/hooks/pre-compact.sh +68 -0
- package/templates/hooks/session-start.sh +106 -0
- package/tools/agents/README.md +224 -0
- package/tools/agents/UAP/README.md +351 -0
- package/tools/agents/UAP/__init__.py +9 -0
- package/tools/agents/UAP/cli.py +675 -0
- package/tools/agents/UAP/version.py +2 -0
- package/tools/agents/benchmarks/benchmark_memory_systems.py +637 -0
- package/tools/agents/benchmarks/results/benchmark_20260106_064817.json +170 -0
- package/tools/agents/benchmarks/results/benchmark_20260106_064817.md +51 -0
- package/tools/agents/config/chat_template.jinja +172 -0
- package/tools/agents/docker-compose.qdrant.yml +24 -0
- package/tools/agents/migrations/apply.py +256 -0
- package/tools/agents/scripts/fix_qwen_chat_template.py +314 -0
- package/tools/agents/scripts/init_qdrant.py +151 -0
- package/tools/agents/scripts/memory_migration.py +518 -0
- package/tools/agents/scripts/migrate_memory_to_qdrant.py +113 -0
- package/tools/agents/scripts/query_memory.py +189 -0
- package/tools/agents/scripts/qwen_tool_call_test.py +419 -0
- package/tools/agents/scripts/qwen_tool_call_wrapper.py +517 -0
- package/tools/agents/scripts/start-services.sh +96 -0
- package/tools/agents/tests/test_uap_compliance.py +257 -0
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Task Classification System for UAP
|
|
3
|
+
*
|
|
4
|
+
* Classifies tasks into categories and routes to appropriate droids/memory.
|
|
5
|
+
* Based on Terminal-Bench 2.0 task categories and Droid's routing strategies.
|
|
6
|
+
*/
|
|
7
|
+
const CATEGORY_PATTERNS = [
|
|
8
|
+
{
|
|
9
|
+
category: 'sysadmin',
|
|
10
|
+
patterns: [
|
|
11
|
+
/kernel|linux|qemu|kvm|virtualization/i,
|
|
12
|
+
/systemd|systemctl|journalctl|service/i,
|
|
13
|
+
/network|dns|firewall|iptables|nftables/i,
|
|
14
|
+
/cron|crontab|scheduling|daemon/i,
|
|
15
|
+
/mount|filesystem|partition|lvm|fdisk/i,
|
|
16
|
+
/docker|container|kubernetes|k8s/i,
|
|
17
|
+
/nginx|apache|web server|reverse proxy/i,
|
|
18
|
+
/ssh|scp|rsync|remote/i,
|
|
19
|
+
],
|
|
20
|
+
keywords: ['kernel', 'qemu', 'systemd', 'network', 'dns', 'cron', 'docker', 'mount', 'ssh'],
|
|
21
|
+
droid: 'sysadmin-expert',
|
|
22
|
+
capabilities: ['shell', 'root', 'networking', 'services'],
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
category: 'security',
|
|
26
|
+
patterns: [
|
|
27
|
+
/cve-?\d{4}-?\d+/i,
|
|
28
|
+
/exploit|vulnerability|attack|injection/i,
|
|
29
|
+
/secret|password|credential|token|api.?key/i,
|
|
30
|
+
/hash|crack|bcrypt|sha|md5/i,
|
|
31
|
+
/ssl|tls|certificate|x509/i,
|
|
32
|
+
/encrypt|decrypt|cipher|aes/i,
|
|
33
|
+
/auth|oauth|jwt|session/i,
|
|
34
|
+
/sanitize|escape|xss|csrf|sqli/i,
|
|
35
|
+
],
|
|
36
|
+
keywords: ['CVE', 'exploit', 'secret', 'hash', 'certificate', 'encrypt', 'authentication'],
|
|
37
|
+
droid: 'security-auditor',
|
|
38
|
+
capabilities: ['security', 'cryptography', 'vulnerability-analysis'],
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
category: 'ml-training',
|
|
42
|
+
patterns: [
|
|
43
|
+
/train|training|model|neural|deep learning/i,
|
|
44
|
+
/pytorch|tensorflow|keras|transformers/i,
|
|
45
|
+
/dataset|dataloader|batch|epoch/i,
|
|
46
|
+
/mteb|embedding|sentence.?transformer/i,
|
|
47
|
+
/classifier|classification|regression/i,
|
|
48
|
+
/reinforcement|rl|reward|agent|gym/i,
|
|
49
|
+
/gpu|cuda|nvidia|tensor/i,
|
|
50
|
+
/hugging.?face|tokenizer|bert|gpt/i,
|
|
51
|
+
],
|
|
52
|
+
keywords: ['train', 'model', 'pytorch', 'dataset', 'embedding', 'classifier', 'GPU'],
|
|
53
|
+
droid: 'ml-training-expert',
|
|
54
|
+
capabilities: ['python', 'ml-frameworks', 'gpu', 'data-processing'],
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
category: 'debugging',
|
|
58
|
+
patterns: [
|
|
59
|
+
/debug|fix|broken|error|exception/i,
|
|
60
|
+
/conda|pip|dependency|conflict|version/i,
|
|
61
|
+
/git|merge|rebase|conflict|reflog/i,
|
|
62
|
+
/stack.?trace|traceback|crash/i,
|
|
63
|
+
/memory.?leak|segfault|core.?dump/i,
|
|
64
|
+
/log|logging|diagnose|troubleshoot/i,
|
|
65
|
+
],
|
|
66
|
+
keywords: ['debug', 'fix', 'error', 'conda', 'pip', 'git', 'conflict', 'crash'],
|
|
67
|
+
droid: 'debug-expert',
|
|
68
|
+
capabilities: ['debugging', 'profiling', 'version-management'],
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
category: 'coding',
|
|
72
|
+
patterns: [
|
|
73
|
+
/implement|function|class|method|algorithm/i,
|
|
74
|
+
/refactor|optimize|improve|clean/i,
|
|
75
|
+
/api|endpoint|rest|graphql|server/i,
|
|
76
|
+
/typescript|javascript|python|rust|go/i,
|
|
77
|
+
/singleton|factory|strategy|pattern/i,
|
|
78
|
+
/async|await|promise|callback/i,
|
|
79
|
+
],
|
|
80
|
+
keywords: ['implement', 'function', 'class', 'refactor', 'API', 'algorithm', 'pattern'],
|
|
81
|
+
droid: 'code-quality-guardian',
|
|
82
|
+
capabilities: ['coding', 'design-patterns', 'apis'],
|
|
83
|
+
},
|
|
84
|
+
{
|
|
85
|
+
category: 'file-ops',
|
|
86
|
+
patterns: [
|
|
87
|
+
/archive|zip|tar|extract|compress/i,
|
|
88
|
+
/download|fetch|curl|wget/i,
|
|
89
|
+
/convert|transform|parse|format/i,
|
|
90
|
+
/csv|json|xml|yaml|parquet/i,
|
|
91
|
+
/file|directory|path|copy|move/i,
|
|
92
|
+
],
|
|
93
|
+
keywords: ['archive', 'download', 'convert', 'file', 'extract'],
|
|
94
|
+
droid: 'terminal-bench-optimizer',
|
|
95
|
+
capabilities: ['file-operations', 'data-formats'],
|
|
96
|
+
},
|
|
97
|
+
{
|
|
98
|
+
category: 'testing',
|
|
99
|
+
patterns: [
|
|
100
|
+
/test|spec|unit|integration|e2e/i,
|
|
101
|
+
/vitest|jest|pytest|mocha|cypress/i,
|
|
102
|
+
/coverage|assertion|mock|stub|spy/i,
|
|
103
|
+
/tdd|bdd|test.?driven/i,
|
|
104
|
+
],
|
|
105
|
+
keywords: ['test', 'spec', 'coverage', 'mock', 'assertion'],
|
|
106
|
+
droid: 'code-quality-guardian',
|
|
107
|
+
capabilities: ['testing', 'test-frameworks', 'coverage'],
|
|
108
|
+
},
|
|
109
|
+
// OPTIMIZATION 3: Added constraint-satisfaction category
|
|
110
|
+
{
|
|
111
|
+
category: 'constraint-satisfaction',
|
|
112
|
+
patterns: [
|
|
113
|
+
/schedul\w+|timetabl\w+|allocat\w+/i,
|
|
114
|
+
/constraint|satisfy|feasible|optimal/i,
|
|
115
|
+
/resource.?alloc|slot|capacity/i,
|
|
116
|
+
/minimize|maximize|objective|cost.?function/i,
|
|
117
|
+
/backtrack|search|pruning|heuristic/i,
|
|
118
|
+
],
|
|
119
|
+
keywords: ['schedule', 'constraint', 'optimize', 'allocate', 'slot', 'feasible'],
|
|
120
|
+
droid: 'code-quality-guardian',
|
|
121
|
+
capabilities: ['algorithms', 'optimization', 'constraint-solving'],
|
|
122
|
+
},
|
|
123
|
+
];
|
|
124
|
+
/**
|
|
125
|
+
* Classify a task based on its instruction/prompt
|
|
126
|
+
* OPTIMIZATION 3: Fixed scoring to use actual max possible scores per category
|
|
127
|
+
*/
|
|
128
|
+
export function classifyTask(instruction) {
|
|
129
|
+
const normalizedInstruction = instruction.toLowerCase();
|
|
130
|
+
const scores = new Map();
|
|
131
|
+
const matchedKeywords = new Map();
|
|
132
|
+
const maxScores = new Map();
|
|
133
|
+
// Score each category based on pattern matches
|
|
134
|
+
for (const categoryPattern of CATEGORY_PATTERNS) {
|
|
135
|
+
let score = 0;
|
|
136
|
+
const keywords = [];
|
|
137
|
+
// OPTIMIZATION 3: Calculate actual max possible score for this category
|
|
138
|
+
const maxPossible = categoryPattern.patterns.length * 2 + categoryPattern.keywords.length;
|
|
139
|
+
maxScores.set(categoryPattern.category, maxPossible);
|
|
140
|
+
// Check regex patterns
|
|
141
|
+
for (const pattern of categoryPattern.patterns) {
|
|
142
|
+
if (pattern.test(instruction)) {
|
|
143
|
+
score += 2;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
// Check keywords
|
|
147
|
+
for (const keyword of categoryPattern.keywords) {
|
|
148
|
+
if (normalizedInstruction.includes(keyword.toLowerCase())) {
|
|
149
|
+
score += 1;
|
|
150
|
+
keywords.push(keyword);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
scores.set(categoryPattern.category, score);
|
|
154
|
+
matchedKeywords.set(categoryPattern.category, keywords);
|
|
155
|
+
}
|
|
156
|
+
// Find best match
|
|
157
|
+
let bestCategory = 'unknown';
|
|
158
|
+
let bestScore = 0;
|
|
159
|
+
for (const [category, score] of scores) {
|
|
160
|
+
if (score > bestScore) {
|
|
161
|
+
bestScore = score;
|
|
162
|
+
bestCategory = category;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
// OPTIMIZATION 3: Calculate confidence using actual max score for the matched category
|
|
166
|
+
// This gives more accurate confidence than a hardcoded estimate
|
|
167
|
+
const categoryMaxScore = maxScores.get(bestCategory) || 20;
|
|
168
|
+
const confidence = Math.min(bestScore / categoryMaxScore, 1);
|
|
169
|
+
// Get pattern config for best category
|
|
170
|
+
const patternConfig = CATEGORY_PATTERNS.find(p => p.category === bestCategory);
|
|
171
|
+
return {
|
|
172
|
+
category: bestCategory,
|
|
173
|
+
confidence,
|
|
174
|
+
keywords: matchedKeywords.get(bestCategory) || [],
|
|
175
|
+
suggestedDroid: patternConfig?.droid || 'terminal-bench-optimizer',
|
|
176
|
+
memoryQueryHints: generateMemoryQueryHints(bestCategory, matchedKeywords.get(bestCategory) || []),
|
|
177
|
+
requiredCapabilities: patternConfig?.capabilities || [],
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Generate memory query hints based on task classification
|
|
182
|
+
*/
|
|
183
|
+
function generateMemoryQueryHints(category, keywords) {
|
|
184
|
+
const hints = [];
|
|
185
|
+
// Add category-specific hints
|
|
186
|
+
switch (category) {
|
|
187
|
+
case 'sysadmin':
|
|
188
|
+
hints.push('linux administration', 'system configuration', 'service management');
|
|
189
|
+
break;
|
|
190
|
+
case 'security':
|
|
191
|
+
hints.push('security vulnerability', 'secret management', 'authentication');
|
|
192
|
+
break;
|
|
193
|
+
case 'ml-training':
|
|
194
|
+
hints.push('model training', 'dataset processing', 'machine learning');
|
|
195
|
+
break;
|
|
196
|
+
case 'debugging':
|
|
197
|
+
hints.push('error fixing', 'dependency resolution', 'debugging techniques');
|
|
198
|
+
break;
|
|
199
|
+
case 'coding':
|
|
200
|
+
hints.push('code implementation', 'design patterns', 'best practices');
|
|
201
|
+
break;
|
|
202
|
+
case 'file-ops':
|
|
203
|
+
hints.push('file operations', 'data conversion', 'archive handling');
|
|
204
|
+
break;
|
|
205
|
+
case 'testing':
|
|
206
|
+
hints.push('unit testing', 'test coverage', 'test patterns');
|
|
207
|
+
break;
|
|
208
|
+
case 'constraint-satisfaction':
|
|
209
|
+
hints.push('constraint solving', 'scheduling algorithms', 'optimization techniques');
|
|
210
|
+
break;
|
|
211
|
+
}
|
|
212
|
+
// Add keyword-based hints
|
|
213
|
+
hints.push(...keywords.slice(0, 3));
|
|
214
|
+
return hints;
|
|
215
|
+
}
|
|
216
|
+
/**
|
|
217
|
+
* Extract entities from task instruction for memory queries
|
|
218
|
+
*/
|
|
219
|
+
export function extractTaskEntities(instruction) {
|
|
220
|
+
const technologies = [];
|
|
221
|
+
const operations = [];
|
|
222
|
+
const files = [];
|
|
223
|
+
const concepts = [];
|
|
224
|
+
// Technology patterns
|
|
225
|
+
const techPatterns = [
|
|
226
|
+
/python|typescript|javascript|rust|go|java|c\+\+/gi,
|
|
227
|
+
/pytorch|tensorflow|keras|transformers/gi,
|
|
228
|
+
/docker|kubernetes|nginx|apache/gi,
|
|
229
|
+
/postgres|mysql|mongodb|redis/gi,
|
|
230
|
+
/react|vue|angular|next\.js/gi,
|
|
231
|
+
/git|npm|pip|conda|cargo/gi,
|
|
232
|
+
];
|
|
233
|
+
for (const pattern of techPatterns) {
|
|
234
|
+
const matches = instruction.match(pattern);
|
|
235
|
+
if (matches) {
|
|
236
|
+
technologies.push(...matches.map(m => m.toLowerCase()));
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
// Operation patterns
|
|
240
|
+
const opPatterns = [
|
|
241
|
+
/\b(create|build|implement|configure|setup|install)\b/gi,
|
|
242
|
+
/\b(fix|debug|repair|resolve|troubleshoot)\b/gi,
|
|
243
|
+
/\b(test|verify|validate|check|ensure)\b/gi,
|
|
244
|
+
/\b(deploy|publish|release|ship)\b/gi,
|
|
245
|
+
/\b(refactor|optimize|improve|clean)\b/gi,
|
|
246
|
+
];
|
|
247
|
+
for (const pattern of opPatterns) {
|
|
248
|
+
const matches = instruction.match(pattern);
|
|
249
|
+
if (matches) {
|
|
250
|
+
operations.push(...matches.map(m => m.toLowerCase()));
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
// File path patterns
|
|
254
|
+
const filePattern = /(?:\/[\w.-]+)+(?:\.\w+)?|[\w.-]+\.(ts|js|py|json|yaml|yml|md|txt|sh)/gi;
|
|
255
|
+
const fileMatches = instruction.match(filePattern);
|
|
256
|
+
if (fileMatches) {
|
|
257
|
+
files.push(...fileMatches);
|
|
258
|
+
}
|
|
259
|
+
// Concept patterns
|
|
260
|
+
const conceptPatterns = [
|
|
261
|
+
/\b(authentication|authorization|security)\b/gi,
|
|
262
|
+
/\b(caching|performance|optimization)\b/gi,
|
|
263
|
+
/\b(api|endpoint|service|microservice)\b/gi,
|
|
264
|
+
/\b(database|storage|persistence)\b/gi,
|
|
265
|
+
/\b(testing|coverage|quality)\b/gi,
|
|
266
|
+
];
|
|
267
|
+
for (const pattern of conceptPatterns) {
|
|
268
|
+
const matches = instruction.match(pattern);
|
|
269
|
+
if (matches) {
|
|
270
|
+
concepts.push(...matches.map(m => m.toLowerCase()));
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
return {
|
|
274
|
+
technologies: [...new Set(technologies)],
|
|
275
|
+
operations: [...new Set(operations)],
|
|
276
|
+
files: [...new Set(files)],
|
|
277
|
+
concepts: [...new Set(concepts)],
|
|
278
|
+
};
|
|
279
|
+
}
|
|
280
|
+
/**
|
|
281
|
+
* Get suggested memory queries based on task classification
|
|
282
|
+
*/
|
|
283
|
+
export function getSuggestedMemoryQueries(classification) {
|
|
284
|
+
const queries = [];
|
|
285
|
+
// Category-based queries
|
|
286
|
+
queries.push(`${classification.category} best practices`);
|
|
287
|
+
queries.push(`${classification.category} common mistakes`);
|
|
288
|
+
queries.push(`${classification.category} patterns`);
|
|
289
|
+
// Keyword-based queries
|
|
290
|
+
for (const keyword of classification.keywords.slice(0, 3)) {
|
|
291
|
+
queries.push(`${keyword} implementation`);
|
|
292
|
+
queries.push(`${keyword} gotchas`);
|
|
293
|
+
}
|
|
294
|
+
// Capability-based queries
|
|
295
|
+
for (const capability of classification.requiredCapabilities.slice(0, 2)) {
|
|
296
|
+
queries.push(`${capability} tips`);
|
|
297
|
+
}
|
|
298
|
+
return queries;
|
|
299
|
+
}
|
|
300
|
+
//# sourceMappingURL=task-classifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-classifier.js","sourceRoot":"","sources":["../../src/memory/task-classifier.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AA8BH,MAAM,iBAAiB,GAAsB;IAC3C;QACE,QAAQ,EAAE,UAAU;QACpB,QAAQ,EAAE;YACR,uCAAuC;YACvC,uCAAuC;YACvC,yCAAyC;YACzC,iCAAiC;YACjC,uCAAuC;YACvC,kCAAkC;YAClC,wCAAwC;YACxC,uBAAuB;SACxB;QACD,QAAQ,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,CAAC;QAC3F,KAAK,EAAE,iBAAiB;QACxB,YAAY,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,UAAU,CAAC;KAC1D;IACD;QACE,QAAQ,EAAE,UAAU;QACpB,QAAQ,EAAE;YACR,kBAAkB;YAClB,yCAAyC;YACzC,4CAA4C;YAC5C,4BAA4B;YAC5B,2BAA2B;YAC3B,6BAA6B;YAC7B,yBAAyB;YACzB,gCAAgC;SACjC;QACD,QAAQ,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,aAAa,EAAE,SAAS,EAAE,gBAAgB,CAAC;QAC1F,KAAK,EAAE,kBAAkB;QACzB,YAAY,EAAE,CAAC,UAAU,EAAE,cAAc,EAAE,wBAAwB,CAAC;KACrE;IACD;QACE,QAAQ,EAAE,aAAa;QACvB,QAAQ,EAAE;YACR,4CAA4C;YAC5C,wCAAwC;YACxC,iCAAiC;YACjC,uCAAuC;YACvC,uCAAuC;YACvC,oCAAoC;YACpC,yBAAyB;YACzB,mCAAmC;SACpC;QACD,QAAQ,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,YAAY,EAAE,KAAK,CAAC;QACpF,KAAK,EAAE,oBAAoB;QAC3B,YAAY,EAAE,CAAC,QAAQ,EAAE,eAAe,EAAE,KAAK,EAAE,iBAAiB,CAAC;KACpE;IACD;QACE,QAAQ,EAAE,WAAW;QACrB,QAAQ,EAAE;YACR,mCAAmC;YACnC,wCAAwC;YACxC,mCAAmC;YACnC,+BAA+B;YAC/B,mCAAmC;YACnC,oCAAoC;SACrC;QACD,QAAQ,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,CAAC;QAC/E,KAAK,EAAE,cAAc;QACrB,YAAY,EAAE,CAAC,WAAW,EAAE,WAAW,EAAE,oBAAoB,CAAC;KAC/D;IACD;QACE,QAAQ,EAAE,QAAQ;QAClB,QAAQ,EAAE;YACR,4CAA4C;YAC5C,kCAAkC;YAClC,mCAAmC;YACnC,uCAAuC;YACvC,qCAAqC;YACrC,+BAA+B;SAChC;QACD,QAAQ,EAAE,CAAC,WAAW,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,CAAC;QACvF,KAAK,EAAE,uBAAuB;QAC9B,YAAY,EAAE,CAAC,QAAQ,EAAE,iBAAiB,EAAE,MAAM,CAAC;KACpD;IACD;QACE,QAAQ,EAAE,UAAU;QACpB,QAAQ,EAAE;YACR,mCAAmC;YACnC,2BAA2B;YAC3B,iCAAiC;YACjC,4BAA4B;YAC5B,gCAAgC;SACjC;QACD,QAAQ,EAAE,CAAC,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,CAAC;QAC/D,KAAK,EAAE,0BAA0B;QACjC,YAAY,EAAE,CAAC,iBAAiB,EAAE,cAAc,CAAC;KAClD;IACD;QACE,QAAQ,EAAE,SAAS;QACnB,QAAQ,EAAE;YACR,iCAAiC;YACjC,mCAAmC;YACnC,mCAAmC;YACnC,uBAAuB;SACxB;QACD,QAAQ,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,WAAW,CAAC;QAC3D,KAAK,EAAE,uBAAuB;QAC9B,YAAY,EAAE,CAAC,SAAS,EAAE,iBAAiB,EAAE,UAAU,CAAC;KACzD;IACD,yDAAyD;IACzD;QACE,QAAQ,EAAE,yBAAyB;QACnC,QAAQ,EAAE;YACR,oCAAoC;YACpC,sCAAsC;YACtC,gCAAgC;YAChC,6CAA6C;YAC7C,qCAAqC;SACtC;QACD,QAAQ,EAAE,CAAC,UAAU,EAAE,YAAY,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,CAAC;QAChF,KAAK,EAAE,uBAAuB;QAC9B,YAAY,EAAE,CAAC,YAAY,EAAE,cAAc,EAAE,oBAAoB,CAAC;KACnE;CACF,CAAC;AAEF;;;GAGG;AACH,MAAM,UAAU,YAAY,CAAC,WAAmB;IAC9C,MAAM,qBAAqB,GAAG,WAAW,CAAC,WAAW,EAAE,CAAC;IACxD,MAAM,MAAM,GAA8B,IAAI,GAAG,EAAE,CAAC;IACpD,MAAM,eAAe,GAAgC,IAAI,GAAG,EAAE,CAAC;IAC/D,MAAM,SAAS,GAA8B,IAAI,GAAG,EAAE,CAAC;IAEvD,+CAA+C;IAC/C,KAAK,MAAM,eAAe,IAAI,iBAAiB,EAAE,CAAC;QAChD,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,MAAM,QAAQ,GAAa,EAAE,CAAC;QAE9B,wEAAwE;QACxE,MAAM,WAAW,GAAG,eAAe,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,GAAG,eAAe,CAAC,QAAQ,CAAC,MAAM,CAAC;QAC1F,SAAS,CAAC,GAAG,CAAC,eAAe,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;QAErD,uBAAuB;QACvB,KAAK,MAAM,OAAO,IAAI,eAAe,CAAC,QAAQ,EAAE,CAAC;YAC/C,IAAI,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC;gBAC9B,KAAK,IAAI,CAAC,CAAC;YACb,CAAC;QACH,CAAC;QAED,iBAAiB;QACjB,KAAK,MAAM,OAAO,IAAI,eAAe,CAAC,QAAQ,EAAE,CAAC;YAC/C,IAAI,qBAAqB,CAAC,QAAQ,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC;gBAC1D,KAAK,IAAI,CAAC,CAAC;gBACX,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;QAED,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QAC5C,eAAe,CAAC,GAAG,CAAC,eAAe,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;IAC1D,CAAC;IAED,kBAAkB;IAClB,IAAI,YAAY,GAAiB,SAAS,CAAC;IAC3C,IAAI,SAAS,GAAG,CAAC,CAAC;IAElB,KAAK,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,MAAM,EAAE,CAAC;QACvC,IAAI,KAAK,GAAG,SAAS,EAAE,CAAC;YACtB,SAAS,GAAG,KAAK,CAAC;YAClB,YAAY,GAAG,QAAQ,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,uFAAuF;IACvF,gEAAgE;IAChE,MAAM,gBAAgB,GAAG,SAAS,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3D,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,gBAAgB,EAAE,CAAC,CAAC,CAAC;IAE7D,uCAAuC;IACvC,MAAM,aAAa,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,YAAY,CAAC,CAAC;IAE/E,OAAO;QACL,QAAQ,EAAE,YAAY;QACtB,UAAU;QACV,QAAQ,EAAE,eAAe,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,EAAE;QACjD,cAAc,EAAE,aAAa,EAAE,KAAK,IAAI,0BAA0B;QAClE,gBAAgB,EAAE,wBAAwB,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACjG,oBAAoB,EAAE,aAAa,EAAE,YAAY,IAAI,EAAE;KACxD,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAS,wBAAwB,CAAC,QAAsB,EAAE,QAAkB;IAC1E,MAAM,KAAK,GAAa,EAAE,CAAC;IAE3B,8BAA8B;IAC9B,QAAQ,QAAQ,EAAE,CAAC;QACjB,KAAK,UAAU;YACb,KAAK,CAAC,IAAI,CAAC,sBAAsB,EAAE,sBAAsB,EAAE,oBAAoB,CAAC,CAAC;YACjF,MAAM;QACR,KAAK,UAAU;YACb,KAAK,CAAC,IAAI,CAAC,wBAAwB,EAAE,mBAAmB,EAAE,gBAAgB,CAAC,CAAC;YAC5E,MAAM;QACR,KAAK,aAAa;YAChB,KAAK,CAAC,IAAI,CAAC,gBAAgB,EAAE,oBAAoB,EAAE,kBAAkB,CAAC,CAAC;YACvE,MAAM;QACR,KAAK,WAAW;YACd,KAAK,CAAC,IAAI,CAAC,cAAc,EAAE,uBAAuB,EAAE,sBAAsB,CAAC,CAAC;YAC5E,MAAM;QACR,KAAK,QAAQ;YACX,KAAK,CAAC,IAAI,CAAC,qBAAqB,EAAE,iBAAiB,EAAE,gBAAgB,CAAC,CAAC;YACvE,MAAM;QACR,KAAK,UAAU;YACb,KAAK,CAAC,IAAI,CAAC,iBAAiB,EAAE,iBAAiB,EAAE,kBAAkB,CAAC,CAAC;YACrE,MAAM;QACR,KAAK,SAAS;YACZ,KAAK,CAAC,IAAI,CAAC,cAAc,EAAE,eAAe,EAAE,eAAe,CAAC,CAAC;YAC7D,MAAM;QACR,KAAK,yBAAyB;YAC5B,KAAK,CAAC,IAAI,CAAC,oBAAoB,EAAE,uBAAuB,EAAE,yBAAyB,CAAC,CAAC;YACrF,MAAM;IACV,CAAC;IAED,0BAA0B;IAC1B,KAAK,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAEpC,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,mBAAmB,CAAC,WAAmB;IAMrD,MAAM,YAAY,GAAa,EAAE,CAAC;IAClC,MAAM,UAAU,GAAa,EAAE,CAAC;IAChC,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,MAAM,QAAQ,GAAa,EAAE,CAAC;IAE9B,sBAAsB;IACtB,MAAM,YAAY,GAAG;QACnB,mDAAmD;QACnD,yCAAyC;QACzC,kCAAkC;QAClC,gCAAgC;QAChC,8BAA8B;QAC9B,2BAA2B;KAC5B,CAAC;IAEF,KAAK,MAAM,OAAO,IAAI,YAAY,EAAE,CAAC;QACnC,MAAM,OAAO,GAAG,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC3C,IAAI,OAAO,EAAE,CAAC;YACZ,YAAY,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC;IAED,qBAAqB;IACrB,MAAM,UAAU,GAAG;QACjB,wDAAwD;QACxD,+CAA+C;QAC/C,2CAA2C;QAC3C,qCAAqC;QACrC,yCAAyC;KAC1C,CAAC;IAEF,KAAK,MAAM,OAAO,IAAI,UAAU,EAAE,CAAC;QACjC,MAAM,OAAO,GAAG,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC3C,IAAI,OAAO,EAAE,CAAC;YACZ,UAAU,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QACxD,CAAC;IACH,CAAC;IAED,qBAAqB;IACrB,MAAM,WAAW,GAAG,wEAAwE,CAAC;IAC7F,MAAM,WAAW,GAAG,WAAW,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IACnD,IAAI,WAAW,EAAE,CAAC;QAChB,KAAK,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,CAAC;IAC7B,CAAC;IAED,mBAAmB;IACnB,MAAM,eAAe,GAAG;QACtB,+CAA+C;QAC/C,0CAA0C;QAC1C,2CAA2C;QAC3C,sCAAsC;QACtC,kCAAkC;KACnC,CAAC;IAEF,KAAK,MAAM,OAAO,IAAI,eAAe,EAAE,CAAC;QACtC,MAAM,OAAO,GAAG,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC3C,IAAI,OAAO,EAAE,CAAC;YACZ,QAAQ,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QACtD,CAAC;IACH,CAAC;IAED,OAAO;QACL,YAAY,EAAE,CAAC,GAAG,IAAI,GAAG,CAAC,YAAY,CAAC,CAAC;QACxC,UAAU,EAAE,CAAC,GAAG,IAAI,GAAG,CAAC,UAAU,CAAC,CAAC;QACpC,KAAK,EAAE,CAAC,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,CAAC;QAC1B,QAAQ,EAAE,CAAC,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,CAAC;KACjC,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,yBAAyB,CAAC,cAAkC;IAC1E,MAAM,OAAO,GAAa,EAAE,CAAC;IAE7B,yBAAyB;IACzB,OAAO,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,QAAQ,iBAAiB,CAAC,CAAC;IAC1D,OAAO,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,QAAQ,kBAAkB,CAAC,CAAC;IAC3D,OAAO,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,QAAQ,WAAW,CAAC,CAAC;IAEpD,wBAAwB;IACxB,KAAK,MAAM,OAAO,IAAI,cAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;QAC1D,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,iBAAiB,CAAC,CAAC;QAC1C,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,UAAU,CAAC,CAAC;IACrC,CAAC;IAED,2BAA2B;IAC3B,KAAK,MAAM,UAAU,IAAI,cAAc,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;QACzE,OAAO,CAAC,IAAI,CAAC,GAAG,UAAU,OAAO,CAAC,CAAC;IACrC,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Terminal-Bench Domain Knowledge Pre-Population
|
|
3
|
+
*
|
|
4
|
+
* This module contains battle-tested domain knowledge that improved
|
|
5
|
+
* Terminal-Bench 2.0 accuracy by +6.7% (53.3% -> 60%).
|
|
6
|
+
*
|
|
7
|
+
* Based on TERMINAL_BENCH_RESULTS.md analysis of improvements:
|
|
8
|
+
* - extract-elf: ELF format knowledge enabled correct parsing
|
|
9
|
+
* - password-recovery: hashcat/john guidance led to successful recovery
|
|
10
|
+
*/
|
|
11
|
+
export interface DomainKnowledge {
|
|
12
|
+
category: string;
|
|
13
|
+
type: 'pattern' | 'tool' | 'format' | 'gotcha' | 'file-creation';
|
|
14
|
+
content: string;
|
|
15
|
+
keywords: string[];
|
|
16
|
+
importance: number;
|
|
17
|
+
}
|
|
18
|
+
export declare const TERMINAL_BENCH_KNOWLEDGE: DomainKnowledge[];
|
|
19
|
+
/**
|
|
20
|
+
* Get domain knowledge relevant to a task
|
|
21
|
+
* Uses fuzzy/stemming matching for better recall
|
|
22
|
+
* OPTIMIZATION 6: file-creation type gets 2x score boost to surface first
|
|
23
|
+
*/
|
|
24
|
+
export declare function getRelevantKnowledge(taskInstruction: string, category?: string): DomainKnowledge[];
|
|
25
|
+
/**
|
|
26
|
+
* Format knowledge for context injection
|
|
27
|
+
*/
|
|
28
|
+
export declare function formatKnowledgeForContext(knowledge: DomainKnowledge[]): string;
|
|
29
|
+
/**
|
|
30
|
+
* Record knowledge outcome and optionally persist to long-term memory.
|
|
31
|
+
* Call this when a task succeeds or fails to improve future accuracy.
|
|
32
|
+
*
|
|
33
|
+
* @param taskPattern - Keywords describing the task (e.g., "password 7z crack")
|
|
34
|
+
* @param success - Whether the task succeeded
|
|
35
|
+
* @param learnedKnowledge - Optional new knowledge to persist (only on success)
|
|
36
|
+
* @param persistPath - Path to long_term_prepopulated.json (optional)
|
|
37
|
+
*/
|
|
38
|
+
export declare function recordKnowledgeOutcome(taskPattern: string, success: boolean, learnedKnowledge?: Omit<DomainKnowledge, 'importance'> & {
|
|
39
|
+
importance?: number;
|
|
40
|
+
}, persistPath?: string): void;
|
|
41
|
+
declare const _default: {
|
|
42
|
+
TERMINAL_BENCH_KNOWLEDGE: DomainKnowledge[];
|
|
43
|
+
getRelevantKnowledge: typeof getRelevantKnowledge;
|
|
44
|
+
formatKnowledgeForContext: typeof formatKnowledgeForContext;
|
|
45
|
+
recordKnowledgeOutcome: typeof recordKnowledgeOutcome;
|
|
46
|
+
};
|
|
47
|
+
export default _default;
|
|
48
|
+
//# sourceMappingURL=terminal-bench-knowledge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"terminal-bench-knowledge.d.ts","sourceRoot":"","sources":["../../src/memory/terminal-bench-knowledge.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAIH,MAAM,WAAW,eAAe;IAC9B,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,SAAS,GAAG,MAAM,GAAG,QAAQ,GAAG,QAAQ,GAAG,eAAe,CAAC;IACjE,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,eAAO,MAAM,wBAAwB,EAAE,eAAe,EA0QrD,CAAC;AAEF;;;;GAIG;AACH,wBAAgB,oBAAoB,CAClC,eAAe,EAAE,MAAM,EACvB,QAAQ,CAAC,EAAE,MAAM,GAChB,eAAe,EAAE,CAoCnB;AAED;;GAEG;AACH,wBAAgB,yBAAyB,CAAC,SAAS,EAAE,eAAe,EAAE,GAAG,MAAM,CAa9E;AAED;;;;;;;;GAQG;AACH,wBAAgB,sBAAsB,CACpC,WAAW,EAAE,MAAM,EACnB,OAAO,EAAE,OAAO,EAChB,gBAAgB,CAAC,EAAE,IAAI,CAAC,eAAe,EAAE,YAAY,CAAC,GAAG;IAAE,UAAU,CAAC,EAAE,MAAM,CAAA;CAAE,EAChF,WAAW,CAAC,EAAE,MAAM,GACnB,IAAI,CA0CN;;;;;;;AA+BD,wBAKE"}
|