X-Git-Url: http://git.sameswireless.fr/l2tpns.git/blobdiff_plain/6b1075b65c4239e97629f3a891f49f5ae9ef3d4b..1eca21ec9caadb684fff8fd21e112e64ac3462ee:/Makefile diff --git a/Makefile b/Makefile index 0bff86f..fd33fc0 100644 --- a/Makefile +++ b/Makefile @@ -9,21 +9,16 @@ statedir = /var/lib/l2tpns DEFINES = DEFINES += -DLIBDIR='"$(libdir)"' DEFINES += -DETCDIR='"$(etcdir)"' -DEFINES += -DSTATEDIR='"$(statedir)"' OPTIM = OPTIM += -g OPTIM += -O3 -OPTIM += -funroll-loops -OPTIM += -fomit-frame-pointer -OPTIM += -finline-functions -#OPTIM += -fstrength-reduce CC = gcc LD = gcc INCLUDES = -I. CPPFLAGS = $(INCLUDES) $(DEFINES) -CFLAGS = -Wall $(OPTIM) +CFLAGS = -Wall -Wformat-security -Wno-format-zero-length $(OPTIM) LDFLAGS = LDLIBS = INSTALL = install -c -D -o root -g root @@ -46,6 +41,8 @@ DEFINES += -DRINGBUFFER DEFINES += -DBGP OBJS += bgp.o +doit = echo $(1); $(1) + all: programs plugins tests programs: $(PROGRAMS) plugins: $(PLUGINS) @@ -61,16 +58,16 @@ depend: mv Makefile Makefile.bak mv Makefile.tmp Makefile -l2tpns: $(OBJS) +l2tpns: $(OBJS) $(LD) $(LDFLAGS) -o $@ $^ $(LDLIBS) $($@.LIBS) -nsctl: nsctl.o control.o +nsctl: nsctl.o control.o $(LD) $(LDFLAGS) -o $@ $^ $(LDLIBS) $($@.LIBS) -generateload: test/generateload.o +generateload: test/generateload.o $(LD) $(LDFLAGS) -o $@ $^ $(LDLIBS) $($@.LIBS) -bounce: test/bounce.o +bounce: test/bounce.o $(LD) $(LDFLAGS) -o $@ $^ $(LDLIBS) $($@.LIBS) %.o: %.c @@ -79,10 +76,6 @@ bounce: test/bounce.o %.so: %.c $(CC) -fPIC -shared $(CFLAGS) $(CPPFLAGS) $(LDFLAGS) -o $@ $< -# install config files only if a startup-config does not exist yet -# this does not interfere when building rpms or debs and makes -# fast upgrading via make install possible - install: all $(INSTALL) -m 0755 l2tpns $(DESTDIR)$(bindir)/l2tpns $(INSTALL) -m 0755 nsctl $(DESTDIR)$(bindir)/nsctl @@ -91,27 +84,29 @@ install: all $(INSTALL) -m 0644 Docs/l2tpns.8 $(DESTDIR)$(man8dir)/l2tpns.8 $(INSTALL) -m 0644 Docs/nsctl.8 $(DESTDIR)$(man8dir)/nsctl.8 - gzip --best $(DESTDIR)$(man5dir)/*.5 $(DESTDIR)$(man8dir)/*.8 + gzip --best --force $(DESTDIR)$(man5dir)/*.5 $(DESTDIR)$(man8dir)/*.8 - @if [ -f $(DESTDIR)$(etcdir)/startup-config ]; then \ - echo '***' Installing default config files in $(DESTDIR)$(etcdir) as .defaults; \ + @for config in startup-config users ip_pool; \ + do \ + suffix=; \ + mode=0600; [ $$config = ip_pool ] && mode=0644; \ + if [ -f $(DESTDIR)$(etcdir)/$$config ]; \ + then \ + cmp -s etc/$$config.default $(DESTDIR)$(etcdir)/$$config && continue; \ suffix=.default; \ - else \ - echo '***' Installing default config files in $(DESTDIR)$(etcdir) - remember to adjust them; \ - suffix=; \ - fi; \ - - $(INSTALL) -m 0600 etc/startup-config.default $(DESTDIR)$(etcdir)/startup-config$$suffix; \ - $(INSTALL) -m 0644 etc/ip_pool.default $(DESTDIR)$(etcdir)/ip_pool$$suffix; \ - $(INSTALL) -m 0600 etc/users.default $(DESTDIR)$(etcdir)/users$$suffix + fi; \ + $(call doit,$(INSTALL) -m $$mode etc/$$config.default $(DESTDIR)$(etcdir)/$$config$$suffix); \ + done - for plugin in $(PLUGINS); do \ - $(INSTALL) -m 0755 $$plugin $(DESTDIR)$(libdir)/$$plugin; \ + @for plugin in $(PLUGINS); \ + do \ + $(call doit,$(INSTALL) -m 0755 $$plugin $(DESTDIR)$(libdir)/$$plugin); \ done - if [ -z $(DESTDIR) ] && [ ! -e /dev/net/tun ]; then \ + @if [ -z $(DESTDIR) ] && [ ! -e /dev/net/tun ]; \ + then \ mkdir /dev/net; \ - mknod /dev/net/tun c 10 200; \ + $(call doit,mknod /dev/net/tun c 10 200); \ fi .PHONY: all clean depend install