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
- dpctl
- frozenlist
- mkl_fft
- mkl-service
- NumPy
- 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.19.0
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-lintcomment (analogous to# noqainflake8);
as well as the following command-line arguments:
--max-line-lengthto control the maximum line length used by pycodestyle;--no-pycodestyleif you don't want the pycodestyle checks;--ban-relative-importsif you want to ban relative imports;--ignoreif you want to ignore some specific pycodestyle checks;--filesto pass a Regex pattern with which to match files to include;--excludeto pass a Regex pattern with which to match files to exclude.
Configuration can be set project-wide in a .cython-lint.toml or pyproject.toml file
at the root of the project. Here's an example:
[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
pycodestylenitpicks (which you can turn off with--no-pycodestyle)- repeated element in set
.strip,.rstrip, or.lstripused with repeated characters- unnecessary list index lookup
- unnecessary import alias
- variable defined but unused
- variable imported but unused
- unnecessary
list/set/dict+ generator (just use a comprehension)
In addition, the following automated fixers are implemented:
- double-quote-cython-strings (replace single quotes with double quotes, like the
blackformatter 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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cython_lint-0.19.0.tar.gz.
File metadata
- Download URL: cython_lint-0.19.0.tar.gz
- Upload date:
- Size: 27.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e4b8af1649b2bcfc40bbf430f33d71057850e0db9466a503fd743406afd572d3
|
|
| MD5 |
65001f877bdc5e4955cc50437d4863e7
|
|
| BLAKE2b-256 |
203c264c477ed35c289d1d62f7e5ffe59e9e59c7415baa7e98c815eab8a43647
|
Provenance
The following attestation bundles were made for cython_lint-0.19.0.tar.gz:
Publisher:
publish_to_pypi.yml on MarcoGorelli/cython-lint
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cython_lint-0.19.0.tar.gz -
Subject digest:
e4b8af1649b2bcfc40bbf430f33d71057850e0db9466a503fd743406afd572d3 - Sigstore transparency entry: 894250239
- Sigstore integration time:
-
Permalink:
MarcoGorelli/cython-lint@facb0499950f6ab1e292f2669d03339998a613d3 -
Branch / Tag:
refs/tags/v0.19.0 - Owner: https://github.com/MarcoGorelli
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish_to_pypi.yml@facb0499950f6ab1e292f2669d03339998a613d3 -
Trigger Event:
push
-
Statement type:
File details
Details for the file cython_lint-0.19.0-py3-none-any.whl.
File metadata
- Download URL: cython_lint-0.19.0-py3-none-any.whl
- Upload date:
- Size: 13.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
27cf99140da205eb57c234005e699b0bce9ca95311c3a0ebdd47bce314ea7e03
|
|
| MD5 |
1f1519bb195332452f8665d469bcc1f1
|
|
| BLAKE2b-256 |
ba18086dce47f4e19d987c44b7c16dd2ed3d0a57b11e9fee8287be4b2204b466
|
Provenance
The following attestation bundles were made for cython_lint-0.19.0-py3-none-any.whl:
Publisher:
publish_to_pypi.yml on MarcoGorelli/cython-lint
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cython_lint-0.19.0-py3-none-any.whl -
Subject digest:
27cf99140da205eb57c234005e699b0bce9ca95311c3a0ebdd47bce314ea7e03 - Sigstore transparency entry: 894250246
- Sigstore integration time:
-
Permalink:
MarcoGorelli/cython-lint@facb0499950f6ab1e292f2669d03339998a613d3 -
Branch / Tag:
refs/tags/v0.19.0 - Owner: https://github.com/MarcoGorelli
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish_to_pypi.yml@facb0499950f6ab1e292f2669d03339998a613d3 -
Trigger Event:
push
-
Statement type: