aboutsummaryrefslogtreecommitdiff
path: root/Buildscr
diff options
context:
space:
mode:
authorSimon Tatham <anakin@pobox.com>2017-08-24 19:12:54 +0100
committerSimon Tatham <anakin@pobox.com>2017-08-24 20:07:20 +0100
commit9d89550a75393723c5937559fa86a434de4a77f0 (patch)
tree5a51e061a6f881ef4b604f3af9b34e55620c3bb7 /Buildscr
parentbfd02e0e475ceaa8ea659c136c1e24ee95c1f3fc (diff)
downloadpuzzles-9d89550a75393723c5937559fa86a434de4a77f0.zip
puzzles-9d89550a75393723c5937559fa86a434de4a77f0.tar.gz
puzzles-9d89550a75393723c5937559fa86a434de4a77f0.tar.bz2
puzzles-9d89550a75393723c5937559fa86a434de4a77f0.tar.xz
Switch the Windows builds over to clang-cl.
This also switches them to being 64-bit, which I think is probably acceptable in this modern age, especially for such a non-essential piece of software. If anyone complains I can always reinstate a parallel 32-bit build. To support the switch to 64-bit, this commit also changes the default install directory in the MSI to 'Program Files' rather than 'Program Files (x86)'.
Diffstat (limited to 'Buildscr')
-rw-r--r--Buildscr28
1 files changed, 18 insertions, 10 deletions
diff --git a/Buildscr b/Buildscr
index b548f9b..d661502 100644
--- a/Buildscr
+++ b/Buildscr
@@ -54,22 +54,30 @@ in puzzles do make -f Makefile.doc clean
in puzzles do make -f Makefile.doc # build help files for installer
in puzzles do mason.pl --args '{"version":"$(Version)","descfile":"gamedesc.txt"}' winwix.mc > puzzles.wxs
in puzzles do perl winiss.pl $(Version) gamedesc.txt > puzzles.iss
-delegate windows
- # FIXME: Cygwin alternative?
- in puzzles with visualstudio do/win nmake -f Makefile.vc clean
- in puzzles with visualstudio do/win nmake -f Makefile.vc VER=-DVER=$(Version)
+ifneq "$(VISUAL_STUDIO)" "yes" then
+ in puzzles with clangcl64 do Platform=x64 make -f Makefile.clangcl clean
+ in puzzles with clangcl64 do Platform=x64 make -f Makefile.clangcl VER=-DVER=$(Version)
# Code-sign the binaries, if the local bob config provides a script
# to do so. We assume here that the script accepts an -i option to
# provide a 'more info' URL, and an optional -n option to provide a
# program name, and that it can take multiple .exe filename
# arguments and sign them all in place.
- ifneq "$(winsigncode)" "" in puzzles do $(winsigncode) -i https://www.chiark.greenend.org.uk/~sgtatham/puzzles/ *.exe
+ ifneq "$(cross_winsigncode)" "" in puzzles do $(cross_winsigncode) -i https://www.chiark.greenend.org.uk/~sgtatham/puzzles/ *.exe
# Build installers.
- in puzzles with wix do/win candle puzzles.wxs && light -ext WixUIExtension -sval puzzles.wixobj
- ifneq "$(winsigncode)" "" in puzzles do $(winsigncode) -i https://www.chiark.greenend.org.uk/~sgtatham/puzzles/ -n "Simon Tatham's Portable Puzzle Collection Installer" puzzles.msi Output/installer.exe
- return puzzles/*.exe
- return puzzles/puzzles.msi
-enddelegate
+ in puzzles with wixonlinux do candle -arch x64 puzzles.wxs && light -ext WixUIExtension -sval puzzles.wixobj
+ ifneq "$(cross_winsigncode)" "" in puzzles do $(cross_winsigncode) -i https://www.chiark.greenend.org.uk/~sgtatham/puzzles/ -n "Simon Tatham's Portable Puzzle Collection Installer" puzzles.msi
+else
+ delegate windows
+ in puzzles with visualstudio do/win nmake -f Makefile.vc clean
+ in puzzles with visualstudio do/win nmake -f Makefile.vc VER=-DVER=$(Version)
+ ifneq "$(winsigncode)" "" in puzzles do $(winsigncode) -i https://www.chiark.greenend.org.uk/~sgtatham/puzzles/ *.exe
+ # Build installers.
+ in puzzles with wix do/win candle puzzles.wxs && light -ext WixUIExtension -sval puzzles.wixobj
+ in puzzles with innosetup do/win iscc puzzles.iss
+ return puzzles/*.exe
+ return puzzles/puzzles.msi
+ enddelegate
+endif
in puzzles do chmod +x *.exe
# Build the Pocket PC binaries and CAB.