U
    g
                     @  s   d dl mZ d dlZd dlmZmZ d dlmZmZ d dl	m
Z
 d dlmZmZmZmZmZ ejdkrxd dlmZmZ nd dlmZmZ erd	d
lmZ edZedddZedZG dd dee ZG dd dedZdS )    )annotationsN)ABCMetaabstractmethod)	AwaitableCallable)TracebackType)TYPE_CHECKINGAnyProtocolTypeVaroverload)      )TypeVarTupleUnpack   )CancelScopeT_RetvalT_contraT)contravariantPosArgsTc                   @  sF   e Zd ZedddddZedddddZdd
ddddZd	S )
TaskStatuszTaskStatus[None]None)selfreturnc                 C  s   d S N r   r   r   4/tmp/pip-unpacked-wheel-3u0cc9gf/anyio/abc/_tasks.pystarted   s    zTaskStatus.startedr   )valuer   c                 C  s   d S r   r   r   r    r   r   r   r      s    NzT_contra | Nonec                 C  s   dS )zx
        Signal that the task has started.

        :param value: object passed back to the starter of the task
        Nr   r!   r   r   r   r      s    )N)__name__
__module____qualname__r   r   r   r   r   r   r      s
   r   c                   @  s   e Zd ZU dZded< edddddd	d
ddZeddddddd
ddZed dddZedddddddZ	dS )	TaskGroupz
    Groups several asynchronous tasks together.

    :ivar cancel_scope: the cancel scope inherited by all child tasks
    :vartype cancel_scope: CancelScope
    r   Zcancel_scopeN)namez,Callable[[Unpack[PosArgsT]], Awaitable[Any]]zUnpack[PosArgsT]objectr   )funcargsr&   r   c                G  s   dS )a  
        Start a new task in this task group.

        :param func: a coroutine function
        :param args: positional arguments to call the function with
        :param name: name of the task, for the purposes of introspection and debugging

        .. versionadded:: 3.0
        Nr   r   r(   r&   r)   r   r   r   
start_soon/   s    zTaskGroup.start_soonzCallable[..., Awaitable[Any]]r	   c                  s   dS )a  
        Start a new task and wait until it signals for readiness.

        :param func: a coroutine function
        :param args: positional arguments to call the function with
        :param name: name of the task, for the purposes of introspection and debugging
        :return: the value passed to ``task_status.started()``
        :raises RuntimeError: if the task finishes without calling
            ``task_status.started()``

        .. versionadded:: 3.0
        Nr   r*   r   r   r   start@   s    zTaskGroup.start)r   c                   s   dS )z:Enter the task group context and allow starting new tasks.Nr   r   r   r   r   
__aenter__T   s    zTaskGroup.__aenter__ztype[BaseException] | NonezBaseException | NonezTracebackType | Nonezbool | None)exc_typeexc_valexc_tbr   c                   s   dS )z<Exit the task group context waiting for all tasks to finish.Nr   )r   r.   r/   r0   r   r   r   	__aexit__X   s    zTaskGroup.__aexit__)
r"   r#   r$   __doc____annotations__r   r+   r,   r-   r1   r   r   r   r   r%   %   s   
r%   )	metaclass)
__future__r   sysabcr   r   collections.abcr   r   typesr   typingr   r	   r
   r   r   version_infor   r   Ztyping_extensionsZ_core._tasksr   r   r   r   r   r%   r   r   r   r   <module>   s   
