docs(search): правило ast-index vs vex (когда что) + ссылки в CLAUDE.md

- .claude/rules/search-tools.md — матрица: ast-index (символы/usages/callers/outline),
  vex (semantic/similar/pattern/duplicates/show)
- usages/callers по JS — только ast-index (vex пропускает)
- CLAUDE.md и ast-index.md ссылаются на новое правило

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
Maxim Dolgolyov
2026-06-01 21:02:12 +03:00
parent fe122b7681
commit f2b0db4d9a
3 changed files with 54 additions and 1 deletions
+3
View File
@@ -1,5 +1,8 @@
# ast-index Rules
> Семантический поиск / AST-паттерны / дубликаты — это **vex**, см. `search-tools.md`.
> Это правило — про ast-index (дефолт для символов, usages, callers, outline).
## Mandatory Search Rules
1. **ALWAYS use ast-index FIRST** for any code search task
+46
View File
@@ -0,0 +1,46 @@
# Search Tools — когда ast-index, когда vex
Два инструмента поиска по коду. **Grep по-прежнему запрещён** (см. `ast-index.md`).
## Правило одной строкой
- Знаешь имя символа / нужны **usages / callers** / outline → **ast-index**
- Ищешь **по смыслу** / **похожее** / **дубликаты** / **AST-паттерн** / компактное тело → **vex**
## ast-index — дефолт
Быстрее (1–10 мс) и точнее на этом **vanilla-JS** проекте. ВСЕГДА первым для:
| Задача | Команда |
|--------|---------|
| Класс / функция по имени | `ast-index class "X"` · `ast-index symbol "x"` |
| Использования | `ast-index usages "X"` |
| Кто вызывает / иерархия | `ast-index callers "x"` · `ast-index call-tree "x"` |
| Структура файла | `ast-index outline "path"` |
| Поиск в файле | `ast-index search "kw" --in-file "f"` |
⚠️ **usages / callers на чистом JS — ТОЛЬКО ast-index.** vex их пропускает (JS у vex не
binder-язык). Проверено: `vex usages "audit"` → пусто, `ast-index usages "audit"` → все 10.
## vex — по смыслу и структуре
Для того, чего ast-index не умеет. Бинарник: `C:\Users\Home\bin\vex.exe` (в новых терминалах — `vex`).
Индекс собран с `--semantic`.
| Задача | Команда |
|--------|---------|
| Поиск по смыслу (имя неизвестно) | `vex search "что делает код" --semantic` |
| Семантически похожие символы | `vex similar "Name"` |
| AST-паттерн (как ast-grep) | `vex pattern --lang js 'function $NAME($$$)'` |
| Near-дубликаты | `vex duplicates --threshold 0.95` |
| Компактное тело символа (экономия токенов) | `vex show "Name"` |
| Всё про символ за 1 вызов | `vex bundle --mode symbol --symbol Name` |
Особенности CLI: `search` / `usages` / `show` берут индекс **текущей папки** и НЕ принимают `--path`;
`pattern` требует `--lang` + `--path`.
## Поддержание индексов
- **ast-index**: `ast-index update` (после pull) · `ast-index rebuild` (после новых файлов)
- **vex**: `vex update` (инкрементально, сохраняет semantic из манифеста) · `vex index --semantic` (полный)
- Обновить сам бинарник vex: `vex self-update`