a
    äIþ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   Zget_running_loopÚcontextvarsZcopy_contextÚ	functoolsÚpartialÚrunZrun_in_executor)ÚfuncÚargsÚkwargsZloopÚctxZ	func_call© r   ú lib/python3.9/asyncio/threads.pyr      s    
r   )Ú__doc__r   r   Ú r   Ú__all__r   r   r   r   r   Ú<module>   s
   