U ËAš`d{ã@s¶dZddlZddlZddlZddlZddlmZddlTddlm Z m Z ddlm Z ddl m Z ddlmZdd lmZdd lmZdd lmZe d ¡Zd d„ZGdd„deƒZdS)z¶distutils.command.build_ext Implements the Distutils 'build_ext' command, for building extension modules (currently limited to C extensions, should accommodate C++ extensions ASAP).éN)ÚCommand)Ú*)Úcustomize_compilerÚget_python_version)Úget_config_h_filename)Ú newer_group)Ú Extension)Ú get_platform)Úlog)Ú USER_BASEz3^[a-zA-Z_][a-zA-Z_0-9]*(\.[a-zA-Z_][a-zA-Z_0-9]*)*$cCsddlm}|ƒdS)Nr©Úshow_compilers)Údistutils.ccompilerr r ©rú1/usr/lib/python3.8/distutils/command/build_ext.pyr s r c@seZdZdZdejZdddddeƒfdd d d efd d ddddefddddddddddgZddddd gZ d!d"d#e fgZ d$d%„Z d&d'„Z d(d)„Zd*d+„Zd,d-„Zd.d/„Zd0d1„Zd2d3„Zd4d5„Zejd6d7„ƒZd8d9„Zd:d;„Zdd?„Zd@dA„ZdBdC„ZdDdE„ZdFdG„Zd"S)HÚ build_extz8build C/C++ extensions (compile/link to build directory)z (separated by '%s'))z build-lib=Úbz(directory for compiled extension modules)z build-temp=Útz1directory for temporary files (build by-products)z plat-name=Úpz>platform name to cross-compile for, if supported (default: %s))ÚinplaceÚiziignore build-lib and put compiled extensions into the source directory alongside your pure Python modulesz include-dirs=ÚIz.list of directories to search for header files)zdefine=ÚDzC preprocessor macros to define)zundef=ÚUz!C preprocessor macros to undefine)z libraries=Úlz!external C libraries to link withz library-dirs=ÚLz.directories to search for external C libraries)zrpath=ÚRz7directories to search for shared C libraries at runtime)z link-objects=ÚOz2extra explicit link objects to include in the link)ÚdebugÚgz'compile/link with debugging information)ÚforceÚfz2forcibly build everything (ignore file timestamps))z compiler=Úczspecify the compiler type)z parallel=Újznumber of parallel build jobs)úswig-cppNz)make SWIG create C++ files (default is C))z swig-opts=Nz!list of SWIG command line options)zswig=Nzpath to the SWIG executable)ÚuserNz#add user include, library and rpathrrr r$r%z help-compilerNzlist available compilerscCs‚d|_d|_d|_d|_d|_d|_d|_d|_d|_d|_ d|_ d|_ d|_ d|_ d|_d|_d|_d|_d|_d|_d|_dS)Nr)Ú extensionsÚ build_libÚ plat_nameÚ build_temprÚpackageÚ include_dirsÚdefineÚundefÚ librariesÚ library_dirsÚrpathÚ link_objectsrr ÚcompilerÚswigÚswig_cppÚ swig_optsr%Úparallel©ÚselfrrrÚinitialize_optionsjs*zbuild_ext.initialize_optionsc Csddlm}| ddddddd d ¡|jdkr8|jj|_|jj|_| ¡}|jd d }|j dkrn|jj pjg|_ t |j t ƒrŠ|j   t j¡|_ tjtjkr®|j  t j tjd ¡¡|j  |  t jj¡¡||krâ|j  |  t jj¡¡| d¡| d¡|jdkrg|_|jdkrg|_nt |jt ƒr:|j  t j¡|_|jdkrNg|_nt |jt ƒrl|j  t j¡|_t jdkrh|j t j tjd¡¡tjtjkr¶|j t j tjd¡¡|jrÒt j |jd¡|_nt j |jd¡|_|j  t j tƒ¡¡t tddƒ}|r|j |¡|j!dkr*d}n|j!dd…}t j tjd¡}|r\t j ||¡}|j |¡tj"dd…dkrÆtj# $t j tjd¡¡rº|j t j tjddt%ƒd¡¡n |j d¡dr| &d ¡r|j'sô|j | &d!¡¡n |j d¡|j(r$|j(  d"¡}d#d$„|Dƒ|_(|j)r:|j)  d"¡|_)|j*dkrNg|_*n|j*  d%¡|_*|j+rÀt j t,d ¡}t j t,d¡} t j -|¡rš|j  |¡t j -| ¡rÀ|j | ¡|j | ¡t |j.t ƒrþzt/|j.ƒ|_.Wnt0k rüt1d&ƒ‚YnXdS)'Nr)Ú sysconfigZbuild)r'r')r)r))r2r2)rr)r r )r6r6)r(r(é)Z plat_specificZincluder.r1ÚntZlibsZDebugZReleaseZ_homeÚwin32éZPCbuildéÚcygwinÚbinZlibÚpythonZconfigÚ.FÚPy_ENABLE_SHAREDZLIBDIRú,cSsg|] }|df‘qS)Ú1r)Ú.0ZsymbolrrrÚ ùsz.build_ext.finalize_options..ú zparallel should be an integer)2Ú distutilsr:Zset_undefined_optionsr*Ú distributionZ ext_packageZ ext_modulesr&Zget_python_incr+Ú isinstanceÚstrÚsplitÚosÚpathsepÚsysÚ exec_prefixÚbase_exec_prefixÚappendÚpathÚjoinÚextendZensure_string_listr.r/r0ÚnameÚprefixrr)ÚdirnamerÚgetattrr(ÚplatformÚ executableÚ startswithrÚget_config_varZ python_buildr,r-r5r%r Úisdirr6ÚintÚ ValueErrorZDistutilsOptionError) r8r:Z py_includeZplat_py_includeZ _sys_homeÚsuffixZnew_libZdefinesZ user_includeZuser_librrrÚfinalize_options‚s° ù        ÿ          þ       zbuild_ext.finalize_optionscCsjddlm}|jsdS|j ¡rL| d¡}|j | ¡p:g¡|j   |j ¡||j |j |j|jd|_ t|j ƒtjdkr”|jtƒkr”|j  |j¡|jdk r¬|j  |j¡|jdk rÔ|jD]\}}|j  ||¡q¼|jdk rö|jD]}|j  |¡qä|jdk r|j  |j¡|j dk r*|j  |j ¡|jdk rD|j  |j¡|j dk r^|j  !|j ¡| "¡dS)Nr)Ú new_compilerÚ build_clib)r2ÚverboseÚdry_runr r<)#rrer&rKZhas_c_librariesÚget_finalized_commandr.rWZget_library_namesr/rTrfr2rgrhr rrOrXr(r Z initializer+Zset_include_dirsr,Z define_macror-Zundefine_macroZ set_librariesZset_library_dirsr0Zset_runtime_library_dirsr1Zset_link_objectsÚbuild_extensions)r8rerfrXÚvalueÚmacrorrrÚruns@   ý         z build_ext.runc Csvt|tƒstdƒ‚t|ƒD]T\}}t|tƒr0qt|tƒrFt|ƒdkrNtdƒ‚|\}}t d|¡t|t ƒrvt   |¡s~tdƒ‚t|t ƒstdƒ‚t||dƒ}dD]"}|  |¡}|d k r¢t|||ƒq¢|  d ¡|_d |krät d ¡|  d ¡}|rhg|_g|_|D]b} t| tƒr"t| ƒdks*tdƒ‚t| ƒdkrJ|j | d¡nt| ƒdkr|j | ¡q|||<qd S)a¬Ensure that the list of extensions (presumably provided as a command option 'extensions') is valid, i.e. it is a list of Extension objects. We also support the old-style list of 2-tuples, where the tuples are (ext_name, build_info), which are converted to Extension instances here. Raise DistutilsSetupError if the structure is invalid anywhere; just returns otherwise. z:'ext_modules' option must be a list of Extension instancesézMeach element of 'ext_modules' option must be an Extension instance or 2-tuplezvold-style (ext_name, build_info) tuple found in ext_modules for extension '%s' -- please convert to Extension instancezRfirst element of each tuple in 'ext_modules' must be the extension name (a string)zOsecond element of each tuple in 'ext_modules' must be a dictionary (build info)Úsources)r+r/r.Ú extra_objectsÚextra_compile_argsÚextra_link_argsNr0Zdef_filez9'def_file' element of build info dict no longer supportedÚmacros)r;rnz9'macros' element of build info dict must be 1- or 2-tupler;r)rLÚlistÚDistutilsSetupErrorÚ enumeraterÚtupleÚlenr ÚwarnrMÚextension_name_reÚmatchÚdictÚgetÚsetattrÚruntime_library_dirsÚ define_macrosÚ undef_macrosrT) r8r&rÚextÚext_nameZ build_infoÚkeyÚvalrsrlrrrÚcheck_extensions_listVs^ ÿ ÿþ ÿÿ ÿ    ÿzbuild_ext.check_extensions_listcCs,| |j¡g}|jD]}| |j¡q|S©N)r†r&rWro)r8Ú filenamesr‚rrrÚget_source_files¤s   zbuild_ext.get_source_filescCs2| |j¡g}|jD]}| | |j¡¡q|Sr‡)r†r&rTÚget_ext_fullpathrX)r8Zoutputsr‚rrrÚ get_outputs­s   zbuild_ext.get_outputscCs(| |j¡|jr| ¡n| ¡dSr‡)r†r&r6Ú_build_extensions_parallelÚ_build_extensions_serialr7rrrrj»s  zbuild_ext.build_extensionsc sºˆj}ˆjdkrt ¡}zddlm}Wntk r@d}YnX|dkrVˆ ¡dS||dP‰‡‡fdd„ˆjDƒ}tˆj|ƒD]&\}}ˆ  |¡|  ¡W5QRXq„W5QRXdS)NTr)ÚThreadPoolExecutor)Z max_workerscsg|]}ˆ ˆj|¡‘qSr)ZsubmitÚbuild_extension)rGr‚©Zexecutorr8rrrHÑsÿz8build_ext._build_extensions_parallel..) r6rOÚ cpu_countZconcurrent.futuresrŽÚ ImportErrorrr&ÚzipÚ_filter_build_errorsÚresult)r8ZworkersrŽZfuturesr‚ZfutrrrrŒÃs"    ÿ z$build_ext._build_extensions_parallelc Cs0|jD]$}| |¡| |¡W5QRXqdSr‡)r&r”r)r8r‚rrrr×s  z"build_ext._build_extensions_serialc csTz dVWnDtttfk rN}z |js*‚| d|j|f¡W5d}~XYnXdS)Nz"building extension "%s" failed: %s)ZCCompilerErrorZDistutilsErrorZ CompileErrorZoptionalryrX)r8r‚Úerrrr”Üs ÿzbuild_ext._filter_build_errorsc CsP|j}|dkst|ttfƒs*td|jƒ‚t|ƒ}| |j¡}||j}|jslt ||dƒslt   d|j¡dSt   d|j¡|  ||¡}|jpŽg}|jdd…}|jD]}| |f¡q¤|jj||j||j|j ||jd}|dd…|_|jrø| |j¡|jpg}|jp|j |¡} |jj||| |¡|j|j||  |¡|j |j| d dS)Nzjin 'ext_modules' option (extension '%s'), 'sources' must be present and must be a list of source filenamesZnewerz$skipping '%s' extension (up-to-date)zbuilding '%s' extension)Z output_dirrsr+rÚextra_postargsÚdepends)r.r/rr—Úexport_symbolsrr)Z target_lang)!rorLrtrwrurXrŠr˜r rr rÚinfoÚ swig_sourcesrqr€rrTr2Úcompiler)r+Z_built_objectsrprWrrÚlanguageZdetect_languageZlink_shared_objectÚ get_librariesr/rÚget_export_symbols) r8r‚roÚext_pathr˜Z extra_argsrsr-ZobjectsrrrrræsXþÿ     ú   ÷zbuild_ext.build_extensioncCs$g}g}i}|jrt d¡|js6d|jks6d|jkrI don't know how to find (much less run) SWIG on platform '%s'N)rOrXrUrVÚisfileZDistutilsPlatformError)r8ZversÚfnrrrr¤gs    ÿÿzbuild_ext.find_swigcCsŽ| |¡}| d¡}| |d¡}|jsRtjj|dd…|gŽ}tj |j|¡Sd |dd…¡}| d¡}tj  |  |¡¡}tj ||¡S)z¡Returns the path of the filename for a given extension. The file is located in `build_lib` or directly in the package (inplace option). rCr¢NrÚbuild_py) Úget_ext_fullnamerNÚget_ext_filenamerrOrUrVr'riÚabspathZget_package_dir)r8rƒÚfullnameÚmodpathÚfilenamer*r­Z package_dirrrrrŠs   zbuild_ext.get_ext_fullpathcCs |jdkr|S|jd|SdS)zSReturns the fullname of a given extension name. Adds the `package.` prefixNrC)r*)r8rƒrrrr®šs zbuild_ext.get_ext_fullnamecCs.ddlm}| d¡}|dƒ}tjj|Ž|S)z¦Convert the name of an extension (eg. "foo.bar") into the name of the file from which it will be loaded (eg. "foo/bar.so", or "foo\bar.pyd"). r©r_rCZ EXT_SUFFIX)Údistutils.sysconfigr_rNrOrUrV)r8rƒr_r Z ext_suffixrrrr¯£s  zbuild_ext.get_ext_filenamecCsxd|j d¡d}z| d¡Wn0tk rRd| d¡ dd¡ d¡}YnXd |}||jkrr|j |¡|jS) aReturn the list of symbols that a shared extension has to export. This either uses 'ext.export_symbols' or, if it's not provided, "PyInit_" + module_name. Only relevant on Windows, where the .pyd file (DLL) must export the module "PyInit_" function. Ú_rCr¢ÚasciirZpunycodeó-ó_ZPyInit)rXrNÚencodeÚUnicodeEncodeErrorÚreplaceÚdecoder™rT)r8r‚rcZ initfunc_namerrrrŸ­s"  zbuild_ext.get_export_symbolscCsètjdkr^ddlm}t|j|ƒsâd}|jr4|d}|tjd?tjd?d@f}|j|gSn„dd l m }d }d rÆ|d ƒrÆt td ƒrŠd }ns$       ÿ