a bǬ@sddlmZddlmZmZddlmZmZzddlmZ Wne yVddl Z Yn0ddl Z ddl Z ddl Z z(e jdkrddlZnddlZeZWne ydZYn0dd Zd Ze d e je jBZe d e je jBZe d e jZe dZe dZe dZe dZdae de j Z!e dZ"e dZ#e dZ$e dZ%e dZ&e dZ'e dZ(ddZ)ddZ*ddZ+d d!Z,d"d#Z-d$d%Z.d&d'Z/d(d)Z0d*d+Z1Gd,d-d-e2Z3dS).)model) COMMON_TYPESresolve_common_type)FFIError CDefError) _pycparserN)cCsddl}ddl}dSNr)Zpycparser.yacctabZpycparser.lextab) pycparserr 3/tmp/pip-target-98j97qn4/lib/python/cffi/cparser.py%_workaround_for_static_import_finderssrzz/\*.*?\*/|//([^\n\\]|\\.)*?$z?^\s*#\s*define\s+([A-Za-z_][A-Za-z_0-9]*)\b((?:[^\n\\]|\\.)*?)$z^[ \t]*#[ \t]*(?:line|\d+)\b.*$z=\s*\.\.\.\s*[,}]|\.\.\.\s*\}z__dotdotdot\d+__$z\[\s*\.\.\.\s*\]z\w+|\Sz-?0?x?[0-9a-f]+[lu]*$z\b(__stdcall|WINAPI)\bz[(]\s*(__stdcall|WINAPI)\bz \b__cdecl\bz9\bextern\s*"(Python|Python\s*\+\s*C|C\s*\+\s*Python)"\s*.z'[*]\s*((const|volatile|restrict)\b\s*)+z3(\b(int|long|short|signed|unsigned|char)\s*)+\.\.\.z\b(double|float)\s*\.\.\.cCstdurtatSN) _parser_cacher ZCParserr r r r _get_parser2srcCsg}t|}|sq||d||dd}|||}|d|rl|d|d7}d}|}|t|kr||}|dkr|d7}n.|dkr|dkrq|d8}n|dvr|dkrq|d7}qt||||||d}q||d|S)N()*rrz,;=) _r_star_const_spacesearchappendstartgroupend startswithlenjoin)csourcepartsmatchclosingendposlevelicr r r _workaround_for_old_pycparser8s6        r'cCs,g}t|}|sq|d}||d|d|dvrR|dn |d||dkr|d|}|dkrtd|d|d|dkrtd |||d|||dd}nB|d |}|dkrtd ||||d||dd}|d q||d |S)NrCz(void __cffi_extern_python_plus_c_start; z!void __cffi_extern_python_start; {}rz!'extern "Python" {': no '}' foundz7cannot use { } inside a block 'extern "Python" { ... }';z'extern "Python": no ';' foundz void __cffi_extern_python_stop;r) _r_extern_pythonrrrrrfindrNotImplementedErrorr)rr r!r#r" semicolonr r r _preprocess_extern_pythonbs2          r0cCsJd|vr dS|D]0}d|vr|dsddl}|dqFqdS)N"#rzString literal found in cdef() or type source. String literals are ignored here, but you should remove them anyway because some character sequences confuse pre-parsing.) splitlineslstriprwarningswarn)rliner5r r r _warn_for_string_literals  r8cCs$|js ddl}|d|jfdS)NrzrGlobal variable '%s' in cdef(): for consistency with C it should have a storage class specifier (usually 'extern'))Zstorager5r6name)declr5r r r /_warn_for_non_extern_non_static_global_variables r;cs$gfdd}t||}|fS)Ncst}|d|S)Nz#line@%d)rrr)mr%line_directivesr r replacesz(_remove_line_directives..replace_r_line_directivesub)rr?r r=r _remove_line_directivess  rCcsfdd}t||S)Ncs.|}|dstdt|ddS)Nz#line@zBunexpected #line directive (should have been processed and removed)rrAssertionErrorint)r<sr=r r r?s z*_put_back_line_directives..replacer@)rr>r?r r=r _put_back_line_directivess rHc Cst|\}}dd}t||}i}t|D](}|\}}|dd}|||<q.td|}tj dkrvt |}t d|}t d|}t d|}t|}t|td |}tt|}tt|D]\}}|} || d kr2|d | |} | | ksJd |d| ||| d df}q|| | d d ksLJd|d| ||| d df}qtd|}td|}|d d}t||}||fS)NcSsd|ddS)N  )rcount)r<r r r replace_keeping_newlinessz-_preprocess..replace_keeping_newlinesz\ rz2.14z volatile volatile const(z volatile volatile const rIz[__dotdotdotarray__]=...z%s,__dotdotdot%d__ %sr z%s __dotdotdot%d__ %sz __dotdotdotint__ z __dotdotdotfloat__ z __dotdotdot__ )rC _r_commentrB _r_definefinditergroupsr?stripr __version__r' _r_stdcall2 _r_stdcall1_r_cdeclr0r8_r_partial_arraylist_r_partial_enum enumeratereversedrr-r_r_int_dotdotdot_r_float_dotdotdotrH) rr>rLmacrosr!Z macronameZ macrovaluematchesnumberpp2r r r _preprocesssF              rdcCstt}|d|d|d|d|dt}d}d}d}t|D]}||vr|dkr|r||||d}nj|dkrd }d}nX|dkr|d 7}nF|dkr|d 8}n4|dkr|r|dkr||||n |||}qV|S) Nr+,rrtypedefFrrTr)setradd_r_wordsfindalldiscard)rZlook_for_wordsZ words_usedZ is_typedefZparenZ previous_wordwordr r r _common_type_namess>             rmc@seZdZddZddZddZddZd:d d Zd dZddZ ddZ ddZ ddZ ddZ ddZddZd;ddZd d!Zdd&d'Zd(d)Zd?d*d+Zd,d-Zd@d.d/Zd0d1Zd2d3Zd4d5Zd6d7Zd8d9Zd S)AParsercCs:i|_t|_d|_t|_i|_i|_g|_ d|_ dSr ) _declarationsrg_included_declarations_anonymous_counterweakrefWeakKeyDictionary_structnode2type_options_int_constants _recomplete_uses_new_featureselfr r r __init__)s zParser.__init__c Cs@t|\}}t|}g}t|jD].}|dr"|dd}||||q"|t|7}g}|d|D]}|d|qp|d|dtf||d|}t durt z^zt |} Wn6t jjy } z|| |WYd} ~ n d} ~ 00Wt dur6t nt dur4t 0| ||fS)Ntypedef z*# 1 ""ztypedef int %s;z@typedef int __dotdotdotint__, __dotdotdotfloat__, __dotdotdot__;z# 1 "%s"rJ)rdrmsortedrorrrkCDEF_SOURCE_STRINGrlockacquirerparser Zc_parser ParseErrorconvert_pycparser_errorrelease) rzrr_Zctn typenamesr9 csourcelinestypenameZ fullcsourceaster r r _parse3s8          $   z Parser._parsecCsfd}t|}tdtf|}|rbt|dd}|}d|krRt|krbnn ||d}|S)Nz %s:(\d+):r )strrer!rrFrr3r)rzrrr7msgr!linenumrr r r _convert_pycparser_errorYs zParser._convert_pycparser_errorcCs@|||}t|}|r*d||f}n d|f}t|dS)Nzcannot parse "%s" %szparse error %s)rrrSr)rzrrr7rr r r rgs   zParser.convert_pycparser_errorFNcCs|r&|dkrtd|r tdd}n$|rF||d@rJtd|fnd}|j}z"|||d|_||W||_n||_0dS)NTzB'packed' should be False or True; use 'pack' to give another valuez$cannot give both 'pack' and 'packed'rz%'pack' must be a power of two, not %rr)overridepacked dllexport) ValueErrorru_internal_parse)rzrrrpackrZ prev_optionsr r r rqs(  z Parser.parsec Cs*||\}}}||t|j}|D]}|jdkr(qDq(dsDJd}zFd|_|D]4}|}t|tjj rz| |qVt|tjj rj|jst d|d}t|j j tjjr|j j jddr||}nt|j tjjr0t|j j tjjr0t|j j j tjjr0|j j j jddr0||}n"|j|j |jdd|jfd \}}|jd |j||d qV|jjd krzqVt d |jj|qVWnt y} z,t| jdkr| j|f| _WYd} ~ nXd} ~ 0ty$} z6|| |} | r| jdd| f| _WYd} ~ n d} ~ 00dS)N __dotdotdot__r__cffi_extern_python_stopz!typedef does not declare any nameZ __dotdotdotTz*(%s *)0)r9partial_length_oktypedef_exampler|qualsZPragmazBunexpected <%s>: this construct is valid C but not valid in cdef()rz *** Err: %s)r_process_macrositerextr9_inside_extern_python isinstancer c_astZDecl _parse_declZTypedefrtypeIdentifierTypenamesr_get_unknown_typePtrDeclTypeDecl_get_unknown_ptr_type_get_type_and_quals_declare __class____name__rargsrr) rzrrr_iteratorr:Z current_declrZrealtyperrr r r rsn            zParser._internal_parsecCs8||jvr*|j||krdStd|f||j|<dS)Nz%multiple declarations of constant: %s)rvr)rzkeyvalr r r _add_constantss zParser._add_constantscCs|d}|d}|r(|dd}|drT|dkrT|dsTd|dd}t|d}|rh| }||||d||dS) Nul-r00xZ0ormacro )lowerrstriprrFrr)rzr9Zint_strnegZpyvaluer r r _add_integer_constants    zParser._add_integer_constantcCsd|D]V\}}|}t|r0|||q|dkrJ|d||qtd||||fqdS)NrNrzonly supports one of the following syntax: #define %s ... (literally dot-dot-dot) #define %s NUMBER (with NUMBER an integer constant, decimal/hex/octal) got: #define %s %s)itemsrS_r_int_literalr!rrr)rzr_rvaluer r r rs  zParser._process_macroscCsX|||}|jdrd}n$|jdkr.d}n|jdkr>d}nd}|||j|dS)Nrzdllexport_python Z__cffi_extern_python_startzextern_python Z!__cffi_extern_python_plus_c_startzextern_python_plus_c z function )_get_type_pointerrugetrrr9)rztprr:tagr r r _declare_functions    zParser._declare_functioncCs|j}t|tjjrJ|j||jd\}}t|tjs8J| |||nt|tjj rf| d|nHt|tjj r| d|n,t|tjj r| d|n|jstd||jr|j|dd\}}|jr| |||n0|r(t|dr(t|jd r(t|jjr(||j|jjn|rt|jtjjr|jjd krt|jjd rt|jjjr||jd |jjjn|tjur|jd r|j|_n^|jd krtd |tj@r|js|jd|j||dnt ||jd|j||ddS)N)r9structunionenumz'construct does not declare any variableTrinitrrZ__cffi_extern_python_rzsz/Parser._parse_function_type..r)rrrZ __stdcall)rYgetattrrr[rrrrrr rrrrpoprrrrrtuple) rzrfuncnamerr%argellipsisrresultrabir ryr rsH      zParser._parse_function_typecCs6t|tjrt|j|St|tjr.|S|SdSr)rrrritemrrrr r r rs   zParser._as_func_argcCs(z |j|WStyYn0|}|j}|durb|durDd|}n|jd7_d|j}d}n"|}d||f}|j|d\}} |dur|dkrt|ddd}nP|dkrt|ddd}n6|dkr|d krt d | ||j }nt d |f|dur2| ||n"|dkr2|j dur2td ||jsD|||jrjd |jvrj| d|j|||j|<|dkr|S|jdur|S|jdurt d|g} g} g} g} |jD]}t|jtjjrd|jjd kr|||q|jdur d}n ||j}d|_|j|jdd\}}|jrF|||t|tjrh|jrh|||| |jpvd| || || |qt!| |_t!| |_"t!| |_#t!| |_$| dgt%| krt|tjr|jrtd|f|j&d|_'|j(r$d|_(|j) ||S)Nz$%srz$%dz%s %s)NNrrrrz!Enums cannot be declared with ...z kind = %rz^enum %s: the '{}' declaration should appear on the first time the enum is mentioned, not laterrz anonymous %sz"duplicate declaration of struct %srrFTrz#%s: using both bitfields and '...;'rr)*rtKeyErrorr9rqrorrZ StructTypeZ UnionTyper_build_enum_typevaluesrErr.rZforce_the_namedeclsfldnamesrrr rrrr _make_partialbitsizer_partial_lengthrpartialrrfldtypes fldbitsizefldqualsrrur completedrw)rzkindrr9rZ force_name explicit_namerr_rrrrr:rZfqualr r r rs                             z"Parser._get_struct_union_enum_typecCs>t|tjstd|f|s4|s4td|fd|_dS)Nz%s cannot be partialz%s is partial but has no C nameT)rrZ StructOrUnionrZ has_c_namer.r)rzrrr r r r_s   zParser._make_partialcCst|tjjr6|j}d|dkr.dkrnn|d}z&|drTt|dWSt|dWSWnbtyt |dkr| ddd krt|d YS| ddd krt|dYSYn0t d |fn`|dd kr(|dd kr(t |dkst |dkr(|ddkr(t |dSt d |ft|tjj r^|jdkr^||jSt|tjj r|jdkr||j St|tjjr|j|jvr|j|jSt|tjjr|jdkr|rd|_dStd|jjt|tjjr||j}||j}|jdkr*||S|jdkr>||S|jdkrR||S|jdkrj|||S|jdkr|||||S|jdkr||>S|jdkr||?S|jdkr||@S|jdkr||BS|jd kr||AStd!|jjdS)"Nrr9ZuUlLr}rrrr0bzinvalid constant %r'rr \+rZ__dotdotdotarray__TrNzT:%d: unsupported '[...]' here, cannot derive the actual array length in this contextr/%z<>&|^z?:%d: unsupported expression: expected a simple numeric constant)rr rConstantrrrrFrrrrordrrrrrr9rvrrrr7ZBinaryOpleftright_c_div)rzrrrGr,r-r r r rfs                         zParser._parse_constantcCs0||}|dk|dkAr,||dkr,|d7}|S)Nrrr )rzabr r r r r.sz Parser._c_divc Cs|durd}g}g}d}|jD]X}t|jr4d}q|jdurJ||j}||j||||j||d7}qt|}t|}t |||}||_ nt |dd}|S)NFrTrr ) enumerators_r_enum_dotdotdotr!r9rrrrrrZEnumTyper) rzrrrr1Z enumvaluesZ nextenumvaluerrr r r rs*       zParser._build_enum_typecCsr|jD]B\}\}}|dr"q |ddd}|dvr |j||d|dq |jD]\}}|||qXdS)Nzanonymous $enum_$rIrr)rrrZ anonymousrfT)rr)rorrrrrvr)rzotherr9rrrkvr r r includes zParser.includecCs|jjj}|dgkr t|jS|dgkrL|jdur@d|j|_t|jS|dgkrx|jdurld|j|_t|jStd|j j dS)NrZ__dotdotdotint__z'typedef int... %s'Z__dotdotdotfloat__z'typedef float... %s'*:%d: unsupported usage of "..." in typedef) rrrZ unknown_typer9rxZUnknownIntegerTypeZUnknownFloatTyperrr7)rzr:rr r r rs           zParser._get_unknown_typecCs2|jjjjdgkrt|jStd|jjdS)Nrr7)rrrZunknown_ptr_typer9rrr7)rzr:r r r rs  zParser._get_unknown_ptr_type)FFNF)Fr)N)NFN)N)NF)F)r __module__ __qualname__r{rrrrrrrrrrrrrrrrrrrrrr.rr6rrr r r r rn's> &  7 3   i # v I rn)4rrZ commontypesrrerrorrrrr ImportErrorrrrsys version_infothread_thread allocate_lockrrrcompileDOTALL MULTILINErOrPrArZr2rXrir IGNORECASErrVrUrWr,rr]r^rr'r0r8r;rCrHrdrmobjectrnr r r r s`                   *2   B(