HEX
Server: LiteSpeed
System: Linux php-prod-1.spaceapp.ru 5.15.0-157-generic #167-Ubuntu SMP Wed Sep 17 21:35:53 UTC 2025 x86_64
User: xnsbb3110 (1041)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: //usr/local/CyberPanel/lib64/python3.10/site-packages/pyparsing/__pycache__/actions.cpython-310.pyc
o

��ha�@sddlmZddlmZmZmZddlmZddlm	Z	m
Z
ddlm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�G/usr/local/CyberPanel/lib/python3.10/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__rrrrrrrrs


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��
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)rArB�	classattrrrr�
with_class�s$rE�replaceWith�removeQuotes�
withAttribute�	withClass�matchOnlyAtColN)r$rrr%)r,rrr%)rrrrrr
rr)r3r4rr%)r@)rArrBrrr%)�
__future__r�typingrrr�
exceptionsr�utilrr	rr
rrr%rr+r0r2r6�objectr7rErFrGrHrIrJrrrr�<module>s0
��



L
*