Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/leinardi/mypy-pycharm
A plugin providing both real-time and on-demand scanning of Python files with Mypy from within PyCharm/IDEA.
https://github.com/leinardi/mypy-pycharm
mypy pycharm pycharm-plugin python
Last synced: 1 day ago
JSON representation
A plugin providing both real-time and on-demand scanning of Python files with Mypy from within PyCharm/IDEA.
- Host: GitHub
- URL: https://github.com/leinardi/mypy-pycharm
- Owner: leinardi
- License: apache-2.0
- Created: 2018-08-31T20:36:35.000Z (over 6 years ago)
- Default Branch: release
- Last Pushed: 2024-10-05T08:02:42.000Z (4 months ago)
- Last Synced: 2025-01-15T13:48:30.612Z (8 days ago)
- Topics: mypy, pycharm, pycharm-plugin, python
- Language: Java
- Homepage:
- Size: 2.47 MB
- Stars: 201
- Watchers: 7
- Forks: 31
- Open Issues: 61
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# mypy-pycharm
[![GitHub (pre-)release](https://img.shields.io/github/release/leinardi/mypy-pycharm/all.svg?style=plastic)](https://github.com/leinardi/mypy-pycharm/releases)
[![Travis](https://img.shields.io/travis/leinardi/mypy-pycharm/master.svg?style=plastic)](https://travis-ci.org/leinardi/mypy-pycharm)
[![GitHub license](https://img.shields.io/github/license/leinardi/mypy-pycharm.svg?style=plastic)](https://github.com/leinardi/mypy-pycharm/blob/master/LICENSE)
[![Stars](https://img.shields.io/github/stars/leinardi/mypy-pycharm.svg?style=social&label=Stars)](https://github.com/leinardi/mypy-pycharm/stargazers)This plugin provides both real-time and on-demand scanning of Python files with Mypy from within PyCharm/IDEA.
Mypy is a Python source code analyzer which looks for programming errors,
helps to enforce a coding standard and sniffs for some code smells
(as defined in Martin Fowler's Refactoring book).![mypy plugin screenshot](https://github.com/leinardi/mypy-pycharm/blob/master/art/mypy-pycharm.png)
## Installation steps
1. In the **Settings/Preferences** dialog (CTRL+Alt+S), click **Plugins**. The [Plugins page](https://www.jetbrains.com/help/pycharm/plugins-settings.html) opens.
2. Click **Browse repositories**.
3. In the [Browse Repositories dialog](https://www.jetbrains.com/help/pycharm/browse-repositories-dialog.html) that opens, right-click on the plugin named **Mypy** and select **Download and Install**.
4. Confirm your intention to download and install the selected plugin.
5. Click **Close**.
6. Click **OK** in the **Settings** dialog and restart PyCharm for the changes to take effect.## Configuration
The only configuration needed is to set the path to Mypy executable, and only if is not already
inside the PATH environment variable.To reach the Plugin configuration screen you can open **Settings/Preferences** dialog (CTRL+Alt+S), click **Other Settings** and then **Mypy** or simply click the gear icon from the side bar of the Mypy tool window.
To change the path to your Mypy executable you can either type the path directly or use
the Browse button to open a file selection dialog.Once you changed the path you should press the Test button to check if the plugin is able to run
the executable.![plugin settings screenshot](https://github.com/leinardi/mypy-pycharm/blob/master/art/mypy-settings.png)
### Inspection severity
By default, Mypy message severity is set to Warning. It is possible to change the severity level
by going to **Settings/Preferences** dialog (CTRL+Alt+S) -> **Editor** -> **Inspections** -> **Mypy** -> **Severity**:![plugin inspection severity screenshot](https://github.com/leinardi/mypy-pycharm/blob/master/art/mypy-inspection-severity.png)
## Usage
![plugin actions screenshot](https://github.com/leinardi/mypy-pycharm/blob/master/art/actions1.png)
![plugin actions screenshot](https://github.com/leinardi/mypy-pycharm/blob/master/art/actions2.png)## FAQ
### When I click "Check Project/Module/Changes" I only get one error for one file, why?
It is a [know issue](https://github.com/python/mypy/issues/3850) of `mypy`: if the validation encounters a blocking error it just bails out completely ignoring the rest of the files. The biggest problem for the plugin is that currently there is no way to know if the check ended normally or because it encountered a blocking error (in the issue ticket there was a suggestion of using `--verbose` but it does not work, for exampble, for `duplicate module naned` errors).### How can I prevent the code inspection to run on a specific folder?
The easiest way to ignore a specific folder is to mark it as Excluded from PyCharm/IDEA:
1. Open PyCharm/IDEA Settings -> *your project* -> Project structure
2. Select the directory you want to exclude
3. Click the Excluded button (red folder icon)More info [here](https://www.jetbrains.com/help/pycharm/configuring-folders-within-a-content-root.html#mark).
### The name of the plugin is `mypy-pycharm`, can I use it also with IntelliJ IDEA?
This plugin officially supports only PyCharm, but it should work also on IntelliJ IDEA
if you have the [Python Community Edition](https://plugins.jetbrains.com/plugin/7322-python-community-edition)
plugin installed. If it does not work, feel free to open a bug on the [issue tracker](https://github.com/leinardi/mypy-pycharm/issues).### I like this plugin, how can I support it?
The best way to support this plugin is to rate it on the [JetBrains Plugin Repository page](https://plugins.jetbrains.com/plugin/11086-mypy) and to star this project on GitHub.
Feedback is always welcome: if you found a bug or would like to suggest a feature,
feel free to open an issue on the [issue tracker](https://github.com/leinardi/mypy-pycharm/issues). If your feedback doesn't fall in the previous categories,
you can always leave a comment on the [Plugin Repository page](https://plugins.jetbrains.com/plugin/11086-mypy).## Acknowledgements
_If I have seen further it is by standing on the shoulders of Giants - Isaac Newton_A huge thanks:
- to the project [CheckStyle-IDEA](https://github.com/jshiell/checkstyle-idea),
which code and architecture I have heavily used when developing this plugin.
- to @intgr, for [the contribution to this project](https://github.com/leinardi/mypy-pycharm/pulls?q=is%3Apr+author%3Aintgr)
## License```
Copyright 2021 Roberto Leinardi.Licensed to the Apache Software Foundation (ASF) under one or more contributor
license agreements. See the NOTICE file distributed with this work for
additional information regarding copyright ownership. The ASF licenses this
file to you under the Apache License, Version 2.0 (the "License"); you may not
use this file except in compliance with the License. You may obtain a copy of
the License athttp://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
License for the specific language governing permissions and limitations under
the License.
```