Skip to main content

A tool to measure the percentage of typed arguments in python functions

Project description

✏️🎚️✅ PyTypeGauge

PyTypeGauge is a Python library that provides comprehensive statistics and metrics for your typed functions and Python code. The primary goal is to encourage developers to achieve 100% type coverage in their codebases.

⚠️ Note: PyTypeGauge is a simple tool designed to encourage better type annotation in your Python code. It does not validate the correctness of the types you add. The concept is straightforward: it recursively scans all Python files in a repository, using regular expressions to identify function prototypes and check whether their arguments and return types are annotated. PyTypeGauge then calculates the proportion of fully typed functions and arguments, providing a summary of your type coverage. Additionally, you can generate a comprehensive report in markdown format, highlighting functions and files that may need refactoring or additional type annotations.

PyTypeGauge is intended to be used with pre-commit hooks and can update your README.md with your project's type coverage progress.

Example Output (current type coverage)

typo_progress

For more advanced type checking and validation, consider using other well-maintained libraries such as mypy or pyright.


🧩 Features

  • Analyze the type coverage of your Python functions.
  • Generate detailed reports on the use of type hints.
  • Track the progress of type hint adoption in your codebase.

📥 Installation

To install PyTypeGauge, run:

pip install pytypegauge

How to Use typegauge

typegauge is a command-line tool designed to analyze the type annotations in your Python code. You can specify a directory or a Python file, and the tool will evaluate the type coverage of your code. Below is a guide on how to use typegauge and the various options available.

Basic Usage

To analyze a specific directory or Python file, simply run:

typegauge <input>

Replace <input> with the path to the directory or Python file you want to analyze.

⚙️ Options

  • -h, --help: Show the help message and exit.

    typegauge -h
    
  • -g, --git: Analyze only files tracked by git. This is useful if you want to exclude untracked or ignored files.

    typegauge -g <input>
    
  • -p, --plot-output: Display a graph showing the distribution of typing coverage in your code.

    typegauge -p <input>
    
  • -csv CSV_OUTPUT, --csv-output CSV_OUTPUT: Save the results to a CSV file. Provide the desired CSV file name.

    typegauge -csv results.csv <input>
    
  • -md, --markdown-output: Output the results in a markdown format suitable for inclusion in a README.md on GitHub. This is useful for creating progress badges or reports in your repository.

    typegauge -md <input>
    
  • -c, --clean-output: Only return the percentage of typed arguments, which is useful for scripts and continuous integration setups.

    typegauge -c <input>
    
  • -f, --full-report: Generate a full report listing all functions that are not fully typed. This can help you identify areas in your code that need improvement.

    typegauge -f <input>
    

By using these options, you can tailor the output of typegauge to suit your needs, whether you want a quick summary, a detailed report, or integration with other tools.

🪝 Hooks

Pytypegauge can be used as a pre-commit hook. To do this, add the following configuration to your .pre-commit-config.yaml file:

-   repo: https://github.com/White-On/pytypegauge
    rev: [version]
    hooks:
    -   id: pytypegauge

The hooks will get all the python files in the repository and check the type coverage of the functions in the files. If there is a README.md file in the repository, the hook will update the file with the type coverage of the repository in a markdown format. you can place a [!typo_progress] and the hook will replace it with the type coverage of the repository.

Note:

  • The hook will not update the README.md file if the file is not in the repository.
  • The hook will not update the README.md file if the file does not contain the [!typo_progress] tag.
  • The hook will take all python files, there is no method for now to exclude some files from the hook.

TODO:

  • Add hooks for pre-commit
  • Add a description of the project
  • Add a list of the project's dependencies in setup.py
  • Fix bugs in the project
  • Add a Logger to the project for Debugging
  • Type correctly the project
  • Add the feature with matplotlib
  • Translate the code in English
  • Add the feature with pandas
  • add tests for the project
  • Clean the code
  • Add to pypi
  • Make the readme more informative
  • Create the hooks to use this project as a template
  • Add the feature to generate a badge
  • Add the feature to generate a markdown file
  • Add verbose mode
  • Clean code and arguments setup

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

pytypegauge-1.0.tar.gz (11.2 kB view details)

Uploaded Source

Built Distribution

pytypegauge-1.0-py3-none-any.whl (10.4 kB view details)

Uploaded Python 3

File details

Details for the file pytypegauge-1.0.tar.gz.

File metadata

  • Download URL: pytypegauge-1.0.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.5

File hashes

Hashes for pytypegauge-1.0.tar.gz
Algorithm Hash digest
SHA256 28dc26842c698a0de5f2b80320313cb0c53fb2a7da9bc08f799f47c6e646bb22
MD5 3844325e6fd7e5ae2504e5d942684049
BLAKE2b-256 7ddff89f047f7f4d7bc9c58ef6661eab224bee2c8066dbb493348f322a257c98

See more details on using hashes here.

File details

Details for the file pytypegauge-1.0-py3-none-any.whl.

File metadata

  • Download URL: pytypegauge-1.0-py3-none-any.whl
  • Upload date:
  • Size: 10.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.5

File hashes

Hashes for pytypegauge-1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1f4941caf12f23fa1421e4b975443abbe99f5711548d47f43e63a28ba5302106
MD5 b799186e1884a602451517c4604645a3
BLAKE2b-256 1bb60d5cdf10bfa5940d357266c38b968c2ab56d9461db27821393fc9d27d66c

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