o
    jTtex$                     @   sJ  d dl Z d dlZd dlZd dlZd dlmZ d dlmZ d dlm	Z	 d dl
mZ G dd deZd1ddZedeeeejejejfZdd Zd1ddZd1ddZd1ddZd1ddZd1ddZdd Zg deddeddgZd d! eD Zd"Ze d#d! ed$d D  d%d& Z!d'd( Z"d)d* Z#d+d, Z$d-d. Z%d/d0 Z&e& Z'dS )2    N)Decimalquote)RemovedInDjango40Warning)Promisec                       s(   e Zd Z fddZ fddZ  ZS )DjangoUnicodeDecodeErrorc                    s   || _ t j|  d S )N)objsuper__init__)selfr   args	__class__ a/var/www/social.2tendo.club/virtuCedar/venv/lib/python3.10/site-packages/django/utils/encoding.pyr
      s   z!DjangoUnicodeDecodeError.__init__c                    s   dt   | jt| jf S )Nz%s. You passed in %r (%s))r	   __str__r   type)r   r   r   r   r      s   z DjangoUnicodeDecodeError.__str__)__name__
__module____qualname__r
   r   __classcell__r   r   r   r   r      s    r   utf-8Fstrictc                 C      t | tr| S t| |||S )z
    Return a string representing 's'. Treat bytestrings using the 'encoding'
    codec.

    If strings_only is True, don't convert (some) non-string-like objects.
    )
isinstancer   	force_strsencodingstrings_onlyerrorsr   r   r   	smart_str   s   
r!   c                 C   s
   t | tS )zDetermine if the object instance is of a protected type.

    Objects of protected types are preserved as-is when passed to
    force_str(strings_only=True).
    )r   _PROTECTED_TYPES)r   r   r   r   is_protected_type'   s   
r#   c              
   C   sx   t t| tr	| S |rt| r| S zt| tr t| ||} W | S t| } W | S  ty; } z	t| g|jR  d}~ww )z
    Similar to smart_str(), except that lazy instances are resolved to
    strings, rather than kept as lazy objects.

    If strings_only is True, don't convert (some) non-string-like objects.
    N)	
issubclassr   strr#   r   bytesUnicodeDecodeErrorr   r   )r   r   r   r    er   r   r   r   0   s   

r   c                 C   r   )z
    Return a bytestring version of 's', encoded as specified in 'encoding'.

    If strings_only is True, don't convert (some) non-string-like objects.
    )r   r   force_bytesr   r   r   r   smart_bytesF   s   
r*   c                 C   s\   t | tr|dkr| S | d|||S |rt| r| S t | tr&t| S t| ||S )z
    Similar to smart_bytes, except that lazy instances are resolved to
    strings, rather than kept as lazy objects.

    If strings_only is True, don't convert (some) non-string-like objects.
    r   )r   r&   decodeencoder#   
memoryviewr%   r   r   r   r   r)   R   s   

r)   c                 C      t jdtdd t| |||S )Nz3smart_text() is deprecated in favor of smart_str().   
stacklevel)warningswarnr   r!   r   r   r   r   
smart_textf   
   r4   c                 C   r.   )Nz3force_text() is deprecated in favor of force_str().r/   r0   )r2   r3   r   r   r   r   r   r   
force_textn   r5   r6   c                 C   s*   | du r| S t | trt| } t| ddS )u  
    Convert an Internationalized Resource Identifier (IRI) portion to a URI
    portion that is suitable for inclusion in a URL.

    This is the algorithm from section 3.1 of RFC 3987, slightly simplified
    since the input is assumed to be a string rather than an arbitrary byte
    stream.

    Take an IRI (string or UTF-8 bytes, e.g. '/I ♥ Django/' or
    b'/I â¥ Django/') and return a string containing the encoded
    result with ASCII chars only (e.g. '/I%20%E2%99%A5%20Django/').
    Nz/#%[]=:;$&()+,!?*@'~safe)r   r   r%   r   )irir   r   r   
iri_to_uriv   s
   
r:   )-   .   _   ~   A   [   a   {   c                 C   s4   i | ]}|D ]}d D ]}||   t|fq
qqS ))z%02xz%02X)r,   r&   ).0ascii_rangecharfmtr   r   r   
<dictcomp>   s    
rG   0123456789ABCDEFabcdefc                 C   s.   i | ]}t D ]}||  t|| qqS r   )_hexdigr,   r&   fromhex)rC   abr   r   r   rG      s       c                 C   s   | du r| S t | } | d}t|dkr| }n=|d g}|j}t}|dd D ]'}|dd }||v rG|||dd   ||dd  q(|d || q(d|}t| S )uL  
    Convert a Uniform Resource Identifier(URI) into an Internationalized
    Resource Identifier(IRI).

    This is the algorithm from section 3.2 of RFC 3987, excluding step 4.

    Take an URI in ASCII bytes (e.g. '/I%20%E2%99%A5%20Django/') and return
    a string containing the encoded result (e.g. '/I%20♥%20Django/').
    N   %   r   r/       )r)   splitlenappend
_hextobytejoinrepercent_broken_unicoder+   )uribitsr9   partsrS   	hextobyteitemhexr   r   r   
uri_to_iri   s$   




r]   c                 C   s   t | ddS )zh
    Escape the unsafe characters from the path portion of a Uniform Resource
    Identifier (URI).
    z/:@&+$,-_.!~*'()r7   r   pathr   r   r   escape_uri_path   s   r`   c                 C   s   |  ddS )z:Return the Punycode of the given domain if it's non-ASCII.idnaascii)r,   r+   )domainr   r   r   punycode   s   rd   c              
   C   st   	 z|    W | S  ty8 } z$t| |j|j dd}| d|j |  | |jd  } W Y d}~nd}~ww q)z
    As per section 3.2 of RFC 3987, step three of converting a URI into an IRI,
    repercent-encode any octet produced that is not part of a strictly legal
    UTF-8 octet sequence.
    Ts   /#%[]=:;$&()+,!?*@'~r7   N)r+   r'   r   startendr,   )r_   r(   	repercentr   r   r   rV      s   
0rV   c                 C   s$   | du r| S t t| ddddS )aA  Convert a file system path to a URI portion that is suitable for
    inclusion in a URL.

    Encode certain chars that would normally be recognized as special chars
    for URIs. Do not encode the ' character, as it is a valid character
    within URIs. See the encodeURIComponent() JavaScript function for details.
    N\/z/~!*()'r7   )r   r%   replacer^   r   r   r   filepath_to_uri   s   rk   c                  C   s:   zt  d pd} t|  W | S  ty   d} Y | S w )z
    The encoding of the default system locale. Fallback to 'ascii' if the
    #encoding is unsupported by Python or could not be determined. See tickets
    #10335 and #5846.
    rO   rb   )localegetdefaultlocalecodecslookup	Exception)r   r   r   r   get_system_encoding  s   rq   )r   Fr   )(rn   datetimerl   r2   decimalr   urllib.parser   django.utils.deprecationr   django.utils.functionalr   r'   r   r!   r   intfloatdatetimer"   r#   r   r*   r)   r4   r6   r:   range_ascii_rangesrT   rI   updater]   r`   rd   rV   rk   rq   DEFAULT_LOCALE_ENCODINGr   r   r   r   <module>   sD    
	
	



"

$
