diff options
author | Jelle Zijlstra <jelle.zijlstra@gmail.com> | 2017-12-13 17:19:17 -0800 |
---|---|---|
committer | Yury Selivanov <yury@magic.io> | 2017-12-13 20:19:17 -0500 |
commit | 176baa326be4ec2dc70ca0c054b7e2ab7ca6a9cf (patch) | |
tree | 308b48c9671eb33abe108d59b87eaaccad40d9eb /Lib/contextlib.py | |
parent | bfbf04ef18c93ca8cab0453f76aeea1d8fc23fb1 (diff) | |
download | cpython-176baa326be4ec2dc70ca0c054b7e2ab7ca6a9cf.tar.gz cpython-176baa326be4ec2dc70ca0c054b7e2ab7ca6a9cf.zip |
bpo-30241: implement contextlib.AbstractAsyncContextManager (#1412)
Diffstat (limited to 'Lib/contextlib.py')
-rw-r--r-- | Lib/contextlib.py | 27 |
1 files changed, 25 insertions, 2 deletions
diff --git a/Lib/contextlib.py b/Lib/contextlib.py index c1f8a84617f..96c8c22084a 100644 --- a/Lib/contextlib.py +++ b/Lib/contextlib.py @@ -6,7 +6,8 @@ from collections import deque from functools import wraps __all__ = ["asynccontextmanager", "contextmanager", "closing", "nullcontext", - "AbstractContextManager", "ContextDecorator", "ExitStack", + "AbstractContextManager", "AbstractAsyncContextManager", + "ContextDecorator", "ExitStack", "redirect_stdout", "redirect_stderr", "suppress"] @@ -30,6 +31,27 @@ class AbstractContextManager(abc.ABC): return NotImplemented +class AbstractAsyncContextManager(abc.ABC): + + """An abstract base class for asynchronous context managers.""" + + async def __aenter__(self): + """Return `self` upon entering the runtime context.""" + return self + + @abc.abstractmethod + async def __aexit__(self, exc_type, exc_value, traceback): + """Raise any exception triggered within the runtime context.""" + return None + + @classmethod + def __subclasshook__(cls, C): + if cls is AbstractAsyncContextManager: + return _collections_abc._check_methods(C, "__aenter__", + "__aexit__") + return NotImplemented + + class ContextDecorator(object): "A base class or mixin that enables context managers to work as decorators." @@ -136,7 +158,8 @@ class _GeneratorContextManager(_GeneratorContextManagerBase, raise RuntimeError("generator didn't stop after throw()") -class _AsyncGeneratorContextManager(_GeneratorContextManagerBase): +class _AsyncGeneratorContextManager(_GeneratorContextManagerBase, + AbstractAsyncContextManager): """Helper for @asynccontextmanager.""" async def __aenter__(self): |