U
    wy]Gh                     @   s  d Z ddlZddlZddlT eehZeee	hZ
eehZeehZeeehB ZdZdd eD ZejfddZd	d
 Zdd Zd,ddZejd Zde> d ZdZeef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S ).zInternal support module for sre    N)*))i   i1  )s   i  )   i  )iE  i  i  )i  i  )i  i  )i  i  )i  i  )i  i  )i  i  )i  i  )i  i  )i  i  )i  i  )ia  i  )i  i  c                    s.   i | ]&}|D ]  t  fd d|D qqS )c                 3   s   | ]} |kr|V  qd S N ).0jir   H/home/stadmin/Documents/SimTableSoftware/Python-3.8.0/Lib/sre_compile.py	<genexpr>>   s      z<dictcomp>.<genexpr>)tuple)r   tr   r
   r   
<dictcomp>>   s
      r   c                 C   s    ||@ r| | M } | |B | @ S r   r   )flags	add_flags	del_flags
TYPE_FLAGSr   r   r   _combine_flagsA   s    
r   c                 C   s  | j }t}t}t}t}t}d }	d }
d }|t@ r\|t@ s\|t@ rPt	j
}	t	j}
t}nt	j}	t	j}
|D ]|\}}||krr|t@ s|| || n|t@ r|t|  || n|	|s|| || n|
|}|s|t|  || n||kr|t|  || nh|t || }|d |tkr2|t |f||  D ]}|t || q@|t || | | |< q`|tkrt||	|
|\}}|t@ r|t@ r|t n(|s|t n|s|t n|t || }|d t|||  || | | |< q`|tkr*|t@ r |t n|t q`||kr6|t@ rLt d|f t!|d r|t"krn|t# n|t$ || }|d ||d  ||d  t%| |d | |t& || | | |< nl|t' || }|d ||d  ||d  t%| |d | || | | |< |t"kr,|t( n|t) q`|t*kr|\}}}}|rj|t+ ||d d  t%| |t,||| |r|t+ ||d d d  q`||kr|| q`||krD|| || }|d |d dkr|d n*|d - \}}||krt d|| t%| |d | |t& || | | |< q`|t.kr|| || }|d t%| || |t& || | | |< q`|t/kr|| |t0@ rt12||}|t@ rt32||}n|t@ rt42||}|| q`|t5kr|| g }|j }|d D ]N}|| }|d t%| || |t6 |||  |d || | | |< q|t |D ]}|| | | |< qlq`|t7kr|| |t@ rt8| }n|t@ rt9| }|| q`|t:kr |t@ s|| n,|t@ r|t; n|s
|t< n|t= ||d  q`|t>kr|| ||d d  || }|d t%| |d | |d r|t6 || }|d || | d | |< t%| |d | || | | |< n|| | d | |< q`t d|f q`d S )Nr   z*internal: unsupported template operator %r      z(look-behind requires fixed-width patternz%internal: unsupported operand type %r)?appendlen_LITERAL_CODES_REPEATING_CODES_SUCCESS_CODES_ASSERT_CODESSRE_FLAG_IGNORECASESRE_FLAG_LOCALESRE_FLAG_UNICODE_sreunicode_iscasedZunicode_tolower_ignorecase_fixesascii_iscasedZascii_tolowerZOP_LOCALE_IGNOREZ	OP_IGNOREZOP_UNICODE_IGNOREIN_UNI_IGNORENOT_LITERALNEGATELITERALFAILUREIN_optimize_charsetIN_LOC_IGNORE	IN_IGNORE_compile_charsetANYSRE_FLAG_DOTALLANY_ALLSRE_FLAG_TEMPLATEerror_simple
MAX_REPEAT
REPEAT_ONEMIN_REPEAT_ONE_compileSUCCESSREPEAT	MAX_UNTIL	MIN_UNTIL
SUBPATTERNMARKr   getwidthZCALLATSRE_FLAG_MULTILINEZAT_MULTILINEgetZ	AT_LOCALEZ
AT_UNICODEBRANCHJUMPCATEGORY	CH_LOCALE
CH_UNICODEGROUPREFGROUPREF_LOC_IGNOREGROUPREF_IGNOREGROUPREF_UNI_IGNOREGROUPREF_EXISTS)codepatternr   emitZ_lenZLITERAL_CODESZREPEATING_CODESZSUCCESS_CODESZASSERT_CODESiscasedZtolowerfixesopavloskipkcharsethascasedgroupr   r   phitailZ
tailappendZskipyesZskipnor   r   r   r8   G   sV   






 




 







  






 


 





  











 
 r8   c                 C   s   |j }| D ]\}}|| |tkr$q
|tkr6|| q
|tksF|tkr`||d  ||d  q
|tkrt|| q
|tkr|| q
|tkr|t	@ r|t
|  q|t@ r|t|  q|| q
td|f q
|t d S )Nr   r   z%internal: unsupported set operator %r)r   r'   r(   RANGERANGE_UNI_IGNORECHARSETextend
BIGCHARSETrE   r   rF   r    rG   r3   r)   )rW   r   rM   rO   rR   rS   r   r   r   r.      s,    

r.   c              	   C   s  g }g }t d}d}| D ]\}}	z,|tkr|rv||	}
d||
< |rd|
|krd||
 D ]}d||< qV|s~||	r~d}nd||	< n|tkr&t|	d |	d d }|r|rt||D ]*}d||< ||kr|| D ]}d||< qqnt||D ]}d||< q|s$tt||}n|D ]}d||< qn(|tkr@|||	f n|||	f W nZ tk
r   t	|dkr|dd 7 }Y q"|rd}|tkrt
}|||	f Y nX qq"qg }d}|d|}|dk rԐq(t	|dkrd }q(|d|}|dk r||t	|f q(|||f q|d k	r|D ]>\}}|| dkr\|t|f n|t||d ff q6||7 }|st	|t	| k r||fS | |fS t	|dkrt|}|t|f ||7 }||fS t|}i }t d}d}t  }tdd	dD ]V}|||d  }||kr4|| ||d < n$| ||d < ||< |d7 }||7 }qt|}|gt| |dd< |t|f ||7 }||fS )
N   Fr   Tr       i   r   i   )	bytearrayr(   r]   rangemapanyr'   r   
IndexErrorr   r^   find
_mk_bitmapr_   bytes_bytes_to_codesra   )rW   rP   ZfixuprQ   Zoutr\   ZcharmaprX   rR   rS   rT   rV   rr   ZrunsqrZ   dataZcompsmappingZblockZchunkr   r   r   r+     s    









r+      r   s   0111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111c                    s8   |  td d d  fddttd  D S )Nc                    s"   g | ]}|  | d qS )r   r   )r   r   	_CODEBITS_intsr   r   
<listcomp>  s   z_mk_bitmap.<locals>.<listcomp>r   )	translate_BITS_TRANSre   r   )bitsrt   ru   r   rs   r   rj     s    rj   c                 C   s   t | d}| S )NI)
memoryviewcasttolist)bar   r   r   rl     s    rl   c                 C   sD   t | dkrdS | d \}}|tkr<|d d ko:t|d S |tkS )Nr   Fr   rr   )r   r=   r4   _UNIT_CODES)rZ   rR   rS   r   r   r   r4     s    r4   c                 C   sn   dgt |  }tdt | D ]L}||d  }| | | | kr\|dkrNd||< q||d  }q,|d ||< q|S )aj  
    Generate an overlap table for the following prefix.
    An overlap table is a table of the same size as the prefix which
    informs about the potential self-overlap for each index in the prefix:
    - if overlap[i] == 0, prefix[i:] can't overlap prefix[0:...]
    - if overlap[i] == k with 0 < k <= i, prefix[i-k+1:i+1] overlaps with
      prefix[0:k]
    r   r   )r   re   )prefixZtabler   Zidxr   r   r   _generate_overlap_table  s    	r   c                 C   s$   | t @ sd S | t@ rtjS tjS d S r   )r   r    r!   r"   r$   )r   r   r   r   _get_iscased  s
    r   c                 C   s   g }|j }d }t|}| jD ]\}}|tkrF|r<||r< q|| q|tkr|\}}	}
}t||	|
}|t@ rz|t@ rz qt||\}}}|d kr|d k	rt	|}n|d k	rt	|| }|
| |s qq qq||dfS ||dfS )NTF)r   r   ro   r(   r=   r   r   r   _get_literal_prefixr   r`   )rN   r   r   Zprefixappendprefix_skiprP   rR   rS   rY   r   r   rZ   Zflags1Zprefix1Zprefix_skip1got_allr   r   r   r     s4    



r   c                 C   sd  | j s
d S | j d \}}|tk	r"qP|\}}}} t|||}|t@ r |t@ r d S q t|}|tkrz|rp||rpd S ||fgS |tkrg }|j}	|d D ]B}
|
s d S |
d \}}|tkr|r||s|	||f q d S q|S |t	kr`|}|r\|D ]f\}}|tkr||rZ d S q|t
kr|d dkr4 d S tt|t|d |d d r d S q|S d S )Nr   r   i  )ro   r=   r   r   r   r   r(   rC   r   r*   r]   rg   rf   re   )rN   r   rR   rS   rY   r   r   rP   rW   ZcharsetappendrZ   r   r   r   _get_charset_prefix  sN    



 r   c                 C   sr  |  \}}|tkrt}|dkr8| tdd||g d S g }d}g }|t@ rT|t@ srt||\}}}|srt||}| j}	|	t t	| }
|	d d}|rt
}|d kr|r|tB }n|r|tB }|	| |tk r|	| n|	t |d t }|	t|t |r@|	t	| |d krt	|}|	| | | | t| n|r^t|\}}t|||  t	| |
 | |
< d S )Nr      )r?   MAXCODEr`   INFOr   r   r   r   r   r   SRE_INFO_PREFIXZSRE_INFO_LITERALSRE_INFO_CHARSETminr   r+   r.   )rM   rN   r   rT   r[   r   r   rW   r   rO   rU   ZmaskrX   r   r   r   _compile_info  sR    
 



r   c                 C   s   t | ttfS r   )
isinstancestrrk   )objr   r   r   isstringS  s    r   c                 C   s8   | j j|B }g }t|| | t|| j| |t |S r   )stater   r   r8   ro   r   r9   )rZ   r   rM   r   r   r   _codeV  s    
r   c                 C   s   dd dd | D  S )N[%s], c                 s   s$   | ]}d t jd d |f V  qdS )z%#0*xr   N)r!   CODESIZEr   xr   r   r   r   f  s     z_hex_code.<locals>.<genexpr>)joinrM   r   r   r   	_hex_codee  s    r   c                    sN   dd l t dttt d  fdddt  d S )Nr   r   c              	      s  d d fdd
}fdd}d7  }||k r| | }|d7 }t | }|tttttttfkrx|| q2|tt	t
tttttfkr| }|d7 }||d|t|f  q2|tkr| }|d7 }tt| }|||dd   q2|tkr*| }|d7 }tt| }|||d	d   q2|ttttfkrr| }||||| d |d ||  ||7 }q2|ttfkr||d
  \}}	|d
7 }||d||	t|t|	f  q2|tkr||t||dt    |dt 7 }q2|tkr| }|d7 }t d!fdd||dt"j#   D }
||||
 |dt"j# 7 }d7 t$|D ].}|t||dt    |dt 7 }qdd8 q2|t%t&t't(t)fkrΈ| }|d7 }||| q2|t*kr| }||||| d |d7 }q2|t+kr|| }||||| d |rr|d ||  ||7 }| | }|rf|d||| d n|t q |d7 }q2|t,t-t.fkr||d  \}}}|t/krd}||||||| d |d ||  ||7 }q2|t0kr||d
  \}}|||||| d |d
7 }q2|t1t2fkrp||d
  \}}|||||| d |d
 ||  ||7 }q2|t3kr||d  \}}}}|t/krd}|||t4||||| d |d  |t5@ r^|d |d  \}}|d| |d    |  }|ddd!dd |D  dd!t6t|   |7  |d  |    |7  |t7@ rd7 |d  ||  d8 ||7 }q2t8|q2d8 d S )N)toc                    sX   | d k	r"  |  |d| f f7 }td kr6dndf dd  d t|  d S )Nz(to %d)z%*d%s :.z  r   end)addprint)r   args)labelsleveloffset_widthstartr   r   print_p  s    

z!dis.<locals>.dis_.<locals>.print_c                     s"   t dd    d t |   d S )N r   r   )r   )r   )r   r   r   r   print_2x  s    z"dis.<locals>.dis_.<locals>.print_2r   z
%#02x (%r)   	   r   z%#02x %#02x (%r-%r)rb       c                 3   s   | ]}| tj jV  qd S r   )to_bytesr!   r   	byteorderr   )sysr   r   r     s   z$dis.<locals>.dis_.<locals>.<genexpr>Zbranch	MAXREPEATr      z  prefix_skipz  prefixr   r   c                 s   s   | ]}d | V  qdS )z%#02xNr   r   r   r   r   r     s     z(%r) z	  overlapZin)9ZOPCODESr9   r)   r/   r1   r;   r<   r'   r(   r&   ZLITERAL_IGNOREZNOT_LITERAL_IGNOREZLITERAL_UNI_IGNOREZNOT_LITERAL_UNI_IGNOREZLITERAL_LOC_IGNOREZNOT_LITERAL_LOC_IGNOREchrr@   r   ZATCODESrE   ZCHCODESr*   r-   r%   r,   r]   r^   r_   r   rt   ra   listr   r!   r   re   r>   rH   rJ   rK   rI   rD   rC   r:   r6   r7   r   rL   ASSERT
ASSERT_NOTr   binr   rf   r   
ValueError)r   r   r   r   r   rR   argrU   rT   r[   rp   r	   r   maxr   Z
prefix_lenr   r   rM   dis_r   r   r   r   )r   r   r   o  s    

  
   

 




















zdis.<locals>.dis_)r   setr   r   r   r   r   r   dish  s     r   c              	   C   s   t | r| }t| |} nd }t| |}|t@ r>t  t| | jj}d g| jj	 }|
 D ]\}}|||< q\t||| jjB || jj	d |t|S )Nr   )r   	sre_parseparser   SRE_FLAG_DEBUGr   r   r   Z	groupdictZgroupsitemsr!   compiler   r   )rZ   r   rN   rM   Z
groupindexZ
indexgrouprV   r   r   r   r   r     s(    

 
 
 r   )NNN)r   )-__doc__r!   r   sre_constantsr(   r&   r   r:   Z
MIN_REPEATr5   r   r9   r)   r   r   r   r   r/   r*   r   Z_equivalencesr#   r   r   r8   r.   r+   r   rt   r   ry   intrj   rl   r4   r   r   r   r   r   r   r   r   r   r   r   r   r   r   <module>   sH   
$
 3
 
	,; 