A Flake8 plugin to checking module level docstrings, future-imports, and dunders as specified in PEP 8
Project description
Module Level Lint
A Flake8 plugin to enforce code quality by checking module level docstrings, future-imports, and module level dunders as specified in PEP 8
Installation
You can install this plugin via pip:
pip install module-level-lint
Usage
After installation, you can use this plugin with the flake8
command. Here's how to run it:
flake8 [path]
To show only module level lint errors, run:
flake8 --select MLL [path]
To show only specific errors
flake8 --select MLL001,MLL002 [path]
To apply formatting
flake8 --select MLL [path] --fix
Features
Lint
Module Docstring Check: Ensure that your docstrings are always at the top of the file
- Linting Error: MLL001
Example:
import random
# Bad: Module docstring is not at the top of the file
"""This is a docstring"""
def foo():
pass
# Good: Docstring present at the top of the file
""" This is a docstring. """
def foo():
pass
Future-Imports Check: Ensure that future-imports are always at the top after module docstrings
- Linting Error: MLL002
Example:
import random
# Bad: Future-imports is not at the top of the file
from __future__ import print_function
# Good: Future-imports is at the top of the file
from __future__ import division
import random
- Linting Error: MLL003
Example:
from __future__ import print_function
# Bad: Docstring is not at the top of the file
"""This is a docstring."""
"""This is a docstring."""
# Good: Future-imports is at the top of the file after docstring
from __future__ import division
Module-Level Dunders: Ensure that module level dunders are always at the top after future-imports or docstrings
- Linting Error: MLL004
Example:
import random
# Bad: Module level dunder after imports
__all__ = ["foo"]
def foo():
pass
# Bad: Module level dunder before docstring
__all__ = ["foo"]
"""This is a docstring"""
def foo():
pass
def foo():
pass
# Bad: Module level dunder after code
__all__ = ["foo"]
# Good: Module level dunder at the top of the file
__all__ = ["foo"]
def foo():
pass
Format
With the --fix
flag, this plugin will try to format the files that have no rule violations. It will fix the newlines in the following format:
"""Docstring goes here""" # An empty line after docstrings
from __future__ import annotations # An empty line after future imports
__all__ = ["foo"] # An empty line after module dunders
import random # Rest of the code
def foo():
return random.randint(1, 10)
Configuration
This plugin doesn't require any specific configuration, but you can include its error codes in your Flake8 configuration file to disable or enable specific checks:
[flake8]
extend-ignore = MLL001, MLL002, MLL003, MLL004
Contributing
Contributions, issues, and feature requests are welcome! Please feel free to submit a pull request or open an issue.
License
This plugin is licensed under the MIT License.
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
Built Distribution
File details
Details for the file module_level_lint-0.2.2.tar.gz
.
File metadata
- Download URL: module_level_lint-0.2.2.tar.gz
- Upload date:
- Size: 4.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0aa416dccca41075ca1f0dc6eb4245f4b76ca30eb5f49212a8fce0e6991c0820 |
|
MD5 | ef7e4ed361713754ceb2f2bced1a664c |
|
BLAKE2b-256 | be4afe8cad780811830d2beef840e683d4be569db848028c63d5f30c4340acfe |
File details
Details for the file module_level_lint-0.2.2-py3-none-any.whl
.
File metadata
- Download URL: module_level_lint-0.2.2-py3-none-any.whl
- Upload date:
- Size: 6.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4fdcd91e7f737413f83e9b6a0e260245c58dfa678093e367bd997d31a76a77f7 |
|
MD5 | ee1faec49dc5e7ba19448d350f94779d |
|
BLAKE2b-256 | ddab66c80aa98c3d8927e1699dcb18375cc9ec1dbb8bde9e0150280db26719ff |