Skip to main content

pyproject-flake8 (`pflake8`), a monkey patching wrapper to connect flake8 with pyproject.toml configuration

Project description

pyproject-flake8 (pflake8)

A monkey patching wrapper to connect flake8 with pyproject.toml configuration.

Update concerning versioning:

pyproject-flake8 so far came without explicit pinning of a flake8 version. Since a recent update broke compatibility – not unexpectedly – the issue arose, how to handle incompatible versions of flake8 and pyproject-flake8. Since there are good reasons for and against version pinning, this project now tries to follow a mix of both: Release versions will follow and pin identical flake8 versions, alpha versions (specific to pyproject-flake8) will pin to the similar non-alpha version of flake8, or later. That way, users of pyproject-flake8 can decide, whether they want a fixed version known to work, or a minimum version, getting later versions, at the risk of future breakage.

Versions 0.0.1x are pyproject-flake8 internal versions and do not correspond to flake8. Furthermore, flake8 3.8.0 was chosen as the first flake8 version to mirror this way.

tl;dr:

# e.g., suggested installation / dependency ... depending on flake8==5.0.4

# for Python 3.8+
pip install pyproject-flake8==5.0.4

# for Python 3.6+
pip install pyproject-flake8==5.0.4.post1

Rationale

flake8 is one of the most popular Python linters, pyproject.toml has become the standard for Python project metadata.

More and more tools are able to utilize a shared pyproject.toml, alleviating the need for many individual configuration files cluttering a project repository.

Since excellent flake8 is not aimed to support pyproject.toml, this wrapper script tries to fix the situation.

Installation

From github

pip install .

From PyPI

pip install pyproject-flake8

Building packages

Use your favorite PEP517 compliant builder, e.g.:

# install first via: pip install build
python -m build
# packages will reside in dist/

Usage

Call pflake8 instead of flake8.

Configuration goes into the tool.flake8 section of pyproject.toml:

[tool.flake8]
max-line-length = 88
extend-ignore = ["E203"]
max-complexity = 10

See also

Two other projects aim to address the same problem:

Both seem to try to do a lot more than just getting pyproject.toml support. pyproject-flake8 tries to stay minimal while solving its task.

flake8-pyproject adds only pyproject.toml support, and does this as a Flake8 plugin, allowing the original flake8 command to work (rather than using pflake8).

Caveat

This script monkey-patches flake8 and the configparser library of Python, therefore loading it as a module may have unforeseen consequences. Alpha quality. Use at your own risk. It will likely break if either Python or flake8 restructure their code significantly. No guarantees for stability between versions.

License

Unlicense

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_flake8-7.0.0.tar.gz (4.6 kB view details)

Uploaded Source

Built Distribution

pyproject_flake8-7.0.0-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

Details for the file pyproject_flake8-7.0.0.tar.gz.

File metadata

  • Download URL: pyproject_flake8-7.0.0.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for pyproject_flake8-7.0.0.tar.gz
Algorithm Hash digest
SHA256 5b953592336bc04d86e8942fdca1014256044a3445c8b6ca9467d08636749158
MD5 d937589caccf7d1d1981cfce0cda5de3
BLAKE2b-256 51c3619735aa5097b41e2af1a7e067e8859dea59689386b00c2efb7a8b7dc401

See more details on using hashes here.

File details

Details for the file pyproject_flake8-7.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pyproject_flake8-7.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 611e91b49916e6d0685f88423ad4baff490888278a258975403c0dee6eb6072e
MD5 b9d63224af2645785a5641b8faf1e68f
BLAKE2b-256 3a4934cb28f055739c442383cffe72f57d5eb924a9535ffc9c80edacff0f37f7

See more details on using hashes here.

Supported by

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