summaryrefslogtreecommitdiff
path: root/tools/win32build
diff options
context:
space:
mode:
Diffstat (limited to 'tools/win32build')
-rw-r--r--tools/win32build/README.txt128
-rw-r--r--tools/win32build/build.py234
-rw-r--r--tools/win32build/doall.py26
3 files changed, 194 insertions, 194 deletions
diff --git a/tools/win32build/README.txt b/tools/win32build/README.txt
index 717b966ef..fe8522c19 100644
--- a/tools/win32build/README.txt
+++ b/tools/win32build/README.txt
@@ -1,64 +1,64 @@
-This directory contains various scripts and code to build binaries installers for
-windows.
-
-It can:
- - prepare a bootstrap environment to build binary in a self-contained
- directory
- - build binaries for different architectures using different site.cfg
- - prepare a nsis-based installer which automatically detects the arch
- on the computer where numpy is installed.
-
-Example:
-========
-
-python doall.py
-
-Should build the numpy 'super' installer for sse2, sse3 and nosse from scratch.
-You have to run it in the win32build directory.
-
-Dependencies:
-=============
-
-You need the following to use those scripts:
- - python and mingw tools (gcc, make, g77 at least).
- - the binaries for atlas/blas/lapack for the various archs supported
- (see vendor in numpy repository root for tools to build those).
- - python, nsis and subversion command line tools should be in your
- PATH, e.g. running python, makensis and svn should work in a DOS
- cmd.exe.
- - the CpuCaps nsis plugin (see below on how to build it).
-
-Components:
-===========
-
-cpuid
------
-
-cpuid: contains a mini C lib to detect SSE variants (SSE 1, 2 and 3 for now).
-It relies on gcc ASM, but porting it to VS should be trivial (only a few lines
-os ASM).
-
-cpucaps:
---------
-
-cpucaps: nsis plugin to add the ability to detect SSE for installers, uses
-cpuid. To build it, you have two options:
- - build it manually: build the CpuCaps.dll with sources cpucaps.c and
- cpuid.c in cpuid directory.
- - with scons: if you have scons, just do scons install. It will build
- and put the CpuCaps.dll in the plugins directory of nsis (if you
- install nsis in the default path).
-
-build.py:
----------
-
-Can build the binaries for each variant of arch in a bootstrap environment
-
-prepare_bootstrap.py
---------------------
-
-Script to prepare a bootstrap environment. A bootstrap environment depends on
-the python version (2.5, 2.4, etc...).
-
-It works by building a source distribution, unzipping it in a bootrap
-directory, and putting everything (build.py, nsis script, etc...) in it.
+This directory contains various scripts and code to build binaries installers for
+windows.
+
+It can:
+ - prepare a bootstrap environment to build binary in a self-contained
+ directory
+ - build binaries for different architectures using different site.cfg
+ - prepare a nsis-based installer which automatically detects the arch
+ on the computer where numpy is installed.
+
+Example:
+========
+
+python doall.py
+
+Should build the numpy 'super' installer for sse2, sse3 and nosse from scratch.
+You have to run it in the win32build directory.
+
+Dependencies:
+=============
+
+You need the following to use those scripts:
+ - python and mingw tools (gcc, make, g77 at least).
+ - the binaries for atlas/blas/lapack for the various archs supported
+ (see vendor in numpy repository root for tools to build those).
+ - python, nsis and subversion command line tools should be in your
+ PATH, e.g. running python, makensis and svn should work in a DOS
+ cmd.exe.
+ - the CpuCaps nsis plugin (see below on how to build it).
+
+Components:
+===========
+
+cpuid
+-----
+
+cpuid: contains a mini C lib to detect SSE variants (SSE 1, 2 and 3 for now).
+It relies on gcc ASM, but porting it to VS should be trivial (only a few lines
+os ASM).
+
+cpucaps:
+--------
+
+cpucaps: nsis plugin to add the ability to detect SSE for installers, uses
+cpuid. To build it, you have two options:
+ - build it manually: build the CpuCaps.dll with sources cpucaps.c and
+ cpuid.c in cpuid directory.
+ - with scons: if you have scons, just do scons install. It will build
+ and put the CpuCaps.dll in the plugins directory of nsis (if you
+ install nsis in the default path).
+
+build.py:
+---------
+
+Can build the binaries for each variant of arch in a bootstrap environment
+
+prepare_bootstrap.py
+--------------------
+
+Script to prepare a bootstrap environment. A bootstrap environment depends on
+the python version (2.5, 2.4, etc...).
+
+It works by building a source distribution, unzipping it in a bootrap
+directory, and putting everything (build.py, nsis script, etc...) in it.
diff --git a/tools/win32build/build.py b/tools/win32build/build.py
index da4f0549e..ff558fde7 100644
--- a/tools/win32build/build.py
+++ b/tools/win32build/build.py
@@ -1,117 +1,117 @@
-"""Python script to build windows binaries to be fed to the "superpack".
-
-The script is pretty dumb: it assumes python executables are installed the
-standard way, and the location for blas/lapack/atlas is harcoded."""
-
-# TODO:
-# - integrate the x86analysis script to check built binaries
-# - make the config configurable with a file
-import sys
-import subprocess
-import os
-import shutil
-from os.path import join as pjoin, split as psplit, dirname
-
-PYEXECS = {"2.5" : "C:\python25\python.exe",
- "2.4" : "C:\python24\python2.4.exe"}
-
-_SSE3_CFG = r"""[atlas]
-library_dirs = C:\local\lib\yop\sse3"""
-_SSE2_CFG = r"""[atlas]
-library_dirs = C:\local\lib\yop\sse2"""
-_NOSSE_CFG = r"""[DEFAULT]
-library_dirs = C:\local\lib\yop\nosse"""
-
-SITECFG = {"sse2" : _SSE2_CFG, "sse3" : _SSE3_CFG, "nosse" : _NOSSE_CFG}
-
-def get_python_exec(ver):
- """Return the executable of python for the given version."""
- # XXX Check that the file actually exists
- try:
- return PYEXECS[ver]
- except KeyError:
- raise ValueError("Version %s not supported/recognized" % ver)
-
-def get_clean():
- if os.path.exists("build"):
- shutil.rmtree("build")
- if os.path.exists("dist"):
- shutil.rmtree("dist")
-
-def write_site_cfg(arch):
- if os.path.exists("site.cfg"):
- os.remove("site.cfg")
- f = open("site.cfg", 'w')
- f.writelines(SITECFG[arch])
- f.close()
-
-def build(arch, pyver):
- print "Building numpy binary for python %s, arch is %s" % (get_python_exec(pyver), arch)
- get_clean()
- write_site_cfg(arch)
-
- cmd = "%s setup.py build -c mingw32 bdist_wininst" % get_python_exec(pyver)
- build_log = "build-%s-%s.log" % (arch, pyver)
- f = open(build_log, 'w')
-
- try:
- try:
- subprocess.check_call(cmd, shell = True, stderr = subprocess.STDOUT, stdout = f)
- finally:
- f.close()
- except subprocess.CalledProcessError, e:
- msg = """
-There was an error while executing the following command:
-
- %s
-
-Error was : %s
-
-Look at the build log (%s).""" % (cmd, str(e), build_log)
- raise Exception(msg)
-
- move_binary(arch, pyver)
-
-def move_binary(arch, pyver):
- if not os.path.exists("binaries"):
- os.makedirs("binaries")
-
- shutil.move(os.path.join('dist', get_windist_exec(pyver)),
- os.path.join("binaries", get_binary_name(arch)))
-
-def get_numpy_version():
- import __builtin__
- __builtin__.__NUMPY_SETUP__ = True
- from numpy.version import version
- return version
-
-def get_binary_name(arch):
- return "numpy-%s-%s.exe" % (get_numpy_version(), arch)
-
-def get_windist_exec(pyver):
- """Return the name of the installer built by wininst command."""
- # Yeah, the name logic is harcoded in distutils. We have to reproduce it
- # here
- name = "numpy-%s.win32-py%s.exe" % (get_numpy_version(), pyver)
- return name
-
-if __name__ == '__main__':
- from optparse import OptionParser
- parser = OptionParser()
- parser.add_option("-a", "--arch", dest="arch",
- help = "Architecture to build (sse2, sse3, nosse, etc...)")
- parser.add_option("-p", "--pyver", dest="pyver",
- help = "Python version (2.4, 2.5, etc...)")
-
- opts, args = parser.parse_args()
- arch = opts.arch
- pyver = opts.pyver
-
- if not pyver:
- pyver = "2.5"
-
- if not arch:
- for arch in SITECFG.keys():
- build(arch, pyver)
- else:
- build(arch, pyver)
+"""Python script to build windows binaries to be fed to the "superpack".
+
+The script is pretty dumb: it assumes python executables are installed the
+standard way, and the location for blas/lapack/atlas is harcoded."""
+
+# TODO:
+# - integrate the x86analysis script to check built binaries
+# - make the config configurable with a file
+import sys
+import subprocess
+import os
+import shutil
+from os.path import join as pjoin, split as psplit, dirname
+
+PYEXECS = {"2.5" : "C:\python25\python.exe",
+ "2.4" : "C:\python24\python2.4.exe"}
+
+_SSE3_CFG = r"""[atlas]
+library_dirs = C:\local\lib\yop\sse3"""
+_SSE2_CFG = r"""[atlas]
+library_dirs = C:\local\lib\yop\sse2"""
+_NOSSE_CFG = r"""[DEFAULT]
+library_dirs = C:\local\lib\yop\nosse"""
+
+SITECFG = {"sse2" : _SSE2_CFG, "sse3" : _SSE3_CFG, "nosse" : _NOSSE_CFG}
+
+def get_python_exec(ver):
+ """Return the executable of python for the given version."""
+ # XXX Check that the file actually exists
+ try:
+ return PYEXECS[ver]
+ except KeyError:
+ raise ValueError("Version %s not supported/recognized" % ver)
+
+def get_clean():
+ if os.path.exists("build"):
+ shutil.rmtree("build")
+ if os.path.exists("dist"):
+ shutil.rmtree("dist")
+
+def write_site_cfg(arch):
+ if os.path.exists("site.cfg"):
+ os.remove("site.cfg")
+ f = open("site.cfg", 'w')
+ f.writelines(SITECFG[arch])
+ f.close()
+
+def build(arch, pyver):
+ print "Building numpy binary for python %s, arch is %s" % (get_python_exec(pyver), arch)
+ get_clean()
+ write_site_cfg(arch)
+
+ cmd = "%s setup.py build -c mingw32 bdist_wininst" % get_python_exec(pyver)
+ build_log = "build-%s-%s.log" % (arch, pyver)
+ f = open(build_log, 'w')
+
+ try:
+ try:
+ subprocess.check_call(cmd, shell = True, stderr = subprocess.STDOUT, stdout = f)
+ finally:
+ f.close()
+ except subprocess.CalledProcessError, e:
+ msg = """
+There was an error while executing the following command:
+
+ %s
+
+Error was : %s
+
+Look at the build log (%s).""" % (cmd, str(e), build_log)
+ raise Exception(msg)
+
+ move_binary(arch, pyver)
+
+def move_binary(arch, pyver):
+ if not os.path.exists("binaries"):
+ os.makedirs("binaries")
+
+ shutil.move(os.path.join('dist', get_windist_exec(pyver)),
+ os.path.join("binaries", get_binary_name(arch)))
+
+def get_numpy_version():
+ import __builtin__
+ __builtin__.__NUMPY_SETUP__ = True
+ from numpy.version import version
+ return version
+
+def get_binary_name(arch):
+ return "numpy-%s-%s.exe" % (get_numpy_version(), arch)
+
+def get_windist_exec(pyver):
+ """Return the name of the installer built by wininst command."""
+ # Yeah, the name logic is harcoded in distutils. We have to reproduce it
+ # here
+ name = "numpy-%s.win32-py%s.exe" % (get_numpy_version(), pyver)
+ return name
+
+if __name__ == '__main__':
+ from optparse import OptionParser
+ parser = OptionParser()
+ parser.add_option("-a", "--arch", dest="arch",
+ help = "Architecture to build (sse2, sse3, nosse, etc...)")
+ parser.add_option("-p", "--pyver", dest="pyver",
+ help = "Python version (2.4, 2.5, etc...)")
+
+ opts, args = parser.parse_args()
+ arch = opts.arch
+ pyver = opts.pyver
+
+ if not pyver:
+ pyver = "2.5"
+
+ if not arch:
+ for arch in SITECFG.keys():
+ build(arch, pyver)
+ else:
+ build(arch, pyver)
diff --git a/tools/win32build/doall.py b/tools/win32build/doall.py
index 72a920ac3..33a374c72 100644
--- a/tools/win32build/doall.py
+++ b/tools/win32build/doall.py
@@ -1,13 +1,13 @@
-import subprocess
-import os
-
-PYVER = "2.5"
-
-# Bootstrap
-subprocess.check_call(['python', 'prepare_bootstrap.py'])
-
-# Build binaries
-subprocess.check_call(['python', 'build.py', '-p', PYVER], cwd = 'bootstrap-%s' % PYVER)
-
-# Build installer using nsis
-subprocess.check_call(['makensis', 'numpy-superinstaller.nsi'], cwd = 'bootstrap-%s' % PYVER)
+import subprocess
+import os
+
+PYVER = "2.5"
+
+# Bootstrap
+subprocess.check_call(['python', 'prepare_bootstrap.py'])
+
+# Build binaries
+subprocess.check_call(['python', 'build.py', '-p', PYVER], cwd = 'bootstrap-%s' % PYVER)
+
+# Build installer using nsis
+subprocess.check_call(['makensis', 'numpy-superinstaller.nsi'], cwd = 'bootstrap-%s' % PYVER)