ez_setup.py 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. #!python
  2. # This file was obtained from:
  3. # http://peak.telecommunity.com/dist/ez_setup.py
  4. # on 2011/1/21.
  5. """Bootstrap setuptools installation
  6. If you want to use setuptools in your package's setup.py, just include this
  7. file in the same directory with it, and add this to the top of your setup.py::
  8. from ez_setup import use_setuptools
  9. use_setuptools()
  10. If you want to require a specific version of setuptools, set a download
  11. mirror, or use an alternate download directory, you can do so by supplying
  12. the appropriate options to ``use_setuptools()``.
  13. This file can also be run as a script to install or upgrade setuptools.
  14. """
  15. import sys
  16. DEFAULT_VERSION = "0.6c11"
  17. DEFAULT_URL = "http://pypi.python.org/packages/%s/s/setuptools/" % sys.version[:3]
  18. md5_data = {
  19. 'setuptools-0.6b1-py2.3.egg': '8822caf901250d848b996b7f25c6e6ca',
  20. 'setuptools-0.6b1-py2.4.egg': 'b79a8a403e4502fbb85ee3f1941735cb',
  21. 'setuptools-0.6b2-py2.3.egg': '5657759d8a6d8fc44070a9d07272d99b',
  22. 'setuptools-0.6b2-py2.4.egg': '4996a8d169d2be661fa32a6e52e4f82a',
  23. 'setuptools-0.6b3-py2.3.egg': 'bb31c0fc7399a63579975cad9f5a0618',
  24. 'setuptools-0.6b3-py2.4.egg': '38a8c6b3d6ecd22247f179f7da669fac',
  25. 'setuptools-0.6b4-py2.3.egg': '62045a24ed4e1ebc77fe039aa4e6f7e5',
  26. 'setuptools-0.6b4-py2.4.egg': '4cb2a185d228dacffb2d17f103b3b1c4',
  27. 'setuptools-0.6c1-py2.3.egg': 'b3f2b5539d65cb7f74ad79127f1a908c',
  28. 'setuptools-0.6c1-py2.4.egg': 'b45adeda0667d2d2ffe14009364f2a4b',
  29. 'setuptools-0.6c10-py2.3.egg': 'ce1e2ab5d3a0256456d9fc13800a7090',
  30. 'setuptools-0.6c10-py2.4.egg': '57d6d9d6e9b80772c59a53a8433a5dd4',
  31. 'setuptools-0.6c10-py2.5.egg': 'de46ac8b1c97c895572e5e8596aeb8c7',
  32. 'setuptools-0.6c10-py2.6.egg': '58ea40aef06da02ce641495523a0b7f5',
  33. 'setuptools-0.6c11-py2.3.egg': '2baeac6e13d414a9d28e7ba5b5a596de',
  34. 'setuptools-0.6c11-py2.4.egg': 'bd639f9b0eac4c42497034dec2ec0c2b',
  35. 'setuptools-0.6c11-py2.5.egg': '64c94f3bf7a72a13ec83e0b24f2749b2',
  36. 'setuptools-0.6c11-py2.6.egg': 'bfa92100bd772d5a213eedd356d64086',
  37. 'setuptools-0.6c2-py2.3.egg': 'f0064bf6aa2b7d0f3ba0b43f20817c27',
  38. 'setuptools-0.6c2-py2.4.egg': '616192eec35f47e8ea16cd6a122b7277',
  39. 'setuptools-0.6c3-py2.3.egg': 'f181fa125dfe85a259c9cd6f1d7b78fa',
  40. 'setuptools-0.6c3-py2.4.egg': 'e0ed74682c998bfb73bf803a50e7b71e',
  41. 'setuptools-0.6c3-py2.5.egg': 'abef16fdd61955514841c7c6bd98965e',
  42. 'setuptools-0.6c4-py2.3.egg': 'b0b9131acab32022bfac7f44c5d7971f',
  43. 'setuptools-0.6c4-py2.4.egg': '2a1f9656d4fbf3c97bf946c0a124e6e2',
  44. 'setuptools-0.6c4-py2.5.egg': '8f5a052e32cdb9c72bcf4b5526f28afc',
  45. 'setuptools-0.6c5-py2.3.egg': 'ee9fd80965da04f2f3e6b3576e9d8167',
  46. 'setuptools-0.6c5-py2.4.egg': 'afe2adf1c01701ee841761f5bcd8aa64',
  47. 'setuptools-0.6c5-py2.5.egg': 'a8d3f61494ccaa8714dfed37bccd3d5d',
  48. 'setuptools-0.6c6-py2.3.egg': '35686b78116a668847237b69d549ec20',
  49. 'setuptools-0.6c6-py2.4.egg': '3c56af57be3225019260a644430065ab',
  50. 'setuptools-0.6c6-py2.5.egg': 'b2f8a7520709a5b34f80946de5f02f53',
  51. 'setuptools-0.6c7-py2.3.egg': '209fdf9adc3a615e5115b725658e13e2',
  52. 'setuptools-0.6c7-py2.4.egg': '5a8f954807d46a0fb67cf1f26c55a82e',
  53. 'setuptools-0.6c7-py2.5.egg': '45d2ad28f9750e7434111fde831e8372',
  54. 'setuptools-0.6c8-py2.3.egg': '50759d29b349db8cfd807ba8303f1902',
  55. 'setuptools-0.6c8-py2.4.egg': 'cba38d74f7d483c06e9daa6070cce6de',
  56. 'setuptools-0.6c8-py2.5.egg': '1721747ee329dc150590a58b3e1ac95b',
  57. 'setuptools-0.6c9-py2.3.egg': 'a83c4020414807b496e4cfbe08507c03',
  58. 'setuptools-0.6c9-py2.4.egg': '260a2be2e5388d66bdaee06abec6342a',
  59. 'setuptools-0.6c9-py2.5.egg': 'fe67c3e5a17b12c0e7c541b7ea43a8e6',
  60. 'setuptools-0.6c9-py2.6.egg': 'ca37b1ff16fa2ede6e19383e7b59245a',
  61. }
  62. import sys, os
  63. try: from hashlib import md5
  64. except ImportError: from md5 import md5
  65. def _validate_md5(egg_name, data):
  66. if egg_name in md5_data:
  67. digest = md5(data).hexdigest()
  68. if digest != md5_data[egg_name]:
  69. print >>sys.stderr, (
  70. "md5 validation of %s failed! (Possible download problem?)"
  71. % egg_name
  72. )
  73. sys.exit(2)
  74. return data
  75. def use_setuptools(
  76. version=DEFAULT_VERSION, download_base=DEFAULT_URL, to_dir=os.curdir,
  77. download_delay=15
  78. ):
  79. """Automatically find/download setuptools and make it available on sys.path
  80. `version` should be a valid setuptools version number that is available
  81. as an egg for download under the `download_base` URL (which should end with
  82. a '/'). `to_dir` is the directory where setuptools will be downloaded, if
  83. it is not already available. If `download_delay` is specified, it should
  84. be the number of seconds that will be paused before initiating a download,
  85. should one be required. If an older version of setuptools is installed,
  86. this routine will print a message to ``sys.stderr`` and raise SystemExit in
  87. an attempt to abort the calling script.
  88. """
  89. was_imported = 'pkg_resources' in sys.modules or 'setuptools' in sys.modules
  90. def do_download():
  91. egg = download_setuptools(version, download_base, to_dir, download_delay)
  92. sys.path.insert(0, egg)
  93. import setuptools; setuptools.bootstrap_install_from = egg
  94. try:
  95. return do_download()
  96. import pkg_resources
  97. except ImportError:
  98. return do_download()
  99. try:
  100. return do_download()
  101. pkg_resources.require("setuptools>="+version); return
  102. except pkg_resources.VersionConflict, e:
  103. if was_imported:
  104. print >>sys.stderr, (
  105. "The required version of setuptools (>=%s) is not available, and\n"
  106. "can't be installed while this script is running. Please install\n"
  107. " a more recent version first, using 'easy_install -U setuptools'."
  108. "\n\n(Currently using %r)"
  109. ) % (version, e.args[0])
  110. sys.exit(2)
  111. except pkg_resources.DistributionNotFound:
  112. pass
  113. del pkg_resources, sys.modules['pkg_resources'] # reload ok
  114. return do_download()
  115. def download_setuptools(
  116. version=DEFAULT_VERSION, download_base=DEFAULT_URL, to_dir=os.curdir,
  117. delay = 15
  118. ):
  119. """Download setuptools from a specified location and return its filename
  120. `version` should be a valid setuptools version number that is available
  121. as an egg for download under the `download_base` URL (which should end
  122. with a '/'). `to_dir` is the directory where the egg will be downloaded.
  123. `delay` is the number of seconds to pause before an actual download attempt.
  124. """
  125. import urllib2, shutil
  126. egg_name = "setuptools-%s-py%s.egg" % (version,sys.version[:3])
  127. url = download_base + egg_name
  128. saveto = os.path.join(to_dir, egg_name)
  129. src = dst = None
  130. if not os.path.exists(saveto): # Avoid repeated downloads
  131. try:
  132. from distutils import log
  133. if delay:
  134. log.warn("""
  135. ---------------------------------------------------------------------------
  136. This script requires setuptools version %s to run (even to display
  137. help). I will attempt to download it for you (from
  138. %s), but
  139. you may need to enable firewall access for this script first.
  140. I will start the download in %d seconds.
  141. (Note: if this machine does not have network access, please obtain the file
  142. %s
  143. and place it in this directory before rerunning this script.)
  144. ---------------------------------------------------------------------------""",
  145. version, download_base, delay, url
  146. ); from time import sleep; sleep(delay)
  147. log.warn("Downloading %s", url)
  148. src = urllib2.urlopen(url)
  149. # Read/write all in one block, so we don't create a corrupt file
  150. # if the download is interrupted.
  151. data = _validate_md5(egg_name, src.read())
  152. dst = open(saveto,"wb"); dst.write(data)
  153. finally:
  154. if src: src.close()
  155. if dst: dst.close()
  156. return os.path.realpath(saveto)
  157. def main(argv, version=DEFAULT_VERSION):
  158. """Install or upgrade setuptools and EasyInstall"""
  159. try:
  160. import setuptools
  161. except ImportError:
  162. egg = None
  163. try:
  164. egg = download_setuptools(version, delay=0)
  165. sys.path.insert(0,egg)
  166. from setuptools.command.easy_install import main
  167. return main(list(argv)+[egg]) # we're done here
  168. finally:
  169. if egg and os.path.exists(egg):
  170. os.unlink(egg)
  171. else:
  172. if setuptools.__version__ == '0.0.1':
  173. print >>sys.stderr, (
  174. "You have an obsolete version of setuptools installed. Please\n"
  175. "remove it from your system entirely before rerunning this script."
  176. )
  177. sys.exit(2)
  178. req = "setuptools>="+version
  179. import pkg_resources
  180. try:
  181. pkg_resources.require(req)
  182. except pkg_resources.VersionConflict:
  183. try:
  184. from setuptools.command.easy_install import main
  185. except ImportError:
  186. from easy_install import main
  187. main(list(argv)+[download_setuptools(delay=0)])
  188. sys.exit(0) # try to force an exit
  189. else:
  190. if argv:
  191. from setuptools.command.easy_install import main
  192. main(argv)
  193. else:
  194. print "Setuptools version",version,"or greater has been installed."
  195. print '(Run "ez_setup.py -U setuptools" to reinstall or upgrade.)'
  196. def update_md5(filenames):
  197. """Update our built-in md5 registry"""
  198. import re
  199. for name in filenames:
  200. base = os.path.basename(name)
  201. f = open(name,'rb')
  202. md5_data[base] = md5(f.read()).hexdigest()
  203. f.close()
  204. data = [" %r: %r,\n" % it for it in md5_data.items()]
  205. data.sort()
  206. repl = "".join(data)
  207. import inspect
  208. srcfile = inspect.getsourcefile(sys.modules[__name__])
  209. f = open(srcfile, 'rb'); src = f.read(); f.close()
  210. match = re.search("\nmd5_data = {\n([^}]+)}", src)
  211. if not match:
  212. print >>sys.stderr, "Internal error!"
  213. sys.exit(2)
  214. src = src[:match.start(1)] + repl + src[match.end(1):]
  215. f = open(srcfile,'w')
  216. f.write(src)
  217. f.close()
  218. if __name__=='__main__':
  219. if len(sys.argv)>2 and sys.argv[1]=='--md5update':
  220. update_md5(sys.argv[2:])
  221. else:
  222. main(sys.argv[1:])