Skip to main content

Pylint output as SARIF

Project description

This is an unofficial fork of the pylint-sarif project. Most code here was written by the original GrammaTech developers, but they are not responsible for any bugs.

This is on PyPI as pylint-sarif-unofficial.

This uses python-jsonschema-objects, which does not currently support version 4.18 of jsonschema. To avoid holding your project's jsonschema version (if it uses it) back, I suggest installing pylint-sarif-unofficial using pipx instead of listing it in your project's manifest file. You can put a command like this in your pylint CI workflow:

pipx install pylint-sarif-unofficial

Or with the specific version you want, for example:

pipx install pylint-sarif-unofficial==0.2.1

Your project can still install pylint itself as a development dependency.

The LICENSE is the same as in the upstream project. The original project readme follows below.

pylint-sarif

This repo contains code for converting from Pylint output to SARIF, and for invoking CodeSonar in a manner that does a analysis and imports the SARIF file.

The version of SARIF supported is the one specified by the version in sarif-spec.json. This is a snapshot taken from here: https://github.com/Microsoft/sarif-sdk/blob/develop/src/Sarif/Schemata/sarif-schema.json

Note that the version string included therein identifies the particular draft of the SARIF specification.

pylint2sarif.py

This runs pylint and converts the output to SARIF v2.

To use:

python pylint2sarif.py --help

Typically, you give it the exact same set of arguments that you would pass to pylint. E.g.,

python pylint2sarif.py ex1.py

pylint2cso.py

This runs CodeSonar to create an analysis and import the SARIF file.

python pylint2cso.py -h

Sample invocation:

codesonar analyze -preset sarif_import Proj localhost:9460 python pylint2cso.py ex.py

Note that this must be run under CodeSonar in this fashion or it will just not work.

Requirements

pylint2sarif.py needs the following:

  • Python 2 or 3, but note that Cygwin python is NOT supported

  • pip install python_jsonschema_objects. This has been tested for release 0.3.12, which corresponds to version 0.0.18

  • pip install pylint

pylint2cso.py needs:

  • A version of CodeSonar supporting the importing of SARIF v2.

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

pylint_sarif_unofficial-0.2.1.tar.gz (23.7 kB view details)

Uploaded Source

Built Distribution

pylint_sarif_unofficial-0.2.1-py3-none-any.whl (24.4 kB view details)

Uploaded Python 3

File details

Details for the file pylint_sarif_unofficial-0.2.1.tar.gz.

File metadata

  • Download URL: pylint_sarif_unofficial-0.2.1.tar.gz
  • Upload date:
  • Size: 23.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.11.4 Linux/5.15.90.1-microsoft-standard-WSL2

File hashes

Hashes for pylint_sarif_unofficial-0.2.1.tar.gz
Algorithm Hash digest
SHA256 73f4354b881af810192c07cdb1b238165b4fbf0c27645c4969c8cbf68faa1249
MD5 696db33c8131b6adb95404b7bf454598
BLAKE2b-256 56a4464536c02dc4ba4d4b454db1e74af3c82a7262899eef5a7dbe587e212111

See more details on using hashes here.

File details

Details for the file pylint_sarif_unofficial-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for pylint_sarif_unofficial-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 82ef7952aacf275ee43b3bb675eda8a15d68c214d7f35af521424f8535159a59
MD5 196b202df3b9cb758c9e7495ba35bffe
BLAKE2b-256 5ebed3a61b203913b020c9a26230530c58ed487601f048161b83769e0b8b209b

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