
    Ig?#              	       p   d dl Z d dlZd dlZddlmZmZmZmZ ddlm	Z
  G d de
j        e
j        e
j        e
j        e
j                  Z eej                  Z e j        dez   dz             Z G d	 d
e          Z G d de          Z G d de          Z G d de          Z G d de          ZdS )    N   )collinelineno_collapse_string_to_ranges)pyparsing_unicodec                       e Zd ZdS )ExceptionWordUnicodeN)__name__
__module____qualname__     f/var/www/html/4nations/venv/lib/python3.11/site-packages/pkg_resources/_vendor/pyparsing/exceptions.pyr
   r
      s        Dr   r
   z([z
]{1,16})|.c                      e Zd ZdZ	 	 	 ddededej        e         fdZe	dd	            Z
ed
             Zedefd            Zedefd            Zedefd            Zedefd            ZdefdZd ZddddedefdZddefdZeZdS )ParseBaseExceptionz7base exception class for all parsing runtime exceptionsr   Npstrlocmsgc                     || _         ||| _        d| _        n|| _        || _        |x| _        | _        |||f| _        d S )N )r   r   r   parser_elementparserElementargs)selfr   r   r   elems        r   __init__zParseBaseException.__init__   sP     ;DHDIIDHDI377d03$			r      c                    ddl }ddlm} |t          j                    }g }t          | t                    r=|                    | j                   |                    d| j	        dz
  z  dz              |                    d
                    t          |           j        |                      |dk    r|                    | j        |          }t                      }t!          || d                   D ]M\  }}|d         }	|	j                            d	d          }
t          |
|          r|	j        j        d
vrHt+          |
          |v rZ|                    t+          |
                     t          |
          }|                    d
                    |j        |j        |
                     n|
Ct          |
          }|                    d
                    |j        |j                             n?|	j        }|j        dv r|                    d
                    |j                             |dz  }|s nOd                    |          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.
        r   Nr   )ParserElement ^z{}: {})contextr   )	parseImpl_parseNoCachez
{}.{} - {}z{}.{})wrapperz<module>z{}
)inspectcorer    sysgetrecursionlimit
isinstancer   appendr   columnformattyper   getinnerframes__traceback__set	enumeratef_localsgetf_codeco_nameidaddr   join)excdepthr(   r    retcallersseenifffrmf_self	self_typecodes                r   explain_exceptionz$ParseBaseException.explain_exception)   sW   " 	''''''=)++Ec-.. 	5JJsx   JJscj1n-3444

8??499#5s;;<<<199,,S->,NNG55D"7E677#344  2e))&$77fm44 :z)1OOO &zzT)) HHRZZ((( $VIJJ$++%0)2Df     ' $VIJJw~~i.BIDVWWXXXX :D|'>>> JJt{{4<88999
 E yy~~r   c                 F     | |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
        )r   r   r   r   )clspes     r   _from_exceptionz"ParseBaseException._from_exceptionk   s#     s27BFBFB,<===r   returnc                 6    t          | j        | j                  S )zG
        Return the line of text where the exception occurred.
        )r   r   r   r   s    r   r   zParseBaseException.lines   s    
 DHdi(((r   c                 6    t          | j        | j                  S )zV
        Return the 1-based line number of text where the exception occurred.
        )r   r   r   rN   s    r   r   zParseBaseException.linenoz   s    
 dh	***r   c                 6    t          | j        | j                  S z]
        Return the 1-based column on the line of text where the exception occurred.
        r   r   r   rN   s    r   r   zParseBaseException.col       
 48TY'''r   c                 6    t          | j        | j                  S rQ   rR   rN   s    r   r.   zParseBaseException.column   rS   r   c                    | j         r| j        t          | j                   k    rd}nut                              | j         | j                  }||                    d          }n| j         | j        | j        dz            }d|z                      dd          }nd}d                    | j        || j        | j	        | j
                  S )	Nz, found end of textr   r   z
, found %rz\\\r   z%{}{}  (at char {}), (line:{}, col:{}))r   r   len_exception_word_extractormatchgroupreplacer/   r   r   r.   )r   foundstrfound_matchfounds       r   __str__zParseBaseException.__str__   s    9 	x3ty>>))0 8==diRR*'--a00EE IdhA&=>E(5099%FFH6==Hh$+t{
 
 	
r   c                      t          |           S N)strrN   s    r   __repr__zParseBaseException.__repr__   s    4yyr   z>!<)markerStringmarker_stringc                    ||n|}| j         }| j        dz
  }|r(d                    |d|         |||d         f          }|                                S )z
        Extracts the exception line from the input string, and marks
        the location of the exception with a special symbol.
        Nr   r   )r   r.   r;   strip)r   re   rd   line_strline_columns        r   mark_input_linez"ParseBaseException.mark_input_line   sm    
 )6(A}}|9kAo 	ww,;,'x7MN H ~~r   c                 .    |                      | |          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``
        )rG   )r   r=   s     r   explainzParseBaseException.explain   s    J %%dE222r   )r   NN)r   ra   )r   r   r   __doc__rb   inttypingOptionalr   staticmethodrG   classmethodrK   propertyr   r   r   r.   r_   rc   rj   rl   markInputliner   r   r   r   r      s       AA $(% %% % _S!	% % % %" ? ? ? \?B > > [> )c ) ) ) X) + + + + X+ (S ( ( ( X( ( ( ( ( X(
 
 
 
 
$         S  SV        %3 %33 %3 %3 %3 %3N $MMMr   r   c                       e Zd ZdZdS )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   r   rm   r   r   r   rv   rv      s           r   rv   c                       e Zd ZdZdS )ParseFatalExceptionzu
    User-throwable exception thrown when inconsistent parse content
    is found; stops all parsing immediately
    Nrw   r   r   r   ry   ry      s           r   ry   c                       e Zd ZdZdS )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.
    Nrw   r   r   r   r{   r{      s           r   r{   c                   $    e Zd ZdZd ZdefdZdS )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>`
    c                     || _         d S ra   )parseElementTrace)r   parseElementLists     r   r   z"RecursiveGrammarException.__init__  s    !1r   rL   c                 6    d                     | j                  S )NzRecursiveGrammarException: {})r/   r   rN   s    r   r_   z!RecursiveGrammarException.__str__
  s    .55d6LMMMr   N)r   r   r   rm   r   rb   r_   r   r   r   r}   r}      sO         2 2 2N N N N N N Nr   r}   )rer*   ro   utilr   r   r   r   unicoder   ppuLatin1LatinALatinBGreekCyrillicr
   	alphanums_extract_alphanumscompilerX   	Exceptionr   rv   ry   r{   r}   r   r   r   <module>r      s   
			 



  ? ? ? ? ? ? ? ? ? ? ? ? - - - - - -	 	 	 	 	3:sz3:sy#, 	 	 	 0/0D0NOO &BJt.@'@<'OPP F$ F$ F$ F$ F$ F$ F$ F$R    '   (    ,       .   N N N N N	 N N N N Nr   