Опечатка (Typo)¶
| Тип | Поддерживаются языки |
Важность | Включена по умолчанию |
Время на исправление (мин) |
Теги |
|---|---|---|---|---|---|
Дефект кода |
BSLOS |
Информационный |
Да |
1 |
badpractice |
Параметры¶
| Имя | Тип | Описание | Значение по умолчанию |
|---|---|---|---|
minWordLength |
Целое |
Минимальная длина проверяемых слов |
3 |
userWordsToIgnore |
Строка |
Пользовательский словарь исключений (через запятую) |
`` |
Описание диагностики¶
Проверка орфографических ошибок осуществляется с помощью LanguageTool. Проверяемые строки разбиваются по camelCase и проверяются на соответствие во встроенном словаре.
Кэш¶
Диагностика использует персистентный кэш на диске (EhCache) для хранения информации об уже проверенных словах. Путь к каталогу кэша настраивается с помощью свойств app.cache.basePath и app.cache.fullPath в конфигурации приложения.
По умолчанию в приложении установлено:
app.cache.basePath=${user.home}
app.cache.fullPath=
Это означает, что:
- Кэш будет создаваться в каталоге пользователя (${user.home}/.bsl-language-server/cache/<hash>/)
- <hash> — MD5-хэш абсолютного пути к текущей рабочей директории, что обеспечивает изоляцию кэша для разных workspace
- Кэш не создается в рабочей директории проекта, не захламляя git-репозитории
Для переопределения пути к кэшу можно использовать:
- app.cache.fullPath — полный путь к каталогу кэша (если задан, используется напрямую)
- app.cache.basePath — базовый путь для автоматического вычисления (по умолчанию ${user.home})
Пример переопределения:
# Задать явный путь к кэшу
app.cache.fullPath=/custom/cache/location
# Или изменить только базовый путь
app.cache.basePath=/opt/bsl-ls
# Результат: /opt/bsl-ls/.bsl-language-server/cache/<hash>/
Рекомендации для CI:
Важно: С новой версией кэш по умолчанию хранится в каталоге пользователя с хэшем workspace. Для CI рекомендуется явно задать app.cache.fullPath для упрощения кэширования между сборками.
- GitHub Actions
- Задайте явный путь к кэшу в переменных окружения или конфигурации
- Используйте
actions/cacheдля сохранения каталога между прогоном сборок и тестов
- name: Cache BSL LS Typo
uses: actions/cache@v3
with:
path: .bsl-ls-cache
key: ${{ runner.os }}-bsl-typo-${{ hashFiles('**/*.bsl') }}
restore-keys: |
${{ runner.os }}-bsl-typo-
- GitLab CI
-
В
.gitlab-ci.ymlиспользуйте секциюcache:variables: APP_CACHE_FULLPATH: ".bsl-ls-cache" cache: key: "bsl-ls-typo-cache" paths: - .bsl-ls-cache/ policy: pull-push -
При необходимости задайте уникальный
keyдля разных веток/раннеров. -
Jenkins
- Задайте переменную окружения
APP_CACHE_FULLPATHдля явного пути к кэшу - В pipeline можно сохранить каталог кэша между сборками несколькими способами:
- Использовать
stash/unstashдля передачи данных между этапами в одной сборке. - Использовать плагин
Workspace Cleanupи настроить сохранение workspace на агенте (если агенты постоянные) или архивировать артефакт с помощьюarchiveArtifactsи скачивать при следующих сборках. - Для Jenkins при использовании динамических агентов (например, Kubernetes) рекомендуется сохранять кэш в сетевом хранилище или в объектном хранилище (S3) и восстанавливать его в начале job.
- Использовать
Общие рекомендации:
- Для CI-окружений рекомендуется явно задать app.cache.fullPath (например, .bsl-ls-cache в workspace проекта) для упрощения кэширования
- Убедитесь, что путь к кэшу доступен процессу сборки и имеет достаточные права.
Источники¶
- Полезная информация: Русский язык для всех
- Страница LanguageTool
Сниппеты¶
Экранирование кода¶
// BSLLS:Typo-off
// BSLLS:Typo-on
Параметр конфигурационного файла¶
"Typo": {
"minWordLength": 3,
"userWordsToIgnore": ""
}