Skip to main content

Mypy type checking extension for Python IDLE

Project description

IdleTypeCheck

Python IDLE extension to perform mypy analysis on an open file

pre-commit.ci status pre-commit code style: black Ruff

Notice

This project is superseded by my other IDLE extension, IdleMypyExtension, which uses the mypy daemon instead and has many more features.

What does this extension do?

This IDLE extension hooks into mypy to type check the currently open file. When type checking the currently open file with the "Type Check File" command, it will add comments to your code wherever mypy had something to say about about that line. You can remove type comments from the currently selected text with the "Remove Type Comments" command. Additionally, you can jump to the next comment this extension created in your file with the "Find Next Type Comment" command.

Note: On use, creates folder mypy within the idle user directory. On Linux systems, this is usually ~/.idlerc/mypy.

Installation (Without root permissions)

  1. Go to terminal and install with pip install idletypecheck[user].
  2. Run command idleuserextend; idletypecheck. You should see the following output: Config should be good! Config should be good!.
  3. Open IDLE, go to Options -> Configure IDLE -> Extensions. If everything went well, alongside ZzDummy there should be and option called idletypecheck. This is where you can configure how idletypecheck works.

Installation (Legacy, needs root permission)

  1. Go to terminal and install with pip install idletypecheck.
  2. Run command idletypecheck. You will likely see a message saying typecheck not in system registered extensions!. Run the command given to add lintcheck to your system's IDLE extension config file.
  3. Again run command typecheck. This time, you should see the following output: Config should be good!.
  4. Open IDLE, go to Options -> Configure IDLE -> Extensions. If everything went well, alongside ZzDummy there should be and option called idletypecheck. This is where you can configure how idletypecheck works.

Information on options

For extra_args, see mypy --help for a list of valid flags. This extension sets the following flags to be able to work properly:

    --hide-error-context
    --no-color-output
    --show-absolute-path
    --no-error-summary
    --soft-error-limit=-1
    --show-traceback
    --cache-dir="~/.idlerc/mypy"

If you add the --show-column-numbers flag to extra_args, when using the "Type Check File" command, it will add a helpful little ^ sign in a new line below the location of the mypy message that provided a column number, as long as that comment wouldn't break your file's indentation too much.

If you add the --show-error-codes flag to extra_args, when using the "Type Check File" command, when it puts mypy's comments in your code, it will tell you what type of error that comment is. For example, it would change the error comment

# typecheck: error: Incompatible types in assignment (expression has type "str", variable has type "int")

to

# typecheck: assignment error: Incompatible types in assignment (expression has type "str", variable has type "int")

search_wrap toggles weather searching for next type comment will wrap around or not.

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

idletypecheck-1.0.1.tar.gz (52.6 kB view details)

Uploaded Source

Built Distribution

idletypecheck-1.0.1-py3-none-any.whl (39.5 kB view details)

Uploaded Python 3

File details

Details for the file idletypecheck-1.0.1.tar.gz.

File metadata

  • Download URL: idletypecheck-1.0.1.tar.gz
  • Upload date:
  • Size: 52.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.0

File hashes

Hashes for idletypecheck-1.0.1.tar.gz
Algorithm Hash digest
SHA256 a3511ba6b0f6a2975435c7a2cc606be90bed82f61d1b52b238a311a31ede823a
MD5 d0e57cb5425ce5aebe3f33b082c17900
BLAKE2b-256 9450e1796c2955a449bb47e461479dee1ea942f82174593861420cb2db8064e3

See more details on using hashes here.

File details

Details for the file idletypecheck-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for idletypecheck-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 92946c1072f4092ad68ca35cd4c45e23f4d54b589218b0c81745519a2bd24341
MD5 ac9f38e93afbe0e38a44ac13718907b9
BLAKE2b-256 f4ef7db3d54c371422d032b1ca1b9e356e2bf1104467ccbe6c8c6c971c4f46a5

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