Skip to main content

Runs one or more linters, but only outputs errors if diffs have lint issues.

Project description

lint-diffs

Build Status Code Coverage

lint-diffs is a simple command line tool for running a set of arbitrarty linters on a set of 'unified diffs'.

Errors on diff-lines will always be reported. Errors on non-diff lines can also be reported, depending on severity.

First you need some diffs, then you pipe it to lint-diffs:

git diff -U0 origin/master | lint-diffs

... or in mercurial: hg outgoing -p | lint-diffs

  • default linter configuration is on for pylint (.py), rubocop (.rb), and clang (.cpp, .hpp)

  • flake8, eslint and other linters need to be enabled (see below) explicitly.

Configuration

lint-diffs will read a config files from ~/.config/lint-diffs and/or ./.lint-diffs.

Example:

[pylint]
always_report=E.*

[flake8]
extensions=.py

[rubocop]
extensions=.rb
always_report=(E.*|W.*)

[eslint]
extensions=.js

[shellcheck]
extensions=.sh

In this example, a flake8 and pylint are run on every diff file ending in .py. Additionally, ruby, eslint and shell script linters have been enabled. The ruby linter has been modified to always report warnings, on any changed file, not just changed lines.

To add new linters

  • The linter has to report to stdout

  • The linter has to have a regex that produces a full file path, a line number and an error class

  • The line numbers and file paths have to match diff target file paths

To enable or disable linters change the 'extensions' config.

Goals

  • Runs with good defaults for many people
  • Should be easy to modify the config for any linter
  • Should be easy to use with any vcs

Development

This project uses Flit to build its packages. That might answer your question in case you are wondering why there is no setup.py here.

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

lint_diffs-0.1.22.tar.gz (11.1 kB view details)

Uploaded Source

Built Distribution

lint_diffs-0.1.22-py3-none-any.whl (9.0 kB view details)

Uploaded Python 3

File details

Details for the file lint_diffs-0.1.22.tar.gz.

File metadata

  • Download URL: lint_diffs-0.1.22.tar.gz
  • Upload date:
  • Size: 11.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.23.0

File hashes

Hashes for lint_diffs-0.1.22.tar.gz
Algorithm Hash digest
SHA256 4760cdc62644760c3f8a4924eb45ae8999b6913363b01129252017ca1dba0c09
MD5 b0850d437def94934febbfc011928e04
BLAKE2b-256 88f28952bc87e6b83fe11fe3414836cf2e48371de12704c9a98884cb56dfcc88

See more details on using hashes here.

File details

Details for the file lint_diffs-0.1.22-py3-none-any.whl.

File metadata

File hashes

Hashes for lint_diffs-0.1.22-py3-none-any.whl
Algorithm Hash digest
SHA256 e716bc634c1dd09e7d010b60382ae5d261d3cfccd8b7b79a70b8b8a816849040
MD5 57433371bc2259502430e0644fbdf530
BLAKE2b-256 ae9f745d30cb75322caeab7372fad3a53d4b3dfdae885b95b4bab6c105014d53

See more details on using hashes here.

Supported by

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