Spaces:
Running
Running
from __future__ import annotations | |
import sys | |
from collections.abc import Callable | |
from typing import TypeVar | |
from warnings import warn | |
from ._core._eventloop import get_async_backend | |
from .abc import CapacityLimiter | |
if sys.version_info >= (3, 11): | |
from typing import TypeVarTuple, Unpack | |
else: | |
from typing_extensions import TypeVarTuple, Unpack | |
T_Retval = TypeVar("T_Retval") | |
PosArgsT = TypeVarTuple("PosArgsT") | |
async def run_sync( | |
func: Callable[[Unpack[PosArgsT]], T_Retval], | |
*args: Unpack[PosArgsT], | |
abandon_on_cancel: bool = False, | |
cancellable: bool | None = None, | |
limiter: CapacityLimiter | None = None, | |
) -> T_Retval: | |
""" | |
Call the given function with the given arguments in a worker thread. | |
If the ``cancellable`` option is enabled and the task waiting for its completion is | |
cancelled, the thread will still run its course but its return value (or any raised | |
exception) will be ignored. | |
:param func: a callable | |
:param args: positional arguments for the callable | |
:param abandon_on_cancel: ``True`` to abandon the thread (leaving it to run | |
unchecked on own) if the host task is cancelled, ``False`` to ignore | |
cancellations in the host task until the operation has completed in the worker | |
thread | |
:param cancellable: deprecated alias of ``abandon_on_cancel``; will override | |
``abandon_on_cancel`` if both parameters are passed | |
:param limiter: capacity limiter to use to limit the total amount of threads running | |
(if omitted, the default limiter is used) | |
:return: an awaitable that yields the return value of the function. | |
""" | |
if cancellable is not None: | |
abandon_on_cancel = cancellable | |
warn( | |
"The `cancellable=` keyword argument to `anyio.to_thread.run_sync` is " | |
"deprecated since AnyIO 4.1.0; use `abandon_on_cancel=` instead", | |
DeprecationWarning, | |
stacklevel=2, | |
) | |
return await get_async_backend().run_sync_in_worker_thread( | |
func, args, abandon_on_cancel=abandon_on_cancel, limiter=limiter | |
) | |
def current_default_thread_limiter() -> CapacityLimiter: | |
""" | |
Return the capacity limiter that is used by default to limit the number of | |
concurrent threads. | |
:return: a capacity limiter object | |
""" | |
return get_async_backend().current_default_thread_limiter() | |