code-navigation
$
npx mdskill add SteelMorgan/1c-agent-based-dev-framework/code-navigationEnables precise navigation through BSL code using Language Server Protocol for definitions, calls, and refactoring.
- Helps locate procedure definitions, function calls, and perform project-wide renaming in BSL projects.
- Integrates with Language Server Protocol tools for code indexing and analysis.
- Uses LSP operations like navigate_symbol and get_call_graph to retrieve accurate code references.
- Presents results through structured operations such as preview changes and diagnostic actions.
SKILL.md
.github/skills/code-navigationView on GitHub ↗
--- name: code-navigation description: Навигация по коду (Code Navigation). Навык учит агента **эффективно перемещаться по BSL-коду** с помощью LSP (Language Server Protocol). --- # Навигация по коду (Code Navigation) Не угадывать расположение кода — использовать LSP. Точные результаты по индексу проекта. ## Когда применять | Триггер | Действие | |---------|----------| | Поиск определений процедуры/функции | `navigate_symbol` operation `definition` | | Все вызовы функции X | `navigate_symbol` `search` или `get_call_graph` `incoming` | | Кого вызывает функция | `get_call_graph` `outgoing` | | Переименование по проекту | `rename_symbol` (сначала `preview: true`) | | Quick Fixes | `get_code_actions` | | Диагностика файла | `get_diagnostics` | | Исследование неизвестного кода | `navigate_symbol` → `get_call_graph` → hover | | Ошибка «метод не найден» на типе платформы | `getMembers` / `getMember` / `getConstructors` | ## Алгоритмы ### Найти все вызовы функции 1. `navigate_symbol(query: "ИмяФункции", operation: "search")` → получить `uri`, `line`, `character` 2. `get_call_graph(uri, line, character, direction: "incoming")` ### Переименование по проекту 1. `navigate_symbol` → `uri`, `line`, `character` 2. `rename_symbol(..., preview: true)` → проверить `changes` 3. `rename_symbol(..., preview: false)` 4. `check_syntax` ### Quick Fixes 1. `get_diagnostics(uri)` → список диагностик 2. `get_code_actions(uri, range, diagnostic)` → применить ### Верификация API платформы после ошибки **Триггер:** ошибка «Метод объекта не обнаружен» / «Неверное количество параметров» на типе платформы. Не угадывать повторно — верифицировать. 1. `search_syntax_reference(query: "ТипОбъекта")` → подтвердить имя, получить `id` 2. `getMembers(typeId)` → точный список методов/свойств 3. `getMember(typeId, member)` → сигнатура конкретного метода 4. `getConstructors(typeId)` → если ошибка про параметры `Новый` **Важно:** Только реакция на ошибку, не превентивный поиск. ## Capabilities | Capability | Назначение | |------------|------------| | `navigate_symbol` | Поиск символов, определение, hover | | `get_call_graph` | Граф вызовов (incoming/outgoing) | | `rename_symbol` | Переименование по проекту | | `get_diagnostics` | LSP-диагностика файла | | `get_code_actions` | Quick Fixes | | `search_syntax_reference` | Поиск типа платформы | | `getMembers` / `getMember` | Методы/свойства типа платформы | | `getConstructors` | Конструкторы типа (`Новый`) | ## Типичные ошибки | Ошибка | Обходной путь | |--------|---------------| | LSP не подключён | Проверить `lsp_status`; запустить BSL Language Server | | Символ не найден | Проверить имя (регистр, язык); нечёткий поиск через `ask_ai_assistant` | | `get_call_graph` таймаут | Уменьшить `depth` | | `rename_symbol` не применим | Проверить позицию курсора; защищённая область → ручное редактирование | | Файл не индексирован | Дождаться индексации LSP | --- depends_on: [] ---
More from SteelMorgan/1c-agent-based-dev-framework
- 1c-ai-agent-cliCLI 1C BSL Agent Framework — tools/install.py (clone, install). Используй при клонировании репозитория, установке компонентов в проект, настройке IDE (Cursor, Claude Code, Windsurf, VS Code+Continue).
- agent-debugПаттерн отладочных сообщений для 1С BSL. Используй, когда стандартная диагностика (event-log, скриншоты) не даёт понять фактическое поведение системы — нужно вставить временные точки логирования в код, запустить тест и проанализировать записи ЖР.
- agent-developmentCreate custom subagents for specialized AI tasks. Use when the user wants to create a new type of subagent, set up task-specific agents, configure code reviewers, debuggers, or domain-specific assistants with custom prompts.
- agent-development-ext>
- agent-git-workflowStandardizes git workflow for the AI agent in the sandbox devcontainer: work in agent/<task>-<yyyymmdd>, integrate via agent, never push to main/master, open PRs via GitHub CLI. Use when the user asks to create branches, push changes, open PRs, or follow this sandbox repo setup.
- auto-skill-bootstrapDeterministic helper to inventory existing project skills, detect missing capability coverage, search skills.sh via Skills CLI, and (optionally) install missing skills under a trust policy. Uses skills-manifest.json + state.json to stay idempotent across changing requirements.
- config-operationsОперации с конфигурацией 1С (CF) — init, info, edit, validate. Используй при создании конфигурации, анализе структуры, изменении свойств и ChildObjects, валидации Configuration.xml.
- epf-buildСобрать EPF/ERF из XML-исходников. Используй после внесения временных диагностических правок в разобранную обработку.
- epf-dumpРазобрать EPF/ERF в XML-исходники. Используй, когда нужно быстро получить исходный код внешней обработки или отчета для анализа и временной модификации.
- epf-operationsОперации с внешними обработками 1С (EPF) — создание, добавление форм и шаблонов. Используй при epf init, add-form, add-template, add-attribute, add-tabular-section.