Skip to content

Commit

Permalink
Convert README.rst to README.md (#1150)
Browse files Browse the repository at this point in the history
Closes: #1149
  • Loading branch information
srittau authored Apr 18, 2022
1 parent 61be04f commit 5c45439
Show file tree
Hide file tree
Showing 3 changed files with 148 additions and 161 deletions.
143 changes: 143 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,143 @@
# Typing Extensions

[![Chat at https://gitter.im/python/typing](https://badges.gitter.im/python/typing.svg)](https://gitter.im/python/typing)

## Overview

The `typing_extensions` module serves two related purposes:

- Enable use of new type system features on older Python versions. For example,
`typing.TypeGuard` is new in Python 3.10, but `typing_extensions` allows
users on Python 3.6 through 3.9 to use it too.
- Enable experimentation with new type system PEPs before they are accepted and
added to the `typing` module.

New features may be added to `typing_extensions` as soon as they are specified
in a PEP that has been added to the [python/peps](https://github.com/python/peps)
repository. If the PEP is accepted, the feature will then be added to `typing`
for the next CPython release. No typing PEP has been rejected so far, so we
haven't yet figured out how to deal with that possibility.

Starting with version 4.0.0, `typing_extensions` uses
[Semantic Versioning](https://semver.org/). The
major version is incremented for all backwards-incompatible changes.
Therefore, it's safe to depend
on `typing_extensions` like this: `typing_extensions >=x.y, <(x+1)`,
where `x.y` is the first version that includes all features you need.

`typing_extensions` supports Python versions 3.7 and higher. In the future,
support for older Python versions will be dropped some time after that version
reaches end of life.

## Included items

This module currently contains the following:

- Experimental features

- `@dataclass_transform()` (see PEP 681)

- In `typing` since Python 3.11

- `assert_never`
- `assert_type`
- `clear_overloads`
- `get_overloads`
- `LiteralString` (see PEP 675)
- `Never`
- `NotRequired` (see PEP 655)
- `reveal_type`
- `Required` (see PEP 655)
- `Self` (see PEP 673)
- `TypeVarTuple` (see PEP 646)
- `Unpack` (see PEP 646)

- In `typing` since Python 3.10

- `Concatenate` (see PEP 612)
- `ParamSpec` (see PEP 612)
- `ParamSpecArgs` (see PEP 612)
- `ParamSpecKwargs` (see PEP 612)
- `TypeAlias` (see PEP 613)
- `TypeGuard` (see PEP 647)
- `is_typeddict`

- In `typing` since Python 3.9

- `Annotated` (see PEP 593)

- In `typing` since Python 3.8

- `final` (see PEP 591)
- `Final` (see PEP 591)
- `Literal` (see PEP 586)
- `Protocol` (see PEP 544)
- `runtime_checkable` (see PEP 544)
- `TypedDict` (see PEP 589)
- `get_origin` (`typing_extensions` provides this function only in Python 3.7+)
- `get_args` (`typing_extensions` provides this function only in Python 3.7+)

- In `typing` since Python 3.7

- `OrderedDict`

- In `typing` since Python 3.5 or 3.6 (see [the typing documentation](https://docs.python.org/3.10/library/typing.html) for details)

- `AsyncContextManager`
- `AsyncGenerator`
- `AsyncIterable`
- `AsyncIterator`
- `Awaitable`
- `ChainMap`
- `ClassVar` (see PEP 526)
- `ContextManager`
- `Coroutine`
- `Counter`
- `DefaultDict`
- `Deque`
- `NewType`
- `NoReturn`
- `overload`
- `Text`
- `Type`
- `TYPE_CHECKING`
- `get_type_hints`

# Other Notes and Limitations

Certain objects were changed after they were added to `typing`, and
`typing_extensions` provides a backport even on newer Python versions:

- `TypedDict` does not store runtime information
about which (if any) keys are non-required in Python 3.8, and does not
honor the `total` keyword with old-style `TypedDict()` in Python
3.9.0 and 3.9.1.
- `get_origin` and `get_args` lack support for `Annotated` in
Python 3.8 and lack support for `ParamSpecArgs` and `ParamSpecKwargs`
in 3.9.
- `@final` was changed in Python 3.11 to set the `.__final__` attribute.
- `@overload` was changed in Python 3.11 to make function overloads
introspectable at runtime. In order to access overloads with
`typing_extensions.get_overloads()`, you must use
`@typing_extensions.overload`.

There are a few types whose interface was modified between different
versions of typing. For example, `typing.Sequence` was modified to
subclass `typing.Reversible` as of Python 3.5.3.

These changes are _not_ backported to prevent subtle compatibility
issues when mixing the differing implementations of modified classes.

Certain types have incorrect runtime behavior due to limitations of older
versions of the typing module:

- `ParamSpec` and `Concatenate` will not work with `get_args` and
`get_origin`. Certain PEP 612 special cases in user-defined
`Generic`s are also not available.

These types are only guaranteed to work for static type checking.

## Running tests

To run tests, navigate into the appropriate source directory and run
`test_typing_extensions.py`.
152 changes: 0 additions & 152 deletions README.rst

This file was deleted.

14 changes: 5 additions & 9 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ build-backend = "flit_core.buildapi"
name = "typing_extensions"
version = "4.2.0"
description = "Backported and Experimental Type Hints for Python 3.7+"
readme = "README.rst"
readme = "README.md"
requires-python = ">=3.7"
license.file = "LICENSE"
keywords = [
Expand All @@ -23,7 +23,7 @@ keywords = [
"typechecking",
"typehinting",
"typehints",
"typing"
"typing",
]
# Classifiers list: https://pypi.org/classifiers/
classifiers = [
Expand All @@ -39,11 +39,11 @@ classifiers = [
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
"Topic :: Software Development"
"Topic :: Software Development",
]

[project.urls]
Home = "https://github.com/python/typing/blob/master/typing_extensions/README.rst"
Home = "https://github.com/python/typing/blob/master/typing_extensions/README.md"
Repository = "https://github.com/python/typing"
Changes = "https://github.com/python/typing/blob/master/typing_extensions/CHANGELOG.md"
Documentation = "https://typing.readthedocs.io/"
Expand All @@ -57,9 +57,5 @@ name = "Guido van Rossum, Jukka Lehtosalo, Łukasz Langa, Michael Lee"
email = "levkivskyi@gmail.com"

[tool.flit.sdist]
include = [
"CHANGELOG.md",
"README.rst",
"*/test*.py"
]
include = ["CHANGELOG.md", "README.md", "*/test*.py"]
exclude = []

0 comments on commit 5c45439

Please sign in to comment.