o
�J�h, � @ s* d dl Z d dlZd dlZd dlZejr%d dlZG dd� dej�Z e�
d�ZdZdd
d�Z
G dd
� d
e�ZG dd� dej�Ze�dee�Zdedejej dejejgef defdd�ZG dd� d�ZzddlmZ ddlmZ ddlmZ W dS ey� ddl mZ ddl mZ ddl mZ Y dS w )� Nc @ s e Zd Zdefdd�ZdS )�HasHTML�returnc C s d S �N� ��selfr r �QC:\pinokio\api\whisper-webui.git\app\env\lib\site-packages\markupsafe\__init__.py�__html__
� zHasHTML.__html__N)�__name__�
__module__�__qualname__�strr r r r r r s r �_Pz2.1.5�func�t.Callable[_P, str]r �t.Callable[_P, Markup]c s t �� �d
� fdd ��}|S )Nr �Markup�args�_P.args�kwargs� _P.kwargsr c sD t t|�t|�| j�}t ||�� | j� | �� | g|�R i |���S r )�_escape_argspec�list� enumerate�escape�items� __class__)r r r �arg_list�r r r �wrapped s z)_simple_escaping_wrapper.<locals>.wrapped)r r r r r r r r )� functools�wraps)r r r r r �_simple_escaping_wrapper s r# c s e Zd ZdZdZ dCdejdeje ded d
f� fdd�
Z dDd
d�Z
dejedf d d
f� fdd�Zdejedf d d
fdd�Z
dE� fdd�ZeZdejd d
f� fdd�Zd ef� fdd�Zdejejedf d d
f� fdd �Zejje_ !dFd"eje d#ed ejd
f� fd$d%�
Zejje_ !dFd"eje d#ed ejd
f� fd&d'�
Zejje_ (dGd)ed ejd
f� fd*d+�
Zejje_d efd,d-�Zd efd.d/�Zed0ejd d
fd1d2��Zeej�Zeej �Z eej!�Z!eej"�Z"eej#�Z#eej$�Z$eej%�Z%eej&�Z&eej'�Z'eej(�Z(eej)�Z)eej*�Z*eej+�Z+eej,�Z,eej-�Z-eej.�Z.eej/�Z/e0j1d3k�r>eej2�Z2eej3�Z3d"ed ej4d4 f� fd5d6�Z5d"ed ej4d4 f� fd7d8�Z6d9ejd:ejd d
fd;d<�Z7d=ej8eejf d d
fd>d?�Z9d@ed d
fdAdB�Z:� Z;S )Hr a� A string that is ready to be safely inserted into an HTML or XML
document, either because it was escaped or because it was marked
safe.
Passing an object to the constructor converts it to text and wraps
it to mark it safe without escaping. To escape the text, use the
:meth:`escape` class method instead.
>>> Markup("Hello, <em>World</em>!")
Markup('Hello, <em>World</em>!')
>>> Markup(42)
Markup('42')
>>> Markup.escape("Hello, <em>World</em>!")
Markup('Hello <em>World</em>!')
This implements the ``__html__()`` interface that some frameworks
use. Passing an object that implements ``__html__()`` will wrap the
output of that method, marking it safe.
>>> class Foo:
... def __html__(self):
... return '<a href="/foo">foo</a>'
...
>>> Markup(Foo())
Markup('<a href="/foo">foo</a>')
This is a subclass of :class:`str`. It has the same methods, but
escapes their arguments and returns a ``Markup`` instance.
>>> Markup("<em>%s</em>") % ("foo & bar",)
Markup('<em>foo & bar</em>')
>>> Markup("<em>Hello</em> ") + "<foo>"
Markup('<em>Hello</em> <foo>')
r � N�strict�base�encoding�errorsr �te.Selfc s: t |d�r |�� }|d u rt� �| |�S t� �| |||�S �Nr )�hasattrr �super�__new__)�clsr&