All Projects → best-doctor → flake8-functions

best-doctor / flake8-functions

Licence: MIT License
flake8 plugin for validation of function parameters (length, complexity, etc)

Programming Languages

python
139335 projects - #7 most used programming language
Makefile
30231 projects
ruby
36898 projects - #4 most used programming language

Projects that are alternatives of or similar to flake8-functions

Wemake Python Styleguide
The strictest and most opinionated python linter ever!
Stars: ✭ 1,714 (+5256.25%)
Mutual labels:  styleguide, flake8, flake8-plugin
flake8-cognitive-complexity
An extension for flake8 that validates cognitive functions complexity
Stars: ✭ 44 (+37.5%)
Mutual labels:  styleguide, flake8, flake8-plugin
Elements Of Python Style
Goes beyond PEP8 to discuss what makes Python code feel great. A Strunk & White for Python.
Stars: ✭ 3,308 (+10237.5%)
Mutual labels:  styleguide, flake8
flake8-docstrings
Integration of pydocstyle and flake8 for combined linting and reporting
Stars: ✭ 73 (+128.13%)
Mutual labels:  flake8, flake8-plugin
flake8-simplify
❄ A flake8 plugin that helps you to simplify code
Stars: ✭ 97 (+203.13%)
Mutual labels:  flake8, flake8-plugin
flake8-type-checking
Flake8 plugin for managing type-checking imports & forward references.
Stars: ✭ 38 (+18.75%)
Mutual labels:  flake8, flake8-plugin
flake8-broken-line
🚨 Flake8 plugin to forbid backslashes (\) for line breaks
Stars: ✭ 85 (+165.63%)
Mutual labels:  flake8, flake8-plugin
flake8-alfred
Alfred is a flake8 plugin to warn on unsafe/obsolete symbols.
Stars: ✭ 26 (-18.75%)
Mutual labels:  flake8, flake8-plugin
Pycodestyle
Simple Python style checker in one Python file
Stars: ✭ 4,465 (+13853.13%)
Mutual labels:  styleguide, flake8-plugin
flake8-annotations
Flake8 Type Annotation Checking
Stars: ✭ 117 (+265.63%)
Mutual labels:  flake8, flake8-plugin
flake8-assertive
Flake8 unittest assert method checker
Stars: ✭ 30 (-6.25%)
Mutual labels:  flake8
papyrum
Papyrum is a tool that will help you in the creation of your design system, style guide or in the documentation of your project based on react
Stars: ✭ 19 (-40.62%)
Mutual labels:  styleguide
bashtemplate
A bash template for better bash coding.
Stars: ✭ 75 (+134.38%)
Mutual labels:  styleguide
vf-core
A (primarily CSS) framework that targets needs of life science websites and services
Stars: ✭ 16 (-50%)
Mutual labels:  styleguide
flask-styleguide
A living Styleguide for your Flask application
Stars: ✭ 47 (+46.88%)
Mutual labels:  styleguide
flake8-aaa
A Flake8 plugin that checks Python tests follow the Arrange-Act-Assert pattern
Stars: ✭ 51 (+59.38%)
Mutual labels:  flake8-plugin
ue5-style-guide
An attempt to make Unreal Engine 4 projects more consistent
Stars: ✭ 2,892 (+8937.5%)
Mutual labels:  styleguide
birdseye
Next generation component catalog
Stars: ✭ 41 (+28.13%)
Mutual labels:  styleguide
frontend-handbook
Our handbook based on 10 years of experience in Frontend/JS development
Stars: ✭ 45 (+40.63%)
Mutual labels:  styleguide
rubric
Linter Config Initializer for Python
Stars: ✭ 21 (-34.37%)
Mutual labels:  flake8

flake8-functions

Build Status Maintainability Test Coverage PyPI version PyPI - Python Version

An extension for flake8 to report on issues with functions.

We believe code readability is very important for a team that consists of more than one person. One of the issues we've encountered is functions that are more that two screens long.

The validator checks for:

  • CFQ001 - function length (default max length is 100)
  • CFQ002 - function arguments number (default max arguments amount is 6)
  • CFQ003 - function is not pure.
  • CFQ004 - function returns number (default max returns amount is 3)

Installation

pip install flake8-functions

Example

def some_long_function(
    first_parameter: int,
    second_parameter: int,
    third_parameter: int,
):
    first_parameter = (
        first_parameter +
        second_parameter +
        third_parameter
    )

    first_parameter = (
        first_parameter +
        second_parameter +
        third_parameter
    )

    first_parameter = (
        first_parameter +
        second_parameter +
        third_parameter
    )

    first_parameter = (
        first_parameter +
        second_parameter +
        third_parameter
    )

    return first_parameter

Usage:

$ flake8 --max-function-length=20 test.py
test.py:1:0: CFQ001 "some_long_function" function has length 25
that exceeds max allowed length 20

Error codes

Error code Description
CFQ001 Function "some_function" has length %function_length% that exceeds max allowed length %max_length%
CFQ002 Function "some_function" has %args_amount% arguments that exceeds max allowed %max_args_amount%
CFQ003 Function "some_function" is not pure.
CFQ004 Function "some_function" has %returns_amount% returns that exceeds max allowed %max_returns_amount%

Code prerequisites

  1. Python 3.7+;

Contributing

We would love you to contribute to our project. It's simple:

  1. Create an issue with bug you found or proposal you have. Wait for approve from maintainer.
  2. Create a pull request. Make sure all checks are green.
  3. Fix review comments if any.
  4. Be awesome.

Here are useful tips:

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].