HEX
Server: Apache
System: Linux 185.122.168.184.host.secureserver.net 5.14.0-570.60.1.el9_6.x86_64 #1 SMP PREEMPT_DYNAMIC Wed Nov 5 05:00:59 EST 2025 x86_64
User: barbeatleanalyti (1024)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: //var/opt/nydus/ops/pycparser/ply/__pycache__/yacc.cpython-39.pyc
a

�,�hk�
@sddlZddlZddlZddlZddlZddlZddlZdZdZ	dZ
dZdZdZ
dZdZd	ZdZejddkrteZneZejZGd
d�de�ZGdd
�d
e�ZGdd�de�Zdd�Zdd�Zdada da!dZ"dd�Z#dd�Z$dd�Z%dd�Z&Gdd�d�Z'Gdd �d �Z(Gd!d"�d"�Z)e�*d#�Z+Gd$d%�d%e�Z,Gd&d'�d'e�Z-Gd(d)�d)e�Z.d*d+�Z/Gd,d-�d-e�Z0Gd.d/�d/e�Z1Gd0d1�d1e�Z2Gd2d3�d3e�Z3d4d5�Z4d6d7�Z5Gd8d9�d9e�Z6Gd:d;�d;e3�Z7d<d=�Z8d>d?�Z9Gd@dA�dAe�Z:de
deddddeddddf
dBdC�Z;dS)D�Nz3.10Tz
parser.out�parsetab�LALR�F�(c@s4eZdZdd�Zdd�ZeZdd�Zdd�ZeZd	S)
�	PlyLoggercCs
||_dS�N)�f)�selfr�r
�C/opt/nydus/tmp/pip-target-wkfpz8uv/lib/python/pycparser/ply/yacc.py�__init__nszPlyLogger.__init__cOs|j�||d�dS)N�
�r�write�r	�msg�args�kwargsr
r
r�debugqszPlyLogger.debugcOs|j�d||d�dS)Nz	WARNING: r
rrr
r
r�warningvszPlyLogger.warningcOs|j�d||d�dS)NzERROR: r
rrr
r
r�erroryszPlyLogger.errorN)	�__name__�
__module__�__qualname__rr�inforr�criticalr
r
r
rrmsrc@seZdZdd�Zdd�ZdS)�
NullLoggercCs|Srr
)r	�namer
r
r�__getattribute__�szNullLogger.__getattribute__cOs|Srr
)r	rrr
r
r�__call__�szNullLogger.__call__N)rrrrrr
r
r
rrsrc@seZdZdS)�	YaccErrorN�rrrr
r
r
rr �sr cCsPt|�}d|vrt|�}t|�tkr4|dt�d}dt|�jt|�|f}|S)Nr
z ...z<%s @ 0x%x> (%s))�repr�len�resultlimit�typer�id)�r�repr_str�resultr
r
r�
format_result�sr*cCsBt|�}d|vrt|�}t|�dkr(|Sdt|�jt|�fSdS)Nr
�z<%s @ 0x%x>)r"r#r%rr&)r'r(r
r
r�format_stack_entry�sr,aPLY: Don't use global functions errok(), token(), and restart() in p_error().
Instead, invoke the methods on the associated parser instance:

    def p_error(p):
        ...
        # Use parser.errok(), parser.token(), parser.restart()
        ...

    parser = yacc.yacc()
cCst�t�t�Sr)�warnings�warn�_warnmsg�_errokr
r
r
r�errok�s
r1cCst�t�t�Sr)r-r.r/�_restartr
r
r
r�restart�s
r3cCst�t�t�Sr)r-r.r/�_tokenr
r
r
r�token�s
r5cCs<|ja|ja|ja||�}z
bbbWnty6Yn0|Sr)r1r0r5r4r3r2�	NameError)�	errorfuncr5�parserr'r
r
r�call_errorfunc�s
r9c@seZdZdd�Zdd�ZdS)�
YaccSymbolcCs|jSr�r%�r	r
r
r�__str__�szYaccSymbol.__str__cCst|�Sr��strr<r
r
r�__repr__�szYaccSymbol.__repr__N)rrrr=r@r
r
r
rr:�sr:c@sfeZdZddd�Zdd�Zdd�Zdd	�Zd
d�Zdd
�Zdd�Z	dd�Z
dd�Zdd�Zdd�Z
dS)�YaccProductionNcCs||_||_d|_d|_dSr)�slice�stack�lexerr8)r	�srCr
r
rr�szYaccProduction.__init__cCsBt|t�rdd�|j|D�S|dkr2|j|jS|j|jSdS)NcSsg|]
}|j�qSr
��value��.0rEr
r
r�
<listcomp>��z.YaccProduction.__getitem__.<locals>.<listcomp>r)�
isinstancerBrGrC�r	�nr
r
r�__getitem__�s

zYaccProduction.__getitem__cCs||j|_dSr)rBrG)r	rN�vr
r
r�__setitem__�szYaccProduction.__setitem__cCsdd�|j||�D�S)NcSsg|]
}|j�qSr
rFrHr
r
rrJ�rKz/YaccProduction.__getslice__.<locals>.<listcomp>)rB)r	�i�jr
r
r�__getslice__�szYaccProduction.__getslice__cCs
t|j�Sr)r#rBr<r
r
r�__len__�szYaccProduction.__len__cCst|j|dd�S)N�linenor��getattrrBrMr
r
rrVszYaccProduction.linenocCs||j|_dSr)rBrV)r	rNrVr
r
r�
set_linenoszYaccProduction.set_linenocCs,t|j|dd�}t|j|d|�}||fS)NrVr�	endlinenorW)r	rN�	startline�endliner
r
r�linespanszYaccProduction.linespancCst|j|dd�S)N�lexposrrWrMr
r
rr^szYaccProduction.lexposcCs,t|j|dd�}t|j|d|�}||fS)Nr^r�	endlexposrW)r	rN�startpos�endposr
r
r�lexspanszYaccProduction.lexspancCst�dSr)�SyntaxErrorr<r
r
rrszYaccProduction.error)N)rrrrrOrQrTrUrVrYr]r^rbrr
r
r
rrA�s
rAc@s\eZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd
d�Zddd�Z	ddd�Z
ddd�ZdS)�LRParsercCs0|j|_|j|_|j|_||_|��d|_dS�NT)	�lr_productions�productions�	lr_action�action�lr_goto�gotor7�set_defaulted_states�errorok)r	ZlrtabZerrorfr
r
rrszLRParser.__init__cCs
d|_dSre)rmr<r
r
rr1&szLRParser.errokcCs@|jdd�=|jdd�=t�}d|_|j�|�|j�d�dS)N�$endr)�
statestack�symstackr:r%�append)r	�symr
r
rr3)szLRParser.restartcCsPi|_|j��D]:\}}t|���}t|�dkr|ddkr|d|j|<qdS�N�r)�defaulted_statesri�items�list�valuesr#)r	�state�actions�rulesr
r
rrl9s
zLRParser.set_defaulted_statescCs
i|_dSr)rur<r
r
r�disable_defaulted_states@sz!LRParser.disable_defaulted_statesNFcCsZ|str.t|t�rttj�}|�|||||�S|rD|�|||||�S|�|||||�SdSr)	�	yaccdevelrL�intr�sys�stderr�
parsedebug�parseopt�parseopt_notrack)r	�inputrDr�tracking�	tokenfuncr
r
r�parseCs

zLRParser.parsec Cs�d}g}|j}|j}	|j}
|j}td�}d}
|�d�|sLddlm}|j}||_||_	|durj|�
|�|durz|j}n|}||_g}||_g}||_
||_d}|�d�t�}d|_|�|�d}|�d�|�d|�||v�r(|�s|s�|�}n|��}|�st�}d|_|j}||�|�}n||}|�d||�|�d	d
d�dd
�|D�dd��t|�f���|du�r�|dk�r�|�|�|}|�d|�|�|�d}|
r�|
d8}
q�|dk�rD|
|}|j}|j}t�}||_d|_|�r<|�d|jdd�dd
�||d�D��d|	|d||�n|�d|jg|	|d|�|�r�||dd�}||d<|�r�|d}|j|_|j|_|d}t|d|j�|_t|d|j�|_||_ zd||d�=||_!|�"|�||d�=|�dt#|d��|�|�|	|d|}|�|�Wq�t$�y�|�|�|�%|dd��|��|d}d|_d|_|}t&}
d|_'Yq�0q�n�|�r�|j|_|j|_|g}||_ zL||_!|�"|�|�dt#|d��|�|�|	|d|}|�|�Wq�t$�y@|�|�|��|d}d|_d|_|}t&}
d|_'Yq�0q�|dk�r�|d}t|dd�}|�dt#|��|�d�|S|du�r�|�(dd
d�dd
�|D�dd��t|�f���|
dk�s�|j'�r�t&}
d|_'|}|jdk�r�d}|j)�r6|�rt*|d��s||_||_!t+|j)||�}|j'�r�|}d}q�n`|�r�t*|d ��rP|j}nd}|�rrt,j-�.d!||jf�nt,j-�.d"|j�nt,j-�.d#�dSnt&}
t|�dk�r�|jdk�r�d}d}d}|dd�=q�|jdk�r�dS|jdk�r�|d}|jdk�r*|�r$t|d |j�|_t|d$|j�|_d}q�t�}d|_t*|d ��rP|j|_|_t*|d$��rj|j|_|_||_|�|�|}q�|��}|�r�|j|_|j|_|��|d}q�t/d%��q�dS)&NrzPLY: PARSE DEBUG STARTrt��lexrn�zState  : %sz#Defaulted state %s: Reduce using %dzStack  : %sz%s . %s� cSsg|]
}|j�qSr
r;�rI�xxr
r
rrJ�rKz'LRParser.parsedebug.<locals>.<listcomp>z Action : Shift and goto state %sz3Action : Reduce rule [%s] with %s and goto state %d�[�,cSsg|]}t|j��qSr
)r,rG)rIZ_vr
r
rrJ�rK�]���rZr_zResult : %srFrGzDone   : Returning %szPLY: PARSE DEBUG ENDzError  : %scSsg|]
}|j�qSr
r;r�r
r
rrJBrKrDrV�(yacc: Syntax error at line %d, token=%s
�yacc: Syntax error, token=%s� yacc: Parse error in input. EOF
r^�yacc: internal parser error!!!
)0rirkrgrurArr�r�rDr8r�r5rorprCrqr:r%r�pop�get�joinr?�lstriprr#rGrVr^rXrZr_rBry�callabler*rc�extend�error_countrmrr7�hasattrr9rr�r�RuntimeError� r	r�rDrr�r��	lookahead�lookaheadstackrzrk�prodru�pslice�
errorcountr��	get_tokenrorp�errtokenrrry�ltype�t�p�pname�plen�targ�t1rNr)�tokrVr
r
rr�\s�





*�






$��








*�

zLRParser.parsedebugc Csjd}g}|j}|j}	|j}
|j}td�}d}
|sBddlm}|j}||_||_|dur`|�	|�|durp|j
}n|}||_
g}||_g}||_||_
d}|�d�t�}d|_|�|�d}||v�r|s�|s�|�}n|��}|s�t�}d|_|j}||�|�}n||}|du�r`|dk�rJ|�|�|}|�|�d}|
r�|
d8}
q�|dk�r>|
|}|j}|j}t�}||_d|_|�r�||dd�}||d<|�r�|d}|j|_|j|_|d}t|d|j�|_t|d|j�|_||_zP||d�=||_|�|�||d�=|�|�|	|d|}|�|�Wq�t�y�|�|�|�|dd��|��|d}d|_d|_|}t }
d	|_!Yq�0q�n�|�r�|j|_|j|_|g}||_z8||_|�|�|�|�|	|d|}|�|�Wq�t�y:|�|�|��|d}d|_d|_|}t }
d	|_!Yq�0q�|dk�r`|d}t|d
d�}|S|du�r\|
dk�s||j!�rDt }
d	|_!|}|jdk�r�d}|j"�r�|�r�t#|d��s�||_||_t$|j"||�}|j!�rB|}d}q�n`|�r2t#|d��r�|j}nd}|�rt%j&�'d
||jf�nt%j&�'d|j�nt%j&�'d�dSnt }
t|�dk�rz|jdk�rzd}d}d}|dd�=q�|jdk�r�dS|jdk�r,|d}|jdk�r�|�r�t|d|j�|_t|d|j�|_d}q�t�}d|_t#|d��r�|j|_|_t#|d��r|j|_|_||_|�|�|}q�|��}|�rJ|j|_|j|_|��|d}q�t(d��q�dS)Nrrtr�rnr�rZr_rFrGrDrVr�r�r�r^r�))rirkrgrurAr�r�rDr8r�r5rorprCrqr:r%r�r�rr#rGrVr^rXrZr_rBryr�rcr�r�rmr7r�r9rr�rr�r�r
r
rr��sV




















zLRParser.parseoptcCs�d}g}|j}|j}	|j}
|j}td�}d}
|sBddlm}|j}||_||_|dur`|�	|�|durp|j
}n|}||_
g}||_g}||_||_
d}|�d�t�}d|_|�|�d}||v�r|s�|s�|�}n|��}|s�t�}d|_|j}||�|�}n||}|du�r|dk�rJ|�|�|}|�|�d}|
r�|
d8}
q�|dk�r�|
|}|j}|j}t�}||_d|_|�rR||dd�}||d<||_zP||d�=||_|�|�||d�=|�|�|	|d|}|�|�Wq�t�yL|�|�|�|dd��|��|d}d|_d|_|}t}
d|_Yq�0q�n�|g}||_z8||_|�|�|�|�|	|d|}|�|�Wq�t�y�|�|�|��|d}d|_d|_|}t}
d|_Yq�0q�|dk�r|d}t|dd�}|S|du�r�|
dk�s |j�r�t}
d|_|}|jdk�r>d}|j�r�|�r^t|d	��s^||_||_t |j||�}|j�r�|}d}q�n`|�r�t|d
��r�|j!}nd}|�r�t"j#�$d||jf�nt"j#�$d|j�nt"j#�$d
�dSnt}
t|�dk�r|jdk�rd}d}d}|dd�=q�|jdk�r.dS|jdk�r�|d}|jdk�rTd}q�t�}d|_t|d
��rz|j!|_!|_%t|d��r�|j&|_&|_'||_|�|�|}q�|��}|��|d}q�t(d��q�dS)Nrrtr�rnr�rFrGrDrVr�r�r�r^r�))rirkrgrurAr�r�rDr8r�r5rorprCrqr:r%r�r�rr#rGrBryr�rcr�r�rmrXr7r�r9rVrr�rrZr^r_r�)r	r�rDrr�r�r�r�rzrkr�rur�r�r�r�rorpr�rrryr�r�r�r�r�r�rNr)r�rVr
r
rr��s6




















zLRParser.parseopt_notrack)NNFFN)NNFFN)NNFFN)NNFFN)rrrrr1r3rlr|r�r�r�r�r
r
r
rrds

]
4rdz^[a-zA-Z0-9_-]+$c@sReZdZdZddd�Zdd�Zd	d
�Zdd�Zd
d�Zdd�Z	dd�Z
dd�ZdS)�
Productionr��rightrNr�c	Cs�||_t|�|_||_||_d|_||_||_||_t	|j�|_	g|_
|jD]}||j
vrL|j
�|�qLg|_d|_
|jr�d|jd�|j�f|_nd|j|_dS�N�%s -> %sr�z
%s -> <empty>)r�tupler��number�funcr��file�line�precr#�usymsrq�lr_items�lr_nextr�r?)	r	r�rr��
precedencer�r�r�rEr
r
rrs$


zProduction.__init__cCs|jSrr>r<r
r
rr==szProduction.__str__cCsdt|�dS)NzProduction(�)r>r<r
r
rr@@szProduction.__repr__cCs
t|j�Sr)r#r�r<r
r
rrUCszProduction.__len__cCsdS�Nrtr
r<r
r
r�__nonzero__FszProduction.__nonzero__cCs
|j|Sr)r��r	�indexr
r
rrOIszProduction.__getitem__c	Cs�|t|j�krdSt||�}zt|j|d|_WnttfyPg|_Yn0z|j|d|_Wnty~d|_Yn0|Sr�)r#r��LRItem�	Prodnames�lr_after�
IndexError�KeyError�	lr_before)r	rNr�r
r
r�lr_itemMs
zProduction.lr_itemcCs|jr||j|_dSr�r�r��r	�pdictr
r
r�bind]szProduction.bind)r�Nr�r)rrr�reducedrr=r@rUr�rOr�r�r
r
r
rr�s
r�c@s,eZdZdd�Zdd�Zdd�Zdd�Zd	S)
�MiniProductioncCs.||_||_||_d|_||_||_||_dSr)rr#r�r�r�r�r?)r	r?rr#r�r�r�r
r
rrfszMiniProduction.__init__cCs|jSrr>r<r
r
rr=oszMiniProduction.__str__cCs
d|jS)NzMiniProduction(%s)r>r<r
r
rr@rszMiniProduction.__repr__cCs|jr||j|_dSrr�r�r
r
rr�vszMiniProduction.bindN)rrrrr=r@r�r
r
r
rr�es	r�c@s$eZdZdd�Zdd�Zdd�ZdS)r�cCsZ|j|_t|j�|_|j|_||_i|_|j�|d�t|j�|_t|j�|_|j	|_	dS)N�.)
rrwr�r��lr_index�
lookaheads�insertr�r#r�)r	r�rNr
r
rr�szLRItem.__init__cCs,|jrd|jd�|j�f}n
d|j}|Sr�)r�rr�)r	rEr
r
rr=�s
zLRItem.__str__cCsdt|�dS)NzLRItem(r�r>r<r
r
rr@�szLRItem.__repr__N)rrrrr=r@r
r
r
rr��sr�cCs6t|�d}|dkr2|||vr(||S|d8}qdSrs)r#)�symbols�	terminalsrRr
r
r�rightmost_terminal�s
r�c@seZdZdS)�GrammarErrorNr!r
r
r
rr��sr�c@s�eZdZdd�Zdd�Zdd�Zdd�Zd$dd
�Zd%dd�Zdd�Z	dd�Z
dd�Zdd�Zdd�Z
dd�Zdd�Zdd�Zd&d d!�Zd"d#�Zd	S)'�GrammarcCsbdg|_i|_i|_i|_|D]}g|j|<qg|jd<i|_i|_i|_i|_t�|_	d|_
dS�Nr)�Productionsr��Prodmap�	Terminals�Nonterminals�First�Follow�
Precedence�set�UsedPrecedence�Start)r	r��termr
r
rr�s
zGrammar.__init__cCs
t|j�Sr)r#r�r<r
r
rrU�szGrammar.__len__cCs
|j|Sr)r�r�r
r
rrO�szGrammar.__getitem__cCsL|jdgksJd��||jvr*td|��|dvr:td��||f|j|<dS)Nz2Must call set_precedence() before add_production()z,Precedence already specified for terminal %r)�leftr��nonassocz:Associativity must be one of 'left','right', or 'nonassoc')r�r�r�)r	r��assoc�levelr
r
r�set_precedence�s
zGrammar.set_precedenceNr�rc	Cs�||jvrtd|||f��|dkr6td|||f��t�|�sRtd|||f��t|�D]�\}}|ddvr�zLt|�}t|�dkr�td||||f��||jvr�g|j|<|||<WqZWnty�Yn0t�|�sZ|d	krZtd
||||f��qZd	|v�r�|dd	k�rtd||f��|d
d	k�r<td||f��|d}	|j�	|	�}
|
�sjtd|||	f��n|j
�|	�|d
d�=nt||j�}	|j�	|	d�}
d||f}||j
v�r�|j
|}td|||fd|j|jf��t|j�}
||jv�rg|j|<|D]J}||jv�r&|j|�|
�n&||jv�r<g|j|<|j|�|
��qt|
|||
|||�}|j�|�||j
|<z|j|�|�Wn t�y�|g|j|<Yn0dS)Nz7%s:%d: Illegal rule name %r. Already defined as a tokenrz5%s:%d: Illegal rule name %r. error is a reserved wordz%s:%d: Illegal rule name %rrz'"rtzA%s:%d: Literal token %s in rule %r may only be a single characterz%precz!%s:%d: Illegal name %r in rule %rr�z+%s:%d: Syntax error. Nothing follows %%prec���zH%s:%d: Syntax error. %%prec can only appear at the end of a grammar rulez/%s:%d: Nothing known about the precedence of %rr�r�z%s:%d: Duplicate rule %s. zPrevious definition at %s:%d)r�r��_is_identifier�match�	enumerate�evalr#rcr�r�r��addr�r�r�r�r�r�rqr�r�r�)r	�prodname�symsr�r�r�rNrE�cZprecnameZprodprec�map�mZpnumberr�r�r
r
r�add_production
sv


�


�
�



zGrammar.add_productioncCsT|s|jdj}||jvr&td|��tdd|g�|jd<|j|�d�||_dS)Nrtzstart symbol %s undefinedr�S')r�rr�r�r�rqr�)r	�startr
r
r�	set_startas
zGrammar.set_startcs>���fdd��t����jdjd��fdd��jD�S)NcsB|�vrdS��|��j�|g�D]}|jD]}�|�q.q$dSr)r�r�r�r�)rEr�r'��mark_reachable_from�	reachabler	r
rr�ts

z5Grammar.find_unreachable.<locals>.mark_reachable_fromrcsg|]}|�vr|�qSr
r
rH)r�r
rrJ~rKz,Grammar.find_unreachable.<locals>.<listcomp>)r�r�r�r�r<r
r�r�find_unreachableqszGrammar.find_unreachablecCs�i}|jD]}d||<q
d|d<|jD]}d||<q&d}|j��D]N\}}|D]@}|jD]}||sXd}qrqXd}|rN||s�d||<d}qBqNqB|s4q�q4g}	|��D]4\}}
|
s�||jvr�||jvr�|dkr�q�|	�|�q�|	S)NTrnFr)r�r�r�rvr�rq)r	Z
terminatesr�rN�some_change�plr�rEZp_terminates�infiniter�r
r
r�infinite_cycles�s8




zGrammar.infinite_cyclescCsPg}|jD]@}|sq
|jD].}||jvr||jvr|dkr|�||f�qq
|Sr�)r�r�r�r�rq)r	r)r�rEr
r
r�undefined_symbols�s

zGrammar.undefined_symbolscCs2g}|j��D]\}}|dkr|s|�|�q|Sr�)r�rvrq)r	Z
unused_tokrErPr
r
r�unused_terminals�s
zGrammar.unused_terminalscCs8g}|j��D]$\}}|s|j|d}|�|�q|S�Nr)r�rvr�rq)r	Zunused_prodrErPr�r
r
r�unused_rules�szGrammar.unused_rulescCs@g}|jD]0}||jvs
||jvs
|�||j|df�q
|Sr)r�r�r�rq)r	ZunusedZtermnamer
r
r�unused_precedence�s

zGrammar.unused_precedencecCsZg}|D]B}d}|j|D]$}|dkr,d}q||vr|�|�q|rFqqVq|�d�|S)NF�<empty>T)r�rq)r	�betar)�xZx_produces_emptyrr
r
r�_first	s
zGrammar._firstcCs�|jr|jS|jD]}|g|j|<qdg|jd<|jD]}g|j|<q6d}|jD]H}|j|D]8}|�|j�D]&}||j|vrn|j|�|�d}qnq^qP|sFq�qF|jS)NrnFT)r�r�r�r�r	r�rq)r	r�rNr�r�rr
r
r�
compute_first,s"



zGrammar.compute_firstc
Cs<|jr|jS|js|��|jD]}g|j|<q |s@|jdj}dg|j|<d}|jdd�D]�}t|j�D]�\}}||jvrl|�|j|dd��}d}|D]:}	|	dkr�|	|j|vr�|j|�	|	�d}|	dkr�d}q�|s�|t
|j�dkrl|j|jD]*}	|	|j|v�r�|j|�	|	�d}�q�qlq^|sL�q6qL|jS)NrtrnFrT)r�r�r
r�r�rr�r�r	rqr#)
r	r��k�didaddr�rR�BZfstZhasemptyrr
r
r�compute_followQs:

zGrammar.compute_followc
Cs�|jD]�}|}d}g}|t|�kr(d}npt||�}z|j|j|d|_Wnttfyhg|_Yn0z|j|d|_Wnty�d|_Yn0||_	|s�q�|�
|�|}|d7}q||_qdS�Nrrt)r�r#r�r�r�r�r�r�r�r�rqr�)r	r�ZlastlrirRr�Zlrir
r
r�
build_lritems�s,



zGrammar.build_lritems)Nr�r)N)N)rrrrrUrOr�r�r�r�rrrrrr	r
rrr
r
r
rr��s $
T
@#%
;r�c@seZdZdS)�VersionErrorNr!r
r
r
rr�src@s,eZdZdd�Zdd�Zdd�Zdd�Zd	S)
�LRTablecCsd|_d|_d|_d|_dSr)rhrjrf�	lr_methodr<r
r
rr�szLRTable.__init__cCszt|tj�r|}ntd|�tj|}|jtkr:td��|j	|_
|j|_g|_
|jD]}|j
�t|��qV|j|_|jS)N�	import %s�&yacc table file version is out of date)rL�types�
ModuleType�execr�modulesZ_tabversion�__tabversion__rZ
_lr_actionrhZ_lr_gotorjrfZ_lr_productionsrqr�Z
_lr_methodrZ
_lr_signature)r	�modulerr�r
r
r�
read_table�s


zLRTable.read_tablecCs�zddl}Wnty&ddl}Yn0tj�|�s8t�t|d�}|�|�}|tkr\t	d��|�|�|_
|�|�}|�|�|_|�|�|_|�|�}g|_
|D]}|j
�t|��q�|��|S)Nr�rbr)�cPickle�ImportError�pickle�os�path�exists�open�loadrrrrhrjrfrqr��close)r	�filenamer Zin_fZ
tabversion�	signaturergr�r
r
r�read_pickle�s(



zLRTable.read_picklecCs|jD]}|�|�qdSr)rfr�)r	r�r�r
r
r�bind_callables�s
zLRTable.bind_callablesN)rrrrrr)r*r
r
r
rr�src	CsLi}|D]}d||<qg}i}|D]$}||dkr"t|||||||�q"|Sr)�traverse)�X�R�FP�NrrC�Fr
r
r�digraphs
r1c	Cs�|�|�t|�}|||<||�||<||�}|D]f}	||	dkrVt|	||||||�t||||	�||<|�|	g�D]}
|
||vrx||�|
�qxq2|||kr�t||d<||||d<|��}||kr�t||d<||||d<|��}q�dS)Nrr�)rqr#r+�minr��MAXINTr�)rr/rCr0r,r-r.�d�rel�y�a�elementr
r
rr+s(
r+c@seZdZdS)�	LALRErrorNr!r
r
r
rr9)sr9c@s�eZdZd$dd�Zdd�Zdd�Zd	d
�Zdd�Zd
d�Zdd�Z	dd�Z
dd�Zdd�Zdd�Z
dd�Zdd�Zdd�Zd%d d!�Zd&d"d#�ZdS)'�LRGeneratedTablerNcCs�|dvrtd|��||_||_|s*t�}||_i|_i|_|j|_i|_	i|_
d|_d|_d|_
g|_g|_g|_|j��|j��|j��|��dS)N)ZSLRrzUnsupported method %sr)r9�grammarrr�logrhrjr�rf�
lr_goto_cache�lr0_cidhash�
_add_countZsr_conflictZrr_conflict�	conflicts�sr_conflicts�rr_conflictsrr
r�lr_parse_table)r	r;�methodr<r
r
rr4s,


zLRGeneratedTable.__init__cCsn|jd7_|dd�}d}|rjd}|D]<}|jD]0}t|dd�|jkrLq4|�|j�|j|_d}q4q*q|S)NrtTF�	lr0_addedr)r?r�rXrqr�rE)r	�I�JrrSrr
r
r�lr0_closureYs

zLRGeneratedTable.lr0_closurec	Cs�|j�t|�|f�}|r|S|j�|�}|s:i}||j|<g}|D]H}|j}|rB|j|krB|�t|��}|s|i}||t|�<|�|�|}qB|�d�}|s�|r�|�|�}||d<n||d<||jt|�|f<|S)Nrn)r=r�r&r�r�rqrH)	r	rFr�grEZgsr�rN�s1r
r
r�lr0_gotoss2




zLRGeneratedTable.lr0_gotoc	Cs�|�|jjdjg�g}d}|D]}||jt|�<|d7}q d}|t|�kr�||}|d7}i}|D]}|jD]}d||<qnqd|D]@}|�||�}|r�t|�|jvr�q�t|�|jt|�<|�	|�q�q@|Sr)
rHr;r�r�r>r&r#r�rKrq)	r	�CrRrFZasyms�iirErrIr
r
r�	lr0_items�s(

zLRGeneratedTable.lr0_itemscCsxt�}d}|jjdd�D]@}|jdkr6|�|j�q|jD]}||vr<qq<|�|j�qt|�|krjqtt|�}q
|Sr)r�r;r�r#r�rr�)r	�nullableZnum_nullabler�r�r
r
r�compute_nullable_nonterminals�s


z.LRGeneratedTable.compute_nullable_nonterminalscCsjg}t|�D]X\}}|D]J}|j|jdkr||j|jdf}|d|jjvr||vr|�|�qq|Sr�)r�r�r#r�r;r�rq)r	rL�transZstatenoryr�r�r
r
r�find_nonterminal_transitions�sz-LRGeneratedTable.find_nonterminal_transitionscCs�i}|\}}g}|�|||�}|D]B}	|	j|	jdkr$|	j|	jd}
|
|jjvr$|
|vr$|�|
�q$|dkr�||jjdjdkr�|�d�|S)Nrtrrn)rKr�r#r�r;r�rqr�)r	rLrQrOZdr_setryr/�termsrIr�r7r
r
r�dr_relation�s
zLRGeneratedTable.dr_relationcCsrg}|\}}|�|||�}|j�t|�d�}|D]:}	|	j|	jdkr2|	j|	jd}
|
|vr2|�||
f�q2|S)Nr�rt)rKr>r�r&r�r#r�rq)r	rLrQ�emptyr5ryr/rIrSr�r7r
r
r�reads_relation	szLRGeneratedTable.reads_relationcCs�i}i}i}|D]}d||<q|D�]�\}}	g}
g}||D�],}|j|	krNq<|j}
|}|
|jdkr�|
d}
|j|
}||f|vr�|
d}||jkr�|j||jjvr�q�|j||vr�q�|d}q�|�||f�|�|||�}|j�	t
|�d�}qX||D]j}|j|jk�rq�|j|jk�r"q�d}||jk�rZ|j||j|dk�rNq�|d}�q&|
�||f�q�q<|D]*}||v�r�g||<||�||	f��qp|
|||	f<q"||fS)Nrtr�r)rr�r#r�r;r�rqrKr>r�r&)r	rLrQrOZlookdictZincludedictZdtransr�ryr/Zlookb�includesr�r�rS�lirIr'rRr
r
r�compute_lookback_includesC	sX





z*LRGeneratedTable.compute_lookback_includescs0���fdd�}���fdd�}t|||�}|S)Ncs���|��Sr)rT�r�rLrOr	r
r�<lambda>�	rKz4LRGeneratedTable.compute_read_sets.<locals>.<lambda>cs���|��Sr)rVrZr[r
rr\�	rK�r1)r	rL�ntransrOr.r-r0r
r[r�compute_read_sets�	sz"LRGeneratedTable.compute_read_setscs(�fdd�}�fdd�}t|||�}|S)Ncs�|Srr
rZ)�readsetsr
rr\�	rKz6LRGeneratedTable.compute_follow_sets.<locals>.<lambda>cs��|g�Sr)r�rZ)�inclsetsr
rr\�	rKr])r	r^r`rar.r-r0r
)rar`r�compute_follow_sets�	sz$LRGeneratedTable.compute_follow_setsc	Csl|��D]^\}}|D]P\}}||jvr0g|j|<|�|g�}|D]"}||j|vr@|j|�|�q@qqdSr)rvr�r�rq)	r	Z	lookbacksZ	followsetrQZlbryr�rr7r
r
r�add_lookaheads�	s

zLRGeneratedTable.add_lookaheadscCsP|��}|�|�}|�|||�}|�|||�\}}|�|||�}|�||�dSr)rPrRr_rYrbrc)r	rLrOrQr`ZlookdZincludedZ
followsetsr
r
r�add_lalr_lookaheads�	s
z$LRGeneratedTable.add_lalr_lookaheadsc$
Cs|jj}|jj}|j}|j}|j}i}|�d|j�|��}|jdkrP|�	|�d}|D�]�}	g}
i}i}i}
|�d�|�d|�|�d�|	D]}|�d|j
|�q�|�d�|	D�]�}|j|jdk�r|j
dkr�d|d	<||d	<�q�|jdk�r|j|}n|jj|j
}|D�]�}|
�||d
|j
|ff�|�|�}|du�r�|dk�r*|�|d�\}}||j
j\}}||k�s�||k�r�|dk�r�|j
||<|||<|�s�|�s�|�d
|�|j�||df�||j
jd7_nB||k�r|dk�rd||<n$|�s�|�d|�|j�||df�n�|dk�r�||}||j
}|j|jk�r�|j
||<|||<||}}||j
jd7_||j
jd8_n
||}}|j�|||f�|�d|||j
||�ntd|��n(|j
||<|||<||j
jd7_�qq�|j}|j|d}||jjvr�|�|	|�}|j�t|�d�}|dkr�|
�||d|f�|�|�}|du�r�|dk�r�||k�r�td|��n�|dk�r�|�|d�\}}|||j
j\}}||k�s�||k�r<|dk�r<|||j
jd8_|||<|||<|�s�|�d|�|j�||df�nH||k�rZ|dk�rZd||<n*|�s�|�s�|�d
|�|j�||df�ntd|��q�|||<|||<q�i}|
D]>\}}}||v�r�|||u�r�|�d||�d|||f<�q�|�d�d}|
D]P\}}}||v�r|||u�r||f|v�r|�d||�d}d|||f<�q|�rb|�d�i} |	D]*}!|!jD]}"|"|jjv�rtd| |"<�qt�qj| D]D}#|�|	|#�}|j�t|�d�}|dk�r�||
|#<|�d|#|��q�|||<|||<|
||<|d7}qXdS)NzParsing method: %srrr�zstate %dz    (%d) %srtr�rnzreduce using rule %d (%s)r�r�z3  ! shift/reduce conflict for %s resolved as reduce�reducer�z2  ! shift/reduce conflict for %s resolved as shift�shiftz=  ! reduce/reduce conflict for %s resolved using rule %d (%s)zUnknown conflict in state %dr�zshift and go to state %dz Shift/shift conflict in state %dr�z    %-15s %sz  ! %-15s [ %s ]z"    %-30s shift and go to state %d) r;r�r�rjrhr<rrrNrdr�r#r�rr�r�rqr�r�rAr�r�rBr9r�r�rKr>r&rr�r�)$r	r�r�rkrir<ZactionprL�strFZactlistZ	st_actionZ
st_actionpZst_gotor�Zlaheadsr7r'ZsprecZslevelZrprecZrlevelZoldp�ppZchosenpZrejectprRrIrSZ	_actprintr�Znot_usedZnkeysrMrErNr
r
rrC�	s

















�












zLRGeneratedTable.lr_parse_tabler�cCs�t|tj�rtd��|�d�d}tj�||�d}�z8t|d�}|�	dtj�
|�t|j|f�d}|�r`i}|j
��D]T\}	}
|
��D]B\}}|�|�}
|
s�ggf}
|
||<|
d�|	�|
d�|�q�qz|�	d	�|��D]f\}}|�	d
|�|dD]}
|�	d|
��q|�	d�|dD]}
|�	d|
��q(|�	d
�q�|�	d�|�	d�nF|�	d�|j
��D]&\}}|�	d|d|d|f��qt|�	d�|�r�i}|j��D]Z\}	}
|
��D]F\}}|�|�}
|
�s�ggf}
|
||<|
d�|	�|
d�|��qʐq�|�	d�|��D]h\}}|�	d
|�|dD]}
|�	d|
��qF|�	d�|dD]}
|�	d|
��qn|�	d
��q(|�	d�|�	d�nF|�	d�|j��D]&\}}|�	d|d|d|f��q�|�	d�|�	d�|jD]Z}|j�r:|�	d|j|j|j|jtj�
|j�|jf�n|�	dt|�|j|jf��q�|�	d�|��Wn(t�y�}z�WYd}~n
d}~00dS)Nz"Won't overwrite existing tabmoduler�r�z.py�wzu
# %s
# This file is automatically generated. Do not edit.
_tabversion = %r

_lr_method = %r

_lr_signature = %r
    rtrz
_lr_action_items = {z%r:([z%r,z],[z]),z}
z�
_lr_action = {}
for _k, _v in _lr_action_items.items():
   for _x,_y in zip(_v[0],_v[1]):
      if not _x in _lr_action:  _lr_action[_x] = {}
      _lr_action[_x][_k] = _y
del _lr_action_items
z
_lr_action = { z(%r,%r):%r,z
_lr_goto_items = {z�
_lr_goto = {}
for _k, _v in _lr_goto_items.items():
   for _x, _y in zip(_v[0], _v[1]):
       if not _x in _lr_goto: _lr_goto[_x] = {}
       _lr_goto[_x][_k] = _y
del _lr_goto_items
z
_lr_goto = { z_lr_productions = [
z  (%r,%r,%d,%r,%r,%d),
z  (%r,%r,%d,None,None,None),
z]
)rLrr�IOError�splitr!r"r�r$r�basenamerrrhrvr�rqrjrfr�r?rr#r�r�r&)r	�	tabmodule�	outputdirr(Zbasemodulenamer'rZsmallerrvrE�ndrrPrRrr��er
r
r�write_table�
s�
�





 




	
 


�
 
zLRGeneratedTable.write_tablecCszddl}Wnty&ddl}Yn0t|d���}|�t|t�|�|j|t�|�||t�|�|j|t�|�|j	|t�g}|j
D]T}|jr�|�|j
|j|j|jtj�|j�|jf�q�|�t
|�|j|jdddf�q�|�||t�Wd�n1�s0YdS)Nr�wb)rrr r$�dumpr�pickle_protocolrrhrjrfr�rqr?rr#r!r"rlr�r�)r	r'r(r �outfZoutpr�r
r
r�pickle_table s 
, zLRGeneratedTable.pickle_table)rN)r�r�)r�)rrrrrHrKrNrPrRrTrVrYr_rbrcrdrCrqrvr
r
r
rr:3s"
%#8+PB
zr:cCs0t�|�}|j��}|j|jkr,|�|j�|Sr)r�	_getframe�	f_globals�copy�f_locals�update)�levelsrZldictr
r
r�get_caller_module_dictCs


r}c
Cs�g}|��}d}|}|D]�}|d7}|��}|s2qz�|ddkrf|sTtd||f��|}	|dd�}
n@|d}	|	}|dd�}
|d}|dkr�|dkr�td||f��|�|||	|
f�Wqty��Yqty�td	|||��f��Yq0q|S)
Nrtr�|z%s:%d: Misplaced '|'��:z::=z!%s:%d: Syntax error. Expected ':'z%s:%d: Syntax error in rule %r)�
splitlinesrkrcrq�	Exception�strip)�docr�r�r;ZpstringsZlastpZdlineZpsr�r�r�Zassignr
r
r�
parse_grammarOs6r�c@s�eZdZd dd�Zdd�Zdd�Zdd	�Zd
d�Zdd
�Zdd�Z	dd�Z
dd�Zdd�Zdd�Z
dd�Zdd�Zdd�Zdd�ZdS)!�
ParserReflectNcCsL||_d|_d|_d|_t�|_g|_d|_|durBtt	j
�|_n||_dS)NF)r�r��
error_func�tokensr�rr;rrrr�r<)r	r�r<r
r
rryszParserReflect.__init__cCs,|��|��|��|��|��dSr)�	get_start�get_error_func�
get_tokens�get_precedence�get_pfunctionsr<r
r
r�get_all�s
zParserReflect.get_allcCs6|��|��|��|��|��|��|jSr)�validate_start�validate_error_func�validate_tokens�validate_precedence�validate_pfunctions�validate_modulesrr<r
r
r�validate_all�szParserReflect.validate_allc	Cs�g}zr|jr|�|j�|jr:|�d�dd�|jD���|jrR|�d�|j��|jD]}|drX|�|d�qXWnttfy�Yn0d�|�S)Nr�cSsg|]}d�|��qS)r�)r�)rIr�r
r
rrJ�rKz+ParserReflect.signature.<locals>.<listcomp>r�r)r�rqr�r�r��pfuncs�	TypeError�
ValueError)r	�partsrr
r
rr(�s
zParserReflect.signaturec	Cs�t�d�}|jD]�}zt�|�\}}Wnty<YqYn0i}t|�D]^\}}|d7}|�|�}|rJ|�d�}|�	|�}	|	s�|||<qJt�
|�}
|j�d|
|||	�qJqdS)Nz\s*def\s+(p_[a-zA-Z_0-9]*)\(rtz;%s:%d: Function %s redefined. Previously defined on line %d)
�re�compiler�inspect�getsourcelinesrjr�r��groupr��
getsourcefiler<r)r	Zfrer�linesZlinenZ	counthashr�r�r�prevr'r
r
rr��s&







�zParserReflect.validate_modulescCs|j�d�|_dS)Nr�)r�r�r�r<r
r
rr��szParserReflect.get_startcCs&|jdur"t|jt�s"|j�d�dS)Nz'start' must be a string)r�rL�string_typesr<rr<r
r
rr��s
zParserReflect.validate_startcCs|j�d�|_dS)N�p_error)r�r�r�r<r
r
rr��szParserReflect.get_error_funccCs�|jr�t|jtj�rd}n*t|jtj�r.d}n|j�d�d|_dS|jjj}|jjj	}t
�|j�}|j�
|�|jjj|}|dkr�|j�d||�d|_dS)Nrrtz2'p_error' defined, but is not a function or methodTz$%s:%d: p_error() requires 1 argument)r�rLr�FunctionType�
MethodTyper<r�__code__�co_firstlineno�co_filenamer��	getmodulerr��co_argcount)r	�ismethodZelineZefilerZargcountr
r
rr��s 

z!ParserReflect.validate_error_funccCsn|j�d�}|s&|j�d�d|_dSt|ttf�sJ|j�d�d|_dS|sd|j�d�d|_dS||_dS)Nr�zNo token list is definedTztokens must be a list or tupleztokens is empty)r�r�r<rrLrwr�r�)r	r�r
r
rr��szParserReflect.get_tokenscCsVd|jvr |j�d�d|_dSt�}|jD]$}||vrF|j�d|�|�|�q,dS)Nrz.Illegal token name 'error'. Is a reserved wordTzToken %r multiply defined)r�r<rr�rr�)r	r�rNr
r
rr�s

zParserReflect.validate_tokenscCs|j�d�|_dS)Nr�)r�r�r�r<r
r
rr�szParserReflect.get_precedencecCsg}|j�rt|jttf�s2|j�d�d|_dSt|j�D]�\}}t|ttf�sj|j�d�d|_dSt|�dkr�|j�d|�d|_dS|d}t|t�s�|j�d�d|_dS|dd�D]<}t|t�s�|j�d	�d|_dS|�	|||df�q�q<||_
dS)
Nz"precedence must be a list or tupleTzBad precedence tablerz?Malformed precedence entry %s. Must be (assoc, term, ..., term)rz)precedence associativity must be a stringrtz precedence items must be strings)r�rLrwr�r<rr�r#r�rq�preclist)r	r�r�r�r�r�r
r
rr�s6

z!ParserReflect.validate_precedencecCs�g}|j��D]\\}}|�d�r|dkr*qt|tjtjf�rt|d|jj	�}t
�|�}|�||||j
f�q|jdd�d�||_dS)N�p_r�r�cSs |dt|d�|d|dfS)Nrrtrrr>)Z
p_functionr
r
rr\Ds

�z.ParserReflect.get_pfunctions.<locals>.<lambda>)�key)r�rv�
startswithrLrr�r�rXr�r�r�r�rq�__doc__�sortr�)r	Zp_functionsr�itemr�rr
r
rr�7s
zParserReflect.get_pfunctionscCsNg}t|j�dkr(|j�d�d|_dS|jD�]\}}}}t�|�}|j|}t|tj	�rbd}nd}|j
j|kr�|j�d|||j�d|_q.|j
j|kr�|j�d|||j�d|_q.|j
s�|j�d|||j�q.z(t|||�}	|	D]}
|�||
f�q�Wn<t�y6}z"|j�t|��d|_WYd}~n
d}~00|j�|�q.|j��D]�\}}
|�d	��r|t|
tjtj	f��r|�qP|�d
��r��qP|�d	��r�|dk�r�|j�d|�t|
tj��r�|
j
jdk�s�t|
tj	��rP|
jj
jdk�rP|
j
�rPz8|
j
�d
�}|ddk�r(|j�d|
j
j|
j
j|�Wnt�y>Yn0�qP||_dS)Nrz+no rules of the form p_rulename are definedTrrtz%%s:%d: Rule %r has too many argumentsz#%s:%d: Rule %r requires an argumentzA%s:%d: No documentation string specified in function %r (ignored)r�Zt_r�z%r not defined as a functionr�r�z9%s:%d: Possible grammar rule %r defined without p_ prefix)r#r�r<rr�r�r�rLrr�r�r�rr�rr�rqrcr?rr�rvr�r��__func__rkr�r�r�r;)r	r;r�rrr�r�r�ZreqargsZparsed_grIrprNrPr
r
rr�Lsf

� 
���
z!ParserReflect.validate_pfunctions)N)rrrrr�r�r(r�r�r�r�r�r�r�r�r�r�r�r
r
r
rr�xs

r�c
<s>	|durt}|rd}|dur&ttj�}�rf�fdd�t��D�}
t|
�}d|vrntj|dj|d<ntd�}|	dur�t	|t
j�r�|j}nLd|vr�|d}n:|�d�}d�
|dd��}td	|�ttj|dd
�}tj�|�}	|�d�}|�rt	|t��rd|v�r|d|}|du�r&||d<t||d
�}|��|j�rJtd��|��}z�t�}|�rl|�|�}n
|�|�}|�s�||k�r�z&|�|j�t||j �}|j!a!|WWSt"�y�}z|�#d|�WYd}~n
d}~00WnFt$�y}z|�#t|��WYd}~nd}~0t%�y(Yn0|
du�r�|�r�ztt&tj�
|	|�d��}
Wn>t'�y�}z$|�#d||f�t(�}
WYd}~n
d}~00nt(�}
|
�)dt*�d}|�+��r�td��|j �s�|�#d�t,|j-�}|j.D]R\}}}z|�/|||�Wn2t0�y0}z|�#d|�WYd}~n
d}~00�q�|j1D]d\}}|\} }!}"}#z|�2|"|#|| |!�Wn6t0�y�}z|�d|�d}WYd}~n
d}~00�q<z&|du�r�|�3|j4�n
|�3|�Wn8t0�y}z|�t|��d}WYd}~n
d}~00|�rtd��|�5�}$|$D]"\}%}&|�d|&j6|&j7|%�d}�q|�8�}'|'�r�|
�)d
�|
�)d�|
�)d
�|'D]}|�#d|�|
�)d|��qp|�r�|
�)d
�|
�)d�|
�)d
�t9|j:�D]\}(})|
�)d|(|)��q�|�;�}*|*D]}&|�#d|&j6|&j7|&j<��q�t=|'�dk�r|�#d�t=|'�dk�r8|�#d t=|'��t=|*�dk�rP|�#d!�t=|*�dk�rn|�#d"t=|*��|�r>|
�)d
�|
�)d#�|
�)d
�t>|j?�}+|+�@�|+D]*}|
�)d$|d%�
d&d�|j?|D����q�|
�)d
�|
�)d'�|
�)d
�t>|jA�},|,�@�|,D]*}-|
�)d$|-d%�
d(d�|jA|-D����q|
�)d
�|�r�|�B�}.|.D]}/|�#d)|/��qP|�C�}0|0D]}1|�d*|1�d}�qp|�D�}2|2D]\}}|�d+||�d}�q�|�r�td��|�r�|�Ed,|�tF|||
�}|�rPt=|jG�}3|3dk�r|�#d-�n|3dk�r|�#d.|3�t=|jH�}4|4dk�r:|�#d/�n|4dk�rP|�#d0|4�|�rz|jG�sf|jH�rz|
�#d
�|
�#d1�|
�#d
�|jGD]\}5}6}7|
�#d2|6|5|7��q�tI�}8|jHD]x\}5}9}:|5tJ|9�tJ|:�f|8v�rڐq�|
�#d3|5|9�|
�#d4|:|5�|�#d3|5|9�|�#d4|:|5�|8�K|5tJ|9�tJ|:�f��q�g};|jHD]@\}5}9}:|:jL�s8|:|;v�r8|
�#d5|:�|�#d5|:�|;�M|:��q8|�r�z|�N||	|�Wn8t'�y�}z|�#d6||f�WYd}~n
d}~00|�	rz|�O||�Wn8t'�	y}z|�#d6||f�WYd}~n
d}~00|�|j�t||j �}|j!a!|S)7Nrcsg|]}|t�|�f�qSr
)rX)rIr�rr
rrJ�rKzyacc.<locals>.<listcomp>�__file__rrr�r�rr��__package__r�)r<zUnable to build parserz.There was a problem loading the table file: %rrizCouldn't open %r. %sz5Created by PLY version %s (http://www.dabeaz.com/ply)Fz no p_error() function is definedz%sTz;%s:%d: Symbol %r used, but not defined as a token or a rulezUnused terminals:zToken %r defined, but not usedz    %sr�zRule %-5d %sz$%s:%d: Rule %r defined, but not usedrtzThere is 1 unused tokenzThere are %d unused tokenszThere is 1 unused rulezThere are %d unused rulesz'Terminals, with rules where they appearz
%-20s : %sr�cSsg|]}t|��qSr
r>rHr
r
rrJG
rKz*Nonterminals, with rules where they appearcSsg|]}t|��qSr
r>rHr
r
rrJO
rKzSymbol %r is unreachablez)Infinite recursion detected for symbol %rz0Precedence rule %r defined for unknown symbol %rzGenerating %s tablesz1 shift/reduce conflictz%d shift/reduce conflictsz1 reduce/reduce conflictz%d reduce/reduce conflictsz
Conflicts:z7shift/reduce conflict for %s in state %d resolved as %sz;reduce/reduce conflict in state %d resolved using rule (%s)zrejected rule (%s) in state %dzRule (%s) is never reducedzCouldn't create %r. %s)P�
tab_modulerrr��dir�dictrr�r}rLrrrkr�rrXr!r"�dirnamer�r?r�r�rr r(rr)rr*r�rdr�r�r�rrrr$rjrr�__version__r�r�r�r�r�r�r;r�r�r�rr�r�rr�r�rrr#rwr�r�r�r�rrrr:rArBr�r&r�r�rqrqrv)<rDrrrmr�Zcheck_recursion�optimizeZwrite_tablesZ	debugfilernZdebuglogZerrorlogZ
picklefileZ_itemsr��srcfiler��pkgname�pkgZpinfor(�lrZread_signaturer8rp�errorsr;r�r�r��funcnameZgramr�r�r�r�rrrr�rrNr�rrSZnontermsZnontermZunreachable�ur��infZunused_precZnum_srZnum_rrryr��
resolution�already_reportedZruleZrejectedZwarned_neverr
r�r�yacc�s�






&"



&












(



(









((r�)<r�rr�os.pathr!r��base64r-r�rZ	yaccdebugZ
debug_filer�Z
default_lrr�r}r$rt�version_info�
basestringr�r?�maxsizer3�objectrrr�r r*r,r0r4r2r/r1r3r5r9r:rArdr�r�r�r�r�r�r�r�rrr1r+r9r:r}r�r�r�r
r
r
r�<module>>s�
4m
H.rT
)
�