403Webshell
Server IP : 192.158.238.246  /  Your IP : 3.15.238.90
Web Server : LiteSpeed
System : Linux uniform.iwebfusion.net 4.18.0-553.27.1.lve.1.el8.x86_64 #1 SMP Wed Nov 20 15:58:00 UTC 2024 x86_64
User : jenniferflocom ( 1321)
PHP Version : 8.1.32
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /opt/alt/python37/lib/python3.7/site-packages/pyparsing/__pycache__/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /opt/alt/python37/lib/python3.7/site-packages/pyparsing/__pycache__/results.cpython-37.pyc
B

o|Se�b�@s�UddlmZmZmZmZddlZddlmZddl	m
Z
mZee
fZe
edfed<edd�d	D��ZGd
d�d�ZGdd
�d
�Ze�e�e�e�dS)�)�MutableMapping�Mapping�MutableSequence�IteratorN)�ref)�Tuple�Any.�str_typeccs|]
}|VqdS)N�)�.0�_r
r
��/builddir/build/BUILDROOT/alt-python37-pyparsing-3.0.9-2.el8.x86_64/opt/alt/python37/lib/python3.7/site-packages/pyparsing/results.py�	<genexpr>srr
c@s2eZdZdgZdd�Zdd�Zdd�Zdd	�Zd
S)�_ParseResultsWithOffset�tupcCs||f|_dS)N)r)�self�p1�p2r
r
r
�__init__sz _ParseResultsWithOffset.__init__cCs
|j|S)N)r)r�ir
r
r
�__getitem__sz#_ParseResultsWithOffset.__getitem__cCs|jS)N)r)rr
r
r
�__getstate__sz$_ParseResultsWithOffset.__getstate__cGs|d|_dS)Nr)r)r�argsr
r
r
�__setstate__sz$_ParseResultsWithOffset.__setstate__N)�__name__�
__module__�__qualname__�	__slots__rrrrr
r
r
r
rs
rc@s
eZdZUdZdgddfZeedfed<ddd	d
ddd
gZGdd�de	�Z
d_dd�Zddddefdd�Z
dd�Zefdd�Zdd�Zed�dd�Zed�dd�Zed�d d!�Zed�d"d#�Zed�d$d%�Zd&d'�Zd(d)�Zd*d+�Zed�d,d-�Zd.d/�Zd`d0d1�Zd2d3�Zd4d5�Z d6d7�Z!d8d9�Z"d:d;�Z#dd�d<d=�Z$dd�d>d?�Z%dd�d@dA�Z&e'd�dBdC�Z(e'd�dDdE�Z)dadFdG�Z*e	d�dHdI�Z+e,d�dJdK�Z-dd�dLdM�Z.dNdO�Z/dbe'd�dQdR�Z0dSdT�Z1dUdV�Z2dWdX�Z3dYdZ�Z4d[d\�Z5e6dcdd�d]d^��Z7e+Z8e-Z9e/Z:dS)d�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@seZdZdZddd�ZdS)zParseResults.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`.)
        NcCs8|dkrg}t|t�s.td�|jt|�j���t�|�S)Nz.{} may only be constructed with a list, not {})�
isinstance�list�	TypeError�formatr�type�__new__)�clsZ	containedr
r
r
r-|s
zParseResults.List.__new__)N)rrr�__doc__r-r
r
r
r
�ListUs%r0cKs�t|t�r|St�|�}d|_d|_t�|_|dkr<g|_n<t|t	t
f�rpt|tj�rd|dd�gnt	|�|_n|g|_t�|_
|S)N)r(r�objectr-r!r"�setr#r%r)�_generator_typer0�dictr&)r.�toklist�name�kwargsrr
r
r
r-�s

zParseResults.__new__Tc
Cs�||_|dk	r�|dkr�||t�r(t|�}|s4|h|_||_||jkr�||ttf�rX|g}|r�||t�r|t	t|j
�d�||<nt	t|d�d�||<|||_nDy|d||<Wn2ttt
fk
r�||k	r�|||<n||_YnXdS)Nrr)r$�int�strr#r!r r	r,rrr%�KeyErrorr*�
IndexError)rr5r6�asList�modalr(r
r
r
r�s.



zParseResults.__init__cCsPt|ttf�r|j|S||jkr4|j|ddStdd�|j|D��SdS)N���rcSsg|]}|d�qS)rr
)r�vr
r
r
�
<listcomp>�sz,ParseResults.__getitem__.<locals>.<listcomp>)r(r8�slicer%r#r&r)rrr
r
r
r�s


zParseResults.__getitem__cCs�||t�r0|j�|t��|g|j|<|d}nD||ttf�rN||j|<|}n&|j�|t��t|d�g|j|<|}||t�r�t|�|_	dS)Nr)
rr&�getr)r8rAr%r�wkrefr")r�kr?r(�subr
r
r
�__setitem__�s



zParseResults.__setitem__c
Cs�t|ttf�r�t|j�}|j|=t|t�rH|dkr:||7}t||d�}tt|�|���}|��x^|j	�
�D]F\}}x<|D]4}x.t|�D]"\}\}}	t||	|	|k�||<q�Wq|WqnWn|j	|=dS)Nr�)
r(r8rA�lenr%r)�range�indices�reverser&�items�	enumerater)
rr�mylen�removedr6�occurrences�jrD�value�positionr
r
r
�__delitem__�s


"zParseResults.__delitem__)�returncCs
||jkS)N)r&)rrDr
r
r
�__contains__�szParseResults.__contains__cCs
t|j�S)N)rHr%)rr
r
r
�__len__�szParseResults.__len__cCs|jp
|jS)N)r%r&)rr
r
r
�__bool__�szParseResults.__bool__cCs
t|j�S)N)�iterr%)rr
r
r
�__iter__�szParseResults.__iter__cCst|jddd��S)Nr>)rYr%)rr
r
r
�__reversed__�szParseResults.__reversed__cCs
t|j�S)N)rYr&)rr
r
r
�keys�szParseResults.keyscs�fdd����D�S)Nc3s|]}�|VqdS)Nr
)rrD)rr
r
rsz&ParseResults.values.<locals>.<genexpr>)r\)rr
)rr
�valuesszParseResults.valuescs�fdd����D�S)Nc3s|]}|�|fVqdS)Nr
)rrD)rr
r
rsz%ParseResults.items.<locals>.<genexpr>)r\)rr
)rr
rLszParseResults.itemscCs
t|j�S)z�
        Since ``keys()`` returns an iterator, this method is helpful in bypassing
        code that looks for the existence of any defined results names.)�boolr&)rr
r
r
�haskeysszParseResults.haskeyscOs�|s
dg}x8|��D],\}}|dkr2|d|f}qtd�|���qWt|dt�sjt|�dksj|d|kr�|d}||}||=|S|d}|SdS)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") + Word(nums)[1, ...]
            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']
        r>�defaultrz-pop() got an unexpected keyword argument {!r}rGN)rLr*r+r(r8rH)rrr7rDr?�index�ret�defaultvaluer
r
r
�pops(&zParseResults.popcCs||kr||S|SdS)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
        Nr
)r�key�
default_valuer
r
r
rBFszParseResults.getcCsZ|j�||�xF|j��D]8\}}x.t|�D]"\}\}}t||||k�||<q,WqWdS)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&rLrMr)rraZ
ins_stringr6rPrDrRrSr
r
r
rg]s
zParseResults.insertcCs|j�|�dS)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
rhvszParseResults.appendcCs&t|t�r|�|�n|j�|�dS)a
        Add sequence of elements to end of ``ParseResults`` list of elements.

        Example::

            patt = Word(alphas)[1, ...]

            # 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
rk�s
zParseResults.extendcCs|jdd�=|j��dS)z7
        Clear all elements and results names.
        N)r%r&�clear)rr
r
r
rm�szParseResults.clearcCs4y||Stk
r.|�d�r*t|��dSXdS)N�__r)r:�
startswith�AttributeError)rr6r
r
r
�__getattr__�s
zParseResults.__getattr__cCs|��}||7}|S)N)�copy)r�otherrbr
r
r
�__add__�szParseResults.__add__cs�|jrnt|j���fdd��|j��}�fdd�|D�}x4|D],\}}|||<t|dt�r>t|�|d_q>W|j|j7_|j|jO_|S)Ncs|dkr�S|�S)Nrr
)�a)�offsetr
r
�<lambda>��z'ParseResults.__iadd__.<locals>.<lambda>c	s4g|],\}}|D]}|t|d�|d��f�qqS)rrG)r)rrD�vlistr?)�	addoffsetr
r
r@�sz)ParseResults.__iadd__.<locals>.<listcomp>r)	r&rHr%rLr(rrCr"r#)rrs�
otheritems�otherdictitemsrDr?r
)rzrvr
rj�s


zParseResults.__iadd__cCs&t|t�r|dkr|��S||SdS)Nr)r(r8rr)rrsr
r
r
�__radd__�szParseResults.__radd__cCsd�t|�j|j|���S)Nz{}({!r}, {}))r+r,rr%�as_dict)rr
r
r
�__repr__�szParseResults.__repr__cCsdd�dd�|jD��dS)N�[z, cSs&g|]}t|t�rt|�nt|��qSr
)r(rr9�repr)rrr
r
r
r@�sz(ParseResults.__str__.<locals>.<listcomp>�])�joinr%)rr
r
r
�__str__�s	zParseResults.__str__cCsPg}xF|jD]<}|r"|r"|�|�t|t�r:||��7}q|�t|��qW|S)N)r%rhr(r�
_asStringListr9)r�sep�outrir
r
r
r��s

zParseResults._asStringListcCsdd�|jD�S)ax
        Returns the parse results as a nested list of matching tokens, all converted to strings.

        Example::

            patt = Word(alphas)[1, ...]
            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']
        cSs"g|]}t|t�r|��n|�qSr
)r(r�as_list)r�resr
r
r
r@�sz(ParseResults.as_list.<locals>.<listcomp>)r%)rr
r
r
r��szParseResults.as_listcs&�fdd��t�fdd�|��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"}
        cs4t|t�r,|��r|��S�fdd�|D�S|SdS)Ncsg|]}�|��qSr
r
)rr?)�to_itemr
r
r@sz9ParseResults.as_dict.<locals>.to_item.<locals>.<listcomp>)r(rr_r~)�obj)r�r
r
r�
s
"z%ParseResults.as_dict.<locals>.to_itemc3s|]\}}|�|�fVqdS)Nr
)rrDr?)r�r
r
rsz'ParseResults.as_dict.<locals>.<genexpr>)r4rL)rr
)r�r
r~�szParseResults.as_dictcCs:t|j�}|j��|_|j|_|j|jO_|j|_|S)zG
        Returns a new copy of a :class:`ParseResults` object.
        )rr%r&rrr"r#r!)rrbr
r
r
rrs
zParseResults.copycs�|jr|jS|jr6|����fdd�}�r2||�SdSt|�dkr�t|j�dkr�tt|j����dddkr�tt|j����SdSdS)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 = user_data[1, ...]

            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
        cst�fdd��j��D�d�S)Nc3s,|]$\}}|D]\}}�|kr|VqqdS)Nr
)rrDryr?�loc)rEr
r
rAsz@ParseResults.get_name.<locals>.find_in_parent.<locals>.<genexpr>)�nextr&rL)rE)�par)rEr
�find_in_parent>s
z-ParseResults.get_name.<locals>.find_in_parentNrGr)rr>)r!r"rHr&r�rYr]r\)rr�r
)r�r
�get_name szParseResults.get_namercCstg}d}|�|r |t|���nd�|�rj|��r�tdd�|��D��}x�|D]x\}}	|rf|�|�|�d�|d||��t|	t�r�|	r�|�|	j	||||dd��q�|�t|	��qP|�t
|	��qPWtd	d�|D���rj|}	x�t|	�D]x\}
}t|t��r<|�d
�|d||
|d|d|j	||||dd���q�|�d|d||
|d|dt|�f�q�Wd�
|�S)aM
        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('1999/12/31')
            print(result.dump())

        prints::

            ['1999', '/', '12', '/', '31']
            - day: '31'
            - month: '12'
            - year: '1999'
        �
rcss|]\}}t|�|fVqdS)N)r9)rrDr?r
r
r
rnsz$ParseResults.dump.<locals>.<genexpr>z
{}{}- {}: z  rG)�indent�full�include_list�_depthcss|]}t|t�VqdS)N)r(r)r�vvr
r
r
r�sz
{}{}[{}]:
{}{}{}z
%s%s[%d]:
%s%s%s)rhr9r�r_�sortedrLr+r(r�dumpr��anyrMr�)rr�r�r�r�r��NLrLrDr?rr�r
r
r
r�SsZ



zParseResults.dumpcOstj|��f|�|�dS)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�)rrr7r
r
r
r��szParseResults.pprintcCs.|j|j��|jdk	r|��p d|j|jffS)N)r%r&rrr"r#r!)rr
r
r
r�s
zParseResults.__getstate__cCs>|\|_\|_}}|_t|�|_|dk	r4t|�|_nd|_dS)N)r%r&r!r2r#rCr")r�stater��inAccumNamesr
r
r
r�s

zParseResults.__setstate__cCs|j|jfS)N)r%r!)rr
r
r
�__getnewargs__�szParseResults.__getnewargs__cCstt|��t|���S)N)�dirr,r)r\)rr
r
r
�__dir__�szParseResults.__dir__cCsvdd�}|g�}xJ|��D]>\}}t|t�r@||j||d�7}q|||g|||�d�7}qW|dk	rr||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.
        cSs2yt|�Wntk
r dSXt|t�SdS)NF)rY�	Exceptionr(r	)r�r
r
r
�is_iterable�s
z+ParseResults.from_dict.<locals>.is_iterable)r6)r6r<N)rLr(r�	from_dict)r.rsr6r�rbrDr?r
r
r
r��s
zParseResults.from_dict)NN)N)r)rTTr)N);rrrr/r rr�__annotations__rr)r0r-r(rrrFrTr^rVr8rWrXrrZr[r\r]rLr_rdrBrgrhrkrmrqrtrjr}r9rr�r�r�r4r~rrr�r�r�rrr�r��classmethodr�r<�asDict�getNamer
r
r
r
rsh
,3
	:

3Pr)�collections.abcrrrrr��weakrefrrC�typingrrr9�bytesr	r,r�r3rr�registerr
r
r
r
�<module>sa


Youez - 2016 - github.com/yon3zu
LinuXploit