U
    muf±  ã                   @   sT   d dl ZddlmZ ejedœdd„Zejej edœdd„Zejedœd	d
„Z	dS )é    Né   )ÚMarkup)ÚsÚreturnc                 C   sJ   t | dƒrt|  ¡ ƒS tt| ƒ dd¡ dd¡ dd¡ dd	¡ d
d¡ƒS )a¾  Replace the characters ``&``, ``<``, ``>``, ``'``, and ``"`` in
    the string with HTML-safe sequences. Use this if you need to display
    text that might contain such characters in HTML.

    If the object has an ``__html__`` method, it is called and the
    return value is assumed to already be safe for HTML.

    :param s: An object to be converted to a string and escaped.
    :return: A :class:`Markup` string with the escaped text.
    Ú__html__ú&z&amp;ú>z&gt;ú<z&lt;ú'z&#39;ú"z&#34;)Úhasattrr   r   ÚstrÚreplace©r   © r   ú6/tmp/pip-unpacked-wheel-kg5xhfg3/markupsafe/_native.pyÚescape   s(    
 ÿ þ ý ü ûÿr   c                 C   s   | dkrt ƒ S t| ƒS )a  Like :func:`escape` but treats ``None`` as the empty string.
    Useful with optional values, as otherwise you get the string
    ``'None'`` when the value is ``None``.

    >>> escape(None)
    Markup('None')
    >>> escape_silent(None)
    Markup('')
    N)r   r   r   r   r   r   Úescape_silent   s    
r   c                 C   s   t | tƒst| ƒS | S )a¨  Convert an object to a string if it isn't already. This preserves
    a :class:`Markup` string rather than converting it back to a basic
    string, so it will still be marked as safe and won't be escaped
    again.

    >>> value = escape("<User 1>")
    >>> value
    Markup('&lt;User 1&gt;')
    >>> escape(str(value))
    Markup('&amp;lt;User 1&amp;gt;')
    >>> escape(soft_str(value))
    Markup('&lt;User 1&gt;')
    )Ú
isinstancer   r   r   r   r   Úsoft_str.   s    
r   )
ÚtypingÚtÚ r   ÚAnyr   ÚOptionalr   r   r   r   r   r   r   Ú<module>   s   