Неверное использование "СтрШаблон" (IncorrectUseOfStrTemplate)¶
| Тип | Поддерживаются языки |
Важность | Включена по умолчанию |
Время на исправление (мин) |
Теги |
|---|---|---|---|---|---|
Ошибка |
BSLOS |
Блокирующий |
Да |
1 |
brainoverloadsuspiciousunpredictable |
Описание диагностики¶
При использовании метода СтрШаблон нужно внимательно составлять шаблонную строку и передавать правильное количество параметров.
И можно довольно легко ошибиться при передаче значений для СтрШаблон.
Важно помнить, что
- СтрШаблон принимает только параметры от %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