mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
4d8782e74f
I've shifted away from using the SVN revision number as a monotonic version identifier (replacing it in the Windows version resource with a count of days since an arbitrary epoch), and I've removed all uses of SVN keyword expansion (replacing them with version information written out by Buildscr). While I'm at it, I've done a major rewrite of the affected code which centralises all the computation of the assorted version numbers and strings into Buildscr, so that they're all more or less alongside each other rather than scattered across multiple source files. I've also retired the MD5-based manifest file system. A long time ago, it seemed like a good idea to arrange that binaries of PuTTY would automatically cease to identify themselves as a particular upstream version number if any changes were made to the source code, so that if someone made a local tweak and distributed the result then I wouldn't get blamed for the results. Since then I've decided the whole idea is more trouble than it's worth, so now distribution tarballs will have version information baked in and people can just cope with that. [originally from svn r10262]
76 lines
2.2 KiB
Makefile
76 lines
2.2 KiB
Makefile
all: man index.html
|
|
|
|
# Decide on the versionid policy.
|
|
#
|
|
# If the user has passed in $(VERSION) on the command line (`make
|
|
# VERSION="Release 0.56"'), we use that as an explicit version string.
|
|
# Otherwise, we use `svnversion' to examine the checked-out
|
|
# documentation source, and if that returns a single revision number
|
|
# then we invent a version string reflecting just that number. Failing
|
|
# _that_, we resort to versionids.but which gives 'version
|
|
# unavailable'.
|
|
#
|
|
# So here, we define VERSION using svnversion if it isn't already
|
|
# defined ...
|
|
ifndef VERSION
|
|
SVNVERSION=$(shell test -d .svn && svnversion .)
|
|
BADCHARS=$(findstring :,$(SVNVERSION))$(findstring S,$(SVNVERSION))
|
|
ifeq ($(BADCHARS),)
|
|
ifneq ($(SVNVERSION),)
|
|
ifneq ($(SVNVERSION),exported)
|
|
VERSION=Built from revision $(patsubst M,,$(SVNVERSION))
|
|
endif
|
|
endif
|
|
endif
|
|
endif
|
|
# ... and now, we condition our build behaviour on whether or not
|
|
# VERSION _is_ defined.
|
|
ifdef VERSION
|
|
VERSIONIDS=vstr
|
|
vstr.but: FORCE
|
|
printf '\\versionid $(VERSION)\n' > vstr.but
|
|
FORCE:;
|
|
else
|
|
VERSIONIDS=vids
|
|
endif
|
|
|
|
CHAPTERS := $(SITE) blurb intro gs using config pscp psftp plink pubkey
|
|
CHAPTERS += pageant errors faq feedback licence udp pgpkeys sshnames
|
|
CHAPTERS += index $(VERSIONIDS)
|
|
|
|
INPUTS = $(patsubst %,%.but,$(CHAPTERS))
|
|
|
|
# This is temporary. Hack it locally or something.
|
|
HALIBUT = halibut
|
|
|
|
index.html: $(INPUTS)
|
|
$(HALIBUT) --text --html --winhelp $(INPUTS)
|
|
|
|
# During formal builds it's useful to be able to build this one alone.
|
|
putty.hlp: $(INPUTS)
|
|
$(HALIBUT) --winhelp $(INPUTS)
|
|
|
|
putty.info: $(INPUTS)
|
|
$(HALIBUT) --info $(INPUTS)
|
|
|
|
chm: putty.hhp
|
|
putty.hhp: $(INPUTS) chm.but
|
|
$(HALIBUT) --html $(INPUTS) chm.but
|
|
|
|
MKMAN = $(HALIBUT) --man=$@ mancfg.but $<
|
|
MANPAGES = putty.1 puttygen.1 plink.1 pscp.1 psftp.1 puttytel.1 pterm.1
|
|
man: $(MANPAGES)
|
|
|
|
putty.1: man-putt.but mancfg.but; $(MKMAN)
|
|
puttygen.1: man-pg.but mancfg.but; $(MKMAN)
|
|
plink.1: man-pl.but mancfg.but; $(MKMAN)
|
|
pscp.1: man-pscp.but mancfg.but; $(MKMAN)
|
|
psftp.1: man-psft.but mancfg.but; $(MKMAN)
|
|
puttytel.1: man-ptel.but mancfg.but; $(MKMAN)
|
|
pterm.1: man-pter.but mancfg.but; $(MKMAN)
|
|
|
|
mostlyclean:
|
|
rm -f *.html *.txt *.hlp *.cnt *.1 *.info vstr.but *.hh[pck]
|
|
clean: mostlyclean
|
|
rm -f *.chm
|