Commit 40150a5e authored by Tim Peters's avatar Tim Peters

Merge tim-2.9-windows-installer branch.

This is the code used to build the Zope 2.9.0 Windows installer.

It bundles Python 2.4.2, lives in peace with zpkgtools, moves
to InnoSetup 5, and simplifies most parts of the build-the-
installer process.
parents 2b3ff316 5d1319ae
Quick instructions: Quick instructions:
The buildout has been tested under Windows 2K and XP Pro SP2. It "almost The buildout has been tested under Windows 2K and XP Pro SP2.
works" on Win98SE (see bottom of file for discussion).
Setup Environment Setup Environment
------------------ ------------------
Install Python 2.4.2 (or whatever is most current) by running its native
Windows installer from python.org.
Note: Python 2.4 switched from using a Wise installer to using a
Microsoft .msi installer, and the latter is harder to work with. The
buildout used to extract Python source and binaries (.exe, .pyd, .dll)
from the Wise installer (which could be treated much like a zip file).
Now the Python installer isn't used at all. Instead, the Python
source is taken from the Python tarball release, and the binaries are
copied from your installed Python.
Install Cygwin from cygwin.org (the default installation should give Install Cygwin from cygwin.org (the default installation should give
you everything you need). you everything you need).
Install Microsoft Visual C++ 6.0 (or MSVC 7 once we get to Python 2.4) Install Microsoft Visual C++ 7.1 (aka Visual Studio .NET 2003). This is
needed to compile Zope's Python C extensions compatible with Python 2.4
(and 2.5, when that's released).
Install InnoSetup 4.2 from www.jrsofware.org (into its default location). Install InnoSetup 5.1.5 (or later) from www.jrsoftware.org, into its
Versions earlier than 4.0.11 are known to not work; any 4.2.x release default location. Inno 4.x (or earlier) cannot work: Inno 5 introduced a
or later should be fine. Inno 5.x versions do *not* work (it appears the vastly simpler way to create the custom dialog pages we want.
Inno "custom dialog" mechanism has changed in an incompatible way)
'svn switch' to, or check out, the Zope tag for which an installer is to be 'svn switch' to, or check out, the Zope tag for which an installer is to be
built. You want a native Windows checkout here, so that the text files have built.
Windows-appropriate line ends.
Within a Zope checkout, parent directory of this package is inst. Make a Within a Zope checkout, the parent directory of this package is inst. Make
"tmp" directory, inst/tmp. Place the necessary pre-requisites in the tmp a "tmp" directory, inst/tmp. Place the necessary pre-requisites in the tmp
directory. At the time of this writing, this includes: directory. At the time of this writing, these are:
- Python-2.3.5.tgz - Python-2.4.2.tgz
- Python-2.3.5.exe (used for binary modules) - pywin32-205.win32-py2.4.exe
- pywin32-205.win32-py2.3.exe (extracts binaries and sources) - Zope-2.9.0.tgz
- Zope.tgz
As time marches on, these version numbers will obviously change. See/edit As time marches on, these version numbers will obviously change. See/edit
mk/python.mk and mk/zope.mk for the exact versions required. mk/python.mk and mk/zope.mk for the exact versions required.
You also need to install the same Windows Python that Zope will repackage.
There doesn't appear to be a sane way to extract binaries (.exe, .pyd,
.dll, .lib) from an .msi installer, and building Python from source is a long
& messy process on Windows. So python.mk just copies them from an installed
Python instead. Cautions:
- If you didn't accept the Python installer's default directory, or if
you did but it's on a different drive, you'll need to change
WIN_PYINSTALLEDDIR in python.mk.
- The main Python DLL must live in WIN_PYINSTALLEDDIR too. Depending on
how you installed Python, that may be sitting in some Windows system
directory instead; if so, make a copy in the root of your Python
installation.
Building Building
-------- --------
...@@ -85,21 +109,44 @@ now required, or the files you've downloaded are not in 'tmp'. ...@@ -85,21 +109,44 @@ now required, or the files you've downloaded are not in 'tmp'.
Testing Zope Testing Zope
------------ ------------
The test suite can be run from inst\build\: XXX This doesn't work right starting with Zope 2.9: it's clumsier than it
XXX should be, and the functional tests don't even try to run (just the
XXX unit tests).
XXX Someone who understands how Zope3 testing from a zpkgtools-tarball build
XXX was made to work again may be able to help here.
The test suite can be run from inst\build\, after building the installer.
- Open a native (not Cygwin) DOS box. We want to test with the Python the - Open a native (not Cygwin) DOS box. We want to test with the Python the
Zope installer includes. Zope installer includes, in an all-native environment, to match what
- cd to inst\build the installer-installed code will do as closely as possible.
- Copy log.ini from the root of the Zope checkout. This isn't necessary for
the tests to pass, but if you don't do it a great many spurious log - cd inst\build
messages will be displayed on the console, some of which "look like"
errors (some of the tests deliberately provoke errors). - Copy log.ini from the root of the Zope _checkout_ -- it's not included
- Enter in the tarball::
bin\python bin\test.py -v --all copy ..\..\log.ini .
Copying log.ini isn't necessary for the tests to pass, but if you don't
do it a great many spurious log messages will be displayed on the
console, some of which "look like" errors (some of the tests deliberately
provoke errors).
- Copy test.py from the unpacked tarball::
copy ..\src\$(ZOPE_VERSION)\test.py .
- Enter::
bin\python test.py -vv -m "!^zope[.]app[.]" --all
or whatever variation you like best. All tests should pass. or whatever variation you like best. All tests should pass.
Note that zope.app tests should be excluded because not all of them _can_
pass (this isn't "a Windows thing", it's a temporary all-platform wart
due to missing bits from Zope3).
Also run the Windows installer, and play with the Zope it installs. Also run the Windows installer, and play with the Zope it installs.
...@@ -116,24 +163,3 @@ All platform notes ...@@ -116,24 +163,3 @@ All platform notes
root of your Cygwin installation -- the same thing the Cygwin shell root of your Cygwin installation -- the same thing the Cygwin shell
desktop shortcut resolves to, so you can get the exact path by looking desktop shortcut resolves to, so you can get the exact path by looking
at the icon's Properties). at the icon's Properties).
Win98SE notes
-------------
- Every time a makefile runs xcopy, there's a segfault in kernel32.dll,
which hangs the bash shell with an endless succession of error boxes.
The only way I found to break out of this was to bring up the debugger,
close it, then type Ctrl+C at the hung bash shell. The bash shell
appears to be fine at that point, but you can never close it (short of
killing it via the task manager).
Same thing if xcopy32 is used instead.
xcopy works OK directly from a bash shell. The segfaults occur if it's
run via a makefile, or via a shell script. Guessing a problem with I/O
redirection, since some other apps can't see keyboard input before the
hung stuff is killed.
Workaround: xxcopy works fine <http://www.xxcopy.com/>; free for
personal use, but not for commercial use. Rename it to xcopy.exe and
get it into your path before the native xcopy, or fiddle the XCOPY
defn in common.mk to use xxcopy instead of xcopy.
cd %1%
set MAKEFLAGS=
nmake build
nmake install
This diff is collapsed.
BASE_DIR=$(shell pwd) # Use immediate assignment to avoid calling out to the shell a zillion times.
WIN_BASE_DIR=$(shell cygpath -w $(BASE_DIR)) BASE_DIR := $(shell pwd)
BUILD_DIR=$(BASE_DIR)/build WIN_BASE_DIR := $(shell cygpath -w $(BASE_DIR))
WIN_BUILD_DIR=$(shell cygpath -w $(BUILD_DIR)) BUILD_DIR := $(BASE_DIR)/build
SRC_DIR=$(BASE_DIR)/src WIN_BUILD_DIR := $(shell cygpath -w $(BUILD_DIR))
WIN_SRC_DIR=$(shell cygpath -w $(SRC_DIR)) SRC_DIR := $(BASE_DIR)/src
TMP_DIR=$(BASE_DIR)/tmp WIN_SRC_DIR := $(shell cygpath -w $(SRC_DIR))
WIN_TMP_DIR=$(shell cygpath -w $(TMP_DIR)) TMP_DIR := $(BASE_DIR)/tmp
WIN_MAKEFILEDIR=$(shell cygpath -w $(MAKEFILEDIR)) WIN_TMP_DIR := $(shell cygpath -w $(TMP_DIR))
WIN_MAKEFILEDIR := $(shell cygpath -w $(MAKEFILEDIR))
# Root of the Windows drive you're working on. The setting here is for # Root of the Windows drive you're working on. The setting here is for
# the C: drive and using a default out-of-the-box Cygwin. # the C: drive and using a default out-of-the-box Cygwin.
...@@ -16,7 +17,17 @@ RM=rm -f ...@@ -16,7 +17,17 @@ RM=rm -f
RMRF=rm -rf RMRF=rm -rf
CD=cd CD=cd
XCOPY=xcopy /i /s /e /y # xcopy args:
# /i = if dest doesn't exist and source has more than one file, assume
# dest shoud be a directory
# /y = don't prompt about overwriting dest if it exists -- just do it
# /s = recurse, copying non-empty subdirectories too
# CAUTION: don't use /e unless you have to! /e copies empty subdirectories
# too, but has another truly bizarre behavior: if you use xcopy to copy
# a single file, and use /e, it creates empty subdirectories in the target's
# directory with the same names as the subdirectories in the source's
# directory. This is worse than useless.
XCOPY=xcopy /i /s /y
CPR=cp -r CPR=cp -r
CP=cp CP=cp
...@@ -26,9 +37,10 @@ TAR=tar ...@@ -26,9 +37,10 @@ TAR=tar
SED=sed SED=sed
TOUCH=touch TOUCH=touch
NMAKE=nmake NMAKE=nmake
CURL=curl -N
CSCRIPT=cscript CSCRIPT=cscript
ECHO=echo ECHO=echo
ISS_DIR=$(CYGROOT)/Progra~1/Inno Setup 4 ISS_DIR=$(CYGROOT)/Progra~1/Inno Setup 5
ISS_COMPILER=$(ISS_DIR)/Compil32.exe ISS_COMPILER=$(ISS_DIR)/Compil32.exe
# We need a version that understands cygwin paths, so /bin/ # We need a version that understands cygwin paths, so /bin/
UNZIP=/bin/unzip UNZIP=/bin/unzip
...@@ -63,4 +75,4 @@ define COPY_AND_WINDOWIZE_LINEENDS ...@@ -63,4 +75,4 @@ define COPY_AND_WINDOWIZE_LINEENDS
$(CP) $< $@ $(CP) $< $@
unix2dos $@ unix2dos $@
$(TOUCH) $@ $(TOUCH) $@
endef endef
\ No newline at end of file
# The Python and pywin32 versions. For Python, both the source tarball # The Python and pywin32 versions.
# and the Windows installer must be in tmp/. For pywin32 (previously known
# as win32all), the Windows installer must be in tmp/. Nothing beyond those
# is required to build Python, and you don't even need a compiler.
PYVERSION_MAJOR=2
PYVERSION_MINOR=3
PYVERSION_PATCH=5
PYVERSION=$(PYVERSION_MAJOR).$(PYVERSION_MINOR).$(PYVERSION_PATCH)
W32ALLVERSION=205
# CAUTION: Extracting files from Wise installers doesn't really do what
# you expect. While a Wise installer is a zip file, the zip file
# structure is flat (Wise reconstructs the intended directory structure
# from metadata stored in proprietary FILEnnnn.DAT files also in the
# zip file). Consequently, the package structure of Python packages is
# lost, and if there's more than one file with the same name, you only
# get "the last one" to be extracted (all files are extracted to the
# same directory).
# #
# For Python, this doesn't matter, because we're only sucking out the # For Python, the source tarball must be in tmp/. You must also install the
# precompiled .pyd and .exe files from the Python installer -- there # appropriate Python on Windows, and set WIN_PYINSTALLEDDIR here to its root
# are no name clashes in that set, and it's a pretty safe bet there never # directory. A copy of the main Python DLL must also be in the root (you
# will be (else Python wouldn't be able to decide which to use!). We # may need to copy it from your Windows system directory). Earlier versions
# use the Python source tarball to get all the non-executable parts we # of this extracted .dll, .exe, and .pyd files from Python's Wise installer,
# need. # but Python 2.4 uses an .msi installer, and there doesn't appear to be a
# way to _just_ extract files from one of those.
# #
# pywin32 doesn't have this problem as it now uses # For pywin32 (previously known as win32all), the Windows installer must be
# a standard distutils 'bdist_wininst' installation .exe. These executables are # in tmp/.
# valid .zip files with a "PLATLIB" directory being the complete directory #
# structure as installed into "site-packages". These recent pywin32 builds have # Nothing beyond those is required to build Python, and you don't even need
# no dependencies on registry settings etc so will work directly as copied out of # a compiler.
# the .exe. The only concerns are the pywintypes/pythoncom dlls, which is PYVERSION_MAJOR := 2
# handled by the Inno installer PYVERSION_MINOR := 4
PYVERSION_PATCH := 2
PYDIRNAME=Python-$(PYVERSION) W32ALLVERSION := 205
# Standard bdist_wininst name - eg: pywin32-203.win32-py2.3[.exe]
W32ALLDIRNAME=pywin32-$(W32ALLVERSION).win32-py$(PYVERSION_MAJOR).$(PYVERSION_MINOR) PYVERSION := $(PYVERSION_MAJOR).$(PYVERSION_MINOR).$(PYVERSION_PATCH)
W32EXCLUDE=*.chm
PYMAJORMINOR := python$(PYVERSION_MAJOR)$(PYVERSION_MINOR)
# This is the default directory into which a Python installs.
WIN_PYINSTALLEDDIR := \$(PYMAJORMINOR)
# pywin32 now uses a standard distutils 'bdist_wininst' installation .exe.
# These executables are valid .zip files with a "PLATLIB" directory being
# the complete directory structure as installed into "site-packages". These
# recent pywin32 builds have no dependencies on registry settings etc so
# will work directly as copied out of the .exe. The only concerns are the
# pywintypes/pythoncom dlls, which are handled by the Inno installer.
PYDIRNAME := Python-$(PYVERSION)
# Standard bdist_wininst name - eg: pywin32-203.win32-py2.3
W32ALLDIRNAME := pywin32-$(W32ALLVERSION).win32-py$(PYVERSION_MAJOR).$(PYVERSION_MINOR)
W32EXCLUDE := *.chm
# The Python tarball is extracted to PYSRCDIR. # The Python tarball is extracted to PYSRCDIR.
# The contents of the Python installer get extracted to PYEXTRACTDIR. # pywin32 is extracted to W32EXTRACTDIR.
# The " " " win32all " " " " W32EXTRACTDIR. PYSRCDIR := $(BASE_DIR)/src/$(PYDIRNAME)
PYSRCDIR=$(BASE_DIR)/src/$(PYDIRNAME) W32EXTRACTDIR := $(BASE_DIR)/src/$(W32ALLDIRNAME)
PYEXTRACTDIR=$(BASE_DIR)/src/$(PYDIRNAME)-extract
W32EXTRACTDIR=$(BASE_DIR)/src/$(W32ALLDIRNAME)
WIN_PYSRCDIR=$(shell cygpath -w $(PYSRCDIR)) WIN_PYSRCDIR := $(shell cygpath -w $(PYSRCDIR))
WIN_PYEXTRACTDIR=$(shell cygpath -w $(PYEXTRACTDIR)) WIN_W32EXTRACTDIR := $(shell cygpath -w $(W32EXTRACTDIR))
WIN_W32EXTRACTDIR=$(shell cygpath -w $(W32EXTRACTDIR))
PYTHON_REQUIRED_FILES=tmp/$(W32ALLDIRNAME).exe \ PYTHON_REQUIRED_FILES := tmp/$(W32ALLDIRNAME).exe \
tmp/$(PYDIRNAME).tgz \ tmp/$(PYDIRNAME).tgz
tmp/$(PYDIRNAME).exe
# Arbitrary files from each of the installers and tarballs, to use as # Arbitrary files from each of the installers and tarballs, to use as
# targets to force them to get unpacked. # targets to force them to get unpacked.
ARB_PYSRCDIR=$(PYSRCDIR)/PCbuild/pcbuild.dsw ARB_PYSRCDIR := $(PYSRCDIR)/PCbuild/pcbuild.dsw
ARB_PYEXTRACTDIR=$(PYEXTRACTDIR)/zlib.pyd ARB_W32EXTRACTDIR := $(W32EXTRACTDIR)/PLATLIB
ARB_W32EXTRACTDIR=$(W32EXTRACTDIR)/PLATLIB
# Building Python just consists of extracting files. # Building Python just consists of extracting files.
build_python: $(ARB_PYSRCDIR) $(ARB_PYEXTRACTDIR) $(ARB_W32EXTRACTDIR) build_python: $(ARB_PYSRCDIR) $(ARB_W32EXTRACTDIR)
# Installing Python consists of copying oodles of files into # Installing Python consists of copying oodles of files into
# $(BUILD_DIR). # $(BUILD_DIR).
...@@ -67,21 +62,27 @@ install_python: $(BUILD_DIR)/bin/python.exe ...@@ -67,21 +62,27 @@ install_python: $(BUILD_DIR)/bin/python.exe
clean_python: clean_python:
$(RMRF) $(PYSRCDIR) $(RMRF) $(PYSRCDIR)
$(RMRF) $(PYEXTRACTDIR)
clean_libs: clean_libs:
$(RMRF) $(W32EXTRACTDIR) $(RMRF) $(W32EXTRACTDIR)
# Fetch dependencies
tmp:
$(MKDIR) tmp
tmp/$(W32ALLDIRNAME).exe: tmp
$(CURL) -o tmp/$(W32ALLDIRNAME).exe http://easynews.dl.sourceforge.net/sourceforge/pywin32/$(W32ALLDIRNAME).exe
$(TOUCH) tmp/$(W32ALLDIRNAME).exe
tmp/$(PYDIRNAME).tgz: tmp
$(CURL) -o tmp/$(PYDIRNAME).tgz http://python.org/ftp/python/$(PYVERSION)/$(PYDIRNAME).tgz
$(TOUCH) tmp/$(PYDIRNAME).tgz
$(ARB_PYSRCDIR): tmp/$(PYDIRNAME).tgz $(ARB_PYSRCDIR): tmp/$(PYDIRNAME).tgz
$(MKDIR) "$(SRC_DIR)" $(MKDIR) "$(SRC_DIR)"
$(CD) "$(SRC_DIR)" && $(TAR) xvzf ../tmp/$(PYDIRNAME).tgz $(CD) "$(SRC_DIR)" && $(TAR) xvzf ../tmp/$(PYDIRNAME).tgz
$(TOUCH) "$(ARB_PYSRCDIR)" $(TOUCH) "$(ARB_PYSRCDIR)"
$(ARB_PYEXTRACTDIR): tmp/$(PYDIRNAME).exe
$(MKDIR) "$(PYEXTRACTDIR)"
"tmp/$(PYDIRNAME).exe" /S /X "$(WIN_PYEXTRACTDIR)"
$(TOUCH) "$(ARB_PYEXTRACTDIR)"
# unzip warns about .exe not being exactly a .zip, then succeeds in # unzip warns about .exe not being exactly a .zip, then succeeds in
# extracting the files, then returns with exit != 0 - ignore exit code # extracting the files, then returns with exit != 0 - ignore exit code
$(ARB_W32EXTRACTDIR): tmp/$(W32ALLDIRNAME).exe $(ARB_W32EXTRACTDIR): tmp/$(W32ALLDIRNAME).exe
...@@ -96,9 +97,8 @@ $(BUILD_DIR)/bin/python.exe: ...@@ -96,9 +97,8 @@ $(BUILD_DIR)/bin/python.exe:
$(CP) "$(MAKEFILEDIR)/doc/ZC_PY_DIST_README.txt" "$(BUILD_DIR)/doc" $(CP) "$(MAKEFILEDIR)/doc/ZC_PY_DIST_README.txt" "$(BUILD_DIR)/doc"
$(CP) "$(PYSRCDIR)/LICENSE" "$(BUILD_DIR)/doc/PYTHON_LICENSE.txt" $(CP) "$(PYSRCDIR)/LICENSE" "$(BUILD_DIR)/doc/PYTHON_LICENSE.txt"
unix2dos "$(BUILD_DIR)/doc/PYTHON_LICENSE.txt" unix2dos "$(BUILD_DIR)/doc/PYTHON_LICENSE.txt"
$(CP) "$(SRC_DIR)/$(W32ALLDIRNAME)/PLATLIB/pythonwin/License.txt" \
$(MKDIR) "$(BUILD_DIR)/bin/DLLs" "$(BUILD_DIR)/doc/PYWIN32_LICENSE.txt"
$(XCOPY) "$(WIN_PYEXTRACTDIR)\*.pyd" "$(WIN_BUILD_DIR)\bin\DLLs"
$(MKDIR) "$(BUILD_DIR)/bin/Lib" $(MKDIR) "$(BUILD_DIR)/bin/Lib"
$(XCOPY) "$(WIN_PYSRCDIR)\Lib\*.py" "$(WIN_BUILD_DIR)\bin\Lib" $(XCOPY) "$(WIN_PYSRCDIR)\Lib\*.py" "$(WIN_BUILD_DIR)\bin\Lib"
...@@ -115,13 +115,17 @@ $(BUILD_DIR)/bin/python.exe: ...@@ -115,13 +115,17 @@ $(BUILD_DIR)/bin/python.exe:
$(XCOPY) "$(WIN_PYSRCDIR)\Include\*.h" "$(WIN_BUILD_DIR)\bin\Include" $(XCOPY) "$(WIN_PYSRCDIR)\Include\*.h" "$(WIN_BUILD_DIR)\bin\Include"
$(XCOPY) "$(WIN_PYSRCDIR)\PC\*.h" "$(WIN_BUILD_DIR)\bin\Include" $(XCOPY) "$(WIN_PYSRCDIR)\PC\*.h" "$(WIN_BUILD_DIR)\bin\Include"
$(MKDIR) "$(BUILD_DIR)/bin"
$(MKDIR) "$(BUILD_DIR)/bin/libs" $(MKDIR) "$(BUILD_DIR)/bin/libs"
$(CP) "$(PYEXTRACTDIR)/python23.lib" "$(BUILD_DIR)/bin/libs" $(MKDIR) "$(BUILD_DIR)/bin/DLLs"
$(XCOPY) "$(WIN_PYINSTALLEDDIR)\python.exe" "$(WIN_BUILD_DIR)\bin"
$(XCOPY) "$(WIN_PYINSTALLEDDIR)\pythonw.exe" "$(WIN_BUILD_DIR)\bin"
$(XCOPY) "$(WIN_PYINSTALLEDDIR)\w9xpopen.exe" "$(WIN_BUILD_DIR)\bin"
$(XCOPY) "$(WIN_PYINSTALLEDDIR)\$(PYMAJORMINOR).dll" \
"$(WIN_BUILD_DIR)\bin"
$(XCOPY) "$(WIN_MAKEFILEDIR)\bin\msvcr71.dll" "$(WIN_BUILD_DIR)\bin"
$(XCOPY) "$(WIN_PYINSTALLEDDIR)\libs" "$(WIN_BUILD_DIR)\bin\libs"
$(XCOPY) "$(WIN_PYINSTALLEDDIR)\DLLs\*.pyd" \
"$(WIN_BUILD_DIR)\bin\DLLs"
$(MKDIR) "$(BUILD_DIR)/bin"
$(CP) "$(PYEXTRACTDIR)/pythonw.exe" "$(BUILD_DIR)/bin"
$(CP) "$(PYEXTRACTDIR)/w9xpopen.exe" "$(BUILD_DIR)/bin"
$(CP) "$(PYEXTRACTDIR)/python23.dll" "$(BUILD_DIR)/bin"
$(CP) "$(PYEXTRACTDIR)/python.exe" "$(BUILD_DIR)/bin"
$(TOUCH) "$(BUILD_DIR)/bin/python.exe" $(TOUCH) "$(BUILD_DIR)/bin/python.exe"
ZOPEVERSION := 2.9.0
ZOPEDIRNAME := Zope-$(ZOPEVERSION)
ZOPE_REQUIRED_FILES=tmp/$(ZOPEDIRNAME).tgz ZOPE_REQUIRED_FILES=tmp/$(ZOPEDIRNAME).tgz
REQUIRED_FILES=$(PYTHON_REQUIRED_FILES)\ REQUIRED_FILES=$(PYTHON_REQUIRED_FILES)\
$(ZOPE_REQUIRED_FILES) $(ZOPE_REQUIRED_FILES)
ZOPEVERSION=2.9.0-final
ZOPEDIRNAME=Zope-$(ZOPEVERSION)
MAKEZOPE="$(MAKEFILEDIR)/bin/makezope.bat" "$(WIN_BUILD_DIR)"
# run the Zope tests
test_zope:
$(CD) "$(BASE_DIR)/src/Zope"
"$(PYPCBUILDDIR)/python.exe" utilities/testrunner.py -a
$(CD) "$(BASE_DIR)"
clean_zope: clean_zope:
$(RMRF) src/$(ZOPEDIRNAME) $(RMRF) src/$(ZOPEDIRNAME)
install_zope: src/$(ZOPEDIRNAME)/inst/configure.py \ install_zope: src/$(ZOPEDIRNAME)/install.py \
$(BUILD_DIR)/lib/python/version.txt install_python \ install_python \
$(BUILD_DIR)/lib/python/Zope2/version.txt \
$(BUILD_DIR)/Zope-$(ZOPEVERSION)-win32.exe $(BUILD_DIR)/Zope-$(ZOPEVERSION)-win32.exe
ESCAPED=$(shell sh $(MAKEFILEDIR)/bin/escape.sh '$(WIN_MAKEFILEDIR)') ESCAPED=$(shell sh $(MAKEFILEDIR)/bin/escape.sh '$(WIN_MAKEFILEDIR)')
SEDSCRIPT="s@<<VERSION>>@$(ZOPEVERSION)@g;s@<<MAKEFILEDIR>>@$(ESCAPED)@g" SEDSCRIPT="s@<<VERSION>>@$(ZOPEVERSION)@g;s@<<MAKEFILEDIR>>@$(ESCAPED)@g"
$(BUILD_DIR)/Zope-$(ZOPEVERSION)-win32.exe: $(BUILD_DIR)/lib/python/version.txt $(BUILD_DIR)/Zope-$(ZOPEVERSION)-win32.exe: $(BUILD_DIR)/lib/python/Zope2/version.txt
$(SED) $(SEDSCRIPT) < "$(MAKEFILEDIR)/etc/zope.iss.in" | unix2dos > "$(BUILD_DIR)/zope.iss" $(SED) $(SEDSCRIPT) < "$(MAKEFILEDIR)/etc/zope.iss.in" | unix2dos > "$(BUILD_DIR)/zope.iss"
# Remove CVS directories from the build tree. # Remove CVS directories and compiled Python files from the build tree.
find $(BUILD_DIR) -name CVS -type d -exec $(RMRF) {} \; -prune find $(BUILD_DIR) -name CVS -type d -exec $(RMRF) {} \; -prune
find $(BUILD_DIR) -name "*.pyc" -o -name "*.pyo" | xargs $(RM)
# Convert text files to Windows line ends. unix2dos has the nice # Convert text files to Windows line ends. unix2dos has the nice
# property that it leaves lines with \r\n alone, so it doesn't hurt # property that it leaves lines with \r\n alone, so it doesn't hurt
# to do this on files already converted to Windows convention. # to do this on files already converted to Windows convention.
find $(BUILD_DIR) -name "*.py" -o -name "*.txt" -o -name "*.bat" | \ find $(BUILD_DIR) -name "*.bat" | xargs unix2dos
xargs unix2dos find $(BUILD_DIR) -name "*.conf" | xargs unix2dos
find $(BUILD_DIR) -name "*.html" | xargs unix2dos
find $(BUILD_DIR) -name "*.in" | xargs unix2dos
find $(BUILD_DIR) -name "*.py" | xargs unix2dos
find $(BUILD_DIR) -name "*.stx" | xargs unix2dos
find $(BUILD_DIR) -name "*.txt" | xargs unix2dos
find $(BUILD_DIR) -name "*.xml" | xargs unix2dos
find $(BUILD_DIR) -name "*.zcml" | xargs unix2dos
# Build the Inno installer. # Build the Inno installer.
$(CD) "$(BUILD_DIR)";"$(ISS_COMPILER)" /cc "$(WIN_BUILD_DIR)\zope.iss" $(CD) "$(BUILD_DIR)";"$(ISS_COMPILER)" /cc "$(WIN_BUILD_DIR)\zope.iss"
$(BUILD_DIR)/lib/python/Zope2/Startup/run.py: # This builds Zope, then installs it into the build directory, then
$(CD) "$(BUILD_DIR)"; \ # creates lib/python/Zope2/version.txt in the build directory.
bin/python.exe \ #
"$(WIN_SRC_DIR)\$(ZOPEDIRNAME)\inst\configure.py" \ # Yuck: for whatever reason, distutils refuses to allow an absolute
--prefix="$(WIN_BUILD_DIR)" --no-compile # path for the --home option, so this hardcodes "build" as the name of
$(MAKEZOPE) # the build directory, and assumes "build" is a sibling of SRC_DIR.
$(TOUCH) "$(BUILD_DIR)/lib/python/Zope2/Startup/run.py" #
# Yuck: the --no-compile option here has no effect: the install step
# creates oodles of unwanted .pyc files. They're removed by the
# $(BUILD_DIR)/Zope-$(ZOPEVERSION)-win32.exe target, though, before
# building the installer.
#
# Yuck: no matter what I pass to --install-headers, it throws away the
# last path component. We actually want to copy the Zope/ZODB headers
# into bin/Include. The "nonsense" at the end gets thrown away, and that
# smells like a bug. When it gets fixed, I suppose this will copy the
# headers to bin/Include/nonsense/.
$(BUILD_DIR)/lib/python/Zope2/version.txt: $(BUILD_DIR)/bin/python.exe
cd "$(SRC_DIR)/$(ZOPEDIRNAME)" && \
"$<" install.py install --no-compile --home=../../build \
--install-headers=../../build/bin/Include/nonsense
echo Zope $(ZOPEVERSION) > $@
$(TOUCH) $@
$(BUILD_DIR)/lib/python/version.txt: $(BUILD_DIR)/lib/python/Zope2/Startup/run.py tmp/$(ZOPEDIRNAME).tgz:
@echo Zope $(ZOPEVERSION) > "$(BUILD_DIR)/lib/python/version.txt" $(CURL) -o tmp/$(ZOPEDIRNAME).tgz http://www.zope.org/Products/Zope/$(ZOPEVERSION)/$(ZOPEDIRNAME).tgz
$(TOUCH) "$(BUILD_DIR)/lib/python/version.txt" $(TOUCH) tmp/$(ZOPEDIRNAME).tgz
src/$(ZOPEDIRNAME)/inst/configure.py: # This merely unpacks the Zope tarball.
src/$(ZOPEDIRNAME)/install.py: tmp/$(ZOPEDIRNAME).tgz
$(MKDIR) "$(SRC_DIR)" $(MKDIR) "$(SRC_DIR)"
$(CD) "$(SRC_DIR)" && $(TAR) xvzf ../tmp/$(ZOPEDIRNAME).tgz \ $(CD) "$(SRC_DIR)" && $(TAR) xvzf ../tmp/$(ZOPEDIRNAME).tgz
&& $(TOUCH) $(ZOPEDIRNAME)/inst/configure.py
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment