From ab795ba00889e6f1c9dc57b053d14ddf6bbc5fee Mon Sep 17 00:00:00 2001 From: Simon Tatham Date: Sun, 4 Feb 2007 12:30:39 +0000 Subject: [PATCH] Version management updates for the new bob build script. There's now a fourth class of PuTTY version tags in addition to release, snapshot and unidentified: we now have `Custom build r1234', indicating a build made from that SVN revision in a context other than that of a dated snapshot. The build script generates these when it doesn't know what else to do; `unidentified builds' will now only occur when you run nmake from the command line. Also, the build script now generates sensible version data in the installer to match this. So I _think_ we should now be set to use bob to generate installer builds of the nightly snapshots, although of course I'll have to wait until tomorrow to test one. [originally from svn r7211] --- Buildscr | 36 ++++++++++++++++++++++++++++-------- version.c | 5 +++++ windows/version.rc2 | 5 +++++ 3 files changed, 38 insertions(+), 8 deletions(-) diff --git a/Buildscr b/Buildscr index 4681dc52..90b66aab 100644 --- a/Buildscr +++ b/Buildscr @@ -2,28 +2,48 @@ # Build script to construct a full distribution directory of PuTTY. # Set up the arguments for the main make command. -set Makeargs -ifneq "$(RELEASE)" "" set Makeargs VER="-DRELEASE=$(RELEASE)" -ifneq "$(SNAPSHOT)" "" set Makeargs VER="-DSNAPSHOT=$(SNAPSHOT)" +set Makeargs VER="-DSVN_REV=$(revision)" +ifneq "$(RELEASE)" "" set Makeargs $(Makeargs) VER="-DRELEASE=$(RELEASE)" +ifneq "$(date)" "" set Makeargs $(Makeargs) VER="-DSNAPSHOT=$(date)" ifneq "$(XFLAGS)" "" set Makeargs $(makeargs) XFLAGS="$(XFLAGS)" ifneq "$(MAKEARGS)" "" set Makeargs $(makeargs) $(MAKEARGS) # Set up the version string for the docs build. -set Docmakeargs +set Docmakeargs VERSION="PuTTY revision $(revision)" ifneq "$(RELEASE)" "" set Docmakeargs VERSION="PuTTY release $(RELEASE)" -ifneq "$(SNAPSHOT)" "" set Docmakeaargs VERSION="PuTTY development snapshot $(SNAPSHOT)" +ifneq "$(date)" "" set Docmakeaargs VERSION="PuTTY development snapshot $(date)" + +# Set up the various version strings for the installer. +set Iversion r$(revision) +set Iname PuTTY revision $(revision) +set Ivertext Revision $(revision) +set Irev $(revision) +ifneq "$(RELEASE)" "" set Iversion $(RELEASE) +ifneq "$(RELEASE)" "" set Iname PuTTY version $(RELEASE) +ifneq "$(RELEASE)" "" set Ivertext Release $(RELEASE) +ifneq "$(RELEASE)" "" set Irev +ifneq "$(date)" "" set Iversion $(date):r$(revision) +ifneq "$(date)" "" set Iname PuTTY development snapshot $(date):r$(revision) +ifneq "$(date)" "" set Ivertext Development snapshot $(date):r$(revision) # Set up the version string for the installer. -set Iversion +set Iversion r$(revision) ifneq "$(RELEASE)" "" set Iversion $(RELEASE) -ifneq "$(SNAPSHOT)" "" set Iversion $(SNAPSHOT) -# FIXME: what about the static version numbers in putty.iss? +ifneq "$(date)" "" set Iversion $(date):r$(revision) in putty do ./mksrcarc.sh in putty do ./mkunxarc.sh $(RELEASE) in putty do perl mkfiles.pl in putty/doc do make $(Docmakeargs) putty.hlp in putty/doc do make $(Docmakeargs) chm + +# Munge the installer script locally so that it reports the version +# we're really building. +in putty/windows do perl -i~ -pe 'BEGIN{$$a=shift@ARGV;}s/^(AppVerName=).*$$/$$1$$a/' '$(Iname)' putty.iss +in putty/windows do perl -i~ -pe 'BEGIN{$$a=shift@ARGV;}s/^(VersionInfoTextVersion=).*$$/$$1$$a/' '$(Ivertext)' putty.iss +in putty/windows do perl -i~ -pe 'BEGIN{$$a=shift@ARGV;}s/^(AppVersion=).*$$/$$1$$a/' '$(Iversion)' putty.iss +in putty/windows do perl -i~ -pe 'BEGIN{$$a=shift@ARGV;$$a=~s/M//;}s/^(VersionInfoVersion=\d+\.\d+\.)\d+(\.\d+)\r?$$/$$1$$a$$2/' '$(Irev)' putty.iss + delegate windows # FIXME: Cygwin alternative? in putty/windows do cmd /c 'vcvars32 & nmake -f Makefile.vc $(Makeargs)' diff --git a/version.c b/version.c index da7e11ca..de658677 100644 --- a/version.c +++ b/version.c @@ -23,6 +23,11 @@ char sshver[] = "PuTTY-Snapshot-" SNAPSHOT_TEXT; char ver[] = "Release " STR(RELEASE); char sshver[] = "PuTTY-Release-" STR(RELEASE); +#elif defined SVN_REV + +char ver[] = "Custom build r" STR(SVN_REV); +char sshver[] = "PuTTY-Custom-r" STR(SVN_REV); + #else char ver[] = "Unidentified build, " __DATE__ " " __TIME__; diff --git a/windows/version.rc2 b/windows/version.rc2 index 8d478722..5bac1ca8 100644 --- a/windows/version.rc2 +++ b/windows/version.rc2 @@ -57,6 +57,11 @@ #define VERSION_TEXT "Release " STR(RELEASE) #define BINARY_VERSION BASE_VERSION,0,0 +#elif defined SVN_REV + +#define VERSION_TEXT "Custom build r" STR(SVN_REV) +#define BINARY_VERSION BASE_VERSION,SVN_REV,0 + #else /* We can't reliably get the same date and time as version.c, so