Skip to main content

Build your own linter in minutes - from Python code to config files (YAML, JSON, TOML)

Project description

lintkit is a framework for building linters/code checking rules

  • Multiple formats: Python-first, but supports YAML, JSON and TOML
  • Comprehensive: noqa comments, file skips and standardized pretty output
  • Quick: Create and run custom rules in a few lines of code
  • Flexible: Rules over file(s), their subelements and more (see Files tutorial)
  • Minimal: Gentle learning curve - <1000 lines of code, tutorials, API reference

🚀 Quick start 📚 Documentation 🤝 Contribute 👍 Adopters 📜 Legal

Quick start

[!TIP] Check out more examples (here) to get a better feel of lintkit.

Below are ~20 lines of code implementing custom linter with two rules and running it on three files:

import lintkit

# Set the name of the linter
lintkit.settings.name = "NOUTILS"

class _NoUtils(lintkit.check.Regex, lintkit.loader.Python, lintkit.rule.Node):
    def regex(self):
        # Regex to match util(s) variations in function/class name
        return r"_?[Uu]til(s|ities)?"

    def values(self):
        # Yield class or function names from a Python file
        data = self.getitem("nodes_map")
        for node in data[self.ast_class()]:
            yield lintkit.Value.from_python(node.name, node)

    def message(self, _):
        return f"{self.ast_class()} name contains util(s) word"

# Concrete rules and their codes
# Disabling linter using noqas supported out of the box!
class ClassNoUtils(_NoUtils, code=0):  # noqa: NOUTILS0
    # ast type we want to focus on in this rule
    def ast_class(self):
        return ast.ClassDef

class FunctionNoUtils(_NoUtils, code=1):  # noqa: NOUTILS0
    def ast_class(self):
        return ast.FunctionDef

lintkit.run(["linter.py", "file1.py", "file2.py"])

# Example output
#/path/file1.py:23:17 NOUTILS0: ClassDef name contains util(s) word
#/path/file2.py:73:21 NOUTILS1: FunctionDef name contains util(s) word

Installation

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

> pip install lintkit

[!NOTE] lintkit provides extras (rich, toml, yaml and all containing everything) to provide additional functionality.

# To create rules utilizing YAML
> pip install lintkit[rich, yaml]

Learn

Check out the following links to learn more about lintkit:

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

lintkit-1.0.0.tar.gz (38.4 kB view details)

Uploaded Source

Built Distribution

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

lintkit-1.0.0-py3-none-any.whl (40.3 kB view details)

Uploaded Python 3

File details

Details for the file lintkit-1.0.0.tar.gz.

File metadata

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

File hashes

Hashes for lintkit-1.0.0.tar.gz
Algorithm Hash digest
SHA256 f6e7790ffb0ab0e9b768b8de520e03b2cfe3c8017bbfc2ab9c12e38c283acb5f
MD5 24ce56d1bf56aa94a7de6e450451a6b0
BLAKE2b-256 0d0cb923318cdf503e7e0ff9cbfe46976721a2723907f0d0aa1181ab7dc2f6d5

See more details on using hashes here.

Provenance

The following attestation bundles were made for lintkit-1.0.0.tar.gz:

Publisher: release.yml on open-nudge/lintkit

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

File details

Details for the file lintkit-1.0.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for lintkit-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 651c69bd36238fdf6fd084f56cee0ddfa3213e25c7f1a87efe9d091ccd562e82
MD5 10d85c6f620a37313457000ef43784f8
BLAKE2b-256 3d43cd6904c5cebed089e4b87dba9e6c0394da378b6c3cd3fcdabb2dcea3536a

See more details on using hashes here.

Provenance

The following attestation bundles were made for lintkit-1.0.0-py3-none-any.whl:

Publisher: release.yml on open-nudge/lintkit

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