X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?p=secnet.git;a=blobdiff_plain;f=Makefile.in;h=dd94837cd3b1eaa212c19e48e1e43bc25631c73c;hp=0e4926c0b590a311c88336ffdb141678c0ac7fcc;hb=18ca0b4428846396356378dfb5949bbc3839a3be;hpb=469fd1d95b2528212a46b155cb115c078de4228f diff --git a/Makefile.in b/Makefile.in index 0e4926c..dd94837 100644 --- a/Makefile.in +++ b/Makefile.in @@ -15,10 +15,10 @@ # along with this program; if not, write to the Free Software # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. -.PHONY: all clean realclean dist install distclean +.PHONY: all clean realclean distclean dist install PACKAGE:=secnet -VERSION:=0.1.10 +VERSION:=0.1.18 @SET_MAKE@ @@ -31,7 +31,17 @@ CC:=@CC@ INSTALL:=@INSTALL@ INSTALL_PROGRAM:=@INSTALL_PROGRAM@ -CFLAGS:=@CFLAGS@ @DEFS@ -Wall -I$(srcdir) -I. +# Use -DHACKY_PARALLEL if you are compiling secnet for an extremely +# slow machine +#CFLAGS:=-Wall @WRITESTRINGS@ @CFLAGS@ -DHACKY_PARALLEL +CFLAGS:=-Wall @WRITESTRINGS@ @CFLAGS@ \ + -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 +ALL_CFLAGS:=@DEFS@ -I$(srcdir) -I. $(CFLAGS) +CPPFLAGS:=@CPPFLAGS@ LDFLAGS:=@LDFLAGS@ LDLIBS:=@LIBS@ @@ -46,34 +56,42 @@ 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 \ - process.o @LIBOBJS@ + process.o @LIBOBJS@ \ + hackypar.o -DISTFILES:=COPYING CREDITS INSTALL LICENSE.txt Makefile.in \ +DISTDIRS:=debian +DISTFILES:=BUGS COPYING CREDITS INSTALL LICENSE.txt Makefile.in \ NEWS NOTES README TODO \ - alloca.c \ + ac_prog_cc_no_writeable_strings.m4 \ conffile.c conffile.fl conffile.h conffile.y \ - conffile_internal.h config.h.bot \ - config.h.in config.h.top configure \ - configure.in debian dh.c \ + 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 md5.c md5.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 + 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 %.c: %.y %.yy.c: %.fl flex -o$@ $< -%.tab.c: %.y +%.tab.c %.tab.h: %.y bison -d -o $@ $< +%.o: %.c + $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c $< -o $@ all: $(TARGETS) @@ -83,7 +101,7 @@ ${srcdir}/configure: configure.in # autoheader might not change config.h.in, so touch a stamp file. ${srcdir}/config.h.in: stamp-h.in -${srcdir}/stamp-h.in: configure.in config.h.top config.h.bot +${srcdir}/stamp-h.in: configure.in cd ${srcdir} && autoheader echo timestamp > ${srcdir}/stamp-h.in @@ -98,37 +116,40 @@ config.status: configure ./config.status --recheck # End of config file remaking rules -# Manual dependencies section - XXX use autodep eventually -$(OBJECTS): config.h secnet.h util.h -conffile.o conffile.tab.o conffile.yy.o: conffile.h conffile_internal.h -secnet.o: conffile.h process.h -process.o: process.h -log.o: process.h -md5.o: md5.h -serpent.o transform.o: serpent.h -serpent.o: serpentsboxes.h -conffile.o: ipaddr.h -site.c util.c: unaligned.h +# C and header file dependency rules +SOURCES:=$(OBJECTS:.o=.c) +DEPENDS:=$(OBJECTS:.o=.d) + +$(DEPENDS): ${srcdir}/depend.sh + +%.d: %.c + ${srcdir}/depend.sh $(srcdir) $(CPPFLAGS) $(ALL_CFLAGS) $< > $@ + +-include $(DEPENDS) + +# Manual dependencies section conffile.yy.c: conffile.fl conffile.tab.c conffile.tab.c: conffile.y -netlink.o tun.o slip.o: netlink.h # End of manual dependencies section secnet: $(OBJECTS) + $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $(OBJECTS) $(LDLIBS) version.c: Makefile - echo "char version[]=\"secnet-$(VERSION)\";" >version.c + echo "char version[]=\"secnet $(VERSION)\";" >version.c install: all - $(INSTALL_PROGRAM) -D secnet $(sbindir)/`echo secnet|sed '$(transform)'` - $(INSTALL_PROGRAM) -D make-secnet-sites $(sbindir)/`echo make-secnet-sites|sed '$(transform)'` - $(INSTALL) -D ipaddr.py $(prefix)/share/secnet/ipaddr.py + $(INSTALL) -d $(prefix)/share/secnet $(sbindir) + $(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 clean: $(RM) -f *.o *.yy.c *.tab.[ch] $(TARGETS) core version.c + $(RM) -f *.d *~ realclean: clean - $(RM) -f *~ Makefile config.h \ + $(RM) -f *~ Makefile config.h *.d \ config.log config.status config.cache \ stamp-h Makefile.bak @@ -138,7 +159,9 @@ pfname:=$(PACKAGE)-$(VERSION) 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 - tar hcf ../$(pfname).tar $(pfname) + 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)