Metadata-Version: 2.4
Name: pyproject-pre-commit
Version: 0.6.1
Summary: pre-commit hooks for python projects using pyproject.toml.
Project-URL: Repository, https://github.com/rcmdnk/pyproject-pre-commit
Project-URL: Documentation, https://github.com/rcmdnk/pyproject-pre-commit
Project-URL: Homepage, https://github.com/rcmdnk/pyproject-pre-commit
Project-URL: Issue, https://github.com/rcmdnk/pyproject-pre-commit/issues
Author-email: rcmdnk <rcmdnk@gmail.com>
License-Expression: Apache-2.0
License-File: LICENSE
Keywords: pre-commit,pyproject.toml,uv
Classifier: Development Status :: 3 - Alpha
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: Operating System :: OS Independent
Classifier: Topic :: Software Development
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Utilities
Requires-Python: >=3.9.0
Requires-Dist: mdformat-beautysh>=0.1.1
Requires-Dist: mdformat-config>=0.2.1
Requires-Dist: mdformat-footnote>=0.1.1
Requires-Dist: mdformat-frontmatter>=2.0.1
Requires-Dist: mdformat-gfm>=0.3.5
Requires-Dist: mdformat-gofmt>=0.0.2
Requires-Dist: mdformat-pyproject>=0.0.1
Requires-Dist: mdformat-ruff>=0.1.3
Requires-Dist: mdformat-rustfmt>=0.0.3
Requires-Dist: mdformat-tables>=1.0.0
Requires-Dist: mdformat-toc>=0.3.0
Requires-Dist: mdformat-web>=0.2.0
Requires-Dist: mdformat>=0.7.22
Requires-Dist: numpydoc>=1.9.0
Requires-Dist: prek>=0.3.2
Requires-Dist: ruff>=0.15.0
Requires-Dist: shellcheck-py>=0.9.0.5
Requires-Dist: ty>=0.0.15
Requires-Dist: validate-pyproject[all]>=0.22
Provides-Extra: black
Requires-Dist: autoflake>=2.2.1; extra == 'black'
Requires-Dist: autopep8>=2.0.4; extra == 'black'
Requires-Dist: bandit[toml]>=1.8.0; extra == 'black'
Requires-Dist: black>=25.11.0; extra == 'black'
Requires-Dist: blacken-docs>=1.16.0; extra == 'black'
Requires-Dist: flake8-annotations-complexity>=0.0.8; extra == 'black'
Requires-Dist: flake8-bugbear>=24.0.0; extra == 'black'
Requires-Dist: flake8-builtins>=2.1.0; extra == 'black'
Requires-Dist: flake8-comprehensions>=3.14.0; extra == 'black'
Requires-Dist: flake8-debugger>=4.1.2; extra == 'black'
Requires-Dist: flake8-docstrings>=1.7.0; extra == 'black'
Requires-Dist: flake8-executable>=2.1.3; extra == 'black'
Requires-Dist: flake8-pep3101>=2.0.0; extra == 'black'
Requires-Dist: flake8-print>=5.0.0; extra == 'black'
Requires-Dist: flake8-pyproject>=1.2.3; extra == 'black'
Requires-Dist: flake8-rst-docstrings>=0.3.0; extra == 'black'
Requires-Dist: flake8-string-format>=0.3.0; extra == 'black'
Requires-Dist: isort>=6.1.0; extra == 'black'
Requires-Dist: pep8-naming>=0.14.0; extra == 'black'
Requires-Dist: pycodestyle>=2.11.0; extra == 'black'
Provides-Extra: mypy
Requires-Dist: mypy>=1.19.1; extra == 'mypy'
Provides-Extra: pre-commit
Requires-Dist: pre-commit>=4.3.0; extra == 'pre-commit'
Description-Content-Type: text/markdown

# pyproject-pre-commit<a name="pyproject-pre-commit"></a>

[![test](https://github.com/rcmdnk/pyproject-pre-commit/actions/workflows/test.yml/badge.svg)](https://github.com/rcmdnk/pyproject-pre-commit/actions/workflows/test.yml)
[![test coverage](https://img.shields.io/badge/coverage-check%20here-blue.svg)](https://github.com/rcmdnk/pyproject-pre-commit/tree/coverage)

[pre-commit](https://pre-commit.com/) hooks for python projects.
[prek](https://github.com/j178/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.

<!-- mdformat-toc start --slug=github --maxlevel=6 --minlevel=2 -->

- [Requirement](#requirement)
- [Usage](#usage)
  - [Install pyproject-pre-commit](#install-pyproject-pre-commit)
  - [Optional dependencies](#optional-dependencies)
  - [Prepare .pre-commit-config.yaml](#prepare-pre-commit-configyaml)
  - [Run prek/pre-commit](#run-prekpre-commit)
- [Available ids](#available-ids)
- [Options for tools](#options-for-tools)
- [pyproject.toml](#pyprojecttoml)

<!-- mdformat-toc end -->

## Requirement<a name="requirement"></a>

- Python >= 3.9.0

## Usage<a name="usage"></a>

### Install pyproject-pre-commit<a name="install-pyproject-pre-commit"></a>

Using uv:

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

Using poetry:

```bash
$ poetry add --dev pyproject-pre-commit
```

Using pip:

```bash
$ 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<a name="optional-dependencies"></a>

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<a name="prepare-pre-commit-configyaml"></a>

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

```yaml
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:

```yaml
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<a name="run-prekpre-commit"></a>

`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<a name="available-ids"></a>

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

There are ids for following tools:

- For Python linting/formatting
  - [ruff-lint-diff](https://docs.astral.sh/ruff/): Just show ruff check result.
  - [ruff-lint](https://docs.astral.sh/ruff/): Fix by ruff for lint.
  - [ruff-format-diff](https://docs.astral.sh/ruff/): Just show ruff format result.
  - [ruff-format](https://docs.astral.sh/ruff/): Format by ruff.
  - [black-diff](https://black.readthedocs.io/en/stable): Just show Black result.
  - [black](https://black.readthedocs.io/en/stable): Black: The uncompromising Python code formatter.
  - [blacken-docs](https://github.com/adamchainz/blacken-docs): Run `black` on python code blocks in documentation files.
  - [autoflake-diff](https://github.com/PyCQA/autoflake): Just show autoflake result.
  - [autoflake](https://github.com/PyCQA/autoflake): autoflake removes unused imports and unused variables from Python code.
  - [autopep8-diff](https://github.com/hhatto/autopep8): Just show autopep8.
  - [autopep8](https://github.com/hhatto/autopep8): autopep8 automatically formats Python code to conform to the PEP 8 style guide.
  - [isort-diff](https://github.com/PyCQA/isort): Just show isort result.
  - [isort](https://github.com/PyCQA/isort): isort your imports, so you don't have to.
  - [flake8](https://github.com/PyCQA/flake8): `flake8` is a command-line utility for enforcing style consistency across Python projects.
    - With following plugins:
      - [flake8-pyproject](https://github.com/csachs/pyproject-flake8)
      - [flake8-annotations-complexity](https://github.com/best-doctor/flake8-annotations-complexity)
      - [flake8-bugbear](https://github.com/PyCQA/flake8-bugbear)
      - [flake8-builtins](https://github.com/gforcada/flake8-builtins)
      - [flake8-comprehensions](https://github.com/adamchainz/flake8-comprehensions)
      - [flake8-debugger](https://github.com/jbkahn/flake8-debugger)
      - [flake8-docstrings](https://github.com/pycqa/flake8-docstrings)
      - [flake8-executable](https://github.com/xuhdev/flake8-executable)
      - [flake8-pep3101](https://github.com/gforcada/flake8-pep3101)
      - [flake8-print](https://github.com/jbkahn/flake8-print)
      - [flake8-rst-docstrings](https://github.com/peterjc/flake8-rst-docstrings)
      - [flake8-string-format](https://github.com/xZise/flake8-string-format)
      - [pep8-naming](https://github.com/PyCQA/pep8-naming)
      - [pycodestyle](https://pycodestyle.pycqa.org/en/latest/)
  - [bandit](https://github.com/PyCQA/bandit): Bandit is a tool for finding common security issues in Python code.
- For Python type checking
  - [ty](https://docs.astral.sh/ty/): An extremely fast Python type checker and language server, written in Rust.
  - [mypy](https://www.mypy-lang.org/): Mypy is a static type checker for Python.
- For Shell script
  - [shellcheck](https://www.shellcheck.net/): ShellCheck - A shell script static analysis tool
- For Markdown
  - mdformat-check: Just show mdformat result.
  - [mdformat](https://mdformat.readthedocs.io/en/stable/): CommonMark compliant Markdown formatter.
    - with following plugins:
      - [mdformat-gfm](https://github.com/hukkin/mdformat-gfm)
      - [mdformat-frontmatter](https://github.com/butler54/mdformat-frontmatter)
      - [mdformat-footnote](https://github.com/executablebooks/mdformat-footnote)
- For GitHub Actions
  - [actionlint](https://github.com/Mateusz-Grzelinski/actionlint-py): Lint GitHub workflows with actionlint.
- For pyproject.toml
  - [validate-pyproject](https://github.com/abravalheri/validate-pyproject): Validate pyproject.toml file.

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<a name="options-for-tools"></a>

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<a name="pyprojecttoml"></a>

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.
