File: //proc/676643/root/usr/lib/python3.10/asyncio/__pycache__/streams.cpython-310.pyc
o
    E�h�d  �                   @   s&  d Z ddlZddlZddlZddlZddlZeed�re d7 Z ddlmZ ddlm	Z	 ddlm
Z
 dd	lmZ dd
lmZ ddl
mZ ddlmZ d
Zded�dd�Zded�dd�Zeed�rpd ed�dd�Zd ed�dd�ZG dd� dej�ZG dd� deej�ZG dd� d�ZG dd� d�ZdS )!)�StreamReader�StreamWriter�StreamReaderProtocol�open_connection�start_server�    N�AF_UNIX)�open_unix_connection�start_unix_server�   )�
coroutines)�events)�
exceptions)�format_helpers)�	protocols)�logger)�sleepi   )�limitc          	      �   s`   �t �� }t||d�}t||d�� |j� fdd�| |fi |��I dH \}}t|� ||�}||fS )a�  A wrapper for create_connection() returning a (reader, writer) pair.
    The reader returned is a StreamReader instance; the writer is a
    StreamWriter instance.
    The arguments are all the usual arguments to create_connection()
    except protocol_factory; most common are positional host and port,
    with various optional keyword arguments following.
    Additional optional keyword arguments are loop (to set the event loop
    instance to use) and limit (to set the buffer limit passed to the
    StreamReader).
    (If you want to customize the StreamReader and/or
    StreamReaderProtocol classes, just copy the code -- there's
    really nothing special here except some convenience.)
    �r   �loop�r   c                      �   � S �N� r   ��protocolr   �&/usr/lib/python3.10/asyncio/streams.py�<lambda>1   �    z!open_connection.<locals>.<lambda>N)r   �get_running_loopr   r   �create_connectionr   )	�host�portr   �kwdsr   �reader�	transport�_�writerr   r   r   r      s   ���r   c                �   s6   �t �� �� ��fdd�}�j|||fi |��I dH S )a�  Start a socket server, call back for each client connected.
    The first parameter, `client_connected_cb`, takes two parameters:
    client_reader, client_writer.  client_reader is a StreamReader
    object, while client_writer is a StreamWriter object.  This
    parameter can either be a plain callback function or a coroutine;
    if it is a coroutine, it will be automatically converted into a
    Task.
    The rest of the arguments are all the usual arguments to
    loop.create_server() except protocol_factory; most common are
    positional host and port, with various optional keyword arguments
    following.  The return value is the same as loop.create_server().
    Additional optional keyword arguments are loop (to set the event loop
    instance to use) and limit (to set the buffer limit passed to the
    StreamReader).
    The return value is the same as loop.create_server(), i.e. a
    Server object which can be used to stop the service.
    c                     �   t ��d�} t| � �d�}|S �Nr   r   �r   r   �r#   r   ��client_connected_cbr   r   r   r   �factoryO   �
   �zstart_server.<locals>.factoryN)r   r   �
create_server)r,   r    r!   r   r"