X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?p=secnet.git;a=blobdiff_plain;f=Makefile.in;h=9884dcd1f0d7d22633b8bd1ece2807597ef1615e;hp=20acdc2b74cdd781f27d4a705c6520e1cd6418a6;hb=27ee084e0b458c71d27c48402e4d62dfbf4a83bf;hpb=74f8576263cf0efb6c8157d47d7aadea90e9b21a diff --git a/Makefile.in b/Makefile.in index 20acdc2..9884dcd 100644 --- a/Makefile.in +++ b/Makefile.in @@ -18,7 +18,7 @@ .PHONY: all clean realclean distclean dist install PACKAGE:=secnet -VERSION:=0.3.0~beta3 +VERSION:=0.3.2~beta1 @SET_MAKE@ @@ -32,11 +32,11 @@ INSTALL:=@INSTALL@ INSTALL_PROGRAM:=@INSTALL_PROGRAM@ CFLAGS:=-Wall @WRITESTRINGS@ @CFLAGS@ -Werror \ - -W -Wno-unused \ + -W -Wno-unused -Wno-unused-parameter \ -Wno-pointer-sign -Wstrict-prototypes -Wmissing-prototypes \ -Wmissing-declarations -Wnested-externs -Wredundant-decls \ -Wpointer-arith -Wformat=2 -Winit-self \ - -Wswitch-enum -Wunused-variable -Wbad-function-cast \ + -Wswitch-enum -Wunused-variable -Wunused-function -Wbad-function-cast \ -Wno-strict-aliasing -fno-strict-aliasing ALL_CFLAGS:=@DEFS@ -I$(srcdir) -I. $(CFLAGS) $(EXTRA_CFLAGS) CPPFLAGS:=@CPPFLAGS@ $(EXTRA_CPPFLAGS) @@ -55,13 +55,19 @@ TARGETS:=secnet OBJECTS:=secnet.o util.o conffile.yy.o conffile.tab.o conffile.o modules.o \ resolver.o random.o udp.o site.o transform-cbcmac.o transform-eax.o \ netlink.o rsa.o dh.o serpent.o serpentbe.o \ - md5.o sha512.o version.o tun.o slip.o sha1.o ipaddr.o log.o \ + md5.o sha512.o tun.o slip.o sha1.o ipaddr.o log.o \ process.o @LIBOBJS@ \ hackypar.o +# version.o is handled specially below and in the link rule for secnet. TEST_OBJECTS:=eax-aes-test.o eax-serpent-test.o eax-serpentbe-test.o \ eax-test.o aes.o +ifeq (version.o,$(MAKECMDGOALS)) +OBJECTS:=version.o +TEST_OBJECTS:= +endif + %.c: %.y %.yy.c: %.fl @@ -114,14 +120,31 @@ conffile.tab.c: conffile.y # End of manual dependencies section secnet: $(OBJECTS) - $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $(OBJECTS) $(LDLIBS) + $(MAKE) version.o # *.o $(filter-out %.o, $^) + $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $(OBJECTS) version.o $(LDLIBS) +# We (always) regenerate the version, but only if we regenerate the +# binary. (This is necessary as the version string is can depend on +# any of the source files, eg to see whether "+" is needed.) + +ifneq (,$(wildcard .git/HEAD)) +# If we have (eg) committed, relink and thus regenerate the version +# with the new info from git describe. +secnet: Makefile .git/HEAD $(shell sed -n 's#^ref: #.git/#p' .git/HEAD) +secnet: $(wildcard .git/packed-refs) +endif check: eax-aes-test.confirm eax-serpent-test.confirm \ eax-serpentbe-test.confirm version.c: Makefile echo "#include \"secnet.h\"" >$@.new - echo "char version[]=\"secnet $(VERSION)\";" >>$@.new + @set -ex; if test -e .git; then \ + v=$$(git describe --match 'v*'); v=$${v#v}; \ + if ! git diff --quiet HEAD; then v="$$v+"; fi; \ + else \ + v="$(VERSION)"; \ + fi; \ + echo "char version[]=\"secnet $$v\";" >>$@.new mv -f $@.new $@ eax-%-test: eax-%-test.o eax-test.o %.o @@ -175,27 +198,29 @@ dist: # # 3. Commit the updates to VERSION (above) and debian/changelog # -# 4. git-tag -s v$(VERSION) +# 4. git-tag -m "secnet $VERSION" -s v$VERSION # -# 5. git-push origin +# 5. git-push origin v$VERSION v${VERSION}~0:master # # 6. Run, again, # make dist # -# 7. gpg --detach-sign ../secnet-$(VERSION).tar.gz +# 7. gpg --detach-sign ../secnet-$VERSION.tar.gz # # 8. rsync -v ../secnet-$VERSION.tar.gz* \ # chiark:/home/ianmdlvl/public-html/secnet/download/ # # 9. On chiark: -# tar zxf ~ianmdlvl/public-html/secnet/download/secnet-$(VERSION).tar.gz -# cd secnet-$(VERSION) +# tar zxf ~ianmdlvl/public-html/secnet/download/secnet-$VERSION.tar.gz +# cd secnet-$VERSION # debian/rules build # fakeroot debian/rules binary -# mv ../secnet_0.1.18.1-1_i386.deb ~/public-html/secnet/download/ +# mv ../secnet_${VERSION}_i386.deb ~ianmdlvl/public-html/secnet/download/ # # 10. On chiark as user secnet: -# cd ~secnet/ -# rsync ~ianmdlvl/public-html/secnet/download/secnet* . +# cd ~secnet/public-html/release/ +# mkdir $VERSION +# cd $VERSION +# ln -s /home/ianmdlvl/public-html/secnet/download/secnet?$VERSION* . # # 11. write and post a release announcement