From c3a265839c3e24590bb1672c2093248a002c7dc0 Mon Sep 17 00:00:00 2001
From: Zooko O'Whielacronx <zooko@zooko.com>
Date: Sat, 22 Dec 2007 10:44:47 -0700
Subject: [PATCH] setup: refactor ez_setup.py and setup.py to satisfy the
 Desert Island scenario, to find and use setuptools egg in-place in
 misc/dependencies, and make it setup_require pyutil (for darcsver)

---
 calcdeps.py                           | 31 +++++++++++----------------
 misc/dependencies/build-deps-setup.py | 30 +++++++++++++++++---------
 setup.py                              |  9 ++++----
 3 files changed, 37 insertions(+), 33 deletions(-)

diff --git a/calcdeps.py b/calcdeps.py
index c41f398f..8439bfdc 100644
--- a/calcdeps.py
+++ b/calcdeps.py
@@ -1,18 +1,18 @@
+import os
 
-import os.path, sys
+miscdeps=os.path.join('misc', 'dependencies')
+dependency_links=[os.path.join(miscdeps, t) for t in os.listdir(miscdeps) if t.endswith(".tar")]
 
-# This form is used when the unpacked source distribution is copied into our
-# tree:
-#  "file:misc/dependencies/zfec-1.0.2/"
-# and this form is used when we provide a tarball
-#  "file:misc/dependencies/zfec-1.0.2.tar.gz",
-# The file: URL can start with either 'misc' or './misc' to get a relative path.
+# By adding a web page to the dependency_links we are able to put new packages
+# up there and have them be automatically discovered by existing copies of the
+# tahoe source when that source was built.
+dependency_links.append("http://allmydata.org/trac/tahoe/wiki/Dependencies")
 
-dependency_tarballs=[ os.path.join("misc", "dependencies", fn)
-                      for fn in os.listdir(os.path.join("misc", "dependencies"))
-                      if fn.endswith(".tar.gz") ]
-
-dependency_links=["http://allmydata.org/trac/tahoe/wiki/Dependencies"] + dependency_tarballs
+install_requires=["zfec >= 1.0.3",
+                  "foolscap >= 0.2.2",
+                  "simplejson >= 1.4",
+                  "pycryptopp >= 0.2.8",
+                  ]
 
 nevow_version = None
 try:
@@ -21,13 +21,6 @@ try:
 except ImportError:
     pass
 
-install_requires=["zfec >= 1.0.3",
-                  "foolscap >= 0.2.2",
-                  "simplejson >= 1.4",
-                  "pycryptopp >= 0.2.8",
-                  ]
-
-
 # We also require zope.interface, but some older versions of setuptools such
 # as setuptools v0.6a9 don't handle the "." in its name correctly, and anyway
 # people have to manually install Twisted before using our automatic
diff --git a/misc/dependencies/build-deps-setup.py b/misc/dependencies/build-deps-setup.py
index ad5189d1..68612ed7 100644
--- a/misc/dependencies/build-deps-setup.py
+++ b/misc/dependencies/build-deps-setup.py
@@ -2,18 +2,27 @@
 
 # N.B.: this expects to run from the top of the source tree
 
-import sys
+import sys, os
+
+miscdeps=os.path.join('misc', 'dependencies')
+
 from ez_setup import use_setuptools
-if 'cygwin' in sys.platform.lower():
-    min_version='0.6c6'
+try:
+    from ez_setup import use_setuptools
+except ImportError:
+    pass
 else:
-    # foolscap uses a module-level os.urandom() during import, which
-    # breaks inside older setuptools' sandboxing. 0.6c4 is the first
-    # version which fixed this problem.
-    min_version='0.6c4'
-use_setuptools(min_version=min_version,
-               download_base="file:misc/dependencies/",
-               download_delay=0)
+    if 'cygwin' in sys.platform.lower():
+        min_version='0.6c6'
+    else:
+        # foolscap uses a module-level os.urandom() during import, which
+        # breaks inside older setuptools' sandboxing. 0.6c4 is the first
+        # version which fixed this problem.
+        min_version='0.6c4'
+    download_base = "file:"+os.path.join('misc', 'dependencies')+os.path.sep
+    use_setuptools(min_version=min_version,
+                   download_base=download_base,
+                   download_delay=0, to_dir=miscdeps)
 
 from setuptools import setup
 
@@ -23,4 +32,5 @@ setup(name='tahoe-deps',
       version="1",
       install_requires=install_requires,
       dependency_links=dependency_links,
+      zip_safe=False
       )
diff --git a/setup.py b/setup.py
index dddd5e16..6f946cf6 100644
--- a/setup.py
+++ b/setup.py
@@ -21,6 +21,9 @@
 # http://allmydata.com/.
 
 import sys, re, os
+
+miscdeps=os.path.join('misc', 'dependencies')
+
 try:
     from ez_setup import use_setuptools
 except ImportError:
@@ -36,7 +39,7 @@ else:
     download_base = "file:"+os.path.join('misc', 'dependencies')+os.path.sep
     use_setuptools(min_version=min_version,
                    download_base=download_base,
-                   download_delay=0)
+                   download_delay=0, to_dir=miscdeps)
 
 from setuptools import Extension, find_packages, setup
 
@@ -105,7 +108,6 @@ The basic idea is that the data in this storage grid is spread over all
 participating nodes, using an algorithm that can recover the data even if a
 majority of the nodes are no longer available."""
 
-
 setup(name='allmydata-tahoe',
       version=verstr,
       description='secure, distributed storage grid',
@@ -120,9 +122,8 @@ setup(name='allmydata-tahoe',
       test_suite="allmydata.test",
       install_requires=install_requires,
       include_package_data=True,
-      setup_requires=["setuptools_darcs >= 1.0.5",],
+      setup_requires=['setuptools_darcs >= 1.0.5', 'pyutil >= 1.3.8'], # pyutil is for darcsver
       dependency_links=dependency_links,
       entry_points = { 'console_scripts': [ 'tahoe = allmydata.scripts.runner:run' ] },
       zip_safe=False, # We prefer unzipped for easier access.
-      extras_require={'autoversioning':'pyutil >= 1.3.8'},
       )
-- 
2.45.2