X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ian/git?a=blobdiff_plain;f=subdirmk%2Fregen.mk.in;h=eb54fc3f7353bf50ee60fc6400407178e66fe495;hb=3ab6a4c8c214d9f050112249359bc4e0f7876a58;hp=e2944f08ffd3f8b8f7265639e38d0ba54c1ab399;hpb=4800c931218887da8996d827a9351335e1e7e5f1;p=subdirmk.git diff --git a/subdirmk/regen.mk.in b/subdirmk/regen.mk.in index e2944f0..eb54fc3 100644 --- a/subdirmk/regen.mk.in +++ b/subdirmk/regen.mk.in @@ -12,18 +12,31 @@ $(top_srcdir)/$(CONFIGURE): $(addprefix $(top_srcdir)/,$(CONFIGURE_ACS)) $(CONFIG_STATUS): $(top_srcdir)/$(CONFIGURE) ./$(CONFIG_STATUS) --recheck -MAKEFILES += subdirmk/regen.mk +MAKEFILE_TEMPLATES += $(top_srcdir)/Perdir.sd.mk +MAKEFILE_TEMPLATES += $(addprefix $(top_srcdir)/, $(addsuffix .in, \ + @_SUBDIRMK_MAKEFILES@ \ + )) main.mk $(MAKEFILES): .makefiles.stamp ; .makefiles.stamp: \ $(top_srcdir)/subdirmk/generate \ $(CONFIG_STATUS) \ - $(top_srcdir)/Perdir.mk.in \ - $(foreach m,$(MAKEFILES),$(top_srcdir)/$(m).in) - : $? X $(filter-out Subdir.mk.in regen.mk.in, $(notdir $?)) + $(MAKEFILE_TEMPLATES) +# This filtering arranges that we can often run config.status to +# generate only particular output files. We look for *inputs* that +# have changed. If the only inputs that have changed are ones that we +# know affect only one output (Subdir.mk.in and regen.mk.in), we pass +# config.status the corresponding output file names. Otherwise we +# pass nothing and config.status does them all. We need to mention +# regen.mk.in twice because if $(top_srcdir) is `.', make elides the +# directory part from $?. ./$(CONFIG_STATUS) $(if \ - $(filter-out Subdir.mk.in regen.mk.in, $(notdir $?)),, \ - $(patsubst %.mk.in,%.mk,$(filter %.mk.in,$?))) + $(filter-out Subdir.sd.mk %/Subdir.sd.mk \ + %.mk.in \ + , $?),, \ + $(sort \ + $(patsubst %.sd.mk,%.mk,$(filter %.sd.mk,$?)) \ + $(patsubst %.mk.in,%.mk,$(filter %.mk.in,$?)))) touch $@ realclean:: clean