
    h4                       d dl mZ d dlmZmZmZ ddlmZ ddlm	Z	m
Z
 ddlmZ eeg ef         eegef         eeegef         eeeegef         f         Z G d d          Zd$dZd%dZd&dZd'dZ e            e_        d(d)dZ e
de          Z e
de          Z e
d e          Z e
d!e          Z e
d"e          Zd#S )*    )annotations)UnionCallableAny   )ParseException)colreplaced_by_pep8)ParseResultsc                  (    e Zd ZdZddZddZd ZdS )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Nonec                @    ddl m}  ||          | _        d| _        d S )Nr   )_trim_arityF)corer   callablecalled)selfr   r   s      f/home/visionen/pythonvenv/lib/python3.11/site-packages/pyparsing-3.2.4-py3.11.egg/pyparsing/actions.py__init__zOnlyOnce.__init__   s0    %%%%%%#K00    sstrlinttr   c                r    | j         s |                     |||          }d| _         |S t          ||d          )NTz.OnlyOnce obj called multiple times w/out reset)r   r   r   )r   r   r   r   resultss        r   __call__zOnlyOnce.__call__   s@    { 	mmAq!,,GDKNQ#STTTr   c                    d| _         dS )zK
        Allow the associated parse action to be called once more.
        FN)r   )r   s    r   resetzOnlyOnce.reset&   s    
 r   N)r   r   r   r   )r   r   r   r   r   r   r   r   )__name__
__module____qualname____doc__r   r"   r$    r   r   r   r      sY         
   U U U U    r   r   nr   r   ParseActionc                     d
 fd	}|S )zt
    Helper method for defining parse actions that require matching at
    a specific column in the input text.
    strgr   locnr   toksr   r   r   c                X    t          ||           k    rt          | |d           d S )Nzmatched token not at column )r	   r   )r-   r.   r/   r*   s      r   
verify_colz%match_only_at_col.<locals>.verify_col4   s9    tT??a t-OA-O-OPPP  r   )r-   r   r.   r   r/   r   r   r   r)   )r*   r1   s   ` r   match_only_at_colr2   .   s/    Q Q Q Q Q Q r   repl_strr   c                      fdS )a  
    Helper method for common parse actions that simply return
    a literal value.  Especially useful when used with
    :meth:`~ParserElement.transform_string`.

    Example:

    .. doctest::

       >>> 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")
       ParseResults([324, 234, nan, 234], {})
    c                
    gS )Nr)   )r   r   r   r3   s      r   <lambda>zreplace_with.<locals>.<lambda>L   s	    H: r   r)   )r3   s   `r   replace_withr7   ;   s    " &%%%%r   r   r   r   r   r   c                "    |d         dd         S )a   
    Helper parse action for removing quotation marks from parsed
    quoted strings, that use a single character for quoting. For parsing
    strings that may have multiple characters, use the :class:`QuotedString`
    class.

    Example:

    .. doctest::

       >>> # by default, quotation marks are included in parsed results
       >>> quoted_string.parse_string("'Now is the Winter of our Discontent'")
       ParseResults(["'Now is the Winter of our Discontent'"], {})

       >>> # use remove_quotes to strip quotation marks from parsed results
       >>> dequoted = quoted_string().set_parse_action(remove_quotes)
       >>> dequoted.parse_string("'Now is the Winter of our Discontent'")
       ParseResults(['Now is the Winter of our Discontent'], {})
    r   r   r)   )r   r   r   s      r   remove_quotesr:   O   s    ( Q4":r   argstuple[str, str]c                     g | r                     |            n'                     |                                           d
fd	}|S )a  
    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.

    The next two examples use the following input data and tag parsers:

    .. testcode::

       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":

    .. testcode::

       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)

    prints:

    .. testoutput::

       1 4 0 1 0

    Construct a match with any div tag having a type attribute,
    regardless of the value:

    .. testcode::

       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:

    .. testoutput::

       1 4 0 1 0
       1,3 2,3 1,1
    r   r   r   r   tokensr   r   r   c                    D ]Y\  }}||vrt          | |d|z             |t          j        k    r,||         |k    r t          | |d|d||         d|          Zd S )Nzno matching attribute z
attribute z has value z
, must be )r   with_attribute	ANY_VALUE)r   r   r>   attrName	attrValue
attrs_lists        r   pazwith_attribute.<locals>.pa   s    #- 	 	Hiv%%$Q+Ch+NOOON4449IY9V9V$cccx8HccV_cc  		 	r   )r   r   r   r   r>   r   r   r   )extenditems)r;   	attr_dictrE   rD   s      @r   r@   r@   f   sm    R )+J -$)//++,,,	 	 	 	 	 	 Ir    	classname	namespacec                0    |r| dnd}t          di || iS )a  
    Simplified version of :meth:`with_attribute` when
    matching on a div class - made difficult because ``class`` is
    a reserved word in Python.

    Using similar input data to the :meth:`with_attribute` examples:

    .. testcode::

       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")

    Only match div tag having the "grid" class:

    .. testcode::

       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)

    prints:

    .. testoutput::

       1 4 0 1 0

    Construct a match with any div tag having a class attribute,
    regardless of the value:

    .. testcode::

       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:

    .. testoutput::

       1 4 0 1 0
       1,3 2,3 1,1
    z:classclassr)   )r@   )rJ   rK   	classattrs      r   
with_classrO      s6    l )2>9$$$$wI33Y	2333r   replaceWithremoveQuoteswithAttribute	withClassmatchOnlyAtColN)r*   r   r   r+   )r3   r   r   r+   )r   r   r   r   r   r   r   r   )r;   r<   r   r+   )rI   )rJ   r   rK   r   r   r+   )
__future__r   typingr   r   r   
exceptionsr   utilr	   r
   r!   r   r   r   r+   r   r2   r7   r:   r@   objectrA   rO   rP   rQ   rR   rS   rT   r)   r   r   <module>rZ      s   " " " " " " ' ' ' ' ' ' ' ' ' ' & & & & & & ' ' ' ' ' ' ' ' ! ! ! ! ! ! RWl^S !c< #%&c3%s*+-       6
 
 
 
& & & &(   .Z Z Z Zz "688 74 74 74 74 74x }l;;>>  .AA[*55	!!"24EFFr   