Skip to content

Commit

Permalink
feat: allow and mention ruff-formatter
Browse files Browse the repository at this point in the history
Signed-off-by: Henry Schreiner <[email protected]>
  • Loading branch information
henryiii committed Oct 25, 2023
1 parent d152f42 commit ccbc45c
Show file tree
Hide file tree
Showing 10 changed files with 135 additions and 38 deletions.
30 changes: 13 additions & 17 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,23 +6,6 @@ ci:
exclude: "^({{cookiecutter\\.project_name}}|hooks/pre_gen_project.py$)"

repos:
- repo: https://github.com/psf/black-pre-commit-mirror
rev: "23.10.0"
hooks:
- id: black-jupyter

- repo: https://github.com/adamchainz/blacken-docs
rev: "1.16.0"
hooks:
- id: blacken-docs
additional_dependencies: [black==23.10.0]

- repo: https://github.com/astral-sh/ruff-pre-commit
rev: "v0.1.1"
hooks:
- id: ruff
args: ["--fix", "--show-fixes"]

- repo: https://github.com/pre-commit/pre-commit-hooks
rev: "v4.5.0"
hooks:
Expand All @@ -39,6 +22,19 @@ repos:
- id: requirements-txt-fixer
- id: trailing-whitespace

- repo: https://github.com/adamchainz/blacken-docs
rev: "1.16.0"
hooks:
- id: blacken-docs
additional_dependencies: [black==23.*]

- repo: https://github.com/astral-sh/ruff-pre-commit
rev: "v0.1.2"
hooks:
- id: ruff
args: ["--fix", "--show-fixes"]
- id: ruff-format

- repo: https://github.com/pre-commit/pygrep-hooks
rev: "v1.10.0"
hooks:
Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -357,7 +357,7 @@ for family, grp in itertools.groupby(collected.checks.items(), key=lambda x: x[1

### Pre-commit
- [`PC100`](https://learn.scientific-python.org/development/guides/style#PC100): Has pre-commit-hooks
- [`PC110`](https://learn.scientific-python.org/development/guides/style#PC110): Uses black
- [`PC110`](https://learn.scientific-python.org/development/guides/style#PC110): Uses black or ruff-format
- [`PC111`](https://learn.scientific-python.org/development/guides/style#PC111): Uses blacken-docs
- [`PC140`](https://learn.scientific-python.org/development/guides/style#PC140): Uses mypy
- [`PC160`](https://learn.scientific-python.org/development/guides/style#PC160): Uses codespell
Expand Down
68 changes: 61 additions & 7 deletions docs/pages/guides/style.md
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,7 @@ ci:
autoupdate_commit_msg: "chore: update pre-commit hooks"
```

## Black
## Format

{% rr PC110 %} [Black](https://black.readthedocs.io/en/latest/) is a popular
auto-formatter from the Python Software Foundation. One of the main features of
Expand All @@ -102,6 +102,8 @@ There are a _few_ options, mostly to enable/disable certain files, remove string
normalization, and to change the line length, and those go in your
`pyproject.toml` file.

{% tabs %} {% tab black Black %}

Here is the snippet to add Black to your `.pre-commit-config.yml`:

```yaml
Expand All @@ -124,6 +126,36 @@ Here is the snippet to add Black to your `.pre-commit-config.yml`:

{% enddetails %}

{% endtab %} {% tab ruff Ruff-format %}

Ruff, the powerful Rust-based linter, also has a formatter that is designed to
look like Black, but run 30x faster. Here is the snippet to add Black to your
`.pre-commit-config.yml` (combine with Ruff below):

```yaml
- repo: https://github.com/astral-sh/ruff-pre-commit
rev: "v0.1.0"
hooks:
- id: ruff-format
```

{% details You can add a Ruff badge to your repo as well %}

[![Code style: Ruff](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/format.json))](https://github.com/astral-sh/ruff)

```md
[![Code style: Ruff](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/format.json))](https://github.com/astral-sh/ruff)
```

```rst
.. image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/format.json
:target: https://github.com/astral-sh/ruff
```

{% enddetails %}

{% endtab %} {% endtabs %}

In _very_ specific situations, you may want to retain special formatting. After
carefully deciding that it is a special use case, you can use `# fmt: on` and
`# fmt: off` around a code block to have it keep custom formatting. _Always_
Expand Down Expand Up @@ -179,15 +211,13 @@ src = ["src"]
exclude = []
[tool.ruff.lint]
select = [
"E", "F", "W", # flake8
extend-select = [
"B", # flake8-bugbear
"I", # isort
"ARG", # flake8-unused-arguments
"C4", # flake8-comprehensions
"EM", # flake8-errmsg
"ICN", # flake8-import-conventions
"ISC", # flake8-implicit-str-concat
"G", # flake8-logging-format
"PGH", # pygrep-hooks
"PIE", # flake8-pie
Expand All @@ -203,6 +233,8 @@ select = [
"EXE", # flake8-executable
"NPY", # NumPy specific rules
"PD", # pandas-vet
"FURB", # referb
"PYI", # flake8-pyi
]
ignore = [
"PLR", # Design related pylint codes
Expand Down Expand Up @@ -255,7 +287,8 @@ without this).
Here are some good error codes to enable on most (but not all!) projects:

- `E`, `F`, `W`: These are the standard flake8 checks, classic checks that have
stood the test of time.
stood the test of time. Not required if you use `extend-select` (`W` not
needed if you use a formatter)
- `B`: This finds patterns that are very bug-prone. {% rr RF101 %}
- `I`: This sorts your includes. There are multiple benefits, such as smaller
diffs, fewer conflicts, a way to auto-inject `__future__` imports, and easier
Expand All @@ -270,7 +303,7 @@ Here are some good error codes to enable on most (but not all!) projects:
error string directly in the exception you are throwing, producing a cleaner
traceback without duplicating the error string.
- `ISC`: Checks for implicit string concatenation, which can help catch mistakes
with missing commas.
with missing commas. (May collide with formatter)
- `PGH`: Checks for patterns, such as type ignores or noqa's without a specific
error code.
- `PL`: A set of four code groups that cover some (200 or so out of 600 rules)
Expand All @@ -284,9 +317,28 @@ Here are some good error codes to enable on most (but not all!) projects:
- `T20`: Disallow `print` in your code (built on the assumption that it's a
common debugging tool).
- `UP`: Upgrade old Python syntax to your `target-version`. {% rr RF103 %}
- `FURB`: From the refurb tool, a collection of helpful cleanups.
- `PYI`: Typing related checks

A few others small ones are included above, and there are even more available in
Ruff.
Ruff. You can use `ALL` to get them all, then ignore the ones you want to
ignore. New checks go into `--preview` before being activated in a minor
release.

{% details You can add a Ruff badge to your repo as well %}

[![Code style: Ruff](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json))](https://github.com/astral-sh/ruff)

```md
[![Code style: Ruff](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json))](https://github.com/astral-sh/ruff)
```

```rst
.. image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json
:target: https://github.com/astral-sh/ruff
```

{% enddetails %}

{% details Separate tools that Ruff replaces %}

Expand Down Expand Up @@ -828,3 +880,5 @@ You also might like the following hook, which cleans Jupyter outputs:

[flake8]: https://github.com/pycqa/flake8
[pycln]: https://hadialqattan.github.io/pycln

<script src="{% link assets/js/tabs.js %}"></script>
4 changes: 1 addition & 3 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -138,15 +138,13 @@ src = ["src"]
exclude = []

[tool.ruff.lint]
select = [
"E", "F", "W", # flake8
extend-select = [
"B", # flake8-bugbear
"I", # isort
"ARG", # flake8-unused-arguments
"C4", # flake8-comprehensions
"EM", # flake8-errmsg
"ICN", # flake8-import-conventions
"ISC", # flake8-implicit-str-concat
"PGH", # pygrep-hooks
"PIE", # flake8-pie
"PL", # pylint
Expand Down
8 changes: 8 additions & 0 deletions src/sp_repo_review/checks/general.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,9 @@ class General:


class PY001(General):

"Has a pyproject.toml"

url = mk_url("packaging-simple")

@staticmethod
Expand All @@ -26,6 +28,7 @@ def check(package: Traversable) -> bool:

class PY002(General):
"Has a README.(md|rst) file"

url = mk_url("packaging-simple")

@staticmethod
Expand All @@ -39,6 +42,7 @@ def check(root: Traversable) -> bool:

class PY003(General):
"Has a LICENSE* file"

url = mk_url("packaging-simple")

@staticmethod
Expand All @@ -49,6 +53,7 @@ def check(package: Traversable) -> bool:

class PY004(General):
"Has docs folder"

url = mk_url("packaging-simple")

@staticmethod
Expand All @@ -59,6 +64,7 @@ def check(package: Traversable) -> bool:

class PY005(General):
"Has tests folder"

url = mk_url("packaging-simple")

@staticmethod
Expand All @@ -79,6 +85,7 @@ def check(package: Traversable) -> bool:

class PY006(General):
"Has pre-commit config"

url = mk_url("style")

@staticmethod
Expand All @@ -89,6 +96,7 @@ def check(root: Traversable) -> bool:

class PY007(General):
"Supports an easy task runner (nox or tox)"

url = mk_url("tasks")

@staticmethod
Expand Down
7 changes: 7 additions & 0 deletions src/sp_repo_review/checks/github.py
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ class GitHub:

class GH100(GitHub):
"Has GitHub Actions config"

url = mk_url("gha-basic")

@staticmethod
Expand All @@ -54,6 +55,7 @@ def check(workflows: dict[str, Any]) -> bool:

class GH101(GitHub):
"Has nice names"

requires = {"GH100"}
url = mk_url("gha-basic")

Expand All @@ -68,6 +70,7 @@ def check(workflows: dict[str, Any]) -> bool:

class GH102(GitHub):
"Auto-cancel on repeated PRs"

requires = {"GH100"}
url = mk_url("gha-basic")

Expand All @@ -87,6 +90,7 @@ def check(workflows: dict[str, Any]) -> bool:

class GH103(GitHub):
"At least one workflow with manual dispatch trigger"

requires = {"GH100"}
url = mk_url("gha-basic")

Expand All @@ -105,6 +109,7 @@ def check(workflows: dict[str, Any]) -> bool:

class GH200(GitHub):
"Maintained by Dependabot"

url = mk_url("gha-basic")

@staticmethod
Expand All @@ -128,6 +133,7 @@ def check(dependabot: dict[str, Any]) -> bool:

class GH210(GitHub):
"Maintains the GitHub action versions with Dependabot"

requires = {"GH200"}
url = mk_url("gha-basic")

Expand All @@ -154,6 +160,7 @@ def check(dependabot: dict[str, Any]) -> bool:

class GH211(GitHub):
"Do not pin core actions as major versions"

requires = {"GH200", "GH210"} # Currently listing both helps - TODO: remove GH200
url = mk_url("gha-basic")

Expand Down
23 changes: 22 additions & 1 deletion src/sp_repo_review/checks/precommit.py
Original file line number Diff line number Diff line change
Expand Up @@ -41,50 +41,71 @@ def check(cls, precommit: dict[str, Any]) -> bool | None | str:

class PC100(PreCommit):
"Has pre-commit-hooks"

repo = "https://github.com/pre-commit/pre-commit-hooks"


class PC110(PreCommit):
"Uses black"
"Uses black or ruff-format"

repo = "https://github.com/psf/black-pre-commit-mirror"
renamed = "https://github.com/psf/black"
alternate = "https://github.com/astral-sh/ruff-pre-commit"

@classmethod
def check(cls, precommit: dict[str, Any]) -> bool | None | str:
"Must have `{self.repo}` or `{self.alternate}` + `id: ruff-format` in `.pre-commit-config.yaml`"
for repo in precommit.get("repos", {}):
if repo.get("repo", "").lower() == cls.alternate and any(
hook.get("id", "") == "ruff-format" for hook in repo.get("hooks", {})
):
return True

return super().check(precommit)


class PC111(PreCommit):
"Uses blacken-docs"

requires = {"PY006", "PC110"}
repo = "https://github.com/adamchainz/blacken-docs"
renamed = "https://github.com/asottile/blacken-docs"


class PC190(PreCommit):
"Uses Ruff"

repo = "https://github.com/astral-sh/ruff-pre-commit"
renamed = "https://github.com/charliermarsh/ruff-pre-commit"


class PC140(PreCommit):
"Uses mypy"

repo = "https://github.com/pre-commit/mirrors-mypy"


class PC160(PreCommit):
"Uses codespell"

repo = "https://github.com/codespell-project/codespell"


class PC170(PreCommit):
"Uses PyGrep hooks (only needed if RST present)"

repo = "https://github.com/pre-commit/pygrep-hooks"


class PC180(PreCommit):
"Uses prettier"

repo = "https://github.com/pre-commit/mirrors-prettier"


class PC191(PreCommit):
"Ruff show fixes if fixes enabled"

requires = {"PC190"}
repo = "https://github.com/astral-sh/ruff-pre-commit"

Expand Down
Loading

0 comments on commit ccbc45c

Please sign in to comment.