Skip to main content

pre-commit hooks for python projects using pyproject.toml.

Project description

pyproject-pre-commit

test test coverage

pre-commit hooks for python projects. prek also works as well (current default depends on prek).

.pre-commit-hooks.yaml provides pre-defined ids which you just need to add these ids to your .pre-commit-config.yaml.

By installing pyproject-pre-commit package, all necessary tools are installed as dependencies.

Requirement

  • Python >= 3.9.0

Usage

Install pyproject-pre-commit

Using uv:

$ uv add --group dev pyproject-pre-commit

Using poetry:

$ poetry add --dev pyproject-pre-commit

Using pip:

$ pip install pyproject-pre-commit

This will install pyproject-pre-commit and

    "prek>=0.3.2",
    "ruff>=0.15.0",
    "ty>=0.0.15",
    "numpydoc>=1.11.0",
    "shellcheck-py>=0.9.0.5",
    "mdformat>=0.7.22",
    "mdformat-pyproject>=0.0.1",
    "mdformat-ruff>=0.1.3",
    "mdformat-beautysh>=0.1.1",
    "mdformat-config>=0.2.1",
    "mdformat-gofmt>=0.0.2",
    "mdformat-rustfmt>=0.0.3",
    "mdformat-footnote>=0.1.1",
    "mdformat-frontmatter>=2.0.1",
    "mdformat-gfm>=0.3.5",
    "mdformat-tables>=1.0.0",
    "mdformat-web>=0.2.0",
    "mdformat-toc>=0.3.0",
    "validate-pyproject[all]>=0.22",

Optional dependencies

if you want to install pre-commit, do:

$ uv add --dev pyproject-pre-commit[pre-commit]

If you want to use black/autoflake/autopep8/flake8/isort/bandit for linting/formatting, do:

$ uv add --dev pyproject-pre-commit[black]

If you need mypy, do:

$ uv add --dev pyproject-pre-commit[mypy]

If you wish to install all, do:

$ uv add --dev pyproject-pre-commit[all]

Prepare .pre-commit-config.yaml

Add https://github.com/rcmdnk/pyproject-pre-commit to your .pre-commit-config.yaml, like:

repos:
  - repo: https://github.com/rcmdnk/pyproject-pre-commit
    rev: v0.6.0
    hooks:
      - id: ruff-lint-diff
      - id: ruff-lint
      - id: ruff-format-diff
      - id: ruff-format
      - id: ty
      - id: numpydoc-validation
      - id: shellcheck
      - id: mdformat-check
      - id: mdformat
      - id: actionlint
      - id: validate-pyproject

By using pyproject-pre-commit, you can simplify your .pre-commit-config.yaml that you need only repo of https://github.com/rcmdnk/pyproject-pre-commit.

These hooks uses local installation of tools, so pre-commit will use tools installed in your working environment.

This can be made by ppc command:

$ ppc pre-commit > .pre-commit-config.yaml

[!NOTE] If you are using poetry, run poetry run ppc ... or run after poetry shell.

If you already have it, add hooks w/o repos: by

$ ppc --pre-commit |grep -v "^repos:" >> .pre-commit-config.yaml

You may want to modify after adding these configurations.

To use black, flake8, isort and mypy, instead of ruff/ty, add following hooks:

repos:
  - repo: https://github.com/rcmdnk/pyproject-pre-commit
    rev: v0.6.0
    hooks:
      - id: black-diff
      - id: black
      - id: blacken-docs
      - id: autoflake-diff
      - id: autoflake
      - id: autopep8-diff
      - id: autopep8
      - id: isort-diff
      - id: isort
      - id: flake8
      - id: bandit
      - id: mypy
      - id: numpydoc-validation
      - id: shellcheck
      - id: mdformat-check
      - id: mdformat
      - id: actionlint
      - id: validate-pyproject

This can be made by ppc command:

$ ppc pre-commit --black --mypy > .pre-commit-config.yaml

Run prek/pre-commit

prek command is installed as dependencies of pyproject-pre-commit package.

After installing pyproject-pre-commit package, you can run prek command.

First, install pre-commit hooks by:

$ prek install

then you can run pre-commit by:

$ prek run -a

[!NOTE] If you are using uv, run uv run pre-commit ...

If you want to use pre-commit command, install pyproject-pre-commit[pre-commit] and use pre-commit command.

Available ids

You can find ids in .pre-commit-hooks.yaml.

There are ids for following tools:

All tools are installed as dependencies of pyproject-pre-commit package.

shellcheck and mdformat are given in addition to python tools as they can be managed by pip and most projects have README.md and some have shell scripts.

For tools which can format files, there are additional ids with -diff or --check which show the results before modifying files. You can see the differences after formatting if you place these ids before ids w/o --diff or --check.

Options for tools

You can set options in pyproject.toml for all tools above.

For flake8, flake8-pyproject allows to read options from pyproject.toml

About bandit, there is a plugin for the flake8, but plugin version does not read options from pyproject.toml even with pyproject.toml. Therefore, use bandit directly and give -c pyproject.toml option in the hooks.

pyproject.toml

You can set options in pyproject.toml for all tools.

Example options can be made by ppc command:

$ ppc --pyproject >> pyproject.toml

or

$ ppc --pyproject --black --mypy >> pyproject.toml

You may want to modify after adding these configurations.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyproject_pre_commit-0.6.1.tar.gz (125.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyproject_pre_commit-0.6.1-py3-none-any.whl (11.8 kB view details)

Uploaded Python 3

File details

Details for the file pyproject_pre_commit-0.6.1.tar.gz.

File metadata

  • Download URL: pyproject_pre_commit-0.6.1.tar.gz
  • Upload date:
  • Size: 125.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for pyproject_pre_commit-0.6.1.tar.gz
Algorithm Hash digest
SHA256 363605b84aafae999709609d2fb2bc957133dd2fa6ba434d871490dc7efc40ed
MD5 bc2f0340b64480dc980fe956152ad1b7
BLAKE2b-256 24862aee32fb94f2ca600dec054a33a3e06e014d5d7dd1e635d53d4ea579bee5

See more details on using hashes here.

File details

Details for the file pyproject_pre_commit-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: pyproject_pre_commit-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 11.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for pyproject_pre_commit-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 23853baebd3e8e334549c6e63f117a4d42ec10c6d8e8565695d9559a2437b2bd
MD5 0308295f849f1e4b401678d61985fc10
BLAKE2b-256 62b6c9c942bcc7b5a1b61c3eda62a875630d528171cf495fb5d077258499c2b2

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page