U
    œ9%ek ã                   @   s  d dl Z d dlZd dlZd dlZd dlZd dlZd dlZdZdZ	dZ
dZdZdZdZdZd	Zd Zejd  dk rteZneZejZG d
d„ deƒZG dd„ deƒZG dd„ deƒZdd„ Zdd„ Zdada da!dZ"dd„ Z#dd„ Z$dd„ Z%dd„ Z&G dd„ dƒZ'G dd „ d ƒZ(G d!d"„ d"ƒZ)e  *d#¡Z+G d$d%„ d%eƒZ,G d&d'„ d'eƒZ-G d(d)„ d)eƒZ.d*d+„ Z/G d,d-„ d-eƒZ0G d.d/„ d/eƒZ1G d0d1„ d1eƒZ2G d2d3„ d3eƒZ3d4d5„ Z4d6d7„ Z5G d8d9„ d9eƒZ6G d:d;„ d;e3ƒZ7d<d=„ Z8d>d?„ Z9G d@dA„ dAeƒZ:de
deddddeddddfdBdC„Z;dS )Dé    Nz3.10Tz
parser.outÚparsetabÚLALRé   Fé(   c                   @   s4   e Zd Zdd„ Zdd„ ZeZdd„ Zdd„ ZeZd	S )
Ú	PlyLoggerc                 C   s
   || _ d S ©N)Úf)Úselfr   © r
   úQ/var/www/html/Darija-Ai-API/env/lib/python3.8/site-packages/pycparser/ply/yacc.pyÚ__init__n   s    zPlyLogger.__init__c                 O   s   | j  || d ¡ d S )NÚ
©r   Úwrite©r	   ÚmsgÚargsÚkwargsr
   r
   r   Údebugq   s    zPlyLogger.debugc                 O   s   | j  d||  d ¡ d S )Nz	WARNING: r   r   r   r
   r
   r   Úwarningv   s    zPlyLogger.warningc                 O   s   | j  d||  d ¡ d S )NzERROR: r   r   r   r
   r
   r   Úerrory   s    zPlyLogger.errorN)	Ú__name__Ú
__module__Ú__qualname__r   r   Úinfor   r   Úcriticalr
   r
   r
   r   r   m   s   r   c                   @   s   e Zd Zdd„ Zdd„ ZdS )Ú
NullLoggerc                 C   s   | S r   r
   )r	   Únamer
   r
   r   Ú__getattribute__€   s    zNullLogger.__getattribute__c                 O   s   | S r   r
   )r	   r   r   r
   r
   r   Ú__call__ƒ   s    zNullLogger.__call__N)r   r   r   r   r   r
   r
   r
   r   r      s   r   c                   @   s   e Zd ZdS )Ú	YaccErrorN©r   r   r   r
   r
   r
   r   r    ‡   s   r    c                 C   sP   t | ƒ}d|krt |ƒ}t|ƒtkr4|d t… d }dt| ƒjt| ƒ|f }|S )Nr   z ...z<%s @ 0x%x> (%s))ÚreprÚlenÚresultlimitÚtyper   Úid)ÚrÚrepr_strÚresultr
   r
   r   Úformat_result‹   s    r*   c                 C   sB   t | ƒ}d|krt |ƒ}t|ƒdk r(|S dt| ƒjt| ƒf S d S )Nr   é   z<%s @ 0x%x>)r"   r#   r%   r   r&   )r'   r(   r
   r
   r   Úformat_stack_entry•   s    r,   a  PLY: 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()
c                   C   s   t  t¡ tƒ S r   )ÚwarningsÚwarnÚ_warnmsgÚ_errokr
   r
   r
   r   Úerrok¯   s    
r1   c                   C   s   t  t¡ tƒ S r   )r-   r.   r/   Ú_restartr
   r
   r
   r   Úrestart³   s    
r3   c                   C   s   t  t¡ tƒ S r   )r-   r.   r/   Ú_tokenr
   r
   r
   r   Útoken·   s    
r5   c                 C   s>   |j a|ja|ja| |ƒ}z
bbbW n tk
r8   Y nX |S r   )r1   r0   r5   r4   r3   r2   Ú	NameError)Ú	errorfuncr5   Úparserr'   r
   r
   r   Úcall_errorfunc¼   s    
r9   c                   @   s   e Zd Zdd„ Zdd„ ZdS )Ú
YaccSymbolc                 C   s   | j S r   ©r%   ©r	   r
   r
   r   Ú__str__Ú   s    zYaccSymbol.__str__c                 C   s   t | ƒS r   ©Ústrr<   r
   r
   r   Ú__repr__Ý   s    zYaccSymbol.__repr__N)r   r   r   r=   r@   r
   r
   r
   r   r:   Ù   s   r:   c                   @   sf   e Zd Zddd„Zdd„ Zdd„ Zdd	„ Zd
d„ Zdd„ Zdd„ Z	dd„ Z
dd„ Zdd„ Zdd„ ZdS )ÚYaccProductionNc                 C   s   || _ || _d | _d | _d S r   )ÚsliceÚstackÚlexerr8   )r	   ÚsrC   r
   r
   r   r   ê   s    zYaccProduction.__init__c                 C   sB   t |tƒrdd„ | j| D ƒS |dkr2| j| jS | j| jS d S )Nc                 S   s   g | ]
}|j ‘qS r
   ©Úvalue©Ú.0rE   r
   r
   r   Ú
<listcomp>ò   s     z.YaccProduction.__getitem__.<locals>.<listcomp>r   )Ú
isinstancerB   rG   rC   ©r	   Únr
   r
   r   Ú__getitem__ð   s
    
zYaccProduction.__getitem__c                 C   s   || j | _d S r   )rB   rG   )r	   rM   Úvr
   r
   r   Ú__setitem__ø   s    zYaccProduction.__setitem__c                 C   s   dd„ | j ||… D ƒS )Nc                 S   s   g | ]
}|j ‘qS r
   rF   rH   r
   r
   r   rJ   ü   s     z/YaccProduction.__getslice__.<locals>.<listcomp>)rB   )r	   ÚiÚjr
   r
   r   Ú__getslice__û   s    zYaccProduction.__getslice__c                 C   s
   t | jƒS r   )r#   rB   r<   r
   r
   r   Ú__len__þ   s    zYaccProduction.__len__c                 C   s   t | j| ddƒS )NÚlinenor   ©ÚgetattrrB   rL   r
   r
   r   rU     s    zYaccProduction.linenoc                 C   s   || j | _d S r   )rB   rU   )r	   rM   rU   r
   r
   r   Ú
set_lineno  s    zYaccProduction.set_linenoc                 C   s,   t | j| ddƒ}t | j| d|ƒ}||fS )NrU   r   Ú	endlinenorV   )r	   rM   Ú	startlineÚendliner
   r
   r   Úlinespan  s    zYaccProduction.linespanc                 C   s   t | j| ddƒS )NÚlexposr   rV   rL   r
   r
   r   r]     s    zYaccProduction.lexposc                 C   s,   t | j| ddƒ}t | j| d|ƒ}||fS )Nr]   r   Ú	endlexposrV   )r	   rM   ÚstartposÚendposr
   r
   r   Úlexspan  s    zYaccProduction.lexspanc                 C   s   t ‚d S r   )ÚSyntaxErrorr<   r
   r
   r   r     s    zYaccProduction.error)N)r   r   r   r   rN   rP   rS   rT   rU   rX   r\   r]   ra   r   r
   r
   r
   r   rA   é   s   
rA   c                   @   s\   e Zd Zdd„ Zdd„ Zdd„ Zdd„ Zd	d
„ Zddd„Zddd„Z	ddd„Z
ddd„ZdS )ÚLRParserc                 C   s0   |j | _|j| _|j| _|| _|  ¡  d| _d S ©NT)	Úlr_productionsÚproductionsÚ	lr_actionÚactionÚlr_gotoÚgotor7   Úset_defaulted_statesÚerrorok)r	   ZlrtabZerrorfr
   r
   r   r     s    zLRParser.__init__c                 C   s
   d| _ d S rd   )rl   r<   r
   r
   r   r1   &  s    zLRParser.errokc                 C   s@   | j d d …= | jd d …= tƒ }d|_| j |¡ | j  d¡ d S )Nú$endr   )Ú
statestackÚsymstackr:   r%   Úappend)r	   Úsymr
   r
   r   r3   )  s    zLRParser.restartc                 C   sP   i | _ | j ¡ D ]:\}}t| ¡ ƒ}t|ƒdkr|d dk r|d | j |< qd S ©Né   r   )Údefaulted_statesrh   ÚitemsÚlistÚvaluesr#   )r	   ÚstateÚactionsÚrulesr
   r
   r   rk   9  s
    zLRParser.set_defaulted_statesc                 C   s
   i | _ d S r   )rt   r<   r
   r
   r   Údisable_defaulted_states@  s    z!LRParser.disable_defaulted_statesNFc                 C   sZ   |st r.t|tƒrttjƒ}|  |||||¡S |rD|  |||||¡S |  |||||¡S d S r   )	Ú	yaccdevelrK   Úintr   ÚsysÚstderrÚ
parsedebugÚparseoptÚparseopt_notrack)r	   ÚinputrD   r   ÚtrackingÚ	tokenfuncr
   r
   r   ÚparseC  s    

zLRParser.parsec                  C   sÂ  d }g }| j }| j}	| j}
| j}td ƒ}d}| d¡ |sLddlm} |j}||_| |_	|d k	rj| 
|¡ |d krz|j}n|}|| _g }|| _g }|| _||_d }| d¡ tƒ }d|_| |¡ d}| d¡ | d|¡ ||kr(|s|sø|ƒ }n| ¡ }|stƒ }d|_|j}||  |¡}n|| }| d|| ¡ | d	d
d dd„ |D ƒdd … ¡t|ƒf  ¡ ¡ |d k	r„|dkr¾| |¡ |}| d|¡ | |¡ d }|rÆ|d8 }qÆ|dk rH|
|  }|j}|j}tƒ }||_d |_|r<| d|jdd dd„ || d … D ƒ¡ d |	|d|   | ¡ n| d|jg |	|d  | ¡ |rŒ|| d d … }||d< |rÀ|d }|j|_|j|_|d }t|d|jƒ|_t|d|jƒ|_||_ zd|| d …= || _!| "|¡ || d …= | dt#|d ƒ¡ | |¡ |	|d  | }| |¡ W qÆ t$k
r†   | |¡ | %|dd… ¡ | ¡  |d }d|_d|_|}t&}d| _'Y qÆX qÆn¼|r¢|j|_|j|_|g}||_ zL|| _!| "|¡ | dt#|d ƒ¡ | |¡ |	|d  | }| |¡ W qÆ t$k
rD   | |¡ | ¡  |d }d|_d|_|}t&}d| _'Y qÆX qÆ|dkr„|d }t|dd ƒ}| dt#|ƒ¡ | d¡ |S |d kr´| (dd
d dd„ |D ƒdd … ¡t|ƒf  ¡ ¡ |dksÔ| j'rœt&}d| _'|}|jdkròd }| j)r:|rt*|dƒs||_|| _!t+| j)|| ƒ}| j'rš|}d }qÆn`|rŠt*|d ƒrT|j}nd}|rvt,j- .d!||jf ¡ nt,j- .d"|j ¡ nt,j- .d#¡ d S nt&}t|ƒdkrÒ|jdkrÒd }d }d}|d d …= qÆ|jdkrâd S |jdkr„|d }|jdkr.|r(t|d |jƒ|_t|d$|jƒ|_d }qÆtƒ }d|_t*|d ƒrT|j |_|_t*|d$ƒrn|j |_|_||_| |¡ |}qÆ| ¡ }|r¢|j|_|j|_| ¡  |d }qÆt/d%ƒ‚qÆd S )&Nr   zPLY: PARSE DEBUG STARTrs   ©Úlexrm   Ú zState  : %sz#Defaulted state %s: Reduce using %dzStack  : %sz%s . %sú c                 S   s   g | ]
}|j ‘qS r
   r;   ©rI   Zxxr
   r
   r   rJ   ±  s     z'LRParser.parsedebug.<locals>.<listcomp>z Action : Shift and goto state %sz3Action : Reduce rule [%s] with %s and goto state %dú[ú,c                 S   s   g | ]}t |jƒ‘qS r
   )r,   rG   )rI   Ú_vr
   r
   r   rJ   Ô  s     ú]éÿÿÿÿrY   r^   zResult : %sr   FrG   zDone   : Returning %szPLY: PARSE DEBUG ENDzError  : %sc                 S   s   g | ]
}|j ‘qS r
   r;   r‹   r
   r
   r   rJ   B  s     rD   rU   ú(yacc: Syntax error at line %d, token=%s
úyacc: Syntax error, token=%sú yacc: Parse error in input. EOF
r]   úyacc: internal parser error!!!
)0rh   rj   rf   rt   rA   r   r‰   rˆ   rD   r8   rƒ   r5   rn   ro   rC   rp   r:   r%   r   ÚpopÚgetÚjoinr?   Úlstripr   r#   rG   rU   r]   rW   rY   r^   rB   rx   Úcallabler*   rb   ÚextendÚerror_countrl   r   r7   Úhasattrr9   r~   r   r   ÚRuntimeError© r	   rƒ   rD   r   r„   r…   Ú	lookaheadÚlookaheadstackry   rj   Úprodrt   ÚpsliceÚ
errorcountrˆ   Ú	get_tokenrn   ro   Úerrtokenrq   rx   ÚltypeÚtÚpÚpnameÚplenÚtargÚt1rM   r)   ÚtokrU   r
   r
   r   r€   \  s„   





*ÿ






$þÿ








*ÿ

zLRParser.parsedebugc                  C   sn  d }g }| j }| j}	| j}
| j}td ƒ}d}|sBddlm} |j}||_| |_|d k	r`| 	|¡ |d krp|j
}n|}|| _
g }|| _g }|| _||_d }| d¡ tƒ }d|_| |¡ d}||kr|sî|sÖ|ƒ }n| ¡ }|sîtƒ }d|_|j}||  |¡}n|| }|d k	rd|dkrJ| |¡ |}| |¡ d }|r¼|d8 }q¼|dk rB|
|  }|j}|j}tƒ }||_d |_|rš|| d d … }||d< |râ|d }|j|_|j|_|d }t|d|jƒ|_t|d|jƒ|_||_zP|| d …= || _| |¡ || d …= | |¡ |	|d  | }| |¡ W q¼ tk
r”   | |¡ | |dd… ¡ | ¡  |d }d|_d|_|}t }d	| _!Y q¼X q¼n¨|r°|j|_|j|_|g}||_z8|| _| |¡ | |¡ |	|d  | }| |¡ W q¼ tk
r>   | |¡ | ¡  |d }d|_d|_|}t }d	| _!Y q¼X q¼|dkrd|d }t|d
d ƒ}|S |d kr`|dks€| j!rHt }d	| _!|}|jdkržd }| j"ræ|r¾t#|dƒs¾||_|| _t$| j"|| ƒ}| j!rF|}d }q¼n`|r6t#|dƒr |j}nd}|r"t%j& 'd||jf ¡ nt%j& 'd|j ¡ nt%j& 'd¡ d S nt }t|ƒdkr~|jdkr~d }d }d}|d d …= q¼|jdkrŽd S |jdkr0|d }|jdkrÚ|rÔt|d|jƒ|_t|d|jƒ|_d }q¼tƒ }d|_t#|dƒr |j |_|_t#|dƒr|j |_|_||_| |¡ |}q¼| ¡ }|rN|j|_|j|_| ¡  |d }q¼t(dƒ‚q¼d S )Nr   rs   r‡   rm   r   rY   r^   r   FrG   rD   rU   r‘   r’   r“   r]   r”   ))rh   rj   rf   rt   rA   r‰   rˆ   rD   r8   rƒ   r5   rn   ro   rC   rp   r:   r%   r•   r–   r   r#   rG   rU   r]   rW   rY   r^   rB   rx   r™   rb   rš   r›   rl   r7   rœ   r9   r~   r   r   r   rž   r
   r
   r   r   ·  sV   



















zLRParser.parseoptc                 C   sÖ  d }g }| j }| j}	| j}
| j}td ƒ}d}|sBddlm} |j}||_| |_|d k	r`| 	|¡ |d krp|j
}n|}|| _
g }|| _g }|| _||_d }| d¡ tƒ }d|_| |¡ d}||kr|sî|sÖ|ƒ }n| ¡ }|sîtƒ }d|_|j}||  |¡}n|| }|d k	r|dkrJ| |¡ |}| |¡ d }|r¼|d8 }q¼|dk ræ|
|  }|j}|j}tƒ }||_d |_|rT|| d d … }||d< ||_zP|| d …= || _| |¡ || d …= | |¡ |	|d  | }| |¡ W q¼ tk
rN   | |¡ | |dd… ¡ | ¡  |d }d|_d|_|}t}d| _Y q¼X q¼n’|g}||_z8|| _| |¡ | |¡ |	|d  | }| |¡ W q¼ tk
râ   | |¡ | ¡  |d }d|_d|_|}t}d| _Y q¼X q¼|dkr|d }t|dd ƒ}|S |d krÈ|dks$| jrìt}d| _|}|jdkrBd }| jrŠ|rbt|d	ƒsb||_|| _t | j|| ƒ}| jrê|}d }q¼n`|rÚt|d
ƒr¤|j!}nd}|rÆt"j# $d||jf ¡ nt"j# $d|j ¡ nt"j# $d¡ d S nt}t|ƒdkr"|jdkr"d }d }d}|d d …= q¼|jdkr2d S |jdkr®|d }|jdkrXd }q¼tƒ }d|_t|d
ƒr~|j! |_!|_%t|dƒr˜|j& |_&|_'||_| |¡ |}q¼| ¡ }| ¡  |d }q¼t(dƒ‚q¼d S )Nr   rs   r‡   rm   r   r   FrG   rD   rU   r‘   r’   r“   r]   r”   ))rh   rj   rf   rt   rA   r‰   rˆ   rD   r8   rƒ   r5   rn   ro   rC   rp   r:   r%   r•   r–   r   r#   rG   rB   rx   r™   rb   rš   r›   rl   rW   r7   rœ   r9   rU   r~   r   r   rY   r]   r^   r   )r	   rƒ   rD   r   r„   r…   rŸ   r    ry   rj   r¡   rt   r¢   r£   rˆ   r¤   rn   ro   r¥   rq   rx   r¦   r§   r¨   r©   rª   r«   rM   r)   r­   rU   r
   r
   r   r‚   é  s6   



















zLRParser.parseopt_notrack)NNFFN)NNFFN)NNFFN)NNFFN)r   r   r   r   r1   r3   rk   r{   r†   r€   r   r‚   r
   r
   r
   r   rc     s   

  ]
  4rc   z^[a-zA-Z0-9_-]+$c                   @   sR   e Zd ZdZddd„Zdd„ Zd	d
„ Zdd„ Zdd„ Zdd„ Z	dd„ Z
dd„ ZdS )Ú
Productionr   ©Úrightr   Nr‰   c           	      C   s¤   || _ t|ƒ| _|| _|| _d | _|| _|| _|| _t	| jƒ| _	g | _
| jD ]}|| j
krL| j
 |¡ qLg | _d | _| jr”d| j d | j¡f | _nd| j  | _d S ©Nú%s -> %srŠ   z%s -> <empty>)r   Útupler¡   ÚnumberÚfuncr™   ÚfileÚlineÚprecr#   Úusymsrp   Úlr_itemsÚlr_nextr—   r?   )	r	   r´   r   r¡   Ú
precedencerµ   r¶   r·   rE   r
   r
   r   r     s$    


zProduction.__init__c                 C   s   | j S r   r>   r<   r
   r
   r   r=   =  s    zProduction.__str__c                 C   s   dt | ƒ d S )NzProduction(ú)r>   r<   r
   r
   r   r@   @  s    zProduction.__repr__c                 C   s
   t | jƒS r   )r#   r¡   r<   r
   r
   r   rT   C  s    zProduction.__len__c                 C   s   dS ©Nrs   r
   r<   r
   r
   r   Ú__nonzero__F  s    zProduction.__nonzero__c                 C   s
   | j | S r   )r¡   ©r	   Úindexr
   r
   r   rN   I  s    zProduction.__getitem__c              	   C   sˆ   |t | jƒkrd S t| |ƒ}zt|j|d   |_W n ttfk
rR   g |_Y nX z|j|d  |_W n tk
r‚   d |_Y nX |S r¾   )r#   r¡   ÚLRItemÚ	ProdnamesÚlr_afterÚ
IndexErrorÚKeyErrorÚ	lr_before)r	   rM   r¨   r
   r
   r   Úlr_itemM  s    
zProduction.lr_itemc                 C   s   | j r|| j  | _d S r   ©rµ   r™   ©r	   Úpdictr
   r
   r   Úbind]  s    zProduction.bind)r¯   Nr‰   r   )r   r   r   Úreducedr   r=   r@   rT   r¿   rN   rÈ   rÌ   r
   r
   r
   r   r®     s   
r®   c                   @   s,   e Zd Zdd„ Zdd„ Zdd„ Zdd„ Zd	S )
ÚMiniProductionc                 C   s.   || _ || _|| _d | _|| _|| _|| _d S r   )r   r#   rµ   r™   r¶   r·   r?   )r	   r?   r   r#   rµ   r¶   r·   r
   r
   r   r   f  s    zMiniProduction.__init__c                 C   s   | j S r   r>   r<   r
   r
   r   r=   o  s    zMiniProduction.__str__c                 C   s
   d| j  S )NzMiniProduction(%s)r>   r<   r
   r
   r   r@   r  s    zMiniProduction.__repr__c                 C   s   | j r|| j  | _d S r   rÉ   rÊ   r
   r
   r   rÌ   v  s    zMiniProduction.bindN)r   r   r   r   r=   r@   rÌ   r
   r
   r
   r   rÎ   e  s   	rÎ   c                   @   s$   e Zd Zdd„ Zdd„ Zdd„ ZdS )rÂ   c                 C   sZ   |j | _ t|jƒ| _|j| _|| _i | _| j |d¡ t| jƒ| _t| jƒ| _|j	| _	d S )NÚ.)
r   rv   r¡   r´   Úlr_indexÚ
lookaheadsÚinsertr³   r#   r¹   )r	   r¨   rM   r
   r
   r   r   ”  s    zLRItem.__init__c                 C   s,   | j rd| jd | j ¡f }n
d| j }|S r±   )r¡   r   r—   )r	   rE   r
   r
   r   r=   Ÿ  s    
zLRItem.__str__c                 C   s   dt | ƒ d S )NzLRItem(r½   r>   r<   r
   r
   r   r@   ¦  s    zLRItem.__repr__N)r   r   r   r   r=   r@   r
   r
   r
   r   rÂ   “  s   rÂ   c                 C   s6   t | ƒd }|dkr2| | |kr(| | S |d8 }qd S rr   )r#   )ÚsymbolsÚ	terminalsrQ   r
   r
   r   Úrightmost_terminal®  s    
rÕ   c                   @   s   e Zd ZdS )ÚGrammarErrorNr!   r
   r
   r
   r   rÖ   ¾  s   rÖ   c                   @   s’   e Zd Zdd„ Zdd„ Zdd„ Zdd„ Zd$dd„Zd%dd„Zdd„ Z	dd„ Z
dd„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ Zd&d d!„Zd"d#„ Zd	S )'ÚGrammarc                 C   sb   d g| _ i | _i | _i | _|D ]}g | j|< qg | jd< i | _i | _i | _i | _tƒ | _	d | _
d S ©Nr   )ÚProductionsrÃ   ÚProdmapÚ	TerminalsÚNonterminalsÚFirstÚFollowÚ
PrecedenceÚsetÚUsedPrecedenceÚStart)r	   rÔ   Útermr
   r
   r   r   Â  s    
zGrammar.__init__c                 C   s
   t | jƒS r   )r#   rÙ   r<   r
   r
   r   rT   æ  s    zGrammar.__len__c                 C   s
   | j | S r   )rÙ   rÀ   r
   r
   r   rN   é  s    zGrammar.__getitem__c                 C   sL   | j d gkstdƒ‚|| jkr*td| ƒ‚|dkr:tdƒ‚||f| j|< d S )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Ù   ÚAssertionErrorrß   rÖ   )r	   rã   ÚassocÚlevelr
   r
   r   Úset_precedenceô  s    
zGrammar.set_precedenceNr‰   r   c              	   C   s¸  || j krtd|||f ƒ‚|dkr6td|||f ƒ‚t |¡sRtd|||f ƒ‚t|ƒD ]œ\}}|d dkrÐzLt|ƒ}t|ƒdkr˜td||||f ƒ‚|| j kr¬g | j |< |||< W qZW n tk
rÎ   Y nX t |¡sZ|d	krZtd
||||f ƒ‚qZd	|kr„|d d	kr td||f ƒ‚|d d	kr>td||f ƒ‚|d }	| j 	|	¡}
|
sltd|||	f ƒ‚n| j
 |	¡ |dd …= nt|| j ƒ}	| j 	|	d¡}
d||f }|| jkrâ| j| }td|||f d|j|jf  ƒ‚t| jƒ}|| jkrg | j|< |D ]J}|| j kr(| j |  |¡ n&|| jkr>g | j|< | j|  |¡ qt||||
|||ƒ}| j |¡ || j|< z| j|  |¡ W n" tk
r²   |g| j|< Y nX d S )Nz7%s:%d: Illegal rule name %r. Already defined as a tokenr   z5%s:%d: Illegal rule name %r. error is a reserved wordz%s:%d: Illegal rule name %rr   z'"rs   zA%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. zPrevious definition at %s:%d)rÛ   rÖ   Ú_is_identifierÚmatchÚ	enumerateÚevalr#   rb   rß   r–   rá   ÚaddrÕ   rÚ   r¶   r·   rÙ   rÜ   rp   r®   rÃ   rÆ   )r	   ÚprodnameÚsymsrµ   r¶   r·   rM   rE   ÚcZprecnameZprodprecÚmapÚmZpnumberr§   r¨   r
   r
   r   Úadd_production  sv    


ÿ


ÿ
ÿ



zGrammar.add_productionc                 C   sT   |s| j d j}|| jkr&td| ƒ‚tdd|gƒ| j d< | j|  d¡ || _d S )Nrs   zstart symbol %s undefinedr   úS')rÙ   r   rÜ   rÖ   r®   rp   râ   )r	   Ústartr
   r
   r   Ú	set_starta  s    
zGrammar.set_startc                    s>   ‡ ‡‡fdd„‰ t ƒ ‰ˆ ˆjd jd ƒ ‡fdd„ˆjD ƒS )Nc                    sB   | ˆkrd S ˆ  | ¡ ˆj | g ¡D ]}|jD ]}ˆ |ƒ q.q$d S r   )rï   rÃ   r–   r¡   )rE   r¨   r'   ©Úmark_reachable_fromÚ	reachabler	   r
   r   rú   t  s    

z5Grammar.find_unreachable.<locals>.mark_reachable_fromr   c                    s   g | ]}|ˆ kr|‘qS r
   r
   rH   )rû   r
   r   rJ   ~  s      z,Grammar.find_unreachable.<locals>.<listcomp>)rà   rÙ   r¡   rÜ   r<   r
   rù   r   Úfind_unreachableq  s    zGrammar.find_unreachablec                 C   sà   i }| j D ]}d||< q
d|d< | jD ]}d||< q&d}| j ¡ D ]N\}}|D ]@}|jD ]}|| sXd} qrqXd}|rN|| sŠd||< d} qBqNqB|s4qšq4g }	| ¡ D ]4\}}
|
s¦|| jkrÐ|| j krÐ|dkrÐq¦|	 |¡ q¦|	S )NTrm   Fr   )rÛ   rÜ   rÃ   ru   r¡   rp   )r	   Z
terminatesr§   rM   Úsome_changeÚplr¨   rE   Zp_terminatesÚinfiniterã   r
   r
   r   Úinfinite_cyclesˆ  s8    




zGrammar.infinite_cyclesc                 C   sP   g }| j D ]@}|sq
|jD ].}|| jkr|| jkr|dkr| ||f¡ qq
|S rØ   )rÙ   r¡   rÃ   rÛ   rp   )r	   r)   r¨   rE   r
   r
   r   Úundefined_symbolsÈ  s    

zGrammar.undefined_symbolsc                 C   s2   g }| j  ¡ D ]\}}|dkr|s| |¡ q|S rØ   )rÛ   ru   rp   )r	   Z
unused_tokrE   rO   r
   r
   r   Úunused_terminalsÙ  s
    zGrammar.unused_terminalsc                 C   s8   g }| j  ¡ D ]$\}}|s| j| d }| |¡ q|S ©Nr   )rÜ   ru   rÃ   rp   )r	   Zunused_prodrE   rO   r¨   r
   r
   r   Úunused_rulesè  s    zGrammar.unused_rulesc                 C   s@   g }| j D ]0}|| jks
|| jks
| || j | d f¡ q
|S r  )rß   rÛ   rá   rp   )r	   ZunusedZtermnamer
   r
   r   Úunused_precedenceù  s
    
zGrammar.unused_precedencec                 C   sZ   g }|D ]B}d}| j | D ]$}|dkr,d}q||kr| |¡ q|rFq qVq| d¡ |S )NFú<empty>T)rÝ   rp   )r	   Úbetar)   ÚxZx_produces_emptyr   r
   r
   r   Ú_first	  s    
zGrammar._firstc                 C   s¨   | j r| j S | jD ]}|g| j |< qdg| j d< | jD ]}g | j |< q6d}| jD ]H}| j| D ]8}|  |j¡D ]&}|| j | krn| j |  |¡ d}qnq^qP|sFq¢qF| j S )Nrm   FT)rÝ   rÛ   rÜ   rÃ   r	  r¡   rp   )r	   r§   rM   rý   r¨   r   r
   r
   r   Úcompute_first,  s"    



zGrammar.compute_firstc           
      C   s<  | j r| j S | js|  ¡  | jD ]}g | j |< q |s@| jd j}dg| j |< d}| jdd … D ]Ì}t|jƒD ]¼\}}|| jkrl|  |j|d d … ¡}d}|D ]:}	|	dkrÌ|	| j | krÌ| j |  	|	¡ d}|	dkržd}qž|sð|t
|jƒd krl| j |j D ]*}	|	| j | k rü| j |  	|	¡ d} qüqlq^|sLq6qL| j S )Nrs   rm   Fr  T)rÞ   rÝ   r
  rÜ   rÙ   r   rí   r¡   r	  rp   r#   )
r	   r÷   ÚkÚdidaddr¨   rQ   ÚBZfstZhasemptyr   r
   r
   r   Úcompute_followQ  s:    

zGrammar.compute_followc              
   C   sÌ   | j D ]À}|}d}g }|t|ƒkr(d }ntt||ƒ}z| j|j|d   |_W n ttfk
rj   g |_Y nX z|j|d  |_W n tk
rš   d |_Y nX ||_	|s¨qÀ| 
|¡ |}|d7 }q||_qd S ©Nr   rs   )rÙ   r#   rÂ   rÃ   r¡   rÄ   rÅ   rÆ   rÇ   r»   rp   rº   )r	   r¨   ZlastlrirQ   rº   Zlrir
   r
   r   Úbuild_lritemsŒ  s,    



zGrammar.build_lritems)Nr‰   r   )N)N)r   r   r   r   rT   rN   ré   rõ   rø   rü   r   r  r  r  r  r	  r
  r  r  r
   r
   r
   r   r×   Á  s    $
T
@#%
;r×   c                   @   s   e Zd ZdS )ÚVersionErrorNr!   r
   r
   r
   r   r  °  s   r  c                   @   s,   e Zd Zdd„ Zdd„ Zdd„ Zdd„ Zd	S )
ÚLRTablec                 C   s   d | _ d | _d | _d | _d S r   )rg   ri   re   Ú	lr_methodr<   r
   r
   r   r   ´  s    zLRTable.__init__c                 C   sz   t |tjƒr|}ntd| ƒ tj| }|jtkr:tdƒ‚|j	| _
|j| _g | _|jD ]}| j t|Ž ¡ qV|j| _|jS )Nú	import %sú&yacc table file version is out of date)rK   ÚtypesÚ
ModuleTypeÚexecr~   ÚmodulesZ_tabversionÚ__tabversion__r  Z
_lr_actionrg   Z_lr_gotori   re   Z_lr_productionsrp   rÎ   Z
_lr_methodr  Z_lr_signature)r	   Úmoduler   r¨   r
   r
   r   Ú
read_tableº  s    


zLRTable.read_tablec                 C   sÂ   zdd l }W n tk
r(   dd l}Y nX tj |¡s:t‚t|dƒ}| |¡}|tkr^t	dƒ‚| |¡| _
| |¡}| |¡| _| |¡| _| |¡}g | _|D ]}| j t|Ž ¡ q | ¡  |S )Nr   Úrbr  )ÚcPickleÚImportErrorÚpickleÚosÚpathÚexistsÚopenÚloadr  r  r  rg   ri   re   rp   rÎ   Úclose)r	   Úfilenamer   Zin_fZ
tabversionÚ	signaturerf   r¨   r
   r
   r   Úread_pickleÎ  s(    



zLRTable.read_picklec                 C   s   | j D ]}| |¡ qd S r   )re   rÌ   )r	   rË   r¨   r
   r
   r   Úbind_callablesê  s    
zLRTable.bind_callablesN)r   r   r   r   r  r)  r*  r
   r
   r
   r   r  ³  s   r  c              	   C   sL   i }| D ]}d||< qg }i }| D ]$}|| dkr"t ||||| ||ƒ q"|S r  )Útraverse)ÚXÚRÚFPÚNr  rC   ÚFr
   r
   r   Údigraph  s    
r1  c              	   C   sü   |  | ¡ t|ƒ}||| < || ƒ|| < || ƒ}|D ]f}	||	 dkrVt|	||||||ƒ t||  ||	 ƒ|| < | |	g ¡D ]}
|
||  krx||    |
¡ qxq2||  |krøt||d < ||  ||d < | ¡ }|| krøt||d < ||  ||d < | ¡ }qÊd S )Nr   r   )rp   r#   r+  Úminr–   ÚMAXINTr•   )r  r/  rC   r0  r,  r-  r.  ÚdÚrelÚyÚaÚelementr
   r
   r   r+    s(    
r+  c                   @   s   e Zd ZdS )Ú	LALRErrorNr!   r
   r
   r
   r   r9  )  s   r9  c                   @   s’   e Zd Zd$dd„Zdd„ Zdd„ Zd	d
„ Zdd„ Zdd„ Zdd„ Z	dd„ Z
dd„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ Zd%d d!„Zd&d"d#„ZdS )'ÚLRGeneratedTabler   Nc                 C   sž   |dkrt d| ƒ‚|| _|| _|s*tƒ }|| _i | _i | _|j| _i | _	i | _
d| _d| _d| _g | _g | _g | _| j ¡  | j ¡  | j ¡  |  ¡  d S )N)ZSLRr   zUnsupported method %sr   )r9  Úgrammarr  r   Úlogrg   ri   rÙ   re   Úlr_goto_cacheÚlr0_cidhashÚ
_add_countZsr_conflictZrr_conflictÚ	conflictsÚsr_conflictsÚrr_conflictsr  r
  r  Úlr_parse_table)r	   r;  Úmethodr<  r
   r
   r   r   4  s,    


zLRGeneratedTable.__init__c                 C   sn   |  j d7  _ |d d … }d}|rjd}|D ]<}|jD ]0}t|ddƒ| j krLq4| |j¡ | j |_d}q4q*q|S )Nrs   TFÚ	lr0_addedr   )r?  rÄ   rW   rp   r»   rE  )r	   ÚIÚJr  rR   r  r
   r
   r   Úlr0_closureY  s    

zLRGeneratedTable.lr0_closurec           	      C   sÐ   | j  t|ƒ|f¡}|r|S | j  |¡}|s:i }|| j |< g }|D ]H}|j}|rB|j|krB| t|ƒ¡}|s|i }||t|ƒ< | |¡ |}qB| d¡}|sº|r²|  |¡}||d< n||d< || j t|ƒ|f< |S )Nrm   )r=  r–   r&   r»   rÇ   rp   rH  )	r	   rF  r  ÚgrE   Úgsr¨   rM   Ús1r
   r
   r   Úlr0_gotos  s2    




zLRGeneratedTable.lr0_gotoc           	      C   sÊ   |   | jjd jg¡g}d}|D ]}|| jt|ƒ< |d7 }q d}|t|ƒk rÆ|| }|d7 }i }|D ]}|jD ]}d ||< qnqd|D ]@}|  ||¡}|r‚t|ƒ| jkr¦q‚t|ƒ| jt|ƒ< | 	|¡ q‚q@|S r  )
rH  r;  rÙ   r»   r>  r&   r#   r¹   rL  rp   )	r	   ÚCrQ   rF  ZasymsÚiirE   r  rI  r
   r
   r   Ú	lr0_items–  s(    

zLRGeneratedTable.lr0_itemsc                 C   sx   t ƒ }d}| jjdd … D ]@}|jdkr6| |j¡ q|jD ]}||kr< qq<| |j¡ qt|ƒ|krjqtt|ƒ}q
|S r  )rà   r;  rÙ   r#   rï   r   r¡   )r	   ÚnullableZnum_nullabler¨   r§   r
   r
   r   Úcompute_nullable_nonterminalsÎ  s    


z.LRGeneratedTable.compute_nullable_nonterminalsc                 C   sj   g }t |ƒD ]X\}}|D ]J}|j|jd k r||j|jd  f}|d | jjkr||kr| |¡ qq|S r¾   )rí   rÐ   r#   r¡   r;  rÜ   rp   )r	   rM  ÚtransZstatenorx   r¨   r§   r
   r
   r   Úfind_nonterminal_transitionsë  s    z-LRGeneratedTable.find_nonterminal_transitionsc                 C   s”   i }|\}}g }|   || |¡}|D ]B}	|	j|	jd k r$|	j|	jd  }
|
| jjkr$|
|kr$| |
¡ q$|dkr|| jjd jd kr| d¡ |S )Nrs   r   rm   )rL  rÐ   r#   r¡   r;  rÛ   rp   rÙ   )r	   rM  rR  rP  Zdr_setrx   r/  ÚtermsrI  r¨   r7  r
   r
   r   Údr_relationÿ  s    
zLRGeneratedTable.dr_relationc                 C   sr   g }|\}}|   || |¡}| j t|ƒd¡}|D ]:}	|	j|	jd k r2|	j|	jd  }
|
|kr2| ||
f¡ q2|S )Nr   rs   )rL  r>  r–   r&   rÐ   r#   r¡   rp   )r	   rM  rR  Úemptyr5  rx   r/  rI  rR   r¨   r7  r
   r
   r   Úreads_relation	  s    zLRGeneratedTable.reads_relationc                 C   s²  i }i }i }|D ]}d||< q|D ]„\}}	g }
g }|| D ],}|j |	krNq<|j}|}||jd k rö|d }|j| }||f|krÒ|d }||jk rÄ|j| | jjkrªqÒ|j| |krºqÒ|d }qŒ| ||f¡ |  || |¡}| j 	t
|ƒd¡}qX|| D ]j}|j |j krqþ|j|jkr"qþd}||jk rZ|j| |j|d  krNqþ|d }q&|
 ||f¡ qþq<|D ]*}||kr†g ||< ||  ||	f¡ qp|
|||	f< q"||fS )Nrs   r   r   )r   rÐ   r#   r¡   r;  rÛ   rp   rL  r>  r–   r&   )r	   rM  rR  rP  ZlookdictZincludedictZdtransr§   rx   r/  ZlookbZincludesr¨   rÐ   rR   ZlirI  r'   rQ   r
   r
   r   Úcompute_lookback_includesC	  sX    





z*LRGeneratedTable.compute_lookback_includesc                    s0   ‡ ‡‡fdd„}‡ ‡‡fdd„}t |||ƒ}|S )Nc                    s   ˆ  ˆ | ˆ¡S r   )rU  ©r  ©rM  rP  r	   r
   r   Ú<lambda>”	  ó    z4LRGeneratedTable.compute_read_sets.<locals>.<lambda>c                    s   ˆ  ˆ | ˆ¡S r   )rW  rY  rZ  r
   r   r[  •	  r\  ©r1  )r	   rM  ÚntransrP  r.  r-  r0  r
   rZ  r   Úcompute_read_sets“	  s    z"LRGeneratedTable.compute_read_setsc                    s(   ‡fdd„}‡ fdd„}t |||ƒ}|S )Nc                    s   ˆ |  S r   r
   rY  )Úreadsetsr
   r   r[  ª	  r\  z6LRGeneratedTable.compute_follow_sets.<locals>.<lambda>c                    s   ˆ   | g ¡S r   )r–   rY  )Úinclsetsr
   r   r[  «	  r\  r]  )r	   r^  r`  ra  r.  r-  r0  r
   )ra  r`  r   Úcompute_follow_sets©	  s    z$LRGeneratedTable.compute_follow_setsc           	      C   sl   |  ¡ D ]^\}}|D ]P\}}||jkr0g |j|< | |g ¡}|D ]"}||j| kr@|j|  |¡ q@qqd S r   )ru   rÑ   r–   rp   )	r	   Z	lookbacksZ	followsetrR  Zlbrx   r¨   r   r7  r
   r
   r   Úadd_lookaheads»	  s    

zLRGeneratedTable.add_lookaheadsc                 C   sP   |   ¡ }|  |¡}|  |||¡}|  |||¡\}}|  |||¡}|  ||¡ d S r   )rQ  rS  r_  rX  rb  rc  )r	   rM  rP  rR  r`  ZlookdZincludedZ
followsetsr
   r
   r   Úadd_lalr_lookaheadsÍ	  s    
z$LRGeneratedTable.add_lalr_lookaheadsc           $   
   C   s  | j j}| j j}| j}| j}| j}i }| d| j¡ |  ¡ }| jdkrP|  	|¡ d}|D ]¦}	g }
i }i }i }| d¡ | d|¡ | d¡ |	D ]}| d|j
|¡ q’| d¡ |	D ]ì}|j|jd kr|jdkrìd|d	< ||d	< q¤| jdkr|j| }n| j j|j }|D ]ö}|
 ||d
|j
|f f¡ | |¡}|d k	rä|dkr*| |d¡\}}||j
 j\}}||k s’||kræ|dkræ|j
 ||< |||< |sÐ|sÐ| d|¡ | j ||df¡ ||j
  jd7  _nB||kr|dkrd ||< n$|sâ| d|¡ | j ||df¡ n¸|dk rÖ||  }||j
 }|j|jkrž|j
 ||< |||< || }}||j
  jd7  _||j
  jd8  _n
|| }}| j |||f¡ | d||| j
|| ¡ ntd| ƒ‚n(|j
 ||< |||< ||j
  jd7  _qq¶|j}|j|d  }|| j jkr¶|  |	|¡}| j t|ƒd¡}|dkr¶|
 ||d| f¡ | |¡}|d k	r”|dkr¢||kr’td| ƒ‚nð|dk r†| |d¡\}}||| j
 j\}}||ksî||kr<|dkr<||| j
  jd8  _|||< |||< |s„| d|¡ | j ||df¡ nH||krZ|dkrZd ||< n*|s’|s’| d|¡ | j ||df¡ ntd| ƒ‚q¶|||< |||< q¶i }|
D ]>\}}}||kr®||| kr®| d||¡ d|||f< q®| d¡ d}|
D ]P\}}}||kr ||| k	r ||f|kr | d||¡ d}d|||f< q |rb| d¡ i } |	D ]*}!|!jD ]}"|"| j jkrtd | |"< qtqj| D ]D}#|  |	|#¡}| j t|ƒd¡}|dkrš|||#< | d|#|¡ qš|||< |||< |||< |d7 }qXd S )NzParsing method: %sr   r   r‰   zstate %dz    (%d) %srs   rö   rm   zreduce 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)zUnknown conflict in state %dr   zshift 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ß   ri   rg   r<  r   r  rO  rd  r´   r#   rÐ   r   rÑ   rÞ   rp   r–   r¸   rA  rÍ   r·   rB  r9  r¡   rÛ   rL  r>  r&   r   r¹   rÜ   )$r	   rÙ   rß   rj   rh   r<  ZactionprM  ÚstrF  ZactlistZ	st_actionZ
st_actionpZst_gotor¨   Zlaheadsr7  r'   ZsprecZslevelZrprecZrlevelZoldpÚppZchosenpZrejectprQ   rI  rR   Z	_actprintrô   Znot_usedZnkeysrN  rE   rM   r
   r
   r   rC  å	  s   

















  ÿ












zLRGeneratedTable.lr_parse_tabler‰   c                 C   sš  t |tjƒrtdƒ‚| d¡d }tj ||¡d }z8t|dƒ}| 	dtj 
|¡t| j|f ¡ d}|r`i }| j ¡ D ]T\}	}
|
 ¡ D ]B\}}| |¡}|s°g g f}|||< |d  |	¡ |d  |¡ qŠqz| 	d	¡ | ¡ D ]f\}}| 	d
| ¡ |d D ]}| 	d| ¡ q | 	d¡ |d D ]}| 	d| ¡ q(| 	d¡ qâ| 	d¡ | 	d¡ nF| 	d¡ | j ¡ D ]&\}}| 	d|d |d |f ¡ qt| 	d¡ |r¨i }| j ¡ D ]Z\}	}
|
 ¡ D ]F\}}| |¡}|sòg g f}|||< |d  |	¡ |d  |¡ qÊqº| 	d¡ | ¡ D ]h\}}| 	d
| ¡ |d D ]}| 	d| ¡ qF| 	d¡ |d D ]}| 	d| ¡ qn| 	d¡ q(| 	d¡ | 	d¡ nF| 	d¡ | j ¡ D ]&\}}| 	d|d |d |f ¡ q¼| 	d¡ | 	d¡ | jD ]Z}|jr:| 	d|j|j|j|jtj 
|j¡|jf ¡ n| 	dt|ƒ|j|jf ¡ qþ| 	d¡ | ¡  W n& tk
r” } z‚ W 5 d }~X Y nX d S )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
    rs   r   z
_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]
)rK   r  r  ÚIOErrorÚsplitr!  r"  r—   r$  r   Úbasenamer  r  rg   ru   r–   rp   ri   re   rµ   r?   r   r#   r¶   r·   r&  )r	   Ú	tabmoduleÚ	outputdirr(  Zbasemodulenamer'  r   Zsmallerru   rE   Úndr   rO   rQ   r  r¨   Úer
   r
   r   Úwrite_table¦
  s’    
ø





 




	
 


  ÿ
 
zLRGeneratedTable.write_tablec                 C   sþ   zdd l }W n tk
r(   dd l}Y nX t|dƒÀ}| t|t¡ | | j|t¡ | ||t¡ | | j|t¡ | | j	|t¡ g }| j
D ]T}|jrÂ| |j|j|j|jtj |j¡|jf¡ qŒ| t|ƒ|j|jd d d f¡ qŒ| ||t¡ W 5 Q R X d S )Nr   Úwb)r  r  r   r$  Údumpr  Úpickle_protocolr  rg   ri   re   rµ   rp   r?   r   r#   r!  r"  rl  r¶   r·   )r	   r'  r(  r   ÚoutfZoutpr¨   r
   r
   r   Úpickle_table   s     
, zLRGeneratedTable.pickle_table)r   N)r‰   r‰   )r‰   )r   r   r   r   rH  rL  rO  rQ  rS  rU  rW  rX  r_  rb  rc  rd  rC  rq  rv  r
   r
   r
   r   r:  3  s"   
%#8+P B
zr:  c                 C   s0   t  | ¡}|j ¡ }|j|jkr,| |j¡ |S r   )r~   Ú	_getframeÚ	f_globalsÚcopyÚf_localsÚupdate)Zlevelsr   Zldictr
   r
   r   Úget_caller_module_dictC  s
    

r|  c              
   C   s   g }|   ¡ }d }|}|D ]â}|d7 }| ¡ }|s2qzˆ|d dkrf|sTtd||f ƒ‚|}	|dd … }
n@|d }	|	}|dd … }
|d }|dkr¦|dkr¦td||f ƒ‚| |||	|
f¡ W q tk
rÐ   ‚ Y q tk
rø   td	||| ¡ f ƒ‚Y qX q|S )
Nrs   r   ú|z%s:%d: Misplaced '|'é   ú:z::=z!%s:%d: Syntax error. Expected ':'z%s:%d: Syntax error in rule %r)Ú
splitlinesrk  rb   rp   Ú	ExceptionÚstrip)Údocr¶   r·   r;  ZpstringsZlastpZdlineZpsr¨   rð   rñ   Zassignr
   r
   r   Úparse_grammarO  s6    r„  c                   @   s†   e Zd Zd dd„Zdd„ Zdd„ Zdd	„ Zd
d„ Zdd„ Zdd„ Z	dd„ Z
dd„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ ZdS )!ÚParserReflectNc                 C   sL   || _ d | _d | _d | _tƒ | _g | _d| _|d krBtt	j
ƒ| _n|| _d S )NF)rË   r÷   Ú
error_funcÚtokensrà   r  r;  r   r   r~   r   r<  )r	   rË   r<  r
   r
   r   r   y  s    zParserReflect.__init__c                 C   s,   |   ¡  |  ¡  |  ¡  |  ¡  |  ¡  d S r   )Ú	get_startÚget_error_funcÚ
get_tokensÚget_precedenceÚget_pfunctionsr<   r
   r
   r   Úget_allˆ  s
    zParserReflect.get_allc                 C   s6   |   ¡  |  ¡  |  ¡  |  ¡  |  ¡  |  ¡  | jS r   )Úvalidate_startÚvalidate_error_funcÚvalidate_tokensÚvalidate_precedenceÚvalidate_pfunctionsÚvalidate_modulesr   r<   r
   r
   r   Úvalidate_all  s    zParserReflect.validate_allc              	   C   sš   g }zr| j r| | j ¡ | jr:| d dd„ | jD ƒ¡¡ | jrR| d | j¡¡ | jD ]}|d rX| |d ¡ qXW n ttfk
rŽ   Y nX d |¡S )Nr‰   c                 S   s   g | ]}d   |¡‘qS )r‰   )r—   )rI   r¨   r
   r
   r   rJ      s     z+ParserReflect.signature.<locals>.<listcomp>rŠ   r   )r÷   rp   r¸   r—   r‡  ÚpfuncsÚ	TypeErrorÚ
ValueError)r	   Úpartsr   r
   r
   r   r(  š  s    
zParserReflect.signaturec              	   C   s²   t  d¡}| jD ]œ}zt |¡\}}W n tk
r>   Y qY nX i }t|ƒD ]^\}}|d7 }| |¡}|rL| d¡}| 	|¡}	|	sŒ|||< qLt 
|¡}
| j d|
|||	¡ qLqd S )Nz\s*def\s+(p_[a-zA-Z_0-9]*)\(rs   z;%s:%d: Function %s redefined. Previously defined on line %d)ÚreÚcompiler  ÚinspectÚgetsourcelinesrj  rí   rì   Úgroupr–   Úgetsourcefiler<  r   )r	   Zfrer  ÚlinesZlinenZ	counthashr·   rô   r   Úprevr'  r
   r
   r   r“  µ  s,    







   ÿzParserReflect.validate_modulesc                 C   s   | j  d¡| _d S )Nr÷   )rË   r–   r÷   r<   r
   r
   r   rˆ  Î  s    zParserReflect.get_startc                 C   s&   | j d k	r"t| j tƒs"| j d¡ d S )Nz'start' must be a string)r÷   rK   Ústring_typesr<  r   r<   r
   r
   r   rŽ  Ò  s    
zParserReflect.validate_startc                 C   s   | j  d¡| _d S )NÚp_error)rË   r–   r†  r<   r
   r
   r   r‰  Ø  s    zParserReflect.get_error_funcc                 C   s    | j rœt| j tjƒrd}n*t| j tjƒr.d}n| j d¡ d| _d S | j jj}| j jj	}t
 | j ¡}| j |¡ | j jj| }|dkrœ| j d||¡ d| _d S )Nr   rs   z2'p_error' defined, but is not a function or methodTz$%s:%d: p_error() requires 1 argument)r†  rK   r  ÚFunctionTypeÚ
MethodTyper<  r   Ú__code__Úco_firstlinenoÚco_filenamer›  Ú	getmoduler  rï   Úco_argcount)r	   ÚismethodZelineZefiler  Zargcountr
   r
   r   r  Ü  s     

z!ParserReflect.validate_error_funcc                 C   sn   | j  d¡}|s&| j d¡ d| _d S t|ttfƒsJ| j d¡ d| _d S |sd| j d¡ d| _d S || _d S )Nr‡  zNo token list is definedTztokens must be a list or tupleztokens is empty)rË   r–   r<  r   rK   rv   r³   r‡  )r	   r‡  r
   r
   r   rŠ  ò  s    zParserReflect.get_tokensc                 C   sV   d| j kr | j d¡ d| _d S tƒ }| j D ]$}||krF| j d|¡ | |¡ q,d S )Nr   z.Illegal token name 'error'. Is a reserved wordTzToken %r multiply defined)r‡  r<  r   rà   r   rï   )r	   rÔ   rM   r
   r
   r   r    s    

zParserReflect.validate_tokensc                 C   s   | j  d¡| _d S )Nr¼   )rË   r–   r¸   r<   r
   r
   r   r‹    s    zParserReflect.get_precedencec                 C   s  g }| j rt| j ttfƒs2| j d¡ d| _d S t| j ƒD ]È\}}t|ttfƒsj| j d¡ d| _ d S t|ƒdk r| j d|¡ d| _ d S |d }t|tƒsº| j d¡ d| _ d S |dd … D ]<}t|tƒsî| j d	¡ d| _  d S | 	|||d f¡ qÆq<|| _
d S )
Nz"precedence must be a list or tupleTzBad precedence tabler~  z?Malformed precedence entry %s. Must be (assoc, term, ..., term)r   z)precedence associativity must be a stringrs   z precedence items must be strings)r¸   rK   rv   r³   r<  r   rí   r#   r¡  rp   Úpreclist)r	   r«  rè   r¨   rç   rã   r
   r
   r   r‘    s6    

z!ParserReflect.validate_precedencec                 C   s†   g }| j  ¡ D ]\\}}| d¡r|dkr*qt|tjtjfƒrt|d|jj	ƒ}t
 |¡}| ||||jf¡ q|jdd„ d || _d S )NÚp_r¢  r¦  c                 S   s    | d t | d ƒ| d | d fS )Nr   rs   r~  r   r>   )Z
p_functionr
   r
   r   r[  D  s
    
üz.ParserReflect.get_pfunctions.<locals>.<lambda>)Úkey)rË   ru   Ú
startswithrK   r  r£  r¤  rW   r¥  r¦  r›  r¨  rp   Ú__doc__Úsortr•  )r	   Zp_functionsr   Úitemr·   r  r
   r
   r   rŒ  7  s    
zParserReflect.get_pfunctionsc                 C   sN  g }t | jƒdkr(| j d¡ d| _d S | jD ]\}}}}t |¡}| j| }t|tj	ƒrbd}nd}|j
j|krŽ| j d|||j¡ d| _q.|j
j|k r¶| j d|||j¡ d| _q.|jsÒ| j d|||j¡ q.z(t|||ƒ}	|	D ]}
| ||
f¡ qäW n: tk
r4 } z| j t|ƒ¡ d| _W 5 d }~X Y nX | j |¡ q.| j ¡ D ]ô\}}| d	¡rzt|tjtj	fƒrzqN| d
¡rŠqN| d	¡r®|dkr®| j d|¡ t|tjƒrÊ|j
jdksèt|tj	ƒrN|jj
jdkrN|jrNz8|j d¡}|d dkr&| j d|j
j|j
j|¡ W n tk
r>   Y nX qN|| _d S )Nr   z+no rules of the form p_rulename are definedTr~  rs   z%%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¬  Zt_r¢  z%r not defined as a functionrŠ   r  z9%s:%d: Possible grammar rule %r defined without p_ prefix)r#   r•  r<  r   r›  rž  rË   rK   r  r¤  r¥  r©  r   r¯  r   r„  rp   rb   r?   r  rï   ru   r®  r£  Ú__func__rk  r§  r¦  rÅ   r;  )r	   r;  r·   r  r   rƒ  r¶   rµ   ZreqargsZparsed_grI  rp  rM   rO   r
   r
   r   r’  L  sn    

  ÿ 
ÿÿ  ÿ
z!ParserReflect.validate_pfunctions)N)r   r   r   r   r  r”  r(  r“  rˆ  rŽ  r‰  r  rŠ  r  r‹  r‘  rŒ  r’  r
   r
   r
   r   r…  x  s   

r…  c           <         s0	  |d krt }|rd}|d kr&ttjƒ}ˆ rf‡ fdd„tˆ ƒD ƒ}t|ƒ}d|krntj|d  j|d< ntdƒ}|	d krât	|t
jƒrŠ|j}nLd|krœ|d }n:| d¡}d |d d… ¡}td	| ƒ ttj| dd
ƒ}tj |¡}	| d¡}|rt	|tƒrd|kr|d | }|d k	r&||d< t||d}| ¡  |jrJtdƒ‚| ¡ }zŽtƒ }|rl| |¡}n
| |¡}|s†||krÞz&| |j¡ t||j ƒ}|j!a!|W W S  t"k
rÜ } z| #d|¡ W 5 d }~X Y nX W nF t$k
r } z| #t|ƒ¡ W 5 d }~X Y n t%k
r&   Y nX |
d krš|r”ztt&tj |	|¡dƒƒ}
W n< t'k
r } z| #d||f ¡ t(ƒ }
W 5 d }~X Y nX nt(ƒ }
|
 )dt*¡ d}| +¡ r¼tdƒ‚|j sÎ| #d¡ t,|j-ƒ}|j.D ]P\}}}z| /|||¡ W n0 t0k
r* } z| #d|¡ W 5 d }~X Y nX qÞ|j1D ]b\}}|\} }!}"}#z| 2|"|#|| |!¡ W n4 t0k
r” } z| d|¡ d}W 5 d }~X Y nX q6z&|d kr´| 3|j4¡ n
| 3|¡ W n6 t0k
rö } z| t|ƒ¡ d}W 5 d }~X Y nX |rtdƒ‚| 5¡ }$|$D ]"\}%}&| d|&j6|&j7|%¡ d}q| 8¡ }'|'r†|
 )d
¡ |
 )d¡ |
 )d
¡ |'D ]}| #d|¡ |
 )d|¡ qf|rÎ|
 )d
¡ |
 )d¡ |
 )d
¡ t9|j:ƒD ]\}(})|
 )d|(|)¡ q´| ;¡ }*|*D ]}&| #d|&j6|&j7|&j<¡ qÚt=|'ƒdkr| #d¡ t=|'ƒdkr.| #d t=|'ƒ¡ t=|*ƒdkrF| #d!¡ t=|*ƒdkrd| #d"t=|*ƒ¡ |r4|
 )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)|/¡ qF| C¡ }0|0D ]}1| d*|1¡ d}qf| D¡ }2|2D ]\}}| d+||¡ d}qŠ|r¶tdƒ‚|rÈ| Ed,| ¡ tF|| |
ƒ}|rFt=|jGƒ}3|3dkrú| #d-¡ n|3dkr| #d.|3¡ t=|jHƒ}4|4dkr0| #d/¡ n|4dkrF| #d0|4¡ |rp|jGs\|jHrp|
 #d
¡ |
 #d1¡ |
 #d
¡ |jGD ]\}5}6}7|
 #d2|6|5|7¡ q€tIƒ }8|jHD ]x\}5}9}:|5tJ|9ƒtJ|:ƒf|8krÐqª|
 #d3|5|9¡ |
 #d4|:|5¡ | #d3|5|9¡ | #d4|:|5¡ |8 K|5tJ|9ƒtJ|:ƒf¡ qªg };|jHD ]@\}5}9}:|:jLs.|:|;kr.|
 #d5|:¡ | #d5|:¡ |; M|:¡ q.|rÀz| N||	|¡ W n6 t'k
r¾ } z| #d6||f ¡ W 5 d }~X Y nX |	rz| O||¡ W n6 t'k
	r } z| #d6||f ¡ W 5 d }~X Y nX | |j¡ t||j ƒ}|j!a!|S )7Nr   c                    s   g | ]}|t ˆ |ƒf‘qS r
   )rW   )rI   r  ©r  r
   r   rJ   ¡  s     zyacc.<locals>.<listcomp>Ú__file__r   r~  rÏ   r   r  r‰   Ú__package__r÷   )r<  zUnable to build parserz.There was a problem loading the table file: %rri  zCouldn'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 rulezUnused terminals:zToken %r defined, but not usedz    %sr×   zRule %-5d %sz$%s:%d: Rule %r defined, but not usedrs   zThere is 1 unused tokenzThere are %d unused tokenszThere is 1 unused rulezThere are %d unused rulesz'Terminals, with rules where they appearz
%-20s : %srŠ   c                 S   s   g | ]}t |ƒ‘qS r
   r>   rH   r
   r
   r   rJ   G  s     z*Nonterminals, with rules where they appearc                 S   s   g | ]}t |ƒ‘qS r
   r>   rH   r
   r
   r   rJ   O  s     zSymbol %r is unreachablez)Infinite recursion detected for symbol %rz0Precedence rule %r defined for unknown symbol %rzGenerating %s tablesz1 shift/reduce conflictz%d shift/reduce conflictsz1 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)zrejected rule (%s) in state %dzRule (%s) is never reducedzCouldn't create %r. %s)PÚ
tab_moduler   r~   r   ÚdirÚdictr  r´  r|  rK   r  r  rk  r—   r  rW   r!  r"  Údirnamer–   r?   r…  r  r   r    r(  r  r)  r  r*  rË   rc   r†  r†   r  r   r  r  r$  rj  r   r   Ú__version__r”  r×   r‡  r«  ré   rÖ   r;  rõ   rø   r÷   r  r¶   r·   r  rí   rÙ   r  r   r#   rv   rÛ   r°  rÜ   rü   r   r  r   r:  rA  rB  rà   r&   rï   rÍ   rp   rq  rv  )<rD  r   r  rm  r÷   Zcheck_recursionÚoptimizeZwrite_tablesZ	debugfilern  ZdebuglogZerrorlogZ
picklefileZ_itemsrË   Úsrcfiler˜  ÚpkgnameÚpkgZpinfor(  ÚlrZread_signaturer8   rp  Úerrorsr;  rã   rç   rè   ÚfuncnameZgramr¶   r·   rð   rñ   r  rq   r¡   r  rM   r¨   r  rT  ZnontermsZnontermZunreachableÚurÿ   ÚinfZunused_precZnum_srZnum_rrrx   r­   Ú
resolutionÚalready_reportedÚruleZrejectedZwarned_neverr
   r³  r   ÚyaccŽ  s„   






"



"












(



(









$$rÇ  )<r™  r  r~   Úos.pathr!  r›  Úbase64r-   rº  r  Z	yaccdebugZ
debug_filer¶  Z
default_lrr›   r|   r$   rt  Úversion_infoÚ
basestringr¡  r?   Úmaxsizer3  Úobjectr   r   r  r    r*   r,   r0   r4   r2   r/   r1   r3   r5   r9   r:   rA   rc   rš  rë   r®   rÎ   rÂ   rÕ   rÖ   r×   r  r  r1  r+  r9  r:  r|  r„  r…  rÇ  r
   r
   r
   r   Ú<module>>   s    
4       m
H.   rT
      )  
      þ