<div dir="ltr"><div><div><div>There's a PR to the peps proposal here:<br><a href="https://github.com/python/peps/pull/242">https://github.com/python/peps/pull/242</a><br><br></div>The full text of the current proposal is below. The motivation for this is that for complex decorators, even if the type checker can figure out what's going on (by taking the signature of the decorator into account), it's sometimes helpful to the human reader of the code to be reminded of the type after applying the decorators (or a stack thereof). Much discussion can be found in the PR. Note that we ended up having `Callable` in the type because there's no rule that says a decorator returns a function type (e.g. `property` doesn't).<br><br></div>This is a small thing but I'd like to run it by a larger audience than the core mypy devs who have commented so far.<br><br></div>Here's the proposed text (wordsmithing suggestions in the PR please):<br><div><div><br>+Decorators<br>+----------<br>+<br>+Decorators can modify the types of the functions or classes they<br>+decorate. Use the ``decorated_type`` decorator to declare the type of<br>+the resulting item after all other decorators have been applied::<br>+<br>+ from typing import ContextManager, Iterator, decorated_type<br>+ from contextlib import contextmanager<br>+<br>+ class DatabaseSession: ...<br>+<br>+ @decorated_type(Callable[[str], ContextManager[DatabaseSession]])<br>+ @contextmanager<br>+ def session(url: str) -> Iterator[DatabaseSession]:<br>+ s = DatabaseSession(url)<br>+ try:<br>+ yield s<br>+ finally:<br>+ s.close()<br>+<br>+The argument of ``decorated_type`` is a type annotation on the name<br>+being declared (``session``, in the example above). If you have<br>+multiple decorators, ``decorated_type`` must be topmost. The<br>+``decorated_type`` decorator is invalid on a function declaration that<br>+is also decorated with ``overload``, but you can annotate the<br>+implementation of the overload series with ``decorated_type``.<br>+<br clear="all"><div><div><br>-- <br><div class="gmail_signature">--Guido van Rossum (<a href="http://python.org/%7Eguido" target="_blank">python.org/~guido</a>)</div>
</div></div></div></div></div>