diff options
author | PJ Eby <distutils-sig@python.org> | 2005-06-12 21:47:34 +0000 |
---|---|---|
committer | PJ Eby <distutils-sig@python.org> | 2005-06-12 21:47:34 +0000 |
commit | 26a5ebfbad61a20d1011dd14585f86bde34211bb (patch) | |
tree | 55e3f2f04d74ebfc0cd187be3035f74eb7b1618c /ez_setup.py | |
parent | 5bf51fa29ddefee5ff82a52b9c14420f70401779 (diff) | |
download | external_python_setuptools-26a5ebfbad61a20d1011dd14585f86bde34211bb.tar.gz external_python_setuptools-26a5ebfbad61a20d1011dd14585f86bde34211bb.tar.bz2 external_python_setuptools-26a5ebfbad61a20d1011dd14585f86bde34211bb.zip |
Add 'ez_setup' bootstrap installer. Prep for 0.4a2 release.
--HG--
branch : setuptools
extra : convert_revision : svn%3A6015fed2-1504-0410-9fe1-9d1591cc4771/sandbox/trunk/setuptools%4041054
Diffstat (limited to 'ez_setup.py')
-rwxr-xr-x | ez_setup.py | 164 |
1 files changed, 164 insertions, 0 deletions
diff --git a/ez_setup.py b/ez_setup.py new file mode 100755 index 00000000..f18ab799 --- /dev/null +++ b/ez_setup.py @@ -0,0 +1,164 @@ +#!python +"""Bootstrap setuptools installation + +If you want to use setuptools in your package's setup.py, just include this +file in the same directory with it, and add this to the top of your setup.py:: + + from ez_setup import use_setuptools + use_setuptools() + +If you want to require a specific version of setuptools, set a download +mirror, or use an alternate download directory, you can do so by supplying +the appropriate options to ``use_setuptools()``. + +This file can also be run as a script to install or upgrade setuptools. +""" + +DEFAULT_VERSION = "0.4a2" +DEFAULT_URL = "http://peak.telecommunity.com/dist/" + +import sys, os + + + + + + + + + + + + + + + + + + + + + +def use_setuptools( + version=DEFAULT_VERSION, download_base=DEFAULT_URL, to_dir=os.curdir +): + """Automatically find/download setuptools and make it available on sys.path + + `version` should be a valid setuptools version number that is available + as an egg for download under the `download_base` URL (which should end with + a '/'). `to_dir` is the directory where setuptools will be downloaded, if + it is not already available. + + If an older version of setuptools is installed, this will print a message + to ``sys.stderr`` and raise SystemExit in an attempt to abort the calling + script. + """ + try: + import setuptools + if setuptools.__version__ == '0.0.1': + print >>sys.stderr, ( + "You have an obsolete version of setuptools installed. Please\n" + "remove it from your system entirely before rerunning this script." + ) + sys.exit(2) + + except ImportError: + sys.path.insert(0, download_setuptools(version, download_base, to_dir)) + + import pkg_resources + try: + pkg_resources.require("setuptools>="+version) + + except pkg_resources.VersionConflict: + # XXX could we install in a subprocess here? + print >>sys.stderr, ( + "The required version of setuptools (>=%s) is not available, and\n" + "can't be installed while this script is running. Please install\n" + " a more recent version first." + ) % version + sys.exit(2) + + + +def download_setuptools( + version=DEFAULT_VERSION, download_base=DEFAULT_URL, to_dir=os.curdir +): + """Download setuptools from a specified location and return its filename + + `version` should be a valid setuptools version number that is available + as an egg for download under the `download_base` URL (which should end + with a '/'). `to_dir` is the directory where the egg will be downloaded. + """ + import urllib2, shutil + egg_name = "setuptools-%s-py%s.egg" % (version,sys.version[:3]) + url = download_base + egg_name + saveto = os.path.join(to_dir, egg_name) + src = dst = None + + try: + src = urllib2.urlopen(url) + dst = open(saveto,"wb") + shutil.copyfileobj(src,dst) + finally: + if src: src.close() + if dst: dst.close() + + return os.path.realpath(saveto) + + + + + + + + + + + + + + + + + +def main(argv, version=DEFAULT_VERSION): + """Install or upgrade setuptools and EasyInstall""" + + try: + import setuptools + except ImportError: + import tempfile, shutil + tmpdir = tempfile.mkdtemp(prefix="easy_install-") + try: + egg = download_setuptools(version, to_dir=tmpdir) + sys.path.insert(0,egg) + from easy_install import main + main(list(argv)+[egg]) + finally: + shutil.rmtree(tmpdir) + else: + if setuptools.__version__ == '0.0.1': + # tell the user to uninstall obsolete version + use_setuptools(version) + + req = "setuptools>="+version + import pkg_resources + try: + pkg_resources.require(req) + except pkg_resources.VersionConflict: + from easy_install import main + main(list(argv)+[req]) + sys.exit(0) # try to force an exit + else: + if argv: + from easy_install import main + main(argv) + else: + print "Setuptools successfully installed or upgraded." + +if __name__=='__main__': + main(sys.argv[1:]) + + + + |