X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?p=secnet.git;a=blobdiff_plain;f=Makefile.in;h=401fbb8c894fdd1ea15d4087567e35f40da02450;hp=52aaaa59752651c783cb5c1c65df0897c7e76b54;hb=92a7d254975db245c3320855515bffc1aebda9e4;hpb=7f861e63553911e2d61c8a7ce8c16b8089446822 diff --git a/Makefile.in b/Makefile.in index 52aaaa5..401fbb8 100644 --- a/Makefile.in +++ b/Makefile.in @@ -18,7 +18,7 @@ .PHONY: all clean realclean distclean dist install PACKAGE:=secnet -VERSION:=0.1.18 +VERSION:=0.2.1 @SET_MAKE@ @@ -31,57 +31,36 @@ CC:=@CC@ INSTALL:=@INSTALL@ INSTALL_PROGRAM:=@INSTALL_PROGRAM@ -# Use -DHACKY_PARALLEL if you are compiling secnet for an extremely -# slow machine -#CFLAGS:=-Wall @WRITESTRINGS@ @CFLAGS@ -DHACKY_PARALLEL -CFLAGS:=-Wall @WRITESTRINGS@ @CFLAGS@ \ +CFLAGS:=-Wall @WRITESTRINGS@ @CFLAGS@ -Werror \ -W -Wno-unused \ -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 \ -Wno-strict-aliasing -fno-strict-aliasing -ALL_CFLAGS:=@DEFS@ -I$(srcdir) -I. $(CFLAGS) -CPPFLAGS:=@CPPFLAGS@ -LDFLAGS:=@LDFLAGS@ -LDLIBS:=@LIBS@ +ALL_CFLAGS:=@DEFS@ -I$(srcdir) -I. $(CFLAGS) $(EXTRA_CFLAGS) +CPPFLAGS:=@CPPFLAGS@ $(EXTRA_CPPFLAGS) +LDFLAGS:=@LDFLAGS@ $(EXTRA_LDFLAGS) +LDLIBS:=@LIBS@ $(EXTRA_LDLIBS) prefix:=@prefix@ exec_prefix:=@exec_prefix@ sbindir:=@sbindir@ sysconfdir:=@sysconfdir@ transform:=@program_transform_name@ +mandir:=@mandir@ 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.o netlink.o rsa.o dh.o \ - serpent.o md5.o version.o tun.o slip.o sha1.o ipaddr.o log.o \ + resolver.o random.o udp.o site.o transform-cbcmac.o \ + netlink.o rsa.o dh.o \ + serpentbe.o md5.o version.o tun.o slip.o sha1.o ipaddr.o log.o \ process.o @LIBOBJS@ \ hackypar.o -DISTDIRS:=debian -DISTFILES:=BUGS COPYING CREDITS INSTALL LICENSE.txt Makefile.in \ - NEWS NOTES README TODO \ - ac_prog_cc_no_writeable_strings.m4 \ - conffile.c conffile.fl conffile.h conffile.y \ - conffile_internal.h \ - config.h.in configure \ - configure.in depend.sh dh.c \ - example.conf \ - getopt.c getopt1.c getopt.h \ - install-sh ipaddr.c ipaddr.h ipaddr.py linux log.c \ - magic.h md5.c md5.h \ - make-secnet-sites \ - modules.c netlink.c netlink.h process.c process.h \ - random.c resolver.c rsa.c \ - secnet.c secnet.h serpent.c serpent.h serpentsboxes.h \ - snprintf.c snprintf.h \ - sha1.c site.c slip.c stamp-h.in transform.c tun.c udp.c \ - unaligned.h util.c util.h \ - hackypar.c hackypar.h -DISTSUBDIRS:=debian/copyright debian/changelog debian/control \ - debian/init debian/rules debian/compat debian/default +TEST_OBJECTS:=eax-aes-test.o eax-serpent-test.o eax-serpentbe-test.o \ + eax-test.o aes.o %.c: %.y @@ -94,7 +73,7 @@ DISTSUBDIRS:=debian/copyright debian/changelog debian/control \ %.o: %.c $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c $< -o $@ -all: $(TARGETS) +all: $(TARGETS) check # Automatic remaking of configuration files, from autoconf documentation ${srcdir}/configure: configure.in @@ -118,8 +97,8 @@ config.status: configure # End of config file remaking rules # C and header file dependency rules -SOURCES:=$(OBJECTS:.o=.c) -DEPENDS:=$(OBJECTS:.o=.d) +SOURCES:=$(OBJECTS:.o=.c) $(TEST_OBJECTS:.o=.c) +DEPENDS:=$(OBJECTS:.o=.d) $(TEST_OBJECTS:.o=.d) $(DEPENDS): ${srcdir}/depend.sh @@ -137,20 +116,36 @@ conffile.tab.c: conffile.y secnet: $(OBJECTS) $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $(OBJECTS) $(LDLIBS) +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 mv -f $@.new $@ -install: all +eax-%-test: eax-%-test.o eax-test.o %.o + $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $^ + +eax-%-test.confirm: eax-%-test eax-%-test.vectors + ./$< <$(srcdir)/eax-$*-test.vectors >$@.new + mv -f $@.new $@ + +.PRECIOUS: eax-%-test + +installdirs: $(INSTALL) -d $(prefix)/share/secnet $(sbindir) + $(INSTALL) -d $(mandir)/man8 + +install: installdirs $(INSTALL_PROGRAM) secnet $(sbindir)/`echo secnet|sed '$(transform)'` $(INSTALL_PROGRAM) ${srcdir}/make-secnet-sites $(sbindir)/`echo make-secnet-sites|sed '$(transform)'` $(INSTALL) ${srcdir}/ipaddr.py $(prefix)/share/secnet/ipaddr.py + $(INSTALL) secnet.8 $(mandir)/man8/secnet.8 clean: $(RM) -f *.o *.yy.c *.tab.[ch] $(TARGETS) core version.c - $(RM) -f *.d *~ + $(RM) -f *.d *~ eax-*-test.confirm eax-*-test realclean: clean $(RM) -f *~ Makefile config.h *.d \ @@ -160,12 +155,47 @@ realclean: clean distclean: realclean pfname:=$(PACKAGE)-$(VERSION) +tarfname:=../$(pfname).tar dist: - $(RM) -rf $(pfname) - mkdir $(pfname) - for i in $(DISTDIRS) ; do mkdir $(pfname)/$$i ; done - for i in $(DISTFILES) ; do ln -s ../$(srcdir)/$$i $(pfname)/ ; done - for i in $(DISTSUBDIRS) ; do ln -s ../../$(srcdir)/$$i $(pfname)/$$i ; done - tar hcf ../$(pfname).tar --exclude=CVS --exclude=.cvsignore $(pfname) - gzip -9f ../$(pfname).tar - $(RM) -rf $(pfname) + $(RM) -rf $(tarfname) $(tarfname).gz + git archive --format=tar --prefix=$(pfname)/ HEAD -o $(tarfname) + gzip -9f $(tarfname) + +# Release checklist: +# 1. Check that the tree has what you want +# +# 2. Update VERSION (above) and debian/changelog +# but DO NOT COMMIT +# +# 3. Run +# ./configure +# make dist +# and check that the resulting tarball looks OK. +# Eg, untar it and build it, or have it reviewed. +# +# 3. Commit the updates to VERSION (above) and debian/changelog +# +# 4. git-tag -s v$(VERSION) +# +# 5. git-push origin +# +# 6. Run, again, +# make dist +# +# 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) +# debian/rules build +# fakeroot debian/rules binary +# mv ../secnet_0.1.18.1-1_i386.deb ~/public-html/secnet/download/ +# +# 10. On chiark as user secnet: +# cd ~secnet/ +# rsync ~ianmdlvl/public-html/secnet/download/secnet* . +# +# 11. write and post a release announcement