Lint Cython files
Project description
cython-lint
Everything flake8
used to do (by accident), plus much more.
A tool and pre-commit hook to lint Cython files.
Used by
Here's some major projects using cython-lint
- is yours missing? Feel free to open a pull request!
- arrow-adbc
- ansible-pylibssh
- arrow
- CuPy
- frozenlist
- open library
- pandas
- pymatgen
- PyRFC
- RAPIDS cuspatial
- RAPIDS cudf
- RAPIDS Memory Manager
- sagemath/sage
- scikit-image
- scikit-learn
- scipy
- spaCy
- yarl
- yt
Installation
$ pip install cython-lint
Usage as a pre-commit hook
See pre-commit for instructions
Sample .pre-commit-config.yaml
:
- repo: https://github.com/MarcoGorelli/cython-lint
rev: v0.16.6
hooks:
- id: cython-lint
- id: double-quote-cython-strings
Command-line example
$ cython-lint my_file_1.pyx my_file_2.pyx
my_file_1.pyx:54:5: 'get_conversion_factor' imported but unused
my_file_2.pyx:1112:38: 'mod' defined but unused (try prefixing with underscore?)
my_file_3.pyx:4:9: dangerous default value!
my_file_3.pyx:5:9: comma after base type in definition
Configuration
The following configuration options are available:
- exclude lines by including a
# no-cython-lint
comment (analogous to# noqa
inflake8
);
as well as the following command-line arguments:
--max-line-length
to control the maximum line length used by pycodestyle;--no-pycodestyle
if you don't want the pycodestyle checks;--ignore
if you want to ignore some specific pycodestyle checks;--files
to pass a Regex pattern with which to match files to include;--exclude
to pass a Regex pattern with which to match files to exclude.
Configuration can be set project-wise in a pyproject.toml
file at the root of the project.
Here's an example pyproject.toml
:
[tool.cython-lint]
max-line-length = 88
ignore = ['E503', 'E504']
exclude = 'my_project/excluded_cython_file.pyx'
Which checks are implemented?
- assert statement with tuple condition (always true...)
- comma after base type definition (e.g.
cdef ndarray, arr
) - comparison between constants
- dangerous default value
- dict key repeated
- dict key variable repeated
- f-string without placeholders
- if-statement with tuple condition (always true...)
- late-binding closures https://docs.python-guide.org/writing/gotchas/#late-binding-closures
- pointless string statement
pycodestyle
nitpicks (which you can turn off with--no-pycodestyle
)- repeated element in set
.strip
,.rstrip
, or.lstrip
used with repeated characters- unnecessary list index lookup
- unnecessary import alias
- variable defined but unused
- variable imported but unused
In addition, the following automated fixers are implemented:
- double-quote-cython-strings (replace single quotes with double quotes, like the
black
formatter does)
More to come! Requests welcome!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file cython_lint-0.16.6.tar.gz
.
File metadata
- Download URL: cython_lint-0.16.6.tar.gz
- Upload date:
- Size: 26.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 829046988d3986443c47183e7ea567a6893d78dfb135144670ffff67d58deb9e |
|
MD5 | 65e658e22555701a6f02d22e4e413707 |
|
BLAKE2b-256 | 03e7a1e6ca82be6a72542f9aa142619dcdd68ed9a000bab4731c61af3a47a81c |
Provenance
The following attestation bundles were made for cython_lint-0.16.6.tar.gz
:
- Repository: MarcoGorelli/cython-lint
- Workflow: publish_to_pypi.yml
-
Statement type: https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
cython_lint-0.16.6.tar.gz
- Subject digest:
829046988d3986443c47183e7ea567a6893d78dfb135144670ffff67d58deb9e
- Transparency log index: 147940832
- Transparency log integration time:
- Predicate type:
File details
Details for the file cython_lint-0.16.6-py3-none-any.whl
.
File metadata
- Download URL: cython_lint-0.16.6-py3-none-any.whl
- Upload date:
- Size: 12.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5057fdbb0ebe41912431293a3d33d1e547c9f2242c5a1426525a14b2b4a869a4 |
|
MD5 | e8691a752847f7e3496b93f01e5c4e3e |
|
BLAKE2b-256 | 03fa1816c44ecc6f1d32dd03857fd9bd2073d471233131857f989781c47f52ed |
Provenance
The following attestation bundles were made for cython_lint-0.16.6-py3-none-any.whl
:
- Repository: MarcoGorelli/cython-lint
- Workflow: publish_to_pypi.yml
-
Statement type: https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
cython_lint-0.16.6-py3-none-any.whl
- Subject digest:
5057fdbb0ebe41912431293a3d33d1e547c9f2242c5a1426525a14b2b4a869a4
- Transparency log index: 147940833
- Transparency log integration time:
- Predicate type: