|
@@ -0,0 +1,33 @@
|
|
|
+Что такое линтер: зачем, когда и кем используется
|
|
|
+
|
|
|
+Что такое линтер
|
|
|
+Линтер (от англ. слова 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. Они плюс-минус похожи, но некоторые аспекты в них могут отличаться. Одни ищут больше ошибки,
|
|
|
+другие следят за “красотой” кода. Одни работают в реальном времени, другие срабатывают перед компиляцией программы.
|