summaryrefslogtreecommitdiffstats
path: root/Doc/library/typing.rst
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2016-09-07 04:12:44 (GMT)
committerGuido van Rossum <guido@python.org>2016-09-07 04:12:44 (GMT)
commite848cd7605a7891378ef1463e933939aa253df71 (patch)
tree12fdf7e3fd0fde1eafa9e6248e9c8d57729a8b31 /Doc/library/typing.rst
parent33d2a492d0c0c29f526fae1e0f164fe14864cc2e (diff)
downloadcpython-e848cd7605a7891378ef1463e933939aa253df71.zip
cpython-e848cd7605a7891378ef1463e933939aa253df71.tar.gz
cpython-e848cd7605a7891378ef1463e933939aa253df71.tar.bz2
Issue #27905: Docs for typing.Type[C], by Michael Lee.
Diffstat (limited to 'Doc/library/typing.rst')
-rw-r--r--Doc/library/typing.rst39
1 files changed, 39 insertions, 0 deletions
diff --git a/Doc/library/typing.rst b/Doc/library/typing.rst
index bc71e1e..83a8dcf 100644
--- a/Doc/library/typing.rst
+++ b/Doc/library/typing.rst
@@ -502,6 +502,45 @@ The module defines the following classes, functions and decorators:
except KeyError:
return default
+.. class:: Type
+
+ A variable annotated with ``C`` may accept a value of type ``C``. In
+ contrast, a variable annotated with ``Type[C]`` may accept values that are
+ classes themselves -- specifically, it will accept the *class object* of
+ ``C``. For example::
+
+ a = 3 # Has type 'int'
+ b = int # Has type 'Type[int]'
+ c = type(a) # Also has type 'Type[int]'
+
+ Note that ``Type[C]`` is covariant::
+
+ class User: ...
+ class BasicUser(User): ...
+ class ProUser(User): ...
+ class TeamUser(User): ...
+
+ # Accepts User, BasicUser, ProUser, TeamUser, ...
+ def make_new_user(user_class: Type[User]) -> User:
+ # ...
+ return user_class()
+
+ The fact that ``Type[C]`` is covariant implies that all subclasses of
+ ``C`` should implement the same constructor signature and class method
+ signatures as ``C``. The type checker should flag violations of this,
+ but should also allow constructor calls in subclasses that match the
+ constructor calls in the indicated base class. How the type checker is
+ required to handle this particular case may change in future revisions of
+ PEP 484.
+
+ The only legal parameters for ``Type`` are classes, unions of classes, and
+ ``Any``. For example::
+
+ def new_non_team_user(user_class: Type[Union[BaseUser, ProUser]]): ...
+
+ ``Type[Any]`` is equivalent to ``Type`` which in turn is equivalent
+ to ``type``, which is the root of Python's metaclass hierarchy.
+
.. class:: Iterable(Generic[T_co])
A generic version of the :class:`collections.abc.Iterable`.