Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/decorator-factory/flake8-pep585
flake8 plugin to enforce new-style type hints (PEP 585)
https://github.com/decorator-factory/flake8-pep585
flake8 flake8-plugin python typing
Last synced: 3 months ago
JSON representation
flake8 plugin to enforce new-style type hints (PEP 585)
- Host: GitHub
- URL: https://github.com/decorator-factory/flake8-pep585
- Owner: decorator-factory
- License: mpl-2.0
- Created: 2022-01-22T15:16:39.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2023-02-28T19:37:34.000Z (almost 2 years ago)
- Last Synced: 2024-11-01T03:32:31.004Z (3 months ago)
- Topics: flake8, flake8-plugin, python, typing
- Language: Python
- Homepage: https://pypi.org/project/flake8-pep585/
- Size: 47.9 KB
- Stars: 22
- Watchers: 2
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-flake8-extensions - flake8-pep585 - Enforce new style annotations from [PEP585](https://peps.python.org/pep-0585/) such as `list[int]` instead of `typing.List[int]`. (Type annotations)
README
# flake8-pep585
This plugin enforces the changes proposed by [PEP 585](https://peps.python.org/pep-0585/).
## What does PEP 585 change?
Before PEP 585, you had to import stuff from `typing` to annotate some objects from the standard library:
- For context managers, you'd import `typing.ContextManager`
- For lists, you'd import `typing.List`
- For callables, you'd import `typing.Callable`
- ...and so onWith PEP 585, you can now use classes already present in the standard library. For example:
- For a context manager giving an `int`, use `contextlib.AbstractContextManager[int]`
- For a `list` of `dict`s mapping `str`s to `int`s, use `list[dict[str, int]]`
- For a callable taking a `float` and returning an `int`, use `collections.abc.Callable[[float], int]``typing.List`, `typing.Callable` etc. are now deprecated. This is pretty hard to discover, since these
imports don't cause a deprecation warning. IDEs don't help either: the "auto-import" feature often suggests
importing a deprecated item.This plugin lets you find these deprecated imports.
## Examples
### Direct import
```py
from typing import Callable
```
```
PEA001 typing.Callable is deprecated, use collections.abc.Callable instead. See PEP 585 for details
```### Qualified import
```py
from datetime import time
import typing as tydef construct_time(match: ty.Match) -> time:
return time(
hour=int(match["hour"]),
minute=int(match["minute"]),
)
```
```
PEA001 typing.Match is deprecated, use re.Match instead. See PEP 585 for details
```# Installation
1. Make sure you have `flake8` installed
2. Run `pip install flake8-pep585`
3. Run `flake8` on your code# Configuration
Via your `setup.cfg` file:
```ini
[flake8]
pep585-activation = always # "always", "auto" or "never"# Symbols that you're okay with being imported from `typing`
pep585-whitelisted-symbols =
Callable
Match
Pattern
```Via the CLI:
```
python -m flake8 --pep585-activation=always your_project/file.py
```This only changes how the plugin behaves on Python 3.7.x and Python 3.8.x. By default ("auto"), it will be enabled
if a `from __future__ import annotations` line is found.