3

Q'ícÍã@s’ddlZddlZddlZddlmZddlmZmZmZmZddl	m
Z
dddd	gZGd
d„dƒZddd„Z
ddd„Zdd
d	„Zdd„ZeƒdS)éN)Ú
StrictVersion)Ú
PKG_DIRECTORYÚPY_COMPILEDÚ	PY_SOURCEÚ	PY_FROZENé)ÚBytecodeÚRequireÚfind_moduleÚget_module_constantÚextract_constantc@sHeZdZdZddd„Zdd„Zdd	„Zddd„Zdd
d„Zddd„Z	dS)r	z7A prerequisite to building or installing a distributionÚNcCsF|dkr|dk	rt}|dk	r0||ƒ}|dkr0d}|jjtƒƒ|`dS)NÚ__version__)rÚ__dict__ÚupdateÚlocalsÚself)rÚnameÚrequested_versionÚmoduleZhomepageÚ	attributeÚformat©rú8/tmp/pip-build-l_bcah40/setuptools/setuptools/depends.pyÚ__init__szRequire.__init__cCs |jdk	rd|j|jfS|jS)z0Return full package/distribution name, w/versionNz%s-%s)rr)rrrrÚ	full_name s
zRequire.full_namecCs*|jdkp(|jdkp(t|ƒdko(||jkS)z%Is 'version' sufficiently up-to-date?NÚunknown)rrÚstrr)rÚversionrrrÚ
version_ok&szRequire.version_okrc
Cs||jdkrBy"t|j|ƒ\}}}|r*|jƒ|Stk
r@dSXt|j|j||ƒ}|dk	rx||k	rx|jdk	rx|j|ƒS|S)a×Get 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)rr
rÚcloseÚImportErrorrr)rÚpathsÚdefaultÚfÚpÚiÚvrrrÚget_version+s

zRequire.get_versioncCs|j|ƒdk	S)z/Return true if dependency is present on 'paths'N)r()rr"rrrÚ
is_presentFszRequire.is_presentcCs |j|ƒ}|dkrdS|j|ƒS)z>Return true if dependency is present and up-to-date on 'paths'NF)r(r)rr"rrrrÚ
is_currentJs
zRequire.is_current)r
NN)Nr)N)N)
Ú__name__Ú
__module__Ú__qualname__Ú__doc__rrrr(r)r*rrrrr	s



c
Csl|jdƒ}x\|rf|jdƒ}tj||ƒ\}}\}}}}	|tkrP|pFdg}|g}q|rtd||fƒ‚qW|	S)z7Just like 'imp.find_module()', but with package supportÚ.rrzCan't find %r in %s)ÚsplitÚpopÚimpr
rr!)
rr"ÚpartsÚpartr$ÚpathÚsuffixÚmodeÚkindÚinforrrr
Rs


c
CsÎyt||ƒ\}}\}}}Wntk
r.dSXz‚|tkrP|jdƒtj|ƒ}	n`|tkrdtj|ƒ}	nL|t	kr~t
|jƒ|dƒ}	n2|tjkržtj
||||||fƒttj||dƒSWd|rÀ|jƒXt|	||ƒS)züFind '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'.NéÚexec)r
r!rÚreadÚmarshalÚloadrr2Úget_frozen_objectrÚcompileÚsysÚmodulesÚload_moduleÚgetattrr r)
rÚsymbolr#r"r$r5r6r7r8Úcoderrrres$


cCs„||jkrdSt|jƒj|ƒ}d}d}d}|}xPt|ƒD]D}|j}	|j}
|	|kr\|j|
}q8|
|krx|	|kst|	|krx|S|}q8WdS)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'.
    NéZéaéd)Úco_namesÚlistÚindexrÚopcodeÚargÚ	co_consts)rFrEr#Zname_idxÚ
STORE_NAMEÚSTORE_GLOBALÚ
LOAD_CONSTÚconstZ	byte_codeÚoprNrrrr‡s
cCsDtjjdƒrtjdkrdSd}x|D]}tƒ|=tj|ƒq&WdS)z•
    Patch the globals to remove the objects not available on some platforms.

    XXX it'd be better to test assertions about bytecode instead.
    ÚjavaÚcliNrr)rr)rAÚplatformÚ
startswithÚglobalsÚ__all__Úremove)ZincompatiblerrrrÚ_update_globals«s
r\)Néÿÿÿÿ)r]Nr])r])rAr2r=Zdistutils.versionrrrrrZ
py33compatrrZr	r
rrr\rrrrÚ<module>sC

"
$