Skip to main content

The strictest and most opinionated python linter ever

Project description

wemake-python-styleguide

wemake.services Build Status Build status Coverage Python Version Documentation Status Dependencies Status


Welcome to the strictest and most opinionated python linter ever.

wemake-python-styleguide is actually a flake8 plugin with some other plugins as dependencies.

The Zen of Python, by Tim Peters

Beautiful is better than ugly.
Explicit is better than implicit.
Simple is better than complex.
Complex is better than complicated.
Flat is better than nested.
Sparse is better than dense.
Readability counts.
Special cases aren't special enough to break the rules.
Although practicality beats purity.
Errors should never pass silently.
Unless explicitly silenced.
In the face of ambiguity, refuse the temptation to guess.
There should be one-- and preferably only one --obvious way to do it.
Although that way may not be obvious at first unless you're Dutch.
Now is better than never.
Although never is often better than *right* now.
If the implementation is hard to explain, it's a bad idea.
If the implementation is easy to explain, it may be a good idea.
Namespaces are one honking great idea -- let's do more of those!

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.

See "Usage" section in the docs for examples and integrations.

What we are about

We have several primary objectives:

  1. Enforce python3.6+ usage
  2. Significantly reduce complexity of your code and make it more maintainable
  3. Enforce "There should be one-- and preferably only one --obvious way to do it" rule
  4. Create consistent coding and naming style

You can find all error codes and plugins in the docs.

What we are not

We are not planning to do the following things:

  1. Assume or check types, use mypy instead
  2. Reformat code, since we believe that developers should do that
  3. Check for SyntaxError or exceptions, write tests instead
  4. Appeal to everyone, this is our linter. But, you can switch off any rules that you don't like

Contributing

We warmly welcome any contributions!

See "Contributing" section in the documentation if you want to contribute.

You can also check which issues need some help right now.

License

MIT. See LICENSE for more details.

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

wemake-python-styleguide-0.5.1.tar.gz (50.5 kB view details)

Uploaded Source

Built Distribution

wemake_python_styleguide-0.5.1-py3-none-any.whl (200.3 kB view details)

Uploaded Python 3

File details

Details for the file wemake-python-styleguide-0.5.1.tar.gz.

File metadata

  • Download URL: wemake-python-styleguide-0.5.1.tar.gz
  • Upload date:
  • Size: 50.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/0.12.3 CPython/3.6.6 Darwin/18.2.0

File hashes

Hashes for wemake-python-styleguide-0.5.1.tar.gz
Algorithm Hash digest
SHA256 d3129aefad90b09d696e7696301a77f40d97f6f81b876b91184482e3ed42a43a
MD5 bff9ad4db721fa1568e1d05f051dbf8a
BLAKE2b-256 19025b5e3dfe64d86f47493f34e26010db870ceee0a7a6b55a891e45b2677909

See more details on using hashes here.

File details

Details for the file wemake_python_styleguide-0.5.1-py3-none-any.whl.

File metadata

File hashes

Hashes for wemake_python_styleguide-0.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 18db5be10424a9009392c4eb7d5a4ae6b64e65aaf61a1d6b75a693e5d97a377d
MD5 7ce6919d5b657e9064f20e69fbe1f2ef
BLAKE2b-256 0a459039475d69bcf34a3ac6c21b8f5e0430d025729cbf10effea5539d89e63d

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