From f04cc5e37b703d51d23b9fc10b0a1766e8f92bb2 Mon Sep 17 00:00:00 2001 From: Nicholas Junge Date: Tue, 31 Oct 2023 09:06:20 +0100 Subject: [PATCH] Drop isort hook for ruff builtin import sorting This behaves the same, and saves a pre-commit step. ruff just needs an additional package location hint to correctly map first-part packages (in this case, `google_benchmark`). This revealed a misformat in the `google_benchmark.__init__`, which is now fixed. --- .pre-commit-config.yaml | 5 ----- bindings/python/google_benchmark/__init__.py | 1 + pyproject.toml | 17 +++++++---------- 3 files changed, 8 insertions(+), 15 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 94ae788f0b..5c4a3df8e2 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -14,11 +14,6 @@ repos: rev: 23.10.1 hooks: - id: black - - repo: https://github.com/pycqa/isort - rev: 5.12.0 - hooks: - - id: isort - args: [--profile, black] - repo: https://github.com/astral-sh/ruff-pre-commit rev: v0.1.3 hooks: diff --git a/bindings/python/google_benchmark/__init__.py b/bindings/python/google_benchmark/__init__.py index 63b4f6616a..7bdd051cf6 100644 --- a/bindings/python/google_benchmark/__init__.py +++ b/bindings/python/google_benchmark/__init__.py @@ -29,6 +29,7 @@ def my_benchmark(state): import atexit from absl import app + from google_benchmark import _benchmark from google_benchmark._benchmark import ( Counter, diff --git a/pyproject.toml b/pyproject.toml index 0bac140bb9..861dfcb32b 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -61,12 +61,6 @@ include = "\\.pyi?$" line-length = 80 target-version = ["py311"] -# Black-compatible settings for isort -# See https://black.readthedocs.io/en/stable/ -[tool.isort] -line_length = "80" -profile = "black" - [tool.mypy] check_untyped_defs = true disallow_incomplete_defs = true @@ -80,11 +74,14 @@ module = ["yaml"] ignore_missing_imports = true [tool.ruff] -# Enable pycodestyle (`E`) and Pyflakes (`F`) codes by default. -select = ["E", "F", "W"] +# explicitly tell ruff the source directory to correctly identify first-party package. +src = ["bindings/python"] +line-length = 80 +# Enable pycodestyle (`E`, `W`), Pyflakes (`F`), and isort (`I`) codes by default. +select = ["E", "F", "I", "W"] ignore = [ - # whitespace before colon (:), rely on black for formatting (in particular, allow spaces before ":" in list/array slices) + # whitespace before colon (:), rely on black for formatting. "E203", - # line too long, rely on black for reformatting of these, since sometimes URLs or comments can be longer + # line too long, rely on black for formatting. "E501", ]