Skip to main content

opennudge Python linter (naming conventions and other automated checks)

Project description

pynudger

opennudge Python linter (naming conventions and other automated checks)

Features 🚀 Quick start 📚 Documentation 🤝 Contribute 👍 Adopters 📜 Legal


Features

pynudger is an opinionated linter for Python projects, focused on naming conventions and making your code "more Pythonic".

  • Length rules: Too long class/function names are flagged.
  • Setters/getters: Discourages usage of setters/getters, encourages properties instead.
  • No helpers/utils/commons: Incentivizes more descriptive and semantically coherent names for functionalities.

Table of contents

Quick start

Installation

[!TIP] You can use your favorite package manager like uv, hatch or pdm instead of pip.

> pip install pynudger

Usage

To check against the rules run the following from the command line:

> pynudger check

You can pass additional arguments to pynudger check, like files to check (by default all Python files in the current directory):

> pynudger check path/to/file.py another_file.py

Advanced

Configuration

You can configure pynudger in pyproject.toml (or .pynudger.toml in the root of your project, just remove the [tool.pynudger] section), for example:

[tool.pynudger]
# include rules by their code
include_codes = [1, 2, 5] # default: all rules included
# exclude rules by their code (takes precedence over include)
exclude_codes = [4, 5, 6] # default: no rules excluded
# whether to exit after first error or all errors
end_mode = "first" # default: "all"

[!TIP] Rule-specific configuration can be found in the section below.

Run as a pre-commit hook

pynudger can be used as a pre-commit hook, to add as a plugin:

repos:
-   repo: "https://github.com/open-nudge/pynudger"
    rev: ...  # select the tag or revision you want, or run `pre-commit autoupdate`
    hooks:
    -   id: "pynudger"

Disable in code

You can disable pynudger on a line-by-line basis (you have to specify exact code), e.g.:

def set_my_too_long_function_name():  # noqa: PYNUDGER0, PYNUDGER16
    pass

or a line span:

# noqa-start: PYNUDGER0, PYNUDGER16
def set_my_too_long_function_name():
    pass

def set_another_long_function():
    pass
# noqa-end: PYNUDGER0, PYNUDGER16

def set_will_error_out_this_time():
    pass

It is also possible to disable all checks in a file by placing the following somewhere in the file (preferably at the top):

# noqa-file: PYNUDGER0, PYNUDGER16

[!NOTE] If you are running pynudger with ruff you should add lint.external = ["PYNUDGER"] to [tool.ruff] section in pyproject.toml to avoid removing # noqa: PYNUDGER comments.

Rules

[!TIP] Run pynudger rules to see the list of available rules.

pynudger provides the following rules:

Name Description
PYNUDGER0 Avoid using setters in class names. Use properties instead.
PYNUDGER1 Avoid using setters in function names. Use properties instead.
PYNUDGER2 Avoid using setters in file names. Define file name without it.
PYNUDGER3 Avoid using getters in class names. Use properties instead.
PYNUDGER4 Avoid using getters in function names. Use properties instead.
PYNUDGER5 Avoid using getters in file names. Define file name without it.
PYNUDGER6 Avoid using utils in class names. Name the class appropriately.
PYNUDGER7 Avoid using utils in function names. Name the function appropriately.
PYNUDGER8 Avoid defining utils modules. Move functionality to appropriate modules.
PYNUDGER9 Avoid using helpers in class names. Name the class appropriately.
PYNUDGER10 Avoid using helpers in function names. Name the function appropriately.
PYNUDGER11 Avoid defining utils modules. Move functionality to appropriate modules.
PYNUDGER12 Avoid using common in class names. Name the class appropriately.
PYNUDGER13 Avoid using common in function names. Name the function appropriately.
PYNUDGER14 Avoid defining common modules. Move functionality to appropriate modules.
PYNUDGER15 Avoid long class names. Specify intent by nesting modules/packages.
PYNUDGER16 Avoid long function names. Specify intent by nesting modules/packages.
PYNUDGER17 Avoid long path names. Specify intent by nesting modules/packages.

with the following configurable options (in pyproject.toml or .pynudger.toml):

Option Description Affected rules Default
pascal_length Maximum allowed length of PascalCase names PYNUDGER15 3
snake_length Maximum allowed length of snake_case names PYNUDGER16, PYNUDGER17 3
pascal_excludes List of words to exclude from PascalCase length check PYNUDGER15 []
snake_excludes List of words to exclude from snake_case length check PYNUDGER16, PYNUDGER17 []

Contribute

We welcome your contributions! Start here:

Legal

  • This project is licensed under the Apache 2.0 License - see the LICENSE file for details.
  • This project is copyrighted by open-nudge - the appropriate copyright notice is included in each file.

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

pynudger-0.1.0.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pynudger-0.1.0-py3-none-any.whl (10.2 kB view details)

Uploaded Python 3

File details

Details for the file pynudger-0.1.0.tar.gz.

File metadata

  • Download URL: pynudger-0.1.0.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for pynudger-0.1.0.tar.gz
Algorithm Hash digest
SHA256 d3b937586181e1337c9ca5de92d495a6ad4a2cc3307850396fcf3b367a2a37b3
MD5 1ddceac4f3e872dc4c1cb8c7f14de709
BLAKE2b-256 ac3a9690a2780fe084e3dae445498355d370fdf5e7e36d6074b90fbebd3d3a7f

See more details on using hashes here.

Provenance

The following attestation bundles were made for pynudger-0.1.0.tar.gz:

Publisher: release.yml on open-nudge/pynudger

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pynudger-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: pynudger-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 10.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for pynudger-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6ceb136e02a330d68e9b90af3a62e7dded1129045daa9d2e81e5fcdf5ca450e2
MD5 b33337eba46e7009d83829354f107cf8
BLAKE2b-256 b8315c4b4a9e08ccc36ae03176edc4f2115efbe7a94d06de7959db3a12692b8e

See more details on using hashes here.

Provenance

The following attestation bundles were made for pynudger-0.1.0-py3-none-any.whl:

Publisher: release.yml on open-nudge/pynudger

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page