Skip to content

Node.js Binding

The node.js binding for the cpp-linter-rs rust project (built using napi-rs and yarn).

Install

Install with npm:

npm -g install @cpp-linter/cpp-linter

Usage

For usage in a CI workflow, see the cpp-linter/cpp-linter-action repository.

For the description of supported Command Line Interface options, see the CLI documentation.

Development

After the native module is built using yarn build:debug, you can invoke the executable script as a normal CLI app:

npx cpp-linter --help

Scripts

If an available script is not described below, it should be considered a convenience tool for the CI/CD workflow.

yarn build

This script builds the native module for distribution (with release profile optimizations).

yarn build:debug

Same as yarn build but does not use the release profile optimizations. You should use this script when testing locally.

yarn test

This script runs a simple test to ensure the native module was built correctly.

Folder structure

Name Description
__test__ The location of the unit test(s).
npm The required metadata for publishing platform-specific binary packages to npm.
src The location for all rust sources related to binding the cpp-linter library.
build.rs The cargo-specific build script used when compiling the binding.
Cargo.toml Metadata about the binding's rust package (which is not intended to be published to crates.io).
package.json Metadata about the npm package (platform agnostic - no binary).
cli.js The executable script invoked as a Command Line Interface.
index.d.ts The generated TypeScript typing and doc info that describes the exposed API in the built native module.
index.js The generated script that delegates which native binary (platform-specific package or dev build) to import.
cpp-linter.x-y-z.node The native module built for a specific platform (where x-y-z denotes the platform's name using the compilation target).

Hidden files and folders are not described in the table above. If they are not ignored by a gitignore specification, then they should be considered important only for maintenance or distribution.