a
    Ó—àa  ã                   @   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ÚctxZ	func_call© r   ú2/home/manager/Python-3.9.10/Lib/asyncio/threads.pyr      s    
r   )Ú__doc__r   r   Ú r   Ú__all__r   r   r   r   r   Ú<module>   s
   