HEX
Server: LiteSpeed
System: Linux standart9.isimtescil.net 3.10.0-962.3.2.lve1.5.26.7.el7.x86_64 #1 SMP Wed Oct 2 07:53:12 EDT 2019 x86_64
User: karalev (5310)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: //opt/alt/python37/lib/python3.7/site-packages/pyparsing/__pycache__/exceptions.cpython-37.pyc
B

�f%d?#�@s�ddlZddlZddlZddlmZmZmZmZddlm	Z
Gdd�de
je
je
j
e
je
j�Zeej�Ze�ded�ZGd	d
�d
e�ZGdd�de�ZGd
d�de�ZGdd�de�ZGdd�de�ZdS)�N�)�col�line�lineno�_collapse_string_to_ranges)�pyparsing_unicodec@seZdZdS)�ExceptionWordUnicodeN)�__name__�
__module__�__qualname__�rr�E/opt/alt/python37/lib/python3.7/site-packages/pyparsing/exceptions.pyrsrz([z
]{1,16})|.c@s�eZdZdZd eeejed�dd�Ze	d!dd	��Z
ed
d��Ze
ed�d
d��Ze
ed�dd��Ze
ed�dd��Ze
ed�dd��Zed�dd�Zdd�Zd"dd�eed�dd�Zd#ed�dd�ZeZdS)$�ParseBaseExceptionz7base exception class for all parsing runtime exceptionsrN)�pstr�loc�msgcCsD||_|dkr||_d|_n||_||_||_|_|||f|_dS)N�)rrrZparser_element�
parserElement�args)�selfrrr�elemrrr
�__init__szParseBaseException.__init__�c
Cs�ddl}ddlm}|dkr$t��}g}t|t�rV|�|j�|�d|j	dd�|�d�
t|�j|��|dk�rz|j
|j|d�}t�}x�t||d��D]�\}}|d}	|	j�d	d�}
t|
|��r|	jjd
kr�q�t|
�|kr�q�|�t|
��t|
�}|�d�
|j|j|
��nP|
dk	�rBt|
�}|�d�
|j|j��n&|	j}|jd
k�rVq�|�d�
|j��|d8}|s�Pq�Wd�|�S)a�
        Method to take an exception and translate the Python internal traceback into a list
        of the pyparsing expressions that caused the exception to be raised.

        Parameters:

        - exc - exception raised during parsing (need not be a ParseException, in support
          of Python exceptions that might be raised in a parse action)
        - depth (default=16) - number of levels back in the stack trace to list expression
          and function names; if None, the full stack trace names will be listed; if 0, only
          the failing input line, marker, and exception string will be shown

        Returns a multi-line string listing the ParserElements and/or function names in the
        exception's stack trace.
        rNr)�
ParserElement� �^z{}: {})�contextr)Z	parseImplZ
_parseNoCachez
{}.{} - {}z{}.{})�wrapperz<module>z{}�
)�inspectZcorer�sys�getrecursionlimit�
isinstancer�appendr�column�format�typer	Zgetinnerframes�
__traceback__�set�	enumerate�f_locals�get�f_code�co_name�id�addr
�join)
�exc�depthrrZretZcallers�seen�iZffZfrmZf_selfZ	self_type�coderrr
�explain_exception)sH


z$ParseBaseException.explain_exceptioncCs||j|j|j|j�S)z�
        internal factory method to simplify creating one type of ParseException
        from another - avoids having __init__ signature conflicts among subclasses
        )rrrr)�clsZperrr
�_from_exceptionksz"ParseBaseException._from_exception)�returncCst|j|j�S)zG
        Return the line of text where the exception occurred.
        )rrr)rrrr
rsszParseBaseException.linecCst|j|j�S)zV
        Return the 1-based line number of text where the exception occurred.
        )rrr)rrrr
rzszParseBaseException.linenocCst|j|j�S)z]
        Return the 1-based column on the line of text where the exception occurred.
        )rrr)rrrr
r�szParseBaseException.colcCst|j|j�S)z]
        Return the 1-based column on the line of text where the exception occurred.
        )rrr)rrrr
r$�szParseBaseException.columncCs�|jrh|jt|j�krd}qlt�|j|j�}|dk	r@|�d�}n|j|j|jd�}d|�dd�}nd}d�|j||j|j	|j
�S)	Nz, found end of textrrz
, found %rz\\�\rz%{}{}  (at char {}), (line:{}, col:{}))rr�len�_exception_word_extractor�match�group�replacer%rrr$)rZfoundstrZfound_match�foundrrr
�__str__�szParseBaseException.__str__cCst|�S)N)�str)rrrr
�__repr__�szParseBaseException.__repr__z>!<)�markerString)�
marker_stringr9cCsL|dk	r|n|}|j}|jd}|rDd�|d|�|||d�f�}|��S)z�
        Extracts the exception line from the input string, and marks
        the location of the exception with a special symbol.
        Nrr)rr$r0�strip)rrErDZline_strZline_columnrrr
�mark_input_line�s
z"ParseBaseException.mark_input_linecCs|�||�S)a
        Method to translate the Python internal traceback into a list
        of the pyparsing expressions that caused the exception to be raised.

        Parameters:

        - depth (default=16) - number of levels back in the stack trace to list expression
          and function names; if None, the full stack trace names will be listed; if 0, only
          the failing input line, marker, and exception string will be shown

        Returns a multi-line string listing the ParserElements and/or function names in the
        exception's stack trace.

        Example::

            expr = pp.Word(pp.nums) * 3
            try:
                expr.parse_string("123 456 A789")
            except pp.ParseException as pe:
                print(pe.explain(depth=0))

        prints::

            123 456 A789
                    ^
            ParseException: Expected W:(0-9), found 'A'  (at char 8), (line:1, col:9)

        Note: the diagnostic output will include string representations of the expressions
        that failed to parse. These representations will be more helpful if you use `set_name` to
        give identifiable names to your expressions. Otherwise they will use the default string
        forms, which may be cryptic to read.

        Note: pyparsing's default truncation of exception tracebacks may also truncate the
        stack of expressions that are displayed in the ``explain`` output. To get the full listing
        of parser expressions, you may have to set ``ParserElement.verbose_stacktrace = True``
        )r6)rr2rrr
�explain�s%zParseBaseException.explain)rNN)r)N)r)r	r
r�__doc__rB�int�typingZOptionalr�staticmethodr6�classmethodr8�propertyrrrr$rArCrGrHZ
markInputlinerrrr
rs(A'rc@seZdZdZdS)�ParseExceptionaq
    Exception thrown when a parse expression doesn't match the input string

    Example::

        try:
            Word(nums).set_name("integer").parse_string("ABC")
        except ParseException as pe:
            print(pe)
            print("column: {}".format(pe.column))

    prints::

       Expected integer (at char 0), (line:1, col:1)
        column: 1

    N)r	r
rrIrrrr
rO�srOc@seZdZdZdS)�ParseFatalExceptionzu
    User-throwable exception thrown when inconsistent parse content
    is found; stops all parsing immediately
    N)r	r
rrIrrrr
rP�srPc@seZdZdZdS)�ParseSyntaxExceptionz�
    Just like :class:`ParseFatalException`, but thrown internally
    when an :class:`ErrorStop<And._ErrorStop>` ('-' operator) indicates
    that parsing is to stop immediately because an unbacktrackable
    syntax error has been found.
    N)r	r
rrIrrrr
rQ�srQc@s&eZdZdZdd�Zed�dd�ZdS)�RecursiveGrammarExceptionz�
    Exception thrown by :class:`ParserElement.validate` if the
    grammar could be left-recursive; parser may need to enable
    left recursion using :class:`ParserElement.enable_left_recursion<ParserElement.enable_left_recursion>`
    cCs
||_dS)N)�parseElementTrace)rZparseElementListrrr
rsz"RecursiveGrammarException.__init__)r9cCsd�|j�S)NzRecursiveGrammarException: {})r%rS)rrrr
rA
sz!RecursiveGrammarException.__str__N)r	r
rrIrrBrArrrr
rRsrR)�rer rK�utilrrrrZunicoderZppuZLatin1ZLatinAZLatinBZGreekZCyrillicrZ	alphanumsZ_extract_alphanums�compiler<�	ExceptionrrOrPrQrRrrrr
�<module>s"
J