o
    ~#gb                     @   s   U d dl mZmZmZmZ d dlZd dlmZ d dl	m
Z
mZ eefZe
edf ed< edd d	D ZG d
d dZG dd dZee ee dS )    )MutableMappingMappingMutableSequenceIteratorN)ref)TupleAny.str_typec                 c   s    | ]}|V  qd S N ).0_r   r   /var/www/static.ux5.de/https/Moving-Object-Detection-with-OpenCV/env/lib/python3.10/site-packages/pip/_vendor/pyparsing/results.py	<genexpr>   s    r   r   c                   @   s2   e Zd ZdgZdd Zdd Zdd Zdd	 Zd
S )_ParseResultsWithOffsettupc                 C   s   ||f| _ d S r
   r   )selfp1p2r   r   r   __init__      z _ParseResultsWithOffset.__init__c                 C   s
   | j | S r
   r   r   ir   r   r   __getitem__      
z#_ParseResultsWithOffset.__getitem__c                 C   s   | j S r
   r   r   r   r   r   __getstate__   s   z$_ParseResultsWithOffset.__getstate__c                 G   s   |d | _ d S Nr   r   )r   argsr   r   r   __setstate__   r   z$_ParseResultsWithOffset.__setstate__N)__name__
__module____qualname__	__slots__r   r   r   r    r   r   r   r   r      s    r   c                   @   s  e Zd ZU dZdg ddfZeedf ed< g dZG dd	 d	e	Z
dYd
dZddddefddZdd ZefddZdd ZdefddZdefddZdefddZdefddZdefddZd d! Zd"d# Zd$d% Zdefd&d'Zd(d) ZdZd*d+Zd,d- Zd.d/ Z d0d1 Z!d2d3 Z"d4d5 Z#d[d6d7Z$d[d8d9Z%d[d:d;Z&de'fd<d=Z(de'fd>d?Z)d\d@dAZ*de	fdBdCZ+de,fdDdEZ-d[dFdGZ.dHdI Z/d]de'fdKdLZ0dMdN Z1dOdP Z2dQdR Z3dSdT Z4dUdV Z5e6dZd[dWdXZ7e+Z8e-Z9e/Z:dS )^ParseResultsa  Structured parse results, to provide multiple means of access to
    the parsed data:

    - as a list (``len(results)``)
    - by list index (``results[0], results[1]``, etc.)
    - by attribute (``results.<results_name>`` - see :class:`ParserElement.set_results_name`)

    Example::

        integer = Word(nums)
        date_str = (integer.set_results_name("year") + '/'
                    + integer.set_results_name("month") + '/'
                    + integer.set_results_name("day"))
        # equivalent form:
        # date_str = (integer("year") + '/'
        #             + integer("month") + '/'
        #             + integer("day"))

        # parse_string returns a ParseResults object
        result = date_str.parse_string("1999/12/31")

        def test(s, fn=repr):
            print("{} -> {}".format(s, fn(eval(s))))
        test("list(result)")
        test("result[0]")
        test("result['month']")
        test("result.day")
        test("'month' in result")
        test("'minutes' in result")
        test("result.dump()", str)

    prints::

        list(result) -> ['1999', '/', '12', '/', '31']
        result[0] -> '1999'
        result['month'] -> '12'
        result.day -> '31'
        'month' in result -> True
        'minutes' in result -> False
        result.dump() -> ['1999', '/', '12', '/', '31']
        - day: 31
        - month: 12
        - year: 1999
    N r   ._null_values)_name_parent
_all_names_modal_toklist_tokdict__weakref__c                   @   s   e Zd ZdZdddZdS )zParseResults.Lista  
        Simple wrapper class to distinguish parsed list results that should be preserved
        as actual Python lists, instead of being converted to :class:`ParseResults`:

            LBRACK, RBRACK = map(pp.Suppress, "[]")
            element = pp.Forward()
            item = ppc.integer
            element_list = LBRACK + pp.delimited_list(element) + RBRACK

            # add parse actions to convert from ParseResults to actual Python collection types
            def as_python_list(t):
                return pp.ParseResults.List(t.as_list())
            element_list.add_parse_action(as_python_list)

            element <<= item | element_list

            element.run_tests('''
                100
                [2,3,4]
                [[2, 1],3,4]
                [(2, 1),3,4]
                (2,3,4)
                ''', post_parse=lambda s, r: (r[0], type(r[0])))

        prints:

            100
            (100, <class 'int'>)

            [2,3,4]
            ([2, 3, 4], <class 'list'>)

            [[2, 1],3,4]
            ([[2, 1], 3, 4], <class 'list'>)

        (Used internally by :class:`Group` when `aslist=True`.)
        Nc                 C   s8   |d u rg }t |tstd| jt|jt| S )Nz.{} may only be constructed with a list, not {})
isinstancelist	TypeErrorformatr!   type__new__)cls	containedr   r   r   r4   |   s   

zParseResults.List.__new__r
   )r!   r"   r#   __doc__r4   r   r   r   r   ListU   s    &r8   c                 K   s   t |tr|S t| }d |_d |_t |_|d u rg |_nt |t	t
fr8t |tjr2|d d  gnt	||_n|g|_t |_|S r
   )r/   r%   objectr4   r(   r)   setr*   r,   r0   _generator_typer8   dictr-   )r5   toklistnamekwargsr   r   r   r   r4      s    


zParseResults.__new__Tc              
   C   s   || _ |d uru|dkrw||trt|}|s|h| _|| _|| jvry||ttfr,|g}|rP||tr>t	t|j
d| |< nt	t|d d| |< || | _d S z	|d | |< W d S  tttfyt   || urn|| |< Y d S || _Y d S w d S d S d S )Nr&   r   )r+   intstrr*   r(   r'   r	   r3   r%   r   r,   KeyErrorr1   
IndexError)r   r=   r>   asListmodalr/   r   r   r   r      s8   




zParseResults.__init__c                 C   sL   t |ttfr| j| S || jvr| j| d d S tdd | j| D S )Nr   c                 S   s   g | ]}|d  qS )r   r   r   vr   r   r   
<listcomp>       z,ParseResults.__getitem__.<locals>.<listcomp>)r/   r@   slicer,   r*   r-   r%   r   r   r   r   r      s
   

zParseResults.__getitem__c                 C   s   ||t r| j|t |g | j|< |d }n"||ttfr'|| j|< |}n| j|t t |dg | j|< |}||trFt| |_	d S d S r   )
r   r-   getr0   r@   rK   r,   r%   wkrefr)   )r   krH   r/   subr   r   r   __setitem__   s   



zParseResults.__setitem__c           
      C   s   t |ttfrXt| j}| j|= t |tr$|dk r||7 }t||d }tt|| }|  | j	
 D ]\}}|D ]}t|D ]\}\}}	t||	|	|k ||< qBq<q6d S | j	|= d S )Nr      )r/   r@   rK   lenr,   r0   rangeindicesreverser-   items	enumerater   )
r   r   mylenremovedr>   occurrencesjrN   valuepositionr   r   r   __delitem__   s&   


zParseResults.__delitem__returnc                 C   s
   || j v S r
   )r-   )r   rN   r   r   r   __contains__   r   zParseResults.__contains__c                 C   
   t | jS r
   )rR   r,   r   r   r   r   __len__   r   zParseResults.__len__c                 C   s   | j p| j  S r
   )r,   r-   r   r   r   r   __bool__   s   zParseResults.__bool__c                 C   ra   r
   iterr,   r   r   r   r   __iter__   r   zParseResults.__iter__c                 C   s   t | jd d d S )NrF   rd   r   r   r   r   __reversed__   s   zParseResults.__reversed__c                 C   ra   r
   )re   r-   r   r   r   r   keys   r   zParseResults.keysc                        fdd   D S )Nc                 3   s    | ]} | V  qd S r
   r   r   rN   r   r   r   r     s    z&ParseResults.values.<locals>.<genexpr>rh   r   r   r   r   values      zParseResults.valuesc                    ri   )Nc                 3   s    | ]	}| | fV  qd S r
   r   rj   r   r   r   r     s    z%ParseResults.items.<locals>.<genexpr>rk   r   r   r   r   rV     rm   zParseResults.itemsc                 C   ra   )z
        Since ``keys()`` returns an iterator, this method is helpful in bypassing
        code that looks for the existence of any defined results names.)boolr-   r   r   r   r   haskeys  s   
zParseResults.haskeysc                 O   s   |sdg}|  D ]\}}|dkr|d |f}q	td|t|d ts2t|dks2|d | v r?|d }| | }| |= |S |d }|S )a  
        Removes and returns item at specified index (default= ``last``).
        Supports both ``list`` and ``dict`` semantics for ``pop()``. If
        passed no argument or an integer argument, it will use ``list``
        semantics and pop tokens from the list of parsed tokens. If passed
        a non-integer argument (most likely a string), it will use ``dict``
        semantics and pop the corresponding value from any defined results
        names. A second default return value argument is supported, just as in
        ``dict.pop()``.

        Example::

            numlist = Word(nums)[...]
            print(numlist.parse_string("0 123 321")) # -> ['0', '123', '321']

            def remove_first(tokens):
                tokens.pop(0)
            numlist.add_parse_action(remove_first)
            print(numlist.parse_string("0 123 321")) # -> ['123', '321']

            label = Word(alphas)
            patt = label("LABEL") + OneOrMore(Word(nums))
            print(patt.parse_string("AAB 123 321").dump())

            # Use pop() in a parse action to remove named result (note that corresponding value is not
            # removed from list form of results)
            def remove_LABEL(tokens):
                tokens.pop("LABEL")
                return tokens
            patt.add_parse_action(remove_LABEL)
            print(patt.parse_string("AAB 123 321").dump())

        prints::

            ['AAB', '123', '321']
            - LABEL: AAB

            ['AAB', '123', '321']
        rF   defaultr   z-pop() got an unexpected keyword argument {!r}rQ   )rV   r1   r2   r/   r@   rR   )r   r   r?   rN   rH   indexretdefaultvaluer   r   r   pop  s   (&zParseResults.popc                 C   s   || v r| | S |S )a^  
        Returns named result matching the given key, or if there is no
        such name, then returns the given ``default_value`` or ``None`` if no
        ``default_value`` is specified.

        Similar to ``dict.get()``.

        Example::

            integer = Word(nums)
            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")

            result = date_str.parse_string("1999/12/31")
            print(result.get("year")) # -> '1999'
            print(result.get("hour", "not specified")) # -> 'not specified'
            print(result.get("hour")) # -> None
        r   )r   keydefault_valuer   r   r   rL   F  s   zParseResults.getc                 C   sR   | j || | j D ]\}}t|D ]\}\}}t||||k ||< qqdS )a;  
        Inserts new element at location index in the list of parsed tokens.

        Similar to ``list.insert()``.

        Example::

            numlist = Word(nums)[...]
            print(numlist.parse_string("0 123 321")) # -> ['0', '123', '321']

            # use a parse action to insert the parse location in the front of the parsed results
            def insert_locn(locn, tokens):
                tokens.insert(0, locn)
            numlist.add_parse_action(insert_locn)
            print(numlist.parse_string("0 123 321")) # -> [0, '0', '123', '321']
        N)r,   insertr-   rV   rW   r   )r   rq   
ins_stringr>   rZ   rN   r\   r]   r   r   r   rw   ]  s   
zParseResults.insertc                 C   s   | j | dS )a  
        Add single element to end of ``ParseResults`` list of elements.

        Example::

            numlist = Word(nums)[...]
            print(numlist.parse_string("0 123 321")) # -> ['0', '123', '321']

            # use a parse action to compute the sum of the parsed integers, and add it to the end
            def append_sum(tokens):
                tokens.append(sum(map(int, tokens)))
            numlist.add_parse_action(append_sum)
            print(numlist.parse_string("0 123 321")) # -> ['0', '123', '321', 444]
        N)r,   append)r   itemr   r   r   ry   v  s   zParseResults.appendc                 C   s(   t |tr| | dS | j| dS )a!  
        Add sequence of elements to end of ``ParseResults`` list of elements.

        Example::

            patt = OneOrMore(Word(alphas))

            # use a parse action to append the reverse of the matched strings, to make a palindrome
            def make_palindrome(tokens):
                tokens.extend(reversed([t[::-1] for t in tokens]))
                return ''.join(tokens)
            patt.add_parse_action(make_palindrome)
            print(patt.parse_string("lskdj sdlkjf lksd")) # -> 'lskdjsdlkjflksddsklfjkldsjdksl'
        N)r/   r%   __iadd__r,   extend)r   itemseqr   r   r   r|     s   
zParseResults.extendc                 C   s   | j dd= | j  dS )z7
        Clear all elements and results names.
        N)r,   r-   clearr   r   r   r   r~     s   zParseResults.clearc                 C   s2   z| | W S  t y   |drt|Y dS w )N__r&   )rB   
startswithAttributeError)r   r>   r   r   r   __getattr__  s   

zParseResults.__getattr__c                 C   s   |   }||7 }|S r
   )copy)r   otherrr   r   r   r   __add__  s   zParseResults.__add__c                    s   |j r5t| jfdd |j  } fdd|D }|D ]\}}|| |< t|d tr4t| |d _q|  j|j7  _|  j|jO  _| S )Nc                    s   | dk r S |   S r   r   )a)offsetr   r   <lambda>  rJ   z'ParseResults.__iadd__.<locals>.<lambda>c              	      s4   g | ]\}}|D ]}|t |d   |d fqqS )r   rQ   )r   )r   rN   vlistrH   )	addoffsetr   r   rI     s    z)ParseResults.__iadd__.<locals>.<listcomp>r   )	r-   rR   r,   rV   r/   r%   rM   r)   r*   )r   r   
otheritemsotherdictitemsrN   rH   r   )r   r   r   r{     s   


zParseResults.__iadd__c                 C   s"   t |tr|dkr|  S ||  S r   )r/   r@   r   )r   r   r   r   r   __radd__  s   zParseResults.__radd__c                 C   s   d t| j| j|  S )Nz{}({!r}, {}))r2   r3   r!   r,   as_dictr   r   r   r   __repr__  s   zParseResults.__repr__c                 C   s   dd dd | jD  d S )N[z, c                 S   s&   g | ]}t |trt|nt|qS r   )r/   r%   rA   repr)r   r   r   r   r   rI     s    z(ParseResults.__str__.<locals>.<listcomp>])joinr,   r   r   r   r   __str__  s   zParseResults.__str__c                 C   sL   g }| j D ]}|r|r|| t|tr|| 7 }q|t| q|S r
   )r,   ry   r/   r%   _asStringListrA   )r   sepoutrz   r   r   r   r     s   


zParseResults._asStringListc                 C   s   dd | j D S )a{  
        Returns the parse results as a nested list of matching tokens, all converted to strings.

        Example::

            patt = OneOrMore(Word(alphas))
            result = patt.parse_string("sldkj lsdkj sldkj")
            # even though the result prints in string-like form, it is actually a pyparsing ParseResults
            print(type(result), result) # -> <class 'pyparsing.ParseResults'> ['sldkj', 'lsdkj', 'sldkj']

            # Use as_list() to create an actual list
            result_list = result.as_list()
            print(type(result_list), result_list) # -> <class 'list'> ['sldkj', 'lsdkj', 'sldkj']
        c                 S   s"   g | ]}t |tr| n|qS r   )r/   r%   as_list)r   resr   r   r   rI     s    z(ParseResults.as_list.<locals>.<listcomp>)r,   r   r   r   r   r     s   zParseResults.as_listc                    s&    fdd t  fdd|  D S )a  
        Returns the named parse results as a nested dictionary.

        Example::

            integer = Word(nums)
            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")

            result = date_str.parse_string('12/31/1999')
            print(type(result), repr(result)) # -> <class 'pyparsing.ParseResults'> (['12', '/', '31', '/', '1999'], {'day': [('1999', 4)], 'year': [('12', 0)], 'month': [('31', 2)]})

            result_dict = result.as_dict()
            print(type(result_dict), repr(result_dict)) # -> <class 'dict'> {'day': '1999', 'year': '12', 'month': '31'}

            # even though a ParseResults supports dict-like access, sometime you just need to have a dict
            import json
            print(json.dumps(result)) # -> Exception: TypeError: ... is not JSON serializable
            print(json.dumps(result.as_dict())) # -> {"month": "31", "day": "1999", "year": "12"}
        c                    s0   t | tr|  r|  S  fdd| D S | S )Nc                    s   g | ]} |qS r   r   rG   to_itemr   r   rI     rJ   z9ParseResults.as_dict.<locals>.to_item.<locals>.<listcomp>)r/   r%   ro   r   objr   r   r   r     s   
"z%ParseResults.as_dict.<locals>.to_itemc                 3   s     | ]\}}| |fV  qd S r
   r   r   rN   rH   r   r   r   r         z'ParseResults.as_dict.<locals>.<genexpr>)r<   rV   r   r   r   r   r     s   zParseResults.as_dictc                 C   s:   t | j}| j |_| j|_| j| jO  _| j|_|S )zG
        Returns a new copy of a :class:`ParseResults` object.
        )r%   r,   r-   r   r)   r*   r(   )r   rr   r   r   r   r     s   
zParseResults.copyc                    s   | j r| j S | jr|    fdd} r|| S dS t| dkr@t| jdkr@tt| j d d dv r@tt| j S dS )a  
        Returns the results name for this token expression. Useful when several
        different expressions might match at a particular location.

        Example::

            integer = Word(nums)
            ssn_expr = Regex(r"\d\d\d-\d\d-\d\d\d\d")
            house_number_expr = Suppress('#') + Word(nums, alphanums)
            user_data = (Group(house_number_expr)("house_number")
                        | Group(ssn_expr)("ssn")
                        | Group(integer)("age"))
            user_info = OneOrMore(user_data)

            result = user_info.parse_string("22 111-22-3333 #221B")
            for item in result:
                print(item.get_name(), ':', item[0])

        prints::

            age : 22
            ssn : 111-22-3333
            house_number : 221B
        c                    s   t  fddj D d S )Nc                 3   s.    | ]\}}|D ]\}} |u r|V  qqd S r
   r   )r   rN   r   rH   locrO   r   r   r   @  s    z@ParseResults.get_name.<locals>.find_in_parent.<locals>.<genexpr>)nextr-   rV   r   parr   r   find_in_parent>  s   
z-ParseResults.get_name.<locals>.find_in_parentNrQ   r   )r   rF   )r(   r)   rR   r-   r   re   rl   rh   )r   r   r   r   r   get_name   s   zParseResults.get_namer   c                 C   sf  g }d}| |r|t|   nd |r|  rctdd |  D }|D ]<\}}	|r1| | | d|d| | t|	tr[|	rS| |	j	||||d d q&| t|	 q&| t
|	 q&td	d | D r| }	t|	D ];\}
}t|tr| d
|d| |
|d|d  |j	||||d d qr| d|d| |
|d|d  t|f  qrd|S )aG  
        Diagnostic method for listing out the contents of
        a :class:`ParseResults`. Accepts an optional ``indent`` argument so
        that this string can be embedded in a nested display of other data.

        Example::

            integer = Word(nums)
            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")

            result = date_str.parse_string('12/31/1999')
            print(result.dump())

        prints::

            ['12', '/', '31', '/', '1999']
            - day: 1999
            - month: 31
            - year: 12
        
r&   c                 s   s     | ]\}}t ||fV  qd S r
   )rA   r   r   r   r   r   n  r   z$ParseResults.dump.<locals>.<genexpr>z
{}{}- {}: z  rQ   )indentfullinclude_list_depthc                 s   s    | ]}t |tV  qd S r
   )r/   r%   )r   vvr   r   r   r     s    z
{}{}[{}]:
{}{}{}z
%s%s[%d]:
%s%s%s)ry   rA   r   ro   sortedrV   r2   r/   r%   dumpr   anyrW   r   )r   r   r   r   r   r   NLrV   rN   rH   r   r   r   r   r   r   S  sj   

	



zParseResults.dumpc                 O   s    t j |  g|R i | dS )a%  
        Pretty-printer for parsed results as a list, using the
        `pprint <https://docs.python.org/3/library/pprint.html>`_ module.
        Accepts additional positional or keyword args as defined for
        `pprint.pprint <https://docs.python.org/3/library/pprint.html#pprint.pprint>`_ .

        Example::

            ident = Word(alphas, alphanums)
            num = Word(nums)
            func = Forward()
            term = ident | num | Group('(' + func + ')')
            func <<= ident + Group(Optional(delimited_list(term)))
            result = func.parse_string("fna a,b,(fnb c,d,200),100")
            result.pprint(width=40)

        prints::

            ['fna',
             ['a',
              'b',
              ['(', 'fnb', ['c', 'd', '200'], ')'],
              '100']]
        N)pprintr   )r   r   r?   r   r   r   r     s    zParseResults.pprintc                 C   s.   | j | j | jd ur|  pd | j| jffS r
   )r,   r-   r   r)   r*   r(   r   r   r   r   r     s   zParseResults.__getstate__c                 C   s@   |\| _ \| _}}| _t|| _|d urt|| _d S d | _d S r
   )r,   r-   r(   r:   r*   rM   r)   )r   stater   inAccumNamesr   r   r   r      s
   

zParseResults.__setstate__c                 C   s   | j | jfS r
   )r,   r(   r   r   r   r   __getnewargs__  s   zParseResults.__getnewargs__c                 C   s   t t| t|   S r
   )dirr3   r0   rh   r   r   r   r   __dir__  s   zParseResults.__dir__c                 C   sr   dd }| g }|  D ]\}}t|tr|| j||d7 }q|| |g|||d7 }q|dur7| |g|d}|S )z
        Helper classmethod to construct a ``ParseResults`` from a ``dict``, preserving the
        name-value relations as results names. If an optional ``name`` argument is
        given, a nested ``ParseResults`` will be returned.
        c                 S   s.   zt |  W n
 ty   Y dS w t| t S )NF)re   	Exceptionr/   r	   r   r   r   r   is_iterable  s   z+ParseResults.from_dict.<locals>.is_iterable)r>   )r>   rD   N)rV   r/   r   	from_dict)r5   r   r>   r   rr   rN   rH   r   r   r   r     s   
zParseResults.from_dict)NNr
   )r_   r%   )r&   )r&   TTr   );r!   r"   r#   r7   r'   r   r   __annotations__r$   r0   r8   r4   r/   r   r   rP   r^   rn   r`   r@   rb   rc   r   rf   rg   rh   rl   rV   ro   rt   rL   rw   ry   r|   r~   r   r   r{   r   rA   r   r   r   r   r<   r   r   r   r   r   r   r    r   r   classmethodr   rD   asDictgetNamer   r   r   r   r%      s`   
 -

3

 	
:




3Pr%   )collections.abcr   r   r   r   r   weakrefr   rM   typingr   r   rA   bytesr	   r3   r   r;   r   r%   registerr   r   r   r   <module>   s        
a