o
    ˜»áf  ã                   @   s0   d Z ddlZddlZddlmZ dZdd„ ZdS )z6High-level support for working with threads in asyncioé    Né   )Úevents)Ú	to_threadc                Ï   s@   t  ¡ }t ¡ }tj|j| g|¢R i |¤Ž}| d|¡I dH S )a†  Asynchronously run function *func* in a separate thread.

    Any *args and **kwargs supplied for this function are directly passed
    to *func*. Also, the current :class:`contextvars.Context` is propagated,
    allowing context variables from the main thread to be accessed in the
    separate thread.

    Return a coroutine that can be awaited to get the eventual result of *func*.
    N)r   Úget_running_loopÚcontextvarsÚcopy_contextÚ	functoolsÚpartialÚrunÚrun_in_executor)ÚfuncÚargsÚkwargsÚloopÚctxÚ	func_call© r   ú&/usr/lib/python3.10/asyncio/threads.pyr      s
   €
r   )Ú__doc__r   r   Ú r   Ú__all__r   r   r   r   r   Ú<module>   s    