
    >wgS)                         d Z ddlmZ ddlZddlmZ dZddd	d
dZi Zd Z	d Z
d Z G d de      Z e
d      Z e
d      Z e
d      Zd dZd ZedfdZd dZd ZedfdZd Z G d de      Z G d de      Zy)!a  

    webencodings
    ~~~~~~~~~~~~

    This is a Python implementation of the `WHATWG Encoding standard
    <http://encoding.spec.whatwg.org/>`. See README for details.

    :copyright: Copyright 2012 by Simon Sapin
    :license: BSD, see LICENSE for details.

    )unicode_literalsN   )LABELSz0.5.1z
iso-8859-8zmac-cyrillicz	mac-romancp874)ziso-8859-8-izx-mac-cyrillic	macintoshzwindows-874c                 ^    | j                  d      j                         j                  d      S )a9  Transform (only) ASCII letters to lower case: A-Z is mapped to a-z.

    :param string: An Unicode string.
    :returns: A new Unicode string.

    This is used for `ASCII case-insensitive
    <http://encoding.spec.whatwg.org/#ascii-case-insensitive>`_
    matching of encoding labels.
    The same matching is also used, among other things,
    for `CSS keywords <http://dev.w3.org/csswg/css-values/#keywords>`_.

    This is different from the :meth:`~py:str.lower` method of Unicode strings
    which also affect non-ASCII characters,
    sometimes mapping them into the ASCII range:

        >>> keyword = u'Bac\N{KELVIN SIGN}ground'
        >>> assert keyword.lower() == u'background'
        >>> assert ascii_lower(keyword) != keyword.lower()
        >>> assert ascii_lower(keyword) == u'bac\N{KELVIN SIGN}ground'

    utf8)encodelowerdecode)strings    L/var/www/horilla/myenv/lib/python3.12/site-packages/webencodings/__init__.pyascii_lowerr   #   s'    . == &&(//77    c                 0   t        | j                  d            } t        j                  |       }|yt        j                  |      }|L|dk(  rddlm} n+t        j                  ||      }t        j                  |      }t        ||      }|t        |<   |S )u<  
    Look for an encoding by its label.
    This is the spec’s `get an encoding
    <http://encoding.spec.whatwg.org/#concept-encoding-get>`_ algorithm.
    Supported labels are listed there.

    :param label: A string.
    :returns:
        An :class:`Encoding` object, or :obj:`None` for an unknown label.

    z	
 Nzx-user-definedr   )
codec_info)r   stripr   getCACHEx_user_definedr   PYTHON_NAMEScodecslookupEncoding)labelnameencodingr   python_names        r   r   r   =   s     K01E::eD|yyH##2&**46K{3JD*-dOr   c                 X    t        | d      r| S t        |       }|t        d| z        |S )z
    Accept either an encoding object or label.

    :param encoding: An :class:`Encoding` object or a label string.
    :returns: An :class:`Encoding` object.
    :raises: :exc:`~exceptions.LookupError` for an unknown label.

    r   zUnknown encoding label: %r)hasattrr   LookupError)encoding_or_labelr   s     r   _get_encodingr#   [   s=      ,/  '(H69JJKKOr   c                       e Zd ZdZd Zd Zy)r   aO  Reresents a character encoding such as UTF-8,
    that can be used for decoding or encoding.

    .. attribute:: name

        Canonical name of the encoding

    .. attribute:: codec_info

        The actual implementation of the encoding,
        a stdlib :class:`~codecs.CodecInfo` object.
        See :func:`codecs.register`.

    c                      || _         || _        y N)r   r   )selfr   r   s      r   __init__zEncoding.__init__|   s    	$r   c                      d| j                   z  S )Nz<Encoding %s>)r   )r'   s    r   __repr__zEncoding.__repr__   s    **r   N)__name__
__module____qualname____doc__r(   r*    r   r   r   r   m   s    %+r   r   zutf-8zutf-16lezutf-16bec                     t        |      }t        |       \  }} |xs |}|j                  j                  | |      d   |fS )a  
    Decode a single string.

    :param input: A byte string
    :param fallback_encoding:
        An :class:`Encoding` object or a label string.
        The encoding to use if :obj:`input` does note have a BOM.
    :param errors: Type of error handling. See :func:`codecs.register`.
    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.
    :return:
        A ``(output, encoding)`` tuple of an Unicode string
        and an :obj:`Encoding`.

    r   )r#   _detect_bomr   r   )inputfallback_encodingerrorsbom_encodingr   s        r   r   r      sM      &&78%e,L%00H%%eV4Q7AAr   c                     | j                  d      rt        | dd fS | j                  d      rt        | dd fS | j                  d      rt        | dd fS d| fS )zBReturn (bom_encoding, input), with any BOM removed from the input.s      Ns   s   ﻿   )
startswith_UTF16LE_UTF16BEUTF8)r2   s    r   r1   r1      sh    $qr""$qr""(U12Y;r   strictc                 R    t        |      j                  j                  | |      d   S )a;  
    Encode a single string.

    :param input: An Unicode string.
    :param encoding: An :class:`Encoding` object or a label string.
    :param errors: Type of error handling. See :func:`codecs.register`.
    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.
    :return: A byte string.

    r   )r#   r   r
   )r2   r   r4   s      r   r
   r
      s'     "--44UFCAFFr   c                 P    t        ||      }t        | |      }t        |      }||fS )a  
    "Pull"-based decoder.

    :param input:
        An iterable of byte strings.

        The input is first consumed just enough to determine the encoding
        based on the precense of a BOM,
        then consumed on demand when the return value is.
    :param fallback_encoding:
        An :class:`Encoding` object or a label string.
        The encoding to use if :obj:`input` does note have a BOM.
    :param errors: Type of error handling. See :func:`codecs.register`.
    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.
    :returns:
        An ``(output, encoding)`` tuple.
        :obj:`output` is an iterable of Unicode strings,
        :obj:`encoding` is the :obj:`Encoding` that is being used.

    )IncrementalDecoder_iter_decode_generatornext)r2   r3   r4   decoder	generatorr   s         r   iter_decoderE      s1    , !!2F;G&ug6IIHhr   c              #   H  K   |j                   }t        |       } | D ].  } ||      }|s|j                  J |j                   |  n.  |dd      }|j                  J |j                   |r| y| D ]  } ||      }|s|   |dd      }|r| yyw)zqReturn a generator that first yields the :obj:`Encoding`,
    then yields output chukns as Unicode strings.

    Nr   Tfinal)r   iterr   )r2   rC   r   chunckoutputs        r   rA   rA      s     
 ^^FKE ##///"""L 4(+++L L Ct$F s   'B"AB"
B"c                 F    t        ||      j                  }t        | |      S )uY  
    “Pull”-based encoder.

    :param input: An iterable of Unicode strings.
    :param encoding: An :class:`Encoding` object or a label string.
    :param errors: Type of error handling. See :func:`codecs.register`.
    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.
    :returns: An iterable of byte strings.

    )IncrementalEncoderr
   _iter_encode_generator)r2   r   r4   r
   s       r   iter_encoderO      s#      &188F!%00r   c              #   Z   K   | D ]  } ||      }|s|   |dd      }|r| y y w)N TrG   r/   )r2   r
   rJ   rK   s       r   rN   rN     sA      L Bd#F s   ++c                        e Zd ZdZddZddZy)r@   uO  
    “Push”-based decoder.

    :param fallback_encoding:
        An :class:`Encoding` object or a label string.
        The encoding to use if :obj:`input` does note have a BOM.
    :param errors: Type of error handling. See :func:`codecs.register`.
    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.

    c                 \    t        |      | _        || _        d| _        d | _        d | _        y )Nr   )r#   _fallback_encoding_errors_buffer_decoderr   )r'   r3   r4   s      r   r(   zIncrementalDecoder.__init__  s.    "/0A"B
 r   c                 B   | j                   }|	 |||      S | j                  |z   }t        |      \  }}|$t        |      dk  r
|s|| _        y| j                  }|j
                  j                  | j                        j                  }|| _         || _	         |||      S )zDecode one chunk of the input.

        :param input: A byte string.
        :param final:
            Indicate that no more input is available.
            Must be :obj:`True` if this is the last call.
        :returns: An Unicode string.

        r8   rQ   )
rW   rV   r1   lenrT   r   incrementaldecoderrU   r   r   )r'   r2   rH   rC   r   s        r   r   zIncrementalDecoder.decode'  s     --5%((u$%e,%5zA~e$22%%88FMM ue$$r   Nreplace)F)r+   r,   r-   r.   r(   r   r/   r   r   r@   r@     s    	
%r   r@   c                       e Zd ZdZedfdZy)rM   u  
    “Push”-based encoder.

    :param encoding: An :class:`Encoding` object or a label string.
    :param errors: Type of error handling. See :func:`codecs.register`.
    :raises: :exc:`~exceptions.LookupError` for an unknown encoding label.

    .. method:: encode(input, final=False)

        :param input: An Unicode string.
        :param final:
            Indicate that no more input is available.
            Must be :obj:`True` if this is the last call.
        :returns: A byte string.

    r=   c                 n    t        |      }|j                  j                  |      j                  | _        y r&   )r#   r   incrementalencoderr
   )r'   r   r4   s      r   r(   zIncrementalEncoder.__init__T  s*     *))<<VDKKr   N)r+   r,   r-   r.   r<   r(   r/   r   r   rM   rM   C  s      !%X Lr   rM   r[   )r.   
__future__r   r   labelsr   VERSIONr   r   r   r   r#   objectr   r<   r:   r;   r   r1   r
   rE   rA   rO   rN   r@   rM   r/   r   r   <module>rd      s    (   
 !$	 	84<$+v +0 g**B,   G8@ !%X 1 0% 0%fL Lr   