Skip to main content

Extendable Clang AST based c/c++ linter

Project description

EXCAL - Extendable Clang AST based Linter.

This is a simple project implementing a C/C++ linter based on the clang AST. The main porpoise is to create a tool which is easily extendable via plugins.

The focus of this project is to provide a tool for the implementation of custom C/C++ coding guidelines. There are no rules provided by the linter itself, rather a toolset to implement your own. (see Plugins)

Installation

This tool is available on PyPI so you can install it via pip:

pip install excal

Usage

To Analyze a file or project the tool expects input files/directories. Additionally you should provide all includes. If no Includes are given Clang will still create an AST, however it will be incomplete and may cause false positives/negatives from the linter.

    excal -f path/to/file_to_analyze.c -i path/to/includes/

A list of all supported options:

Command arguments Description
-a List of compiler arguments provide compiler arguments for Clang, may improve the AST
–argfile File Compiler arguments may be provided in a File, seperated by newlines
-i List of files/directories Include Files used by the compiler to build the AST
-f (required) List of files/directories Files/Directories to analyze.
-e List of files/directories Files/Directories within given directories, which should be ignored.
-p - If this flag is provided the Linter will print the AST of all included files. This is useful for creating Plugins.
-cpp - Libclang will analyze files based on their extension. If the extension is not cpp specific (eg. .h instead .hpp) this flag will force all files to be analyzed as c++ code.
-ext List of file extensions If provided only files with the given extensions will be parsed.

Config files

If a single directory is given as input, excal will scan said directory for a setup.cfg file. Here some project parameters may be provided. At the moment only the options given in belows example are being used, additional ones will be added.

[EXCAL]
includes = 
  /opt/ros/foxy/include/
exclude_files =
  file/to/exclude.c
  files/to/exclude/
  **/venv
force_cpp = True

Plugins

The Goal of this project is to provide an interface that allows it to easily implement linter rules based on an AST.

A Plugin will need to provide a register method in which it will register itself within the Project by calling the register method of the given PluginManager. The Plugin then can provide a class which inherits from the NodeVisitor class. Here the visit_X (X is the coresponding part of the AST. When printing the Ast wit hthe -p flag, each node Will have a name like: CursorKind.NODE_NAME the coresponding visit function would be visit_node_name) functions can be overwritten. When parsing the AST, these functions will be called whenever a desired Node is reached. From there further operations may be done on the provided AstNode.

See the following example:

    from visitor import NodeVisitor
    from pluginManager import PluginManager
    from astNode import AstNode
    
    PLUGIN_NAME = "AutonomusReply"
    
    class customVisitor(NodeVisitor):
        def __init__(self) -> None:
            super().__init__()
    
        def visit_class_base(self, node: AstNode) -> None:
            return
    
    def register(pm: PluginManager):
        pm.register(PLUGIN_NAME, customVisitor)

There are two ways to provide Plugins. The preferred one is to Create as a standalone python Package. See this example.

The other way is to put the Plugin in the plugins folder and register it in the plugins.json file.

    {
      "plugins": ["plugins.myPlugin"]
    }

All possible functions can be seen in src/visitor.py. To see which function may be needed for your use-cases run the excal project using the -p flag. This will print an AST of the desired 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

excal-0.0.2.tar.gz (12.5 kB view details)

Uploaded Source

Built Distribution

excal-0.0.2-py3-none-any.whl (12.8 kB view details)

Uploaded Python 3

File details

Details for the file excal-0.0.2.tar.gz.

File metadata

  • Download URL: excal-0.0.2.tar.gz
  • Upload date:
  • Size: 12.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/18.0.1 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.10

File hashes

Hashes for excal-0.0.2.tar.gz
Algorithm Hash digest
SHA256 0c3a5b81ad490428abd6120b04c18cadb69712598fafdc2410bdb8b12b46e373
MD5 6c8ccbf8a44c6622f063e888d2182506
BLAKE2b-256 e1fa37076d9b641ed95170b80a9979fafa2ecec298a2d542eab2f205da2270b3

See more details on using hashes here.

File details

Details for the file excal-0.0.2-py3-none-any.whl.

File metadata

  • Download URL: excal-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 12.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/18.0.1 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.10

File hashes

Hashes for excal-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ceb1eb1d0b060730570438807974196874ba3284b631d1df7fb7b0eb7c158f7a
MD5 f825ce30bc4e2a3595e900a64a2e52b9
BLAKE2b-256 d36c53e220de4f9e53a1788da117684a4097355b918f76b71672ebd946b87626

See more details on using hashes here.

Supported by

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