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 []
dir_ignores List of (sub)directories to be excluded in case no files are provided ALL ["__pypackages__", ".venv", ".git", "__pycache__"]
extend_dir_ignores Additional (sub)directories to ignore, extending the default ignores ALL []

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.3.0.tar.gz (17.1 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.3.0-py3-none-any.whl (10.6 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for pynudger-0.3.0.tar.gz
Algorithm Hash digest
SHA256 d40d44a5fa8140fba2454204d6e42ef91e78dbeee10ac77db48621c82975e9ae
MD5 71bf78a2c3b658fb94c0803638573b29
BLAKE2b-256 54a15f8e9a52b36863be401efe55eef116cee3a7c3db2624ee13381693820a04

See more details on using hashes here.

Provenance

The following attestation bundles were made for pynudger-0.3.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.3.0-py3-none-any.whl.

File metadata

  • Download URL: pynudger-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 10.6 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.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 996bd29cd3984d39bb1d989e785a84507be13bceba37c9e13db70481f40e8c14
MD5 a20fc0d74fa0c4e2c6d9bbccc38e8e4a
BLAKE2b-256 e73e501e4539d1f61578229773ac06d10eab9f215ffa9e16bac2450a78f94616

See more details on using hashes here.

Provenance

The following attestation bundles were made for pynudger-0.3.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