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

Устаревшие методы не должны использоваться (DeprecatedMethodCall)

Тип Поддерживаются
языки
Важность Включена
по умолчанию
Время на
исправление (мин)
Теги
Дефект кода BSL
OS
Незначительный Да 3 deprecated
design

Описание диагностики

В случаях когда возникает необходимость отметить процедуру (функцию) как устаревшую, в первой строке ее описания размещается слово "Устарела." (англ. "Deprecated.").

Следует избегать использования или расширения устаревших методов. Пометка метода как устаревшего - это предупреждение о том, что метод будет удален в будущих версиях и оставлен для временной обратной совместимости.

Исключение: допустимо вызывать устаревшие методы из устаревших методов.

Помимо пользовательских методов диагностика срабатывает на вызовы платформенных методов и обращения к свойствам, помеченным устаревшими в синтакс-помощнике. Источник сведений об устаревании - синтакс-помощник установленной платформы 1С (через bsl-context) либо встроенный справочник, поэтому проверка работает и без подключенного справочника платформы. Срабатывание учитывает целевую версию платформы: член считается устаревшим, если целевая версия не ниже версии, начиная с которой член устарел. Целевая версия определяется по приоритету: настройка v8platform.targetVersion, затем режим совместимости конфигурации, а если ничего не задано - считается, что используется самая свежая платформа.

Дополнительно подсвечиваются обращения к свойствам конфигурации с префиксом Удалить/Delete - стандартная 1С-конвенция пометки устаревших реквизитов, значений перечислений и объектов конфигурации.

Для OneScript диагностика также подсвечивает обращения к устаревшим членам, помеченным во встроенном справочнике типов (механизм версионирования платформы 1С к OneScript неприменим, поэтому деpreкейт там трактуется как «устаревший всегда»).

Примеры

// Устарела. Следует использовать НеУстаревшаяПроцедура.
Процедура УстаревшаяПроцедура()
КонецПроцедуры

УстаревшаяПроцедура(); // Срабатывание диагностики

Источники

Сниппеты

Экранирование кода

// BSLLS:DeprecatedMethodCall-off
// BSLLS:DeprecatedMethodCall-on

Параметр конфигурационного файла

"DeprecatedMethodCall": false