Skip to content

Allow to extend return types of functions decorated by ContextDecorator with None #14439

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Draft
wants to merge 7 commits into
base: main
Choose a base branch
from
Draft
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Improve the comments
  • Loading branch information
bswck committed Jul 22, 2025
commit ed5debcd689485f99dc3eddab61d748535e799e3
19 changes: 9 additions & 10 deletions stdlib/contextlib.pyi
Original file line number Diff line number Diff line change
Expand Up @@ -64,17 +64,16 @@ class AbstractAsyncContextManager(ABC, Protocol[_T_co, _ExitT_co]): # type: ign
self, exc_type: type[BaseException] | None, exc_value: BaseException | None, traceback: TracebackType | None, /
) -> _ExitT_co: ...

_SuppressedExcReturnT = TypeVar("_SuppressedExcReturnT", Never, None, default=Never)
_ExcReturnT = TypeVar("_ExcReturnT", Never, None, default=Never)

# __exit__ can suppress exceptions by returning a true value.
# _SuppressedReturnT extends the decorated function's return type with
# - Never (default, has no effect on the return type)
# if the decorating context manager never suppresses exceptions;
# - None if the decorating context manager may suppress exceptions.
# _ExcReturnT describes function's return type after an exception occurs:
# - Never (default, the context manager never suppresses exceptions)
# - None (the context manager may suppress exceptions)
# See #13512.
class ContextDecorator(Generic[_SuppressedExcReturnT]):
class ContextDecorator(Generic[_ExcReturnT]):
def _recreate_cm(self) -> Self: ...
def __call__(self, func: Callable[_P, _R]) -> Callable[_P, _R | _SuppressedExcReturnT]: ...
def __call__(self, func: Callable[_P, _R]) -> Callable[_P, _R | _ExcReturnT]: ...

class _GeneratorContextManagerBase(Generic[_G_co]):
# Ideally this would use ParamSpec, but that requires (*args, **kwargs), which this isn't. see #6676
Expand All @@ -96,10 +95,10 @@ class _GeneratorContextManager(
def contextmanager(func: Callable[_P, Iterator[_T_co]]) -> Callable[_P, _GeneratorContextManager[_T_co]]: ...

if sys.version_info >= (3, 10):
# _SuppressedReturnT: see ContextDecorator.
class AsyncContextDecorator(Generic[_SuppressedExcReturnT]):
# _ExcReturnT: see ContextDecorator.
class AsyncContextDecorator(Generic[_ExcReturnT]):
def _recreate_cm(self) -> Self: ...
def __call__(self, func: Callable[_P, _R]) -> Callable[_P, _R | _SuppressedExcReturnT]: ...
def __call__(self, func: Callable[_P, _R]) -> Callable[_P, _R | _ExcReturnT]: ...

class _AsyncGeneratorContextManager(
_GeneratorContextManagerBase[AsyncGenerator[_T_co, _SendT_contra]],
Expand Down
Loading
pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy