The strictest and most opinionated python linter ever
Project description
wemake-python-styleguide
Welcome to the strictest and most opinionated python linter ever.
wemake-python-styleguide
is actually a flake8
plugin with some other plugins as dependencies.
Installation
pip install wemake-python-styleguide
You will also need to create a setup.cfg
file with the following contents.
This file is required to configure our linter and all 3rd party plugins it uses. However, this is a temporary solution. We are working at providing the required configuration for you in the future.
Running
flake8 your_module.py
This app is still just good old flake8
!
And it won't change your existing workflow.
See "Usage" section in the docs for examples and integrations.
What we are about
The ultimate goal of this project is
to make all people write exactly the same python
code.
black | pylint | flake8 | wemake-python-styleguide | |
---|---|---|---|---|
Formats code? | ✅ | ❌ | ❌ | ❌ |
Finds bugs? | ❌ | ✅ | 🤔 | ✅ |
Finds complex code? | ❌ | ✅ | 🤔 | ✅ |
Has a lot of strict rules? | ❌ | 🤔 | ❌ | ✅ |
Has a lot of plugins? | ❌ | ❌ | ✅ | ✅ |
We have several primary objectives:
- Enforce
python3.6+
usage - Significantly reduce complexity of your code and make it more maintainable
- Enforce "There should be one -- and preferably only one -- obvious way to do it" rule to coding and naming styles
- Protect developers from possible errors and enforce best practices
You can find all error codes and plugins in the docs.
What we are not
We are not planning to do the following things:
- Assume or check types, use
mypy
instead - Reformat code, since we believe that developers should do that
- Check for
SyntaxError
or logical bugs, write tests instead - Appeal to everyone. But, you can switch off any rules that you don't like
Supporting us
We in wemake.services make all our tools open-source by default, so the community can benefit from them. If you use our tools and they make your life easier and brings business value, you can return us a favor by supporting the work we do.
Show your style
If you use our linter - it means that your code is awesome.
You can be proud of it!
And you should share your accomplishment with others
by including a badge to your README
file. It looks like this:
Markdown
[![wemake-python-styleguide](https://img.shields.io/badge/style-wemake-000000.svg)](https://github.com/wemake-services/wemake-python-styleguide)
Restructured text
.. image:: https://img.shields.io/badge/style-wemake-000000.svg
:target: https://github.com/wemake-services/wemake-python-styleguide
Contributing
We warmly welcome all contributions!
See "Contributing" section in the documentation if you want to contribute.
You can start with issues that need some help right now.
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 wemake-python-styleguide-0.11.0.tar.gz
.
File metadata
- Download URL: wemake-python-styleguide-0.11.0.tar.gz
- Upload date:
- Size: 88.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/0.12.11 CPython/3.7.3 Darwin/18.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 52b00dec760d2a333b1a753cfb66ac2c206ee8c769235e294a79cc76c07ce4c2 |
|
MD5 | 3b4123768ba0f0e1aee586616dc60e3e |
|
BLAKE2b-256 | 21d35ac43cf58ad3ef93bc4f4b568824fc429aec192ce92b3c896de784a5d357 |
File details
Details for the file wemake_python_styleguide-0.11.0-py3-none-any.whl
.
File metadata
- Download URL: wemake_python_styleguide-0.11.0-py3-none-any.whl
- Upload date:
- Size: 372.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/0.12.11 CPython/3.7.3 Darwin/18.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 031aed4be5e8cd9fb826f61bc4a741928ef8fda01c8d874789ab9b5e1f341e94 |
|
MD5 | 041c6181994df400b46f80bb5317f585 |
|
BLAKE2b-256 | 6f2142775e967cef1602bb459e8ad12cb549d6ca9373e3b3d1948589306cde1f |