o �J�ha�@sddlmZddlmZmZmZddlmZddlm Z m Z ddl m Z eegefee gefee e gefeee e geffZGdd�d�Zd)d d�Zd*dd�Zd+dd�Zd,dd�Ze�e_d-d.d!d"�Ze d#e�Ze d$e�Ze d%e�Ze d&e�Ze d'e�Zd(S)/�)� annotations)�Union�Callable�Any�)�ParseException)�col�replaced_by_pep8)� ParseResultsc@s,eZdZdZddd�Zddd�Zdd�ZdS)�OnlyOncez� Wrapper for parse actions, to ensure they are only called once. Note: parse action signature must include all 3 arguments. � method_call�'Callable[[str, int, ParseResults], Any]�return�NonecCs ddlm}||�|_d|_dS)Nr)� _trim_arityF)�corer�callable�called)�selfr r�r�OC:\pinokio\api\whisper-webui.git\app\env\lib\site-packages\pyparsing\actions.py�__init__s   zOnlyOnce.__init__�s�str�l�int�tr cCs*|js|�|||�}d|_|St||d��)NTz.OnlyOnce obj called multiple times w/out reset)rrr)rrrr�resultsrrr�__call__s  zOnlyOnce.__call__cCs d|_dS)zK Allow the associated parse action to be called once more. FN)r)rrrr�reset&s zOnlyOnce.resetN)r r rr)rrrrrr rr )�__name__� __module__� __qualname__�__doc__rrrrrrrr s    r �nrr� ParseActioncsd �fd d � }|S) zt Helper method for defining parse actions that require matching at a specific column in the input text. �strgr�locnr�toksr rrcs$t||��krt||d�����dS)Nzmatched token not at column )rr)r&r'r(�r$rr� verify_col4s�z%match_only_at_col.<locals>.verify_colN)r&rr'rr(r rrr)r$r*rr)r�match_only_at_col.sr+�repl_strrcs �fdd�S)a� Helper method for common parse actions that simply return a literal value. Especially useful when used with :class:`transform_string<ParserElement.transform_string>` (). Example:: num = Word(nums).set_parse_action(lambda toks: int(toks[0])) na = one_of("N/A NA").set_parse_action(replace_with(math.nan)) term = na | num term[1, ...].parse_string("324 234 N/A 234") # -> [324, 234, nan, 234] cs�gS)Nr�rrr�r,rr�<lambda>Iszreplace_with.<locals>.<lambda>rr.rr.r� replace_with;s r0rrrr rcCs|ddd�S)a# Helper parse action for removing quotation marks from parsed quoted strings. Example:: # by default, quotation marks are included in parsed results quoted_string.parse_string("'Now is the Winter of our Discontent'") # -> ["'Now is the Winter of our Discontent'"] # use remove_quotes to strip quotation marks from parsed results quoted_string.set_parse_action(remove_quotes) quoted_string.parse_string("'Now is the Winter of our Discontent'") # -> ["Now is the Winter of our Discontent"] rr�����rr-rrr� remove_quotesLsr2�args�tuple[str, str]cs4g�|r ��|�n��|���d �fd d � }|S) aJ Helper to create a validating parse action to be used with start tags created with :class:`make_xml_tags` or :class:`make_html_tags`. Use ``with_attribute`` to qualify a starting tag with a required attribute value, to avoid false matches on common tags such as ``<TD>`` or ``<DIV>``. Call ``with_attribute`` with a series of attribute names and values. Specify the list of filter attributes names and values as: - keyword arguments, as in ``(align="right")``, or - as an explicit dict with ``**`` operator, when an attribute name is also a Python reserved word, as in ``**{"class":"Customer", "align":"right"}`` - a list of name-value tuples, as in ``(("ns1:class", "Customer"), ("ns2:align", "right"))`` For attribute names with a namespace prefix, you must use the second form. Attribute names are matched insensitive to upper/lower case. If just testing for ``class`` (with or without a namespace), use :class:`with_class`. To verify that the attribute exists, but without specifying a value, pass ``with_attribute.ANY_VALUE`` as the value. Example:: html = ''' <div> Some text <div type="grid">1 4 0 1 0</div> <div type="graph">1,3 2,3 1,1</div> <div>this has no type</div> </div> ''' div,div_end = make_html_tags("div") # only match div tag having a type attribute with value "grid" div_grid = div().set_parse_action(with_attribute(type="grid")) grid_expr = div_grid + SkipTo(div | div_end)("body") for grid_header in grid_expr.search_string(html): print(grid_header.body) # construct a match with any div tag having a type attribute, regardless of the value div_any_type = div().set_parse_action(with_attribute(type=with_attribute.ANY_VALUE)) div_expr = div_any_type + SkipTo(div | div_end)("body") for div_header in div_expr.search_string(html): print(div_header.body) prints:: 1 4 0 1 0 1 4 0 1 0 1,3 2,3 1,1 rrrr�tokensr rrc sb�D],\}}||vrt||d|��|tjkr.|||kr.t||d|�d||�d|����qdS)Nzno matching attribute z attribute z has value z , must be )r�with_attribute� ANY_VALUE)rrr5�attrName� attrValue�Z attrs_listrr�pa�s ���zwith_attribute.<locals>.paN)rrrrr5r rr)�extend�items)r3� attr_dictr;rr:rr6]s 8  r6�� classname� namespacecCs$|r|�d�nd}tdi||i��S)a� Simplified version of :class:`with_attribute` when matching on a div class - made difficult because ``class`` is a reserved word in Python. Example:: html = ''' <div> Some text <div class="grid">1 4 0 1 0</div> <div class="graph">1,3 2,3 1,1</div> <div>this &lt;div&gt; has no class</div> </div> ''' div,div_end = make_html_tags("div") div_grid = div().set_parse_action(with_class("grid")) grid_expr = div_grid + SkipTo(div | div_end)("body") for grid_header in grid_expr.search_string(html): print(grid_header.body) div_any_type = div().set_parse_action(with_class(withAttribute.ANY_VALUE)) div_expr = div_any_type + SkipTo(div | div_end)("body") for div_header in div_expr.search_string(html): print(div_header.body) prints:: 1 4 0 1 0 1 4 0 1 0 1,3 2,3 1,1 z:class�classNr)r6)r@rA� classattrrrr� with_class�s$rD� replaceWith� removeQuotes� withAttribute� withClass�matchOnlyAtColN)r$rrr%)r,rrr%)rrrrrr rr)r3r4rr%)r?)r@rrArrr%)� __future__r�typingrrr� exceptionsr�utilrr rr rrr%r r+r0r2r6�objectr7rDrErFrGrHrIrrrr�<module>s0     ��   L  *   
Memory