Перейти к содержанию

Неверное использование "СтрШаблон" (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