a c@sddlZddlZddlZddlmZddlmZddlmZm Z m Z m Z ddl mZgdZ Gdd d Zd d Zdd dZdddZddZedS)N) StrictVersion)Bytecode) find_module PY_COMPILED PY_FROZEN PY_SOURCE) py27compat)Requirerget_module_constantextract_constantc@sHeZdZdZdddZddZdd Zdd d Zdd dZdddZ dS)r z7A prerequisite to building or installing a distributionNcCsF|dur|durt}|dur0||}|dur0d}|jt|`dS)N __version__)r__dict__updatelocalsself)rnamerequested_versionmoduleZhomepage attributeformatr_/workspaces/shunt/resources/test-fastapi/venv/lib/python3.9/site-packages/setuptools/depends.py__init__szRequire.__init__cCs |jdurd|j|jfS|jS)z0Return full package/distribution name, w/versionNz%s-%s)rr)rrrr full_name#s zRequire.full_namecCs*|jdup(|jdup(t|dko(||jkS)z%Is 'version' sufficiently up-to-date?Nunknown)rrstrr)rversionrrr version_ok)szRequire.version_okrcCs~|jdurDz$t|j|\}}}|r*||WStyBYdS0t|j|j||}|durz||urz|jdurz||S|S)aGet version number of installed module, 'None', or 'default' Search 'paths' for module. If not found, return 'None'. If found, return the extracted version attribute, or 'default' if no version attribute was specified, or the value cannot be determined without importing the module. The version is formatted according to the requirement's version format (if any), unless it is 'None' or the supplied 'default'. N)rrrclose ImportErrorr r)rpathsdefaultfpivrrr get_version.s   zRequire.get_versioncCs||duS)z/Return true if dependency is present on 'paths'N)r()rr"rrr is_presentIszRequire.is_presentcCs ||}|durdS||S)z>Return true if dependency is present and up-to-date on 'paths'NF)r(r)rr"rrrr is_currentMs zRequire.is_current)r NN)Nr)N)N) __name__ __module__ __qualname____doc__rrrr(r)r*rrrrr s   r cCs"tjdd}|s|St|S)Ncss dVdS)NrrrrremptyVszmaybe_close..empty) contextlibcontextmanagerclosing)r$r/rrr maybe_closeUs  r3c Cszt||\}}\}}}} Wnty2YdS0t||tkr\|dt|} nX|tkrrt ||} nB|t krt ||d} n(t ||| } t | |dWdSWdn1s0Yt| ||S)zFind 'module' by searching 'paths', and extract 'symbol' Return 'None' if 'module' does not exist on 'paths', or it does not define 'symbol'. If the module defines 'symbol' as a constant, return the constant. Otherwise, return 'default'.Nexec)rr!r3rreadmarshalloadrr get_frozen_objectrcompileZ get_modulegetattrr ) rsymbolr#r"r$pathsuffixmodekindinfocodeZimportedrrrr `s    8r c Cs||jvrdSt|j|}d}d}d}|}t|D]H}|j} |j} | |krZ|j| }q6| |krz| |ksr| |krz|S|}q6dS)aExtract the constant value of 'symbol' from 'code' If the name 'symbol' is bound to a constant value by the Python code object 'code', return that value. If 'symbol' is bound to an expression, return 'default'. Otherwise, return 'None'. Return value is based on the first assignment to 'symbol'. 'symbol' must be a global, or at least a non-"fast" local in the code block. That is, only 'STORE_NAME' and 'STORE_GLOBAL' opcodes are checked, and 'symbol' must be present in 'code.co_names'. NZad)co_nameslistindexropcodearg co_consts) rCr=r#Zname_idx STORE_NAME STORE_GLOBAL LOAD_CONSTconstZ byte_codeoprKrrrr }s   r cCs>tjdstjdkrdSd}|D]}t|=t|q"dS)z Patch the globals to remove the objects not available on some platforms. XXX it'd be better to test assertions about bytecode instead. javacliN)r r )sysplatform startswithglobals__all__remove)Z incompatiblerrrr_update_globalss rZ)r4N)r4)rTr8r0Zdistutils.versionrZ py33compatrr rrrrr rXr r3r r rZrrrrs   D  $