123456789101112131415161718192021222324252627282930313233 |
- Что такое линтер: зачем, когда и кем используется
- Что такое линтер
- Линтер (от англ. слова lint) – статический анализатор кода, который указывает на “подозрительные” участки программы и тем самым помогает программисту писать
- более качественный код. Подозрительными участками может быть любой код, в котором есть ошибка (по мнению линтера). Обычно, линтер устанавливается на компьютер
- программиста, а точнее в IDE.
- IDE – это среда разработки, например, Xcode, Android Studio, Visual Code Studio.
- Зачем нужен линтер
- Когда несколько программистов работают на одном большом проекте, возникают проблемы – у каждого программиста свой стиль написания кода, свое понимание того как нужно
- реализовывать различные участки программы. Из-за того что все пишут так как они этого хотят, другим разработчикам сложно быстро вовлечься в процесс работы в новом для них
- проекте.
- В линтер можно “установить” определенный набор правил, которым должен будет соответствовать написанный программистом код. Например, можно ограничить длину строки до 100
- символов, запретить вложенные тернарные операторы и лишние пробелы. Это может помочь привести код проекта к более единому стилю.
- Также, когда программист пишет код, он может забывать убирать лишние переменные и пробелы в коде. Линтер же будет “подсвечивать” весь мусор, поэтому программист сможет на
- это вовремя обратить внимание.
- Какие бывают линтеры?
- Самые простые проверяют только стиль, например, Flake8. В какой-то степени ещё и Black, но скорее это автоформатор-линтер. Линтеры сложнее проверяют семантику, а не только
- стилистику: что вы делаете, зачем, и бьют вас по рукам, если пишете с ошибками. Хороший пример — Pylint, который мы все знаем, пользуемся и любим. Я называю такие линтеры —
- Best practices. Третий тип — Type checking, эти линтеры немного в стороне. Type checking в Python — новинка, её сейчас делают две конкурирующие платформы: Mypy и Pyre.
- Как работает линтер
- Обычно линтер работает в реальном времени и анализирует файлы и написанный код на ходу. Хотя, все зависит и от самого инструмента (ага, он не один): есть линтеры работающие
- в реальном времени, а есть линтеры, которые необходимо запустить, например, перед отправкой кода в GitHub.
- Стоит отметить, что для каждого языка программирования существует свой анализатор кода, и даже не один. Например, у языка программирования JavaScript есть ESlint, JSLint,
- JSHint. У PHP есть PHP_CodeSniffer, NoVerify. А у Python есть Flake8 и Pylint. Они плюс-минус похожи, но некоторые аспекты в них могут отличаться. Одни ищут больше ошибки,
- другие следят за “красотой” кода. Одни работают в реальном времени, другие срабатывают перед компиляцией программы.
|