Неверное использование "СтрШаблон" (IncorrectUseOfStrTemplate)¶
Тип | Поддерживаются языки |
Важность | Включена по умолчанию |
Время на исправление (мин) |
Теги |
---|---|---|---|---|---|
Ошибка |
BSL OS |
Блокирующий |
Да |
1 |
brainoverload suspicious unpredictable |
Описание диагностики¶
При использовании метода СтрШаблон
нужно внимательно составлять шаблонную строку и передавать правильное количество параметров.
И можно довольно легко ошибиться при передаче значений для СтрШаблон
.
Важно помнить, что
- СтрШаблон
принимает только параметры от %1
до %10
- если требуется передать сразу после шаблона число, нужно добавить скобки - "%(1)45"
Примеры¶
Вариант 1 - количество переданных после шаблонной строки значений не равно (меньше или больше) максимальному номеру из строки вида %N внутри шаблонной строки
СтрШаблон("Наименование (версия %1)"); // не передан необходимый параметр для %1
СтрШаблон("%1 (версия %2)", Наименование); // не передан необходимый параметр для %2
Вариант 2 - не передается вообще никаких значений, кроме форматированной строки из-за большого количества скобок внутри несложного выражения с НСтр
и СтрШаблон
:
СтрШаблон(НСтр("ru='Наименование (версия %1)'", Версия()));
Здесь ошибочно не закрыта скобка для НСтр
. В итоге выражение после вычисления НСтр
становится пустым.
Выявить подобную ошибку чтением кода довольно сложно из-за наличия скобок. И можно поймать только в рантайме, получив исключение.
Правильный вариант
- СтрШаблон(НСтр("ru='Наименование (версия %1)'"), Версия());
Вариант 3 - правильный пример передачи цифр сразу после шаблонного значения
- СтрШаблон("Наименование %(1)2"), Наименование); // если передать значение "МояСтрока", то результат будет "МояСтрока2"
Источники¶
Сниппеты¶
Экранирование кода¶
// BSLLS:IncorrectUseOfStrTemplate-off
// BSLLS:IncorrectUseOfStrTemplate-on
Параметр конфигурационного файла¶
"IncorrectUseOfStrTemplate": false