Skip to main content

A CLI utility for linting and analyzing Tcl code.

Project description

tclint   CI

tclint is a collection of modern dev tools for Tcl. It includes a linter, a formatter, and a language server that provides Tcl support to your editor of choice.

Features

Getting Started

Install tclint from PyPI using pipx (recommended):

pipx install tclint

Or with pip:

pip install tclint

Run tclint on a Tcl source file by providing its path as a positional argument:

tclint example.tcl

If the file contains any lint violations, they will be printed and tclint will return a non-zero exit code. Otherwise, the output will be empty and tclint will exit successfully.

Example

$ cat example.tcl
if { [expr {$input > 10}] } {
  puts $input is greater than 10!
}
$ tclint example.tcl
data/example.tcl:1:6: unnecessary command substitution within expression [redundant-expr]
data/example.tcl:2:3: too many args for puts: got 5, expected no more than 3 [command-args]

Usage

tclint is a command-line utility. It takes a list of paths as positional arguments, which may either be direct paths to source files, or directories which will be recursively searched for files ending in .tcl, .sdc, .xdc, or .upf.

Collected files will be checked for lint violations. See the Violations documentation page for a description of all lint violations tclint may report.

Aspects of tclint's behavior can be controlled by a configuration file. By default, tclint will search for a file named tclint.toml or .tclint by walking the parent directories of source files, but a path to an alternate configuration file can be provided using the -c or --config flag. See Configuration for documentation on the configuration file.

tclint includes a plugin system for checking EDA tool-specific commands. See the Plugins documentation page for more info.

Contributing

tclint welcomes community contributions. The best way to help the project is to open an issue if you find a bug or have a feature request.

PRs are also welcome, but for non-trivial changes please open an issue first to solicit feedback. This helps avoid wasted effort.

Use the following steps to set up tclint for local development:

$ git clone https://github.com/nmoroze/tclint.git # or URL to fork
$ cd tclint
$ python3 -m venv .venv # set up a venv to ensure clean environment
$ source .venv/bin/activate
(venv) $ pip install --upgrade pip # development requires pip >= 25.1
(venv) $ pip install -e . --group dev

Please format, lint, and run tests before submitting changes:

$ source .venv/bin/activate
(venv) $ black .
(venv) $ ./util/pre-commit

License

This project is copyright Noah Moroze, released under the MIT license.

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

tclint-0.7.0.tar.gz (90.5 kB view details)

Uploaded Source

Built Distribution

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

tclint-0.7.0-py3-none-any.whl (53.9 kB view details)

Uploaded Python 3

File details

Details for the file tclint-0.7.0.tar.gz.

File metadata

  • Download URL: tclint-0.7.0.tar.gz
  • Upload date:
  • Size: 90.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for tclint-0.7.0.tar.gz
Algorithm Hash digest
SHA256 bd605b11d44708e1537b902e63d7dd1d05f2d85c2c99a36854b157606eac1e8a
MD5 27899322f13900df615626553f0eeb61
BLAKE2b-256 8457bac53151cc404c8fd5b15c69943cde772b404cd740ee576d5a7ca12732d1

See more details on using hashes here.

Provenance

The following attestation bundles were made for tclint-0.7.0.tar.gz:

Publisher: release.yml on nmoroze/tclint

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

File details

Details for the file tclint-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: tclint-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 53.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for tclint-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 58b54bf333a96ef4b4eac3bde23da997a64a4414a4cdec8e5e0a9fbafb6dcd25
MD5 eabdd13a03b2ab7925e2d46f49e82158
BLAKE2b-256 44721465bedba4f2ea4ae501eaa9f8e06d31e62627f053c88c58544c50ec4ac5

See more details on using hashes here.

Provenance

The following attestation bundles were made for tclint-0.7.0-py3-none-any.whl:

Publisher: release.yml on nmoroze/tclint

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