[Numpy-svn] r5552 - trunk/tools/win32build

numpy-svn at scipy.org numpy-svn at scipy.org
Mon Jul 28 00:22:44 EDT 2008


Author: cdavid
Date: 2008-07-27 23:22:40 -0500 (Sun, 27 Jul 2008)
New Revision: 5552

Modified:
   trunk/tools/win32build/prepare_bootstrap.py
Log:
Bootstrap script now works from scratch.

Modified: trunk/tools/win32build/prepare_bootstrap.py
===================================================================
--- trunk/tools/win32build/prepare_bootstrap.py	2008-07-28 04:21:49 UTC (rev 5551)
+++ trunk/tools/win32build/prepare_bootstrap.py	2008-07-28 04:22:40 UTC (rev 5552)
@@ -3,9 +3,8 @@
 import shutil
 from os.path import join as pjoin, split as psplit, dirname
 from zipfile import ZipFile
+import re
 
-from build import get_numpy_version, get_binary_name
-
 def get_sdist_tarball():
     """Return the name of the installer built by wininst command."""
     # Yeah, the name logic is harcoded in distutils. We have to reproduce it
@@ -25,7 +24,7 @@
         os.chdir(cwd)
 
 def prepare_numpy_sources(bootstrap = 'bootstrap'):
-    zid = ZipFile(pjoin('../..', 'dist', get_sdist_tarball()))
+    zid = ZipFile(pjoin('..', '..', 'dist', get_sdist_tarball()))
     root = 'numpy-%s' % get_numpy_version()
 
     # From the sdist-built tarball, extract all files into bootstrap directory,
@@ -33,12 +32,13 @@
     for name in zid.namelist():
         cnt = zid.read(name)
         if name.startswith(root):
-            name = name.split(os.sep, 1)[1]
+            # XXX: even on windows, the path sep in zip is '/' ?
+            name = name.split('/', 1)[1]
         newname = pjoin(bootstrap, name)
 
         if not os.path.exists(dirname(newname)):
             os.makedirs(dirname(newname))
-        fid = open(newname, 'w')
+        fid = open(newname, 'wb')
         fid.write(cnt)
 
 def prepare_nsis_script(bootstrap, pyver, numver):
@@ -51,11 +51,11 @@
     cnt = cnt.replace('@NUMPY_INSTALLER_NAME@', installer_name)
     for arch in ['nosse', 'sse2', 'sse3']:
         cnt = cnt.replace('@%s_BINARY@' % arch.upper(),
-                          get_binary_name(arch)))
+                          get_binary_name(arch))
 
     target.write(cnt)
 
-def prepare_bootstrap(pyver = "2.5"):
+def prepare_bootstrap(numver, pyver = "2.5"):
     bootstrap = "bootstrap-%s" % pyver
     if os.path.exists(bootstrap):
         shutil.rmtree(bootstrap)
@@ -67,5 +67,32 @@
     shutil.copy('build.py', bootstrap)
     prepare_nsis_script(bootstrap, pyver, get_numpy_version())
 
+def get_binary_name(arch):
+    return "numpy-%s-%s.exe" % (get_numpy_version(), arch)
+
+def get_numpy_version(chdir = pjoin('..', '..')):
+    cwd = os.getcwd()
+    try:
+        if not chdir:
+            chdir = cwd
+        os.chdir(chdir)
+        version = subprocess.Popen(['python', '-c', 'import __builtin__; __builtin__.__NUMPY_SETUP__ = True; from numpy.version import version;print version'], stdout =  subprocess.PIPE).communicate()[0]
+        version = version.strip()
+        if 'dev' in version:
+            out = subprocess.Popen(['svn', 'info'], stdout = subprocess.PIPE).communicate()[0] 
+            r = re.compile('Revision: ([0-9]+)')
+            svnver = None
+            for line in out.split('\n'):
+                m = r.match(line)
+                if m:
+                    svnver = m.group(1)
+
+            if not svnver:
+                raise ValueError("Error while parsing svn version ?")
+            version += svnver
+    finally:
+        os.chdir(cwd)
+    return version
+
 if __name__ == '__main__':
     prepare_bootstrap("2.5")




More information about the Numpy-svn mailing list