123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- 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()
|