
    vg                        d dl mZ d dlmZmZmZmZ d dlmZm	Z	m
Z
 g dZ G d de          Z G d deeef                   Z G d	 d
e	          Ze
eeeef         eeeef                  ef         ZdS )    )annotations)IterableIteratorMappingMutableMapping)AnyProtocolUnion)HeadersHeadersLikeMultipleValuesErrorc                  $     e Zd ZdZd fdZ xZS )r   zP
    Exception raised when :class:`Headers` has multiple values for a key.

    returnstrc                    t          | j                  dk    rt          | j        d                   S t                                                      S N   r   )lenargsreprsuper__str__)self	__class__s    V/var/www/pixelcanvas.ch/venv/lib/python3.11/site-packages/websockets/datastructures.pyr   zMultipleValuesError.__str__   s>    ty>>Q	!%%%ww       r   r   )__name__
__module____qualname____doc__r   __classcell__r   s   @r   r   r   
   sG         
! ! ! ! ! ! ! ! ! !r   r   c                       e Zd ZdZddgZd%d
Zd&dZd&dZd'dZd(dZ	d)dZ
d*dZd+dZd,dZd-dZd.dZd/dZd0dZd% fd Zd1d"Zd2d$Z xZS )3r   a  
    Efficient data structure for manipulating HTTP headers.

    A :class:`list` of ``(name, values)`` is inefficient for lookups.

    A :class:`dict` doesn't suffice because header names are case-insensitive
    and multiple occurrences of headers with the same name are possible.

    :class:`Headers` stores HTTP headers in a hybrid data structure to provide
    efficient insertions and lookups while preserving the original data.

    In order to account for multiple values with minimal hassle,
    :class:`Headers` follows this logic:

    - When getting a header with ``headers[name]``:
        - if there's no value, :exc:`KeyError` is raised;
        - if there's exactly one value, it's returned;
        - if there's more than one value, :exc:`MultipleValuesError` is raised.

    - When setting a header with ``headers[name] = value``, the value is
      appended to the list of values for that header.

    - When deleting a header with ``del headers[name]``, all values for that
      header are removed (this is slow).

    Other methods for manipulating headers are consistent with this logic.

    As long as no header occurs multiple times, :class:`Headers` behaves like
    :class:`dict`, except keys are lower-cased to provide case-insensitivity.

    Two methods support manipulating multiple values explicitly:

    - :meth:`get_all` returns a list of all values for a header;
    - :meth:`raw_items` returns an iterator of ``(name, values)`` pairs.

    _dict_listr   r   kwargsr   r   Nonec                <    i | _         g | _         | j        |i | d S N)r%   r&   update)r   r   r'   s      r   __init__zHeaders.__init__@   s-    +-
,.
T$V$$$$$r   c                P    d                     d | j        D                       dz   S )N c              3  ,   K   | ]\  }}| d | dV  dS )z: 
N ).0keyvalues      r   	<genexpr>z"Headers.__str__.<locals>.<genexpr>F   s7      JJe#,,,,,JJJJJJr   r0   )joinr&   r   s    r   r   zHeaders.__str__E   s*    wwJJtzJJJJJVSSr   c                0    | j         j         d| j        dS )N())r   r   r&   r7   s    r   __repr__zHeaders.__repr__H   s     .);;DJ;;;;r   c                    |                                  }| j                                        |_        | j                                        |_        |S r*   )r   r%   copyr&   )r   r=   s     r   r=   zHeaders.copyK   s<    ~~Z__&&
Z__&&
r   bytesc                D    t          |                                           S r*   )r   encoder7   s    r   	serializezHeaders.serializeQ   s    4yy!!!r   r3   objectboolc                b    t          |t                    o|                                | j        v S r*   )
isinstancer   lowerr%   r   r3   s     r   __contains__zHeaders.__contains__W   s&    #s##A		tz(AAr   Iterator[str]c                *    t          | j                  S r*   )iterr%   r7   s    r   __iter__zHeaders.__iter__Z   s    DJr   intc                *    t          | j                  S r*   )r   r%   r7   s    r   __len__zHeaders.__len__]   s    4:r   c                    | j         |                                         }t          |          dk    r|d         S t          |          r   )r%   rF   r   r   r   r3   r4   s      r   __getitem__zHeaders.__getitem__b   s<    
399;;'u::??8O%c***r   r4   c                    | j                             |                                g                               |           | j                            ||f           d S r*   )r%   
setdefaultrF   appendr&   rQ   s      r   __setitem__zHeaders.__setitem__i   sP    
ciikk2..55e<<<
3,'''''r   c                    |                                 | j                                       fd| j        D             | _        d S )Nc                N    g | ]!\  }}|                                 k    ||f"S r1   )rF   )r2   kv	key_lowers      r   
<listcomp>z'Headers.__delitem__.<locals>.<listcomp>q   s3    NNNAqwwyyI7M7Mq!f7M7M7Mr   )rF   r%   __delitem__r&   )r   r3   r[   s     @r   r]   zHeaders.__delitem__m   sG    IIKK	
y)))NNNNNNN


r   otherr   c                Z    t          |t                    st          S | j        |j        k    S r*   )rE   r   NotImplementedr%   )r   r^   s     r   __eq__zHeaders.__eq__s   s)    %)) 	"!!zU[((r   c                "    i | _         g | _        dS )z&
        Remove all headers.

        N)r%   r&   r7   s    r   clearzHeaders.clearx   s    
 



r   c                l    t          d |D                       } t                      j        |i | dS )zT
        Update from a :class:`Headers` instance and/or keyword arguments.

        c              3  l   K   | ]/}t          |t                    r|                                n|V  0d S r*   )rE   r   	raw_items)r2   args     r   r5   z!Headers.update.<locals>.<genexpr>   sN       
 
EHz#w77@CMMOOOS
 
 
 
 
 
r   N)tupler   r+   )r   r   r'   r   s      r   r+   zHeaders.update   sS    
  
 
LP
 
 
 
 
 	''''''r   	list[str]c                \    | j                             |                                g           S )z|
        Return the (possibly empty) list of all values for a header.

        Args:
            key: Header name.

        )r%   getrF   rG   s     r   get_allzHeaders.get_all   s"     z~~ciikk2...r   Iterator[tuple[str, str]]c                *    t          | j                  S )zO
        Return an iterator of all values as ``(name, value)`` pairs.

        )rK   r&   r7   s    r   rf   zHeaders.raw_items   s    
 DJr   )r   r   r'   r   r   r(   r   )r   r   )r   r>   )r3   rB   r   rC   )r   rI   )r   rM   r3   r   r   r   )r3   r   r4   r   r   r(   )r3   r   r   r(   )r^   r   r   rC   )r   r(   )r3   r   r   ri   )r   rm   )r   r   r    r!   	__slots__r,   r   r;   r=   rA   rH   rL   rO   rR   rV   r]   ra   rc   r+   rl   rf   r"   r#   s   @r   r   r      s       # #J '"I% % % %
T T T T< < < <   " " " "B B B B          
+ + + +( ( ( (O O O O) ) ) )
   ( ( ( ( ( (/ / / /               r   r   c                  "    e Zd ZdZd	dZd
dZdS )SupportsKeysAndGetItemz_
    Dict-like types with ``keys() -> str`` and ``__getitem__(key: str) -> str`` methods.

    r   Iterable[str]c                    d S r*   r1   r7   s    r   keyszSupportsKeysAndGetItem.keys         r   r3   r   c                    d S r*   r1   rG   s     r   rR   z"SupportsKeysAndGetItem.__getitem__   rv   r   N)r   rs   ro   )r   r   r    r!   ru   rR   r1   r   r   rr   rr      s4         
 )(((//////r   rr   N)
__future__r   collections.abcr   r   r   r   typingr   r	   r
   __all__LookupErrorr   r   r   rr   rh   r   r1   r   r   <module>r}      s3   " " " " " " G G G G G G G G G G G G ' ' ' ' ' ' ' ' ' ' <
;
;
! 
! 
! 
! 
!+ 
! 
! 
!D  D  D  D  D nS#X& D  D  D P0 0 0 0 0X 0 0 0 CHU38_ r   