ruff 0.0.52
pip install ruff==0.0.52
Released:
An extremely fast Python linter, written in Rust.
Navigation
Unverified details
These details have not been verified by PyPIProject links
Meta
- License: MIT License
- Tags automation, flake8, pycodestyle, pyflakes, pylint, clippy
- Requires: Python >=3.7
Classifiers
- Development Status
- Environment
- Intended Audience
- License
- Operating System
- Programming Language
- Topic
Project description
ruff
An extremely fast Python linter, written in Rust.
Linting the CPython codebase from scratch.
- ⚡️ 10-100x faster than existing linters
- 🐍 Installable via
pip
- 🤝 Python 3.10 compatibility
- 🛠️
pyproject.toml
support - 📦 ESLint-inspired cache support
- 🔧 ESLint-inspired
--fix
support - 👀 TypeScript-inspired
--watch
support - ⚖️ Near-complete parity with the built-in Flake8 rule set
Read the launch blog post.
Installation and usage
Installation
Available as ruff on PyPI:
pip install ruff
Usage
To run ruff, try any of the following:
ruff path/to/code/to/check.py
ruff path/to/code/
ruff path/to/code/*.py
You can run ruff in --watch
mode to automatically re-run on-change:
ruff path/to/code/ --watch
ruff also works with pre-commit:
repos:
- repo: https://github.com/charliermarsh/ruff-pre-commit
rev: v0.0.48
hooks:
- id: lint
Configuration
ruff is configurable both via pyproject.toml
and the command line.
For example, you could configure ruff to only enforce a subset of rules with:
[tool.ruff]
line-length = 88
select = [
"F401",
"F403",
]
Alternatively, on the command-line:
ruff path/to/code/ --select F401 --select F403
See ruff --help
for more:
ruff: An extremely fast Python linter.
Usage: ruff [OPTIONS] <FILES>...
Arguments:
<FILES>...
Options:
-v, --verbose
Enable verbose logging
-q, --quiet
Disable all logging (but still exit with status code "1" upon detecting errors)
-e, --exit-zero
Exit with status code "0", even upon detecting errors
-w, --watch
Run in watch mode by re-running whenever files change
-f, --fix
Attempt to automatically fix lint errors
-n, --no-cache
Disable cache reads
--select <SELECT>
List of error codes to enable
--extend-select <EXTEND_SELECT>
Like --select, but adds additional error codes on top of the selected ones
--ignore <IGNORE>
List of error codes to ignore
--extend-ignore <EXTEND_IGNORE>
Like --ignore, but adds additional error codes on top of the ignored ones
--exclude <EXCLUDE>
List of paths, used to exclude files and/or directories from checks
--extend-exclude <EXTEND_EXCLUDE>
Like --exclude, but adds additional files and directories on top of the excluded ones
--per-file-ignores <PER_FILE_IGNORES>
List of mappings from file pattern to code to exclude
--format <FORMAT>
Output serialization format for error messages [default: text] [possible values: text, json]
--show-files
See the files ruff will be run against with the current settings
--show-settings
See ruff's settings
--add-noqa
Enable automatic additions of noqa directives to failing lines
--dummy-variable-rgx <DUMMY_VARIABLE_RGX>
Regular expression matching the name of dummy variables
-h, --help
Print help information
-V, --version
Print version information
Excluding files
Exclusions are based on globs, and can be either:
- Single-path patterns, like
.mypy_cache
(to exclude any directory named.mypy_cache
in the tree),foo.py
(to exclude any file namedfoo.py
), orfoo_*.py
(to exclude any file matchingfoo_*.py
). - Relative patterns, like
directory/foo.py
(to exclude that specific file) ordirectory/*.py
(to exclude any Python files indirectory
). Note that these paths are relative to the project root (e.g., the directory containing yourpyproject.toml
).
Ignoring errors
To omit a lint check entirely, add it to the "ignore" list via --ignore
or --extend-ignore
,
either on the command-line or in your project.toml
file.
To ignore an error in-line, ruff uses a noqa
system similar to Flake8.
To ignore an individual error, add # noqa: {code}
to the end of the line, like so:
# Ignore F841.
x = 1 # noqa: F841
# Ignore E741 and F841.
i = 1 # noqa: E741, F841
# Ignore _all_ errors.
x = 1 # noqa
Note that, for multi-line strings, the noqa
directive should come at the end of the string, and
will apply to the entire body, like so:
"""Lorem ipsum dolor sit amet.
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
""" # noqa: E501
ruff supports several (experimental) workflows to aid in noqa
management.
First, ruff provides a special error code, M001
, to enforce that your noqa
directives are
"valid", in that the errors they say they ignore are actually being triggered on that line (and
thus suppressed). You can run ruff /path/to/file.py --extend-select M001
to flag unused noqa
directives.
Second, ruff can automatically remove unused noqa
directives via its autofix functionality.
You can run ruff /path/to/file.py --extend-select M001 --fix
to automatically remove unused
noqa
directives.
Third, ruff can automatically add noqa
directives to all failing lines. This is useful when
migrating a new codebase to ruff. You can run ruff /path/to/file.py --add-noqa
to automatically
add noqa
directives to all failing lines, with the appropriate error codes.
Compatibility with Black
ruff is compatible with Black out-of-the-box, as long as
the line-length
setting is consistent between the two.
As a project, ruff is designed to be used alongside Black and, as such, will defer implementing stylistic lint rules that are obviated by autoformatting.
Parity with Flake8
ruff's goal is to achieve feature-parity with Flake8 when used (1) without plugins, (2) alongside Black, and (3) on Python 3 code.
Under those conditions, ruff implements 44 out of 60 rules. (ruff is missing: 14 rules related
to string .format
calls, 1 rule related to docstring parsing, and 1 rule related to redefined
variables.)
Beyond rule-set parity, ruff suffers from the following limitations vis-à-vis Flake8:
- Flake8 has a plugin architecture and supports writing custom lint rules.
- ruff does not yet support a few Python 3.9 and 3.10 language features, including structural pattern matching and parenthesized context managers.
Rules
Code | Name | Message |
---|---|---|
E402 | ModuleImportNotAtTopOfFile | Module level import not at top of file |
E501 | LineTooLong | Line too long (89 > 88 characters) |
E711 | NoneComparison | Comparison to None should be cond is None |
E712 | TrueFalseComparison | Comparison to True should be cond is True |
E713 | NotInTest | Test for membership should be not in |
E714 | NotIsTest | Test for object identity should be is not |
E721 | TypeComparison | do not compare types, use isinstance() |
E722 | DoNotUseBareExcept | Do not use bare except |
E731 | DoNotAssignLambda | Do not assign a lambda expression, use a def |
E741 | AmbiguousVariableName | ambiguous variable name '...' |
E742 | AmbiguousClassName | ambiguous class name '...' |
E743 | AmbiguousFunctionName | ambiguous function name '...' |
E902 | IOError | ... |
E999 | SyntaxError | SyntaxError: ... |
F401 | UnusedImport | ... imported but unused |
F402 | ImportShadowedByLoopVar | import '...' from line 1 shadowed by loop variable |
F403 | ImportStarUsed | from ... import * used; unable to detect undefined names |
F404 | LateFutureImport | from future imports must occur at the beginning of the file |
F405 | ImportStarUsage | '...' may be undefined, or defined from star imports: ... |
F406 | ImportStarNotPermitted | from ... import * only allowed at module level |
F407 | FutureFeatureNotDefined | future feature '...' is not defined |
F541 | FStringMissingPlaceholders | f-string without any placeholders |
F601 | MultiValueRepeatedKeyLiteral | Dictionary key literal repeated |
F602 | MultiValueRepeatedKeyVariable | Dictionary key ... repeated |
F621 | TooManyExpressionsInStarredAssignment | too many expressions in star-unpacking assignment |
F622 | TwoStarredExpressions | two starred expressions in assignment |
F631 | AssertTuple | Assert test is a non-empty tuple, which is always True |
F632 | IsLiteral | use ==/!= to compare constant literals |
F633 | InvalidPrintSyntax | use of >> is invalid with print function |
F634 | IfTuple | If test is a tuple, which is always True |
F701 | BreakOutsideLoop | break outside loop |
F702 | ContinueOutsideLoop | continue not properly in loop |
F704 | YieldOutsideFunction | a yield or yield from statement outside of a function/method |
F706 | ReturnOutsideFunction | a return statement outside of a function/method |
F707 | DefaultExceptNotLast | an except: block as not the last exception handler |
F722 | ForwardAnnotationSyntaxError | syntax error in forward annotation '...' |
F821 | UndefinedName | Undefined name ... |
F822 | UndefinedExport | Undefined name ... in __all__ |
F823 | UndefinedLocal | Local variable ... referenced before assignment |
F831 | DuplicateArgumentName | Duplicate argument name in function definition |
F841 | UnusedVariable | Local variable ... is assigned to but never used |
F901 | RaiseNotImplemented | raise NotImplemented should be raise NotImplementedError |
A001 | BuiltinVariableShadowing | Variable ... is shadowing a python builtin |
A002 | BuiltinArgumentShadowing | Argument ... is shadowing a python builtin |
A003 | BuiltinAttributeShadowing | class attribute ... is shadowing a python builtin |
SPR001 | SuperCallWithParameters | Use super() instead of super(__class__, self) |
R001 | UselessObjectInheritance | Class ... inherits from object |
R002 | NoAssertEquals | assertEquals is deprecated, use assertEqual instead |
M001 | UnusedNOQA | Unused noqa directive |
Integrations
PyCharm
ruff can be installed as an External Tool in PyCharm. Open the Preferences pane, then navigate to "Tools", then "External Tools". From there, add a new tool with the following configuration:
ruff should then appear as a runnable action:
GitHub Actions
GitHub Actions has everything you need to run ruff out-of-the-box:
name: CI
on: push
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Install Python
uses: actions/setup-python@v2
with:
python-version: "3.10"
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install ruff
- name: Run ruff
run: ruff .
Development
ruff is written in Rust (1.63.0). You'll need to install the Rust toolchain for development.
Assuming you have cargo
installed, you can run:
cargo run resources/test/fixtures
cargo fmt
cargo clippy
cargo test
Deployment
ruff is distributed on PyPI, and published via maturin
.
See: .github/workflows/release.yaml
.
Benchmarking
First, clone CPython. It's a large and diverse Python codebase, which makes it a good target for benchmarking.
git clone --branch 3.10 https://github.com/python/cpython.git resources/test/cpython
Add this pyproject.toml
to the CPython directory:
[tool.ruff]
line-length = 88
extend-exclude = [
"Lib/lib2to3/tests/data/bom.py",
"Lib/lib2to3/tests/data/crlf.py",
"Lib/lib2to3/tests/data/different_encoding.py",
"Lib/lib2to3/tests/data/false_encoding.py",
"Lib/lib2to3/tests/data/py2_test_grammar.py",
"Lib/test/bad_coding2.py",
"Lib/test/badsyntax_3131.py",
"Lib/test/badsyntax_pep3120.py",
"Lib/test/encoded_modules/module_iso_8859_1.py",
"Lib/test/encoded_modules/module_koi8_r.py",
"Lib/test/test_fstring.py",
"Lib/test/test_grammar.py",
"Lib/test/test_importlib/test_util.py",
"Lib/test/test_named_expressions.py",
"Lib/test/test_patma.py",
"Lib/test/test_source_encoding.py",
"Tools/c-analyzer/c_parser/parser/_delim.py",
"Tools/i18n/pygettext.py",
"Tools/test2to3/maintest.py",
"Tools/test2to3/setup.py",
"Tools/test2to3/test/test_foo.py",
"Tools/test2to3/test2to3/hello.py",
]
Next, to benchmark the release build:
cargo build --release
hyperfine --ignore-failure --warmup 10 --runs 100 \
"./target/release/ruff ./resources/test/cpython/ --no-cache" \
"./target/release/ruff ./resources/test/cpython/"
Benchmark 1: ./target/release/ruff ./resources/test/cpython/ --no-cache
Time (mean ± σ): 297.4 ms ± 4.9 ms [User: 2460.0 ms, System: 67.2 ms]
Range (min … max): 287.7 ms … 312.1 ms 100 runs
Warning: Ignoring non-zero exit code.
Benchmark 2: ./target/release/ruff ./resources/test/cpython/
Time (mean ± σ): 79.6 ms ± 7.3 ms [User: 59.7 ms, System: 356.1 ms]
Range (min … max): 62.4 ms … 111.2 ms 100 runs
Warning: Ignoring non-zero exit code.
To benchmark against the ecosystem's existing tools:
hyperfine --ignore-failure --warmup 5 \
"./target/release/ruff ./resources/test/cpython/ --no-cache" \
"pylint --recursive=y resources/test/cpython/" \
"pyflakes resources/test/cpython" \
"autoflake --recursive --expand-star-imports --remove-all-unused-imports --remove-unused-variables --remove-duplicate-keys resources/test/cpython" \
"pycodestyle resources/test/cpython" \
"flake8 resources/test/cpython" \
"python -m scripts.run_flake8 resources/test/cpython"
In order, these evaluate:
- ruff
- Pylint
- PyFlakes
- autoflake
- pycodestyle
- Flake8
- Flake8, with a hack to enable multiprocessing on macOS
(You can poetry install
from ./scripts
to create a working environment for the above.)
Benchmark 1: ./target/release/ruff ./resources/test/cpython/ --no-cache
Time (mean ± σ): 297.9 ms ± 7.0 ms [User: 2436.6 ms, System: 65.9 ms]
Range (min … max): 289.9 ms … 314.6 ms 10 runs
Warning: Ignoring non-zero exit code.
Benchmark 2: pylint --recursive=y resources/test/cpython/
Time (mean ± σ): 37.634 s ± 0.225 s [User: 36.728 s, System: 0.853 s]
Range (min … max): 37.201 s … 38.106 s 10 runs
Warning: Ignoring non-zero exit code.
Benchmark 3: pyflakes resources/test/cpython
Time (mean ± σ): 40.950 s ± 0.449 s [User: 40.688 s, System: 0.229 s]
Range (min … max): 40.348 s … 41.671 s 10 runs
Warning: Ignoring non-zero exit code.
Benchmark 4: autoflake --recursive --expand-star-imports --remove-all-unused-imports --remove-unused-variables --remove-duplicate-keys resources/test/cpython
Time (mean ± σ): 11.562 s ± 0.160 s [User: 107.022 s, System: 1.143 s]
Range (min … max): 11.417 s … 11.917 s 10 runs
Benchmark 5: pycodestyle resources/test/cpython
Time (mean ± σ): 67.428 s ± 0.985 s [User: 67.199 s, System: 0.203 s]
Range (min … max): 65.313 s … 68.496 s 10 runs
Warning: Ignoring non-zero exit code.
Benchmark 6: flake8 resources/test/cpython
Time (mean ± σ): 116.099 s ± 1.178 s [User: 115.217 s, System: 0.845 s]
Range (min … max): 114.180 s … 117.724 s 10 runs
Warning: Ignoring non-zero exit code.
Benchmark 7: python -m scripts.run_flake8 resources/test/cpython
Time (mean ± σ): 20.477 s ± 0.349 s [User: 142.372 s, System: 1.504 s]
Range (min … max): 20.107 s … 21.183 s 10 runs
Summary
'./target/release/ruff ./resources/test/cpython/ --no-cache' ran
38.81 ± 1.05 times faster than 'autoflake --recursive --expand-star-imports --remove-all-unused-imports --remove-unused-variables --remove-duplicate-keys resources/test/cpython'
68.74 ± 1.99 times faster than 'python -m scripts.run_flake8 resources/test/cpython'
126.33 ± 3.05 times faster than 'pylint --recursive=y resources/test/cpython/'
137.46 ± 3.55 times faster than 'pyflakes resources/test/cpython'
226.35 ± 6.23 times faster than 'pycodestyle resources/test/cpython'
389.73 ± 9.92 times faster than 'flake8 resources/test/cpython'
License
MIT
Contributing
Contributions are welcome and hugely appreciated. To get started, check out the contributing guidelines.
Project details
Unverified details
These details have not been verified by PyPIProject links
Meta
- License: MIT License
- Tags automation, flake8, pycodestyle, pyflakes, pylint, clippy
- Requires: Python >=3.7
Classifiers
- Development Status
- Environment
- Intended Audience
- License
- Operating System
- Programming Language
- Topic
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 Distributions
Uploaded
Python 3
musllinux: musl 1.2+ x86-64
Uploaded
Python 3
musllinux: musl 1.2+ i686
Uploaded
Python 3
musllinux: musl 1.2+ ARMv7l
Uploaded
Python 3
musllinux: musl 1.2+ ARM64
Uploaded
Python 3
manylinux: glibc 2.17+ x86-64
Uploaded
Python 3
manylinux: glibc 2.17+ s390x
Uploaded
Python 3
manylinux: glibc 2.17+ ppc64le
Uploaded
Python 3
manylinux: glibc 2.17+ ppc64
Uploaded
Python 3
manylinux: glibc 2.17+ i686
Uploaded
Python 3
manylinux: glibc 2.17+ ARMv7l
Uploaded
Python 3
manylinux: glibc 2.17+ ARM64
Uploaded
Python 3
macOS 10.9+ universal2 (ARM64, x86-64)
macOS 10.9+ x86-64
macOS 11.0+ ARM64
Uploaded
Python 3
macOS 10.7+ x86-64
File details
Details for the file ruff-0.0.52.tar.gz
.
File metadata
- Download URL: ruff-0.0.52.tar.gz
- Upload date:
- Size: 128.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9837889c2dae4f8925b381155b27ad83cc2480a5f930efdb49decb7d0efce478 |
|
MD5 | b997f8691863ff835d214328fef180eb |
|
BLAKE2b-256 | 153026b39bac17ac7105217879ab7438a1ed8a0a5abebcdc6a8968225d541f65 |
File details
Details for the file ruff-0.0.52-py3-none-win_amd64.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-win_amd64.whl
- Upload date:
- Size: 2.9 MB
- Tags: Python 3, Windows x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1ed90bea36b9f9643a0252685cdecdb45ffc4dae1d03d640a4ea6cef70353783 |
|
MD5 | 299626480f843c21201181bd36e97d79 |
|
BLAKE2b-256 | e82a293f78e6c606804a1999baa5bafe05be55b61831bad61a4aa4fd0fcb6daf |
File details
Details for the file ruff-0.0.52-py3-none-win32.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-win32.whl
- Upload date:
- Size: 2.8 MB
- Tags: Python 3, Windows x86
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0a206b923425d04730099db9bf4bb395d97c9ce4156fdcce64fda196f53bdce9 |
|
MD5 | 6feb3a8974b0328f6ca808ff00cda2d9 |
|
BLAKE2b-256 | ad47a92f96ff4a0bc0225a7b4fe5212fae632508704df788439bf29541903cfd |
File details
Details for the file ruff-0.0.52-py3-none-musllinux_1_2_x86_64.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-musllinux_1_2_x86_64.whl
- Upload date:
- Size: 3.1 MB
- Tags: Python 3, musllinux: musl 1.2+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 45c35577b4628c343155c3002728aff6034a1b1ad6a376a48678b7988c0b7b36 |
|
MD5 | eb34aef26b697ebafb9c5c5aca1f2fdb |
|
BLAKE2b-256 | 4753fd0d40e8be6d79064147d768db00d3bf603470495eb7936240a005cf7c4b |
File details
Details for the file ruff-0.0.52-py3-none-musllinux_1_2_i686.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-musllinux_1_2_i686.whl
- Upload date:
- Size: 3.1 MB
- Tags: Python 3, musllinux: musl 1.2+ i686
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4a7b75f965210c77fea3e76aa6c184582c843132bf429e17eb8e963181ec7e0c |
|
MD5 | a89eb6d14ff43ecfc6e4d153adf60f63 |
|
BLAKE2b-256 | 5a23a5b4115414677a1dfe4699726d395a65219f4ff19d8f7b65e6668c9c034c |
File details
Details for the file ruff-0.0.52-py3-none-musllinux_1_2_armv7l.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-musllinux_1_2_armv7l.whl
- Upload date:
- Size: 2.8 MB
- Tags: Python 3, musllinux: musl 1.2+ ARMv7l
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | dfcc687bb8750a76a950dd9485a6bdc43ccc1b0cc9e60fe1c0199dc9ffc9975a |
|
MD5 | 04bf95b82120f0827cd41826136bc490 |
|
BLAKE2b-256 | b7d99da94cd1d290e465a0eca50f305a41372a3a12d535c481f15f70de0f90a8 |
File details
Details for the file ruff-0.0.52-py3-none-musllinux_1_2_aarch64.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-musllinux_1_2_aarch64.whl
- Upload date:
- Size: 2.9 MB
- Tags: Python 3, musllinux: musl 1.2+ ARM64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7259931f1e8fe60a77b84fedb6755a44d4b96e4ae0f0db8b00937c12016e7a45 |
|
MD5 | 712bdb6ee6815905ed815a2b444b4f97 |
|
BLAKE2b-256 | 031d049f6a2c096b2c4e6376214f1703a5d3def48586275720f89efaed84fd75 |
File details
Details for the file ruff-0.0.52-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 3.1 MB
- Tags: Python 3, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 76b9ad5f23eb2c8dacbb3260e739f78e0e91d4e163ea7325661154e849bf11e9 |
|
MD5 | 887472d104cf4ef4147455e3a97abcee |
|
BLAKE2b-256 | 6449e5d299b4943b81ebaf6c396ce3d6413c9da49ed7de4f00965b974963e639 |
File details
Details for the file ruff-0.0.52-py3-none-manylinux_2_17_s390x.manylinux2014_s390x.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-manylinux_2_17_s390x.manylinux2014_s390x.whl
- Upload date:
- Size: 2.7 MB
- Tags: Python 3, manylinux: glibc 2.17+ s390x
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1a5fb22e6617c6b9b445cc02303a94a33f0d3dc1e2cd6dec1d8393151ce4ec3a |
|
MD5 | 4cc7f6112bc59dcff3ad0c329827f183 |
|
BLAKE2b-256 | 4e9402ec8c7a7d2d7eabb2fb11f4ee875503c749106fe6a3a0d530529cda88b4 |
File details
Details for the file ruff-0.0.52-py3-none-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl
- Upload date:
- Size: 2.5 MB
- Tags: Python 3, manylinux: glibc 2.17+ ppc64le
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c17336605b837ed20860653a8f962e148804c2089bfe1d1d641f878331fbf82b |
|
MD5 | 4cb67360814936ce71c2f1cf84d720dc |
|
BLAKE2b-256 | 41b34d46e1a0376ddd67edee95cd73465eda91b0bd78672e2d0038abb4877e74 |
File details
Details for the file ruff-0.0.52-py3-none-manylinux_2_17_ppc64.manylinux2014_ppc64.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-manylinux_2_17_ppc64.manylinux2014_ppc64.whl
- Upload date:
- Size: 2.5 MB
- Tags: Python 3, manylinux: glibc 2.17+ ppc64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0aa1fee2eafd9cc7d4ee3230d016087928c32d1708aba2ed6636b259b94410ad |
|
MD5 | 37b817970b27b36beb448f9c08f71da8 |
|
BLAKE2b-256 | 049ff695a19aae604b6d413e8ea5699c3a2f836252cc384563b25af7e9493004 |
File details
Details for the file ruff-0.0.52-py3-none-manylinux_2_17_i686.manylinux2014_i686.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-manylinux_2_17_i686.manylinux2014_i686.whl
- Upload date:
- Size: 3.2 MB
- Tags: Python 3, manylinux: glibc 2.17+ i686
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7b3d7dc1b8509a7ebb9d032b59fd4b1c6e28cfe749b37ddb385191d1a9dbff66 |
|
MD5 | c25c62f83d0ec4d9e3bf522bed96e059 |
|
BLAKE2b-256 | 8a55d816c56d18c0f84f1442591000f39f31ee6a9362c6cc1bf989b89a4793e9 |
File details
Details for the file ruff-0.0.52-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.whl
- Upload date:
- Size: 2.2 MB
- Tags: Python 3, manylinux: glibc 2.17+ ARMv7l
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f30fedf6eb2aa4395e11a9e1a51a7e87d055a643898b24a0963eec85cc2d376c |
|
MD5 | 67da5a503f26abedce9e1ec193379a44 |
|
BLAKE2b-256 | 2984bd97da42ef06db098f6627ec6fda48b8610a7a770abfd841fbe54b57ad4a |
File details
Details for the file ruff-0.0.52-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
- Upload date:
- Size: 2.9 MB
- Tags: Python 3, manylinux: glibc 2.17+ ARM64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1c904432b38721c415b86965cc56586f8e14a4993ed537d4f0bb0db555fecf7d |
|
MD5 | 5a7298dd46e7c861e5908d1c3735cbaf |
|
BLAKE2b-256 | 3341964b25cb0d076ac25084346ac05cf6ce531814a9664011e867ed78083308 |
File details
Details for the file ruff-0.0.52-py3-none-macosx_10_9_x86_64.macosx_11_0_arm64.macosx_10_9_universal2.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-macosx_10_9_x86_64.macosx_11_0_arm64.macosx_10_9_universal2.whl
- Upload date:
- Size: 5.9 MB
- Tags: Python 3, macOS 10.9+ universal2 (ARM64, x86-64), macOS 10.9+ x86-64, macOS 11.0+ ARM64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6c4d7d2f84337b9934617da59f237821ac1c3eaf43c5e051e32314182dcdc1b2 |
|
MD5 | 58213e82eb242adebe1829c2c0fba668 |
|
BLAKE2b-256 | aad3761121feb12ac46a0122f8d8211fbf7f9c1c75d3eb5beb77da1486179fed |
File details
Details for the file ruff-0.0.52-py3-none-macosx_10_7_x86_64.whl
.
File metadata
- Download URL: ruff-0.0.52-py3-none-macosx_10_7_x86_64.whl
- Upload date:
- Size: 3.0 MB
- Tags: Python 3, macOS 10.7+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 43eb5db7b45b02175653bf436db7c9db38e78cdc71c4b6ccac847c01b689be1e |
|
MD5 | 4d58a51e2e1e5bf0aef452be236717bb |
|
BLAKE2b-256 | dca07ea03ea011bb3172a595591f1b66385353efe05bfdb58614ebd17ece2965 |