aboutsummaryrefslogtreecommitdiffstats
path: root/ez_setup.py
diff options
context:
space:
mode:
authorPJ Eby <distutils-sig@python.org>2005-06-12 21:47:34 +0000
committerPJ Eby <distutils-sig@python.org>2005-06-12 21:47:34 +0000
commit26a5ebfbad61a20d1011dd14585f86bde34211bb (patch)
tree55e3f2f04d74ebfc0cd187be3035f74eb7b1618c /ez_setup.py
parent5bf51fa29ddefee5ff82a52b9c14420f70401779 (diff)
downloadexternal_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-xez_setup.py164
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:])
+
+
+
+