Skip to main content

Extract and filter pre-commit hooks.

Project description

status release ci release

Filter-Pre-Commit-Hooks

Small Python program that extracts and filters pre-commit hooks so that only a subset of them can be executed. Why is such a program helpful? Pre-commit only provides a way to skip hooks. There is no way to explicitly state which hooks should be run.

The program is available in this repository as the script filter_pre_commit_hooks.py and as the package filter-pre-commit-hooks on PyPI.

By default, the program returns all hooks that have the given tags. In the following example, all pre-commit hooks that are tagged with fix and task are executed (tagging is described further below):

SKIP=$(uv run -s filter_pre_commit_hooks.py fix task) pre-commit run -a

The program itself is executed with uv run, a subcommand of uv, which is a package manager for Python. This is because the script contains inline script metadata specifying required dependencies. The script also contains a shebang, so it can be executed directly.

Using the package from PyPI, the equivalent command looks like this:

SKIP=$(filter-pre-commit-hooks fix task) pre-commit run -a

Tags are extracted from the "alias" field of every hook. Tags are declared by putting them into parenthesis at the end of the respective alias. Individual tags are separated by commas. Here are two exemplary aliases:

forbid-new-submodules (check, task)
mixed-line-ending (fix, task)

Options can be passed to the script to change the behavior of the script. For example, to filter hooks by their identifier instead of their tags. For more information on this, try out the --help option of the script or read the source code.

A valid config used with the script can be found in .pre-commit-config.yaml. Some tasks in Justfile run selected pre-commit hooks using the script.

Project status

The project is maintained by me, Tim, and I am interested in keeping it alive as I am actively using it.

I'm also using the project to test out various tools and workflows.

Versioning

The project follows Semantic Versioning.

Contributing

Contributions are welcome. Please refer to CONTRIBUTE.md.

Licensing

This work is licensed under the ISC license. See LICENSE for the license text.

The license is also included in the script src/filter_pre_commit_hooks.py itself.

Template

This project is based on the following Copier template: https://github.com/trallnag/copier-template-python-script.

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

filter_pre_commit_hooks-2.0.4.tar.gz (29.9 kB view details)

Uploaded Source

Built Distribution

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

filter_pre_commit_hooks-2.0.4-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

Details for the file filter_pre_commit_hooks-2.0.4.tar.gz.

File metadata

  • Download URL: filter_pre_commit_hooks-2.0.4.tar.gz
  • Upload date:
  • Size: 29.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for filter_pre_commit_hooks-2.0.4.tar.gz
Algorithm Hash digest
SHA256 ae08105ac3532fe93e57f4694e44a1f12782d5e3bf7f74c776567088e4558a98
MD5 460fca5842b688ca6925bd8e69cec11a
BLAKE2b-256 19b52ce5fc753eb491ae318c6e9ba442159ed6a5368329ed82e644bd7ac7ea85

See more details on using hashes here.

Provenance

The following attestation bundles were made for filter_pre_commit_hooks-2.0.4.tar.gz:

Publisher: release.yaml on trallnag/filter-pre-commit-hooks

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file filter_pre_commit_hooks-2.0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for filter_pre_commit_hooks-2.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 40b3a11bad1f56e63fe4b1c5acd0e5e7a64955faf7ee2c4ca50c1a93db5d65ca
MD5 67c70421c6d5396669e5b53288754527
BLAKE2b-256 9ef1ae280ceba877a3bb424c56d5153b1426a0b3a4b38ad5e0336a774541ebbc

See more details on using hashes here.

Provenance

The following attestation bundles were made for filter_pre_commit_hooks-2.0.4-py3-none-any.whl:

Publisher: release.yaml on trallnag/filter-pre-commit-hooks

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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