????

Your IP : 3.149.255.21


Current Path : /lib/python3.9/site-packages/pycparser/__pycache__/
Upload File :
Current File : //lib/python3.9/site-packages/pycparser/__pycache__/c_lexer.cpython-39.pyc

a

�,NbN?�@s<ddlZddlZddlmZddlmZGdd�de�ZdS)�N)�lex)�TOKENc@sReZdZdZdd�Zdd�Zdd�Zdd	�Zd
d�Zdd
�Z	dd�Z
dd�ZdZiZ
eD]4Zedkrnee
d<qXedkr�ee
d<qXee
e��<qXedZdZdZdZdZdZdZdeded Zd!eZeeeZeeeZd"Zd#Zd$Zd%Zd&Zd'ed(ed(ed)Z d*Z!d+e d Z"d,e"d,Z#d-e#Z$d,e"d.Z%d/e"d0e"d1Z&d/e"d2ed3Z'd4e!d Z(d5e(d6Z)d-e)Z*d5e(d7ee(d6Z+d8Z,d9Z-d:e-d e,d;e,d<Z.d=Z/d>ed?ed@edAZ0dBedBed(e0d e/dCZ1dDZ2dEdF�Z3e4e)�dGdH��Z5e4e�dIdJ��Z6dKdL�Z7dMdN�Z8dOZ9dPdQ�Z:dRdS�Z;dTdU�Z<dOZ=dVdW�Z>dXdY�Z?dOZ@dZd[�ZAd\ZBd]ZCd^ZDd_ZEd`ZFdaZGdbZHdcZIddZJdeZKdfZLdgZMdhZNdiZOdjZPdkZQdlZRdmZSdnZTdoZUdpZVdqZWdrZXdsZYdtZZduZ[dvZ\dwZ]dxZ^dyZ_dzZ`d{Zad|Zbd}Zcd~ZddZed�Zfd�Zgd�Zhd�Zid�Zjd�Zkd�Zld�Zme4d��d�d���Zne4d��d�d���Zoe)Zpe4e.�d�d���Zqe4e1�d�d���Zre4e�d�d���Zse4e�d�d���Zte4e�d�d���Zue4e�d�d���Zve4e�d�d���Zwe4e%�d�d���Zxe4e#�d�d���Zye4e$�d�d���Zze4e&�d�d���Z{e4e'�d�d���Z|e4e*�d�d���Z}e4e+�d�d���Z~e4e�d�d���Zd�d��Z�d�S)��CLexera A lexer for the C language. After building it, set the
        input text with input(), and call token() to get new
        tokens.

        The public attribute filename can be set to an initial
        filename, but the lexer will update it upon #line
        directives.
    cCs@||_||_||_||_d|_d|_t�d�|_t�d�|_	dS)ab Create a new Lexer.

            error_func:
                An error function. Will be called with an error
                message, line and column as arguments, in case of
                an error during lexing.

            on_lbrace_func, on_rbrace_func:
                Called when an LBRACE or RBRACE is encountered
                (likely to push/pop type_lookup_func's scope)

            type_lookup_func:
                A type lookup function. Given a string, it must
                return True IFF this string is a name of a type
                that was defined with a typedef earlier.
        �Nz([ \t]*line\W)|([ \t]*\d+)z[ \t]*pragma\W)
�
error_func�on_lbrace_func�on_rbrace_func�type_lookup_func�filename�
last_token�re�compile�line_pattern�pragma_pattern)�selfrrrr	�r�5/usr/lib/python3.9/site-packages/pycparser/c_lexer.py�__init__szCLexer.__init__cKstjfd|i|��|_dS)z� Builds the lexer from the specification. Must be
            called after the lexer object is created.

            This method exists separately, because the PLY
            manual warns against calling lex.lex inside
            __init__
        �objectN)r�lexer)r�kwargsrrr�build:szCLexer.buildcCsd|j_dS)z? Resets the internal line number counter of the lexer.
        �N)r�lineno�rrrr�reset_linenoDszCLexer.reset_linenocCs|j�|�dS�N)r�input)r�textrrrrIszCLexer.inputcCs|j��|_|jSr)r�tokenrrrrrrLszCLexer.tokencCs|jj�dd|j�}|j|S)z3 Find the column of the token in its line.
        �
r)r�lexdata�rfind�lexpos)rrZlast_crrrr�find_tok_columnPszCLexer.find_tok_columncCs0|�|�}|�||d|d�|j�d�dS)Nrr)�_make_tok_locationrr�skip)r�msgr�locationrrr�_error[s
z
CLexer._errorcCs|j|�|�fSr)rr$)rrrrrr%`szCLexer._make_tok_location)&�_BOOL�_COMPLEXZAUTOZBREAKZCASEZCHARZCONSTZCONTINUEZDEFAULTZDOZDOUBLE�ELSEZENUMZEXTERNZFLOATZFORZGOTOZIFZINLINEZINTZLONGZREGISTERZOFFSETOFZRESTRICTZRETURNZSHORTZSIGNEDZSIZEOFZSTATICZSTRUCTZSWITCHZTYPEDEFZUNIONZUNSIGNEDZVOIDZVOLATILEZWHILEZ__INT128r*Z_Boolr+Z_Complex)>�ID�TYPEIDZ
INT_CONST_DECZ
INT_CONST_OCTZ
INT_CONST_HEXZ
INT_CONST_BINZINT_CONST_CHARZFLOAT_CONSTZHEX_FLOAT_CONSTZ
CHAR_CONSTZWCHAR_CONSTZSTRING_LITERALZWSTRING_LITERAL�PLUS�MINUSZTIMESZDIVIDEZMOD�ORZANDZNOTZXORZLSHIFTZRSHIFTZLORZLANDZLNOTZLTZLEZGTZGEZEQZNEZEQUALSZ
TIMESEQUALZDIVEQUALZMODEQUAL�	PLUSEQUALZ
MINUSEQUALZLSHIFTEQUALZRSHIFTEQUALZANDEQUALZXOREQUALZOREQUALZPLUSPLUSZ
MINUSMINUSZARROWZCONDOPZLPARENZRPARENZLBRACKETZRBRACKET�LBRACE�RBRACE�COMMAZPERIOD�SEMI�COLON�ELLIPSIS�PPHASHZPPPRAGMA�PPPRAGMASTRz[a-zA-Z_$][0-9a-zA-Z_$]*z0[xX]z[0-9a-fA-F]+z0[bB]z[01]+zD(([uU]ll)|([uU]LL)|(ll[uU]?)|(LL[uU]?)|([uU][lL])|([lL][uU]?)|[uU])?z(0z)|([1-9][0-9]*�)z0[0-7]*z0[0-7]*[89]z,([a-wyzA-Z._~!=&\^\-\\?'"]|x(?![0-9a-fA-F]))z(\d+)(?!\d)z(x[0-9a-fA-F]+)(?![0-9a-fA-F])z#([\\][^a-zA-Z._~^!=&\^\-\\?'"x0-9])z(\\(�|z))z(\\[0-9a-zA-Z._~!=&\^\-\\?'"])z
([^'\\\n]|�'�Lz{2,4}'z('z*\n)|('z*$)z[^'
]+')|('')|('z	[^'\n]*')z
([^"\\\n]|�"z*"�*z([eE][-+]?[0-9]+)z([0-9]*\.[0-9]+)|([0-9]+\.)z((((z
?)|([0-9]+z
))[FfLl]?)z([pP][+-]?[0-9]+)z(((z)?\.z)|(z\.))�(z[FfLl]?)))�ppline�	exclusive)�pppragmarCcCsf|jj|jj|jjd�r2|j�d�d|_|_n0|jj|jj|jjd�rX|j�d�n
d|_	|SdS)z[ \t]*\#)�posrBNrDr9)
r�matchrr!r#�begin�pp_line�pp_filenamer�type�r�trrr�t_PPHASHszCLexer.t_PPHASHcCs0|jdur|�d|�n|j�d��d�|_dS)Nz$filename before line number in #liner?)rHr)�value�lstrip�rstriprIrKrrr�t_ppline_FILENAMEs
zCLexer.t_ppline_FILENAMEcCs|jdur|j|_ndSr)rHrNrKrrr�t_ppline_LINE_NUMBER&s

zCLexer.t_ppline_LINE_NUMBERcCsH|jdur|�d|�n t|j�|j_|jdur8|j|_|j�d�dS)�\nNzline number missing in #line�INITIAL)rHr)�intrrrIr
rGrKrrr�t_ppline_NEWLINE/s

zCLexer.t_ppline_NEWLINEcCsdS)�lineNrrKrrr�t_ppline_PPLINE;szCLexer.t_ppline_PPLINEz 	cCs|�d|�dS)Nzinvalid #line directive�r)rKrrr�t_ppline_errorAszCLexer.t_ppline_errorcCs |jjd7_|j�d�dS)rSrrTN)rrrGrKrrr�t_pppragma_NEWLINEGszCLexer.t_pppragma_NEWLINEcCs|S)ZpragmarrKrrr�t_pppragma_PPPRAGMALszCLexer.t_pppragma_PPPRAGMAcCs
d|_|S)z.+r:)rJrKrrr�t_pppragma_STRRszCLexer.t_pppragma_STRcCs|�d|�dS)Nzinvalid #pragma directiverYrKrrr�t_pppragma_errorWszCLexer.t_pppragma_errorcCs|jj|j�d�7_dS)z\n+r N)rrrN�countrKrrr�	t_NEWLINE`szCLexer.t_NEWLINEz\+�-z\*�/�%z\|�&�~z\^z<<z>>z\|\|z&&�!�<�>z<=z>=z==z!=�=z\*=z/=z%=z\+=z-=z<<=z>>=z&=z\|=z\^=z\+\+z--z->z\?z\(z\)z\[z\]�,z\.�;�:z\.\.\.z\{cCs|��|Sr)rrKrrr�t_LBRACE�szCLexer.t_LBRACEz\}cCs|��|Sr)rrKrrr�t_RBRACE�szCLexer.t_RBRACEcCs|SrrrKrrr�
t_FLOAT_CONST�szCLexer.t_FLOAT_CONSTcCs|SrrrKrrr�t_HEX_FLOAT_CONST�szCLexer.t_HEX_FLOAT_CONSTcCs|SrrrKrrr�t_INT_CONST_HEX�szCLexer.t_INT_CONST_HEXcCs|SrrrKrrr�t_INT_CONST_BIN�szCLexer.t_INT_CONST_BINcCsd}|�||�dS)NzInvalid octal constantrY�rrLr'rrr�t_BAD_CONST_OCT�szCLexer.t_BAD_CONST_OCTcCs|SrrrKrrr�t_INT_CONST_OCT�szCLexer.t_INT_CONST_OCTcCs|SrrrKrrr�t_INT_CONST_DEC�szCLexer.t_INT_CONST_DECcCs|SrrrKrrr�t_INT_CONST_CHAR�szCLexer.t_INT_CONST_CHARcCs|SrrrKrrr�t_CHAR_CONST�szCLexer.t_CHAR_CONSTcCs|SrrrKrrr�
t_WCHAR_CONST�szCLexer.t_WCHAR_CONSTcCsd}|�||�dS)NzUnmatched 'rYrsrrr�t_UNMATCHED_QUOTE�szCLexer.t_UNMATCHED_QUOTEcCsd|j}|�||�dS)NzInvalid char constant %s)rNr)rsrrr�t_BAD_CHAR_CONST�s
zCLexer.t_BAD_CHAR_CONSTcCs|SrrrKrrr�t_WSTRING_LITERAL�szCLexer.t_WSTRING_LITERALcCsd}|�||�dS)Nz#String contains invalid escape coderYrsrrr�t_BAD_STRING_LITERAL�szCLexer.t_BAD_STRING_LITERALcCs2|j�|jd�|_|jdkr.|�|j�r.d|_|S)Nr-r.)�keyword_map�getrNrJr	rKrrr�t_ID�szCLexer.t_IDcCs"dt|jd�}|�||�dS)NzIllegal character %sr)�reprrNr)rsrrr�t_errorszCLexer.t_errorN)��__name__�
__module__�__qualname__�__doc__rrrrrr$r)r%�keywordsr~�keyword�lower�tokensZ
identifierZ
hex_prefixZ
hex_digitsZ
bin_prefixZ
bin_digitsZinteger_suffix_optZdecimal_constantZoctal_constantZhex_constantZbin_constantZbad_octal_constantZ
simple_escapeZdecimal_escapeZ
hex_escapeZ
bad_escapeZescape_sequenceZescape_sequence_start_in_stringZcconst_charZ
char_constZwchar_constZmulticharacter_constantZunmatched_quoteZbad_char_constZstring_charZstring_literalZwstring_literalZbad_string_literalZ
exponent_partZfractional_constantZfloating_constantZbinary_exponent_partZhex_fractional_constantZhex_floating_constantZstatesrMrrQrRrVrXZt_ppline_ignorerZr[r\Zt_pppragma_ignorer]r^Zt_ignorer`Zt_PLUSZt_MINUSZt_TIMESZt_DIVIDEZt_MODZt_ORZt_ANDZt_NOTZt_XORZt_LSHIFTZt_RSHIFTZt_LORZt_LANDZt_LNOTZt_LTZt_GTZt_LEZt_GEZt_EQZt_NEZt_EQUALSZt_TIMESEQUALZ
t_DIVEQUALZ
t_MODEQUALZt_PLUSEQUALZt_MINUSEQUALZ
t_LSHIFTEQUALZ
t_RSHIFTEQUALZ
t_ANDEQUALZ	t_OREQUALZ
t_XOREQUALZ
t_PLUSPLUSZt_MINUSMINUSZt_ARROWZt_CONDOPZt_LPARENZt_RPARENZ
t_LBRACKETZ
t_RBRACKETZt_COMMAZt_PERIODZt_SEMIZt_COLONZ
t_ELLIPSISrmrnZt_STRING_LITERALrorprqrrrtrurvrwrxryrzr{r|r}r�r�rrrrrs(!



=$



















r)r�sysZplyrZply.lexrrrrrrr�<module>	s