X-Git-Url: https://git.distorted.org.uk/~mdw/exim-config/blobdiff_plain/185b5456076ca86959643ce2f19c98c0f82f281e..534d411b5c96107030e30da491e06734ea09a7b3:/Makefile diff --git a/Makefile b/Makefile index a88c324..5178728 100644 --- a/Makefile +++ b/Makefile @@ -21,6 +21,10 @@ ### along with this program; if not, write to the Free Software Foundation, ### Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +###-------------------------------------------------------------------------- +### Utility macros. + +## Silent-rules machinery. V = 0 v_tag = $(call v_tag_$V,$1) v_tag_0 = @printf " %-6s %s\n" $1 $@; @@ -29,20 +33,31 @@ V_GEN = $(call v_tag,GEN) V_AT = $(V_AT_$V) V_AT_0 = @ +## Splitting things at slashes -- don't leave the slash. dir-nosl = $(patsubst %/,%,$(dir $1)) +###-------------------------------------------------------------------------- +### Introductory machinery. + all: .SECONDEXPANSION: # sorry CLEANFILES += $(TARGETS) +###-------------------------------------------------------------------------- +### Main source files. + +## There's a base set of files, and a number of optional modules. A +## collection of modules is called a `mode', and we generate an output file +## for each required mode. + EARLY = defs.m4 divmap.m4 config.m4 MAIN = lists.m4 base.m4 MODES = MODES += satellite -OPTIONS_satellite = satellite.m4 +OPTIONS_satellite = satellite.m4 sat-rewrite.m4 MODES += hub OPTIONS_hub = auth.m4 exchange.m4 local.m4 spam.m4 vhost.m4 @@ -52,6 +67,9 @@ OPTIONS_usersat = auth.m4 local.m4 satellite.m4 -include local.mk +###-------------------------------------------------------------------------- +### Resolving what needs to be built. + HOST_MODES += $(foreach m, $(MODES), \ $(foreach h, $(HOSTS_$m), $h/$m)) @@ -59,28 +77,40 @@ CONFIGS = $(foreach m, $(MODES), exim4-$m.conf) TARGETS += $(CONFIGS) $(CONFIGS): exim4-%.conf: $(EARLY) $$(HOOKS_$$*) $(MAIN) $$(OPTIONS_$$*) $(V_GEN)m4 -P -DMODE=$* $^ >$@.new - $(V_AT)exim4 -C$@.new -bV >/dev/null + $(V_AT)$(CHECK_$*)exim4 -C$@.new -bV >/dev/null $(V_AT)mv $@.new $@ all: $(TARGETS) +host-mode = $(notdir $(filter $1/%, $(HOST_MODES))) + +HOSTS = $(sort $(call dir-nosl, $(HOST_MODES))) + +###-------------------------------------------------------------------------- +### Propagating configuration to remote hosts. + THISHOST = $(shell hostname) +OTHERHOSTS = $(filter-out $(THISHOST), $(HOSTS)) ROOT = sudo -INSTALL_TARGETS = $(addprefix install-, $(HOST_MODES)) +install_rune = \ + exim4 -C/etc/exim4/exim4.conf.new -bV >/dev/null && \ + mv /etc/exim4/exim4.conf.new /etc/exim4/exim4.conf && \ + service exim4 reload -$(filter install-$(THISHOST)/%, $(INSTALL_TARGETS)): \ -install-$(THISHOST)/%: exim4-%.conf - $(ROOT) install -m644 $< /etc/exim4/exim4.conf - $(ROOT) service exim4 reload +install/$(THISHOST): exim4-$(call host-mode,$(THISHOST)).conf + $(ROOT) cp $< /etc/exim4/exim4.conf.new + $(ROOT) sh -c '$(install_rune)' -$(filter-out install-$(THISHOST)/%, $(INSTALL_TARGETS)): \ -install-%: exim4-$$(notdir $$*).conf - $(ROOT) scp $< root@$(call dir-nosl,$*):/etc/exim4/exim4.conf - $(ROOT) ssh root@$(call dir-nosl,$*) service exim4 reload +$(addprefix install/, $(OTHERHOSTS)): \ +install/%: exim4-$$(call host-mode,$$*).conf + $(ROOT) scp $< root@$*:/etc/exim4/exim4.conf.new + $(ROOT) ssh root@$* '$(install_rune)' -install: $(INSTALL_TARGETS) +install: $(addprefix install/, $(HOSTS)) clean:; rm -f $(CLEANFILES) .PHONY: clean + +###----- That's all, folks --------------------------------------------------