
    wh/                        d dl mZ d dlZd dlmZ d dlZd dlZddl	m
Z
  G d de
eeef            Z ej                  d      ZddZ G d	 d
e      Z ej                  d      ZddZ G d de      Z G d de      Zy)    )annotationsN   )ImmutableListc                  ~    e Zd ZdZ	 d	 	 	 d fdZddZddZej                  dd       Z	ej                  dd       Z	ej                  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ej                  d#d       Zej                  d$d%d       Z	 d&	 	 	 	 	 d'dZed(d       Z xZS ))Accepta  An :class:`Accept` object is just a list subclass for lists of
    ``(value, quality)`` tuples.  It is automatically sorted by specificity
    and quality.

    All :class:`Accept` objects work similar to a list but provide extra
    functionality for working with the data.  Containment checks are
    normalized to the rules of that header:

    >>> a = CharsetAccept([('ISO-8859-1', 1), ('utf-8', 0.7)])
    >>> a.best
    'ISO-8859-1'
    >>> 'iso-8859-1' in a
    True
    >>> 'UTF8' in a
    True
    >>> 'utf7' in a
    False

    To get the quality for an item you can use normal item lookup:

    >>> print a['utf-8']
    0.7
    >>> a['utf7']
    0

    .. versionchanged:: 0.5
       :class:`Accept` objects are forced immutable now.

    .. versionchanged:: 1.0.0
       :class:`Accept` internal values are no longer ordered
       alphabetically for equal quality tags. Instead the initial
       order is preserved.

    c                     |t                    d _        y t        |t              r!|j                   _        t            |       y d _        t        | fdd      }t            |       y )NFTc                6    j                  | d         | d   fS )Nr   r   )_specificity)xselfs    V/var/www/flask-api/venv/lib/python3.12/site-packages/werkzeug/datastructures/accept.py<lambda>z!Accept.__init__.<locals>.<lambda>;   s    t'8'81'>!&E     )keyreverse)super__init__provided
isinstancer   sorted)r   values	__class__s   ` r   r   zAccept.__init__/   sf     >G!DM'"OODMGV$ DMEtF GV$r   c                    |dk7  fS )z3Returns a tuple describing the value's specificity.* r   values     r   r
   zAccept._specificity?   s    r   c                R    |dk(  xs! |j                         |j                         k(  S )z-Check if a value matches a given accept item.r   )lowerr   r   items      r   _value_matcheszAccept._value_matchesC   s"    s{;djjlekkm;;r   c                     y Nr   r   r   s     r   __getitem__zAccept.__getitem__G   s    .1r   c                     y r$   r   r%   s     r   r&   zAccept.__getitem__I   s    FIr   c                     y r$   r   r%   s     r   r&   zAccept.__getitem__K   s    BEr   c                p    t        |t              r| j                  |      S t        j	                  | |      S )zBesides index lookup (getting item n) you can also pass it a string
        to get the quality for the item.  If the item is not in the list, the
        returned quality is ``0``.
        )r   strqualitylistr&   r%   s     r   r&   zAccept.__getitem__M   s0     c3<<$$c**r   c                D    | D ]  \  }}| j                  ||      s|c S  y)zReturns the quality of the key.

        .. versionadded:: 0.6
           In previous versions you had to use the item-lookup syntax
           (eg: ``obj[key]`` instead of ``obj.quality(key)``)
        r   r"   )r   r   r!   r+   s       r   r+   zAccept.qualityX   s1     " 	MD'""3-	 r   c                @    | D ]  \  }}| j                  ||      s y y)NTFr.   )r   r   r!   _qualitys       r   __contains__zAccept.__contains__d   s-    " 	ND(""5$/	 r   c                h    dj                  d | D              }t        |       j                   d| dS )N, c              3  4   K   | ]  \  }}d |d| d  yw)(r3   )Nr   ).0r   ys      r   	<genexpr>z"Accept.__repr__.<locals>.<genexpr>k   s"     ?$!Q!b1o?s   z([z]))jointype__name__)r   	pairs_strs     r   __repr__zAccept.__repr__j   s4    II?$??	t*%%&b266r   c                    t        |t              r7t        |       D ]  \  }\  }}| j                  ||      s|c S  t	        |      t
        j                  | |      S )zGet the position of an entry or raise :exc:`ValueError`.

        :param key: The key to be looked up.

        .. versionchanged:: 0.5
           This used to raise :exc:`IndexError`, which was inconsistent
           with the list API.
        )r   r*   	enumerater"   
ValueErrorr,   index)r   r   idxr!   r0   s        r   rB   zAccept.indexn   s]     c3)24 %%dH&&sD1J S/!zz$$$r   c                D    	 | j                  |      S # t        $ r Y yw xY w)zaGet the position of an entry or return -1.

        :param key: The key to be looked up.
        )rB   rA   r%   s     r   findzAccept.find~   s'    
	::c?" 		s    	c              #  (   K   | D ]	  }|d     yw)zIterate over all values.r   Nr   )r   r!   s     r   r   zAccept.values   s      	Dq'M	s   c                v    g }| D ]"  \  }}|dk7  r| d| }|j                  |       $ dj                  |      S )z2Convert the header set into an HTTP header string.r   z;q=,)appendr:   )r   resultr   r+   s       r   	to_headerzAccept.to_header   sN    " 	!NE7!| 'WI.MM% 	! xxr   c                "    | j                         S r$   )rL   r   s    r   __str__zAccept.__str__   s    ~~r   c                H    | D ]  \  }}| j                  ||      s||fc S  y r$   r.   )r   matchclient_itemr+   s       r   _best_single_matchzAccept._best_single_match   s6    $( 	, K""5+6"G++	, r   c                     y r$   r   r   matchess     r   
best_matchzAccept.best_match       EHr   c                     y r$   r   r   rV   defaults      r   rW   zAccept.best_match       RUr   c                    |}d}d}|D ]H  }| j                  |      }|s|\  }}	| j                  |      }
|	dk  s|	|k  r8|	|kD  s|
|kD  sC|}|	}|
}J |S )aV  Returns the best match from a list of possible matches based
        on the specificity and quality of the client. If two items have the
        same quality and specificity, the one is returned that comes first.

        :param matches: a list of matches to check for
        :param default: the value that is returned if none match
        rE   )rE   r   )rS   r
   )r   rV   r[   rK   best_qualitybest_specificityserver_itemrQ   rR   r+   specificitys              r   rW   zAccept.best_match   s      .3" 	/K++K8E#( K++K8K!|w5%7G)G$&#. 	/ r   c                    | r| d   d   S y)zThe best match as value.r   Nr   rN   s    r   bestzAccept.best   s     71:r   )r   )r   z0Accept | cabc.Iterable[tuple[str, float]] | NonereturnNoner   r*   rd   ztuple[bool, ...]r   r*   r!   r*   rd   bool)r   r*   rd   float)r   zt.SupportsIndexrd   ztuple[str, float])r   slicerd   zlist[tuple[str, float]])r   zstr | t.SupportsIndex | slicerd   z3float | tuple[str, float] | list[tuple[str, float]])r   r*   rd   rh   )rd   r*   )r   zstr | tuple[str, float]rd   int)rd   zcabc.Iterator[str])rQ   r*   rd   ztuple[str, float] | NonerV   cabc.Iterable[str]rd   
str | None.rV   rm   r[   r*   rd   r*   r$   rV   rm   r[   rn   rd   rn   )rd   rn   )r<   
__module____qualname____doc__r   r
   r"   toverloadr&   r+   r1   r>   rB   rF   r   rL   rO   rS   rW   propertyrc   __classcell__r   s   @r   r   r      s   !H JL%F%	% < ZZ1 1ZZI IZZE E	+0	+	<	+
7% 
   ZZH HZZU UAE)4>	8  r   r   z/|(?:\s*;\s*)c                H    t         j                  | j                               S r$   )_mime_split_resplitr   r   s    r   _normalize_mimer~      s    ..r   c                  V    e Zd ZdZddZd	dZed
d       Zed
d       Zed
d       Z	y)
MIMEAcceptzRLike :class:`Accept` but with special methods and behavior for
    mimetypes.
    c                L    t        d t        j                  |      D              S )Nc              3  &   K   | ]	  }|d k7    yw)r   Nr   )r7   r   s     r   r9   z*MIMEAccept._specificity.<locals>.<genexpr>   s     C!Q#XCs   )tupler{   r|   r   s     r   r
   zMIMEAccept._specificity   s    C~';';E'BCCCr   c                t   d|vryd|vrt        d|      t        |      }|d d \  }}t        |dd        }|dk(  r|dk7  rt        d|      t        |      }|d d \  }}	t        |dd        }
|dk(  r|	dk7  ry|dk(  xr |	dk(  xs |dk(  xr |dk(  xs! ||k(  xr |	dk(  xs |dk(  xs |	|k(  xr |
|k(  S )N/Fzinvalid mimetype    r   )rA   r~   r   )r   r   r!   normalized_value
value_typevalue_subtypevalue_paramsnormalized_item	item_typeitem_subtypeitem_paramss              r   r"   zMIMEAccept._value_matches   s1   d? e0	:;; +51$4Ra$8!
M.qr23 #!50	:;; *$/"1"1"5	<_QR01  3 #5,#"5 <c!:ms&:

 # # S C'S M1Qk\6Q
	
r   c                &    d| v xs | j                   S )z!True if this object accepts HTML.z	text/html)accept_xhtmlrN   s    r   accept_htmlzMIMEAccept.accept_html   s     d"7d&7&77r   c                    d| v xs d| v S )z"True if this object accepts XHTML.zapplication/xhtml+xmlzapplication/xmlr   rN   s    r   r   zMIMEAccept.accept_xhtml  s     '$.K2Ct2KKr   c                
    d| v S )z!True if this object accepts JSON.zapplication/jsonr   rN   s    r   accept_jsonzMIMEAccept.accept_json
  s     "T))r   Nrf   rg   )rd   rh   )
r<   rr   rs   rt   r
   r"   rw   r   r   r   r   r   r   r   r      sQ    D&
P 8 8 L L * *r   r   z[_-]c                H    t         j                  | j                               S )z$Process a language tag for matching.)_locale_delim_rer|   r   r}   s    r   _normalize_langr     s    !!%++-00r   c                       e Zd ZdZddZej                  dd       Zej                  dd	d       Z	 d
	 	 	 	 	 d fdZ xZS )LanguageAcceptz>Like :class:`Accept` but with normalization for language tags.c                >    |dk(  xs t        |      t        |      k(  S )Nr   )r   r    s      r   r"   zLanguageAccept._value_matches  s     s{Moe48MMMr   c                     y r$   r   rU   s     r   rW   zLanguageAccept.best_match  rX   r   c                     y r$   r   rZ   s      r   rW   zLanguageAccept.best_match   r\   r   c           	     t   t         |   |      S t        | D cg c]#  }t        j	                  |d   d      d   |d   f% c}      }|j                  |      S |D cg c]  }t        j	                  |d      d    }}t         |   |      t        fd|D              S |S c c}w c c}w )a  Given a list of supported values, finds the best match from
        the list of accepted values.

        Language tags are normalized for the purpose of matching, but
        are returned unchanged.

        If no exact match is found, this will fall back to matching
        the first subtag (primary language only), first with the
        accepted values then with the match values. This partial is not
        applied to any other language subtags.

        The default is returned if no exact or fallback match is found.

        :param matches: A list of supported languages to find a match.
        :param default: The value that is returned if none match.
        r   r   c              3  F   K   | ]  }|j                        s|  y wr$   )
startswith)r7   r!   rK   s     r   r9   z,LanguageAccept.best_match.<locals>.<genexpr>O  s     LDOOF4KLs   !!)r   rW   r   r   r|   next)r   rV   r[   r!   fallbackfallback_matchesrK   r   s         @r   rW   zLanguageAccept.best_match"  s    * #G,M
 JNO$$$T!Wa03T!W=O
 $$W-M LSS4,224;A>SS#$45 LLLL# P Ts   (B0' B5rg   rl   ro   rp   r$   rq   )	r<   rr   rs   rt   r"   ru   rv   rW   rx   ry   s   @r   r   r     sW    HN ZZH HZZU UAE/)/4>/	/ /r   r   c                      e Zd ZdZddZy)CharsetAcceptz9Like :class:`Accept` but with normalization for charsets.c                :    dd}|dk(  xs  ||       ||      k(  S )Nc                    	 t        j                  |       j                  S # t        $ r | j	                         cY S w xY wr$   )codecslookupnameLookupErrorr   )r   s    r   
_normalizez0CharsetAccept._value_matches.<locals>._normalizeX  s7    $}}T*/// $zz|#$s   ! ==r   )r   r*   rd   r*   r   )r   r   r!   r   s       r   r"   zCharsetAccept._value_matchesW  s'    	$ s{Cj/:d3CCCr   Nrg   )r<   rr   rs   rt   r"   r   r   r   r   r   T  s    CDr   r   )r   r*   rd   z	list[str])
__future__r   r   collections.abcabccabcretypingru   
structuresr   r   r*   ri   r   compiler{   r~   r   r   r   r   r   r   r   r   <module>r      s    "   	  %{]5e,- {| ,-/=* =*@ 2::g& 1
9V 9x
DF 
Dr   