Skip to content

Commit

Permalink
Bug 1811850 - [lint] Replace flake8 linter with ruff, r=linter-review…
Browse files Browse the repository at this point in the history
…ers,sylvestre

Ruff is a very fast linter implemented in Rust and it can act as a drop-in
replacement for flake8. When running the same set of rules across all files
in mozilla-central (without mozlint), flake8 takes 900 seconds whereas ruff
takes 0.9 seconds.

Ruff also implements rules from other popular Python linters such as pylint,
isort and pyupgrade. There are even plans to implement feature parity with
black in the future. Ultimately, it can become our one stop shop for all Python
linting and formatting.

This stack will swap out all our Python lint tools for ruff (excluding black
for now).

Differential Revision: https://phabricator.services.mozilla.com/D172313
  • Loading branch information
ahal committed Mar 20, 2023
1 parent 787579f commit dd673c2
Show file tree
Hide file tree
Showing 30 changed files with 472 additions and 633 deletions.
130 changes: 0 additions & 130 deletions .flake8

This file was deleted.

3 changes: 3 additions & 0 deletions .hgignore
Original file line number Diff line number Diff line change
Expand Up @@ -225,6 +225,9 @@ _OPT\.OBJ/
# Unit test
\.pytest_cache/

# Ruff
\.ruff_cache/

# Ignore files created when running a reftest.
^lextab.py$

Expand Down
16 changes: 5 additions & 11 deletions docs/code-quality/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -90,11 +90,11 @@ In this document, we try to list these all tools.
- Meta bug
- More info
- Upstream
* - Flake8
- Yes (with `autopep8 <https://github.com/hhatto/autopep8>`_)
- `bug 1155970 <https://bugzilla.mozilla.org/show_bug.cgi?id=1155970>`__
- :ref:`Flake8`
- http://flake8.pycqa.org/
* - ruff
- Yes
- `bug 1811850 <https://bugzilla.mozilla.org/show_bug.cgi?id=1811850>`__
- :ref:`ruff`
- https://github.com/charliermarsh/ruff
* - black
- Yes
- `bug 1555560 <https://bugzilla.mozilla.org/show_bug.cgi?id=1555560>`__
Expand All @@ -105,12 +105,6 @@ In this document, we try to list these all tools.
- `bug 1623024 <https://bugzilla.mozilla.org/show_bug.cgi?id=1623024>`__
- :ref:`pylint`
- https://www.pylint.org/
* - Python 2/3 compatibility check
-
- `bug 1496527 <https://bugzilla.mozilla.org/show_bug.cgi?id=1496527>`__
- :ref:`Python 2/3 compatibility check`
-


.. list-table:: Rust
:widths: 20 20 20 20 20
Expand Down
46 changes: 0 additions & 46 deletions docs/code-quality/lint/linters/flake8.rst

This file was deleted.

44 changes: 44 additions & 0 deletions docs/code-quality/lint/linters/ruff.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
Ruff
====

`Ruff <https://github.com/charliermarsh/ruff>`_ is an extremely fast Python
linter and formatter, written in Rust. It can process all of mozilla-central in
under a second, and implements rule sets from a large array of Python linters
and formatters, including:

* flake8 (pycodestyle, pyflakes and mccabe)
* isort
* pylint
* pyupgrade
* and many many more!

Run Locally
-----------

The mozlint integration of ruff can be run using mach:

.. parsed-literal::
$ mach lint --linter ruff <file paths>
Configuration
-------------

Ruff is configured in the root `pyproject.toml`_ file. Additionally, ruff will
pick up any ``pyproject.toml`` or ``ruff.toml`` files in subdirectories. The
settings in these files will only apply to files contained within these
subdirs. For more details on configuration discovery, see the `configuration
documentation`_.

For a list of options, see the `settings documentation`_.

Sources
-------

* `Configuration (YAML) <https://searchfox.org/mozilla-central/source/tools/lint/ruff.yml>`_
* `Source <https://searchfox.org/mozilla-central/source/tools/lint/python/ruff.py>`_

.. _pyproject.toml: https://searchfox.org/mozilla-central/source/pyproject.toml
.. _configuration documentation: https://beta.ruff.rs/docs/configuration/
.. _settings documentation: https://beta.ruff.rs/docs/settings/
3 changes: 3 additions & 0 deletions moz.build
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,9 @@ with Files("docs/**"):
with Files("mach*"):
BUG_COMPONENT = ("Firefox Build System", "Mach Core")

with Files("pyproject.toml"):
BUG_COMPONENT = ("Developer Infrastructure", "Lint and Formatting")

with Files("*moz*"):
BUG_COMPONENT = ("Firefox Build System", "General")

Expand Down
Loading

0 comments on commit dd673c2

Please sign in to comment.