o
    q>¨e±  ã                   @   sZ   d dl ZddlmZ dejdefdd„Zdejej defdd	„Zdejdef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   úS/var/www/bmteknikk.ddns.net/venv/lib/python3.10/site-packages/markupsafe/_native.pyÚescape   s   
úr   c                 C   s   | du 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
    