2.4 KiB
2.4 KiB
TOOLS KNOWLEDGE BASE
OVERVIEW
20+ tools: LSP (6), AST-Grep (2), Search (2), Session (4), Agent delegation (4), System (2), Skill (3).
STRUCTURE
tools/
├── [tool-name]/
│ ├── index.ts # Barrel export
│ ├── tools.ts # ToolDefinition
│ ├── types.ts # Zod schemas
│ └── constants.ts # Fixed values
├── lsp/ # 6 tools: definition, references, symbols, diagnostics, rename
├── ast-grep/ # 2 tools: search, replace (25 languages)
├── delegate-task/ # Category-based routing (1039 lines)
├── session-manager/ # 4 tools: list, read, search, info
├── grep/ # Custom grep with timeout
├── glob/ # 60s timeout, 100 file limit
├── interactive-bash/ # Tmux session management
├── look-at/ # Multimodal PDF/image
├── skill/ # Skill execution
├── skill-mcp/ # Skill MCP operations
├── slashcommand/ # Slash command dispatch
├── call-omo-agent/ # Direct agent invocation
└── background-task/ # background_output, background_cancel
TOOL CATEGORIES
| Category | Tools | Purpose |
|---|---|---|
| LSP | lsp_goto_definition, lsp_find_references, lsp_symbols, lsp_diagnostics, lsp_prepare_rename, lsp_rename | Semantic code intelligence |
| Search | ast_grep_search, ast_grep_replace, grep, glob | Pattern discovery |
| Session | session_list, session_read, session_search, session_info | History navigation |
| Agent | delegate_task, call_omo_agent, background_output, background_cancel | Task orchestration |
| System | interactive_bash, look_at | CLI, multimodal |
| Skill | skill, skill_mcp, slashcommand | Skill execution |
HOW TO ADD
- Create
src/tools/[name]/with standard files - Use
tool()from@opencode-ai/plugin/tool - Export from
src/tools/index.ts - Add to
builtinToolsobject
LSP SPECIFICS
- Client:
client.tsmanages stdio, JSON-RPC - Singleton:
LSPServerManagerwith ref counting - Capabilities: definition, references, symbols, diagnostics, rename
AST-GREP SPECIFICS
- Engine:
@ast-grep/napifor 25+ languages - Patterns:
$VAR(single),$$$(multiple)
ANTI-PATTERNS
- Sequential bash: Use
&&or delegation - Raw file ops: Never mkdir/touch in tool logic
- Sleep: Use polling loops