chiark / gitweb /
wip docs
[subdirmk.git] / subdirmk / regen.mk.in
index e2944f08ffd3f8b8f7265639e38d0ba54c1ab399..b8e031f7686c929cf5e1da072162a43bebe621e3 100644 (file)
@@ -14,16 +14,28 @@ $(CONFIG_STATUS): $(top_srcdir)/$(CONFIGURE)
 
 MAKEFILES += subdirmk/regen.mk
 
+MAKEFILE_TEMPLATES += $(top_srcdir)/Perdir.mk.in
+
 main.mk $(MAKEFILES): .makefiles.stamp ;
 .makefiles.stamp:                                              \
                $(top_srcdir)/subdirmk/generate                 \
                $(CONFIG_STATUS)                                \
-               $(top_srcdir)/Perdir.mk.in                      \
+               $(MAKEFILE_TEMPLATES)                           \
                $(foreach m,$(MAKEFILES),$(top_srcdir)/$(m).in)
-       : $? X $(filter-out Subdir.mk.in regen.mk.in, $(notdir $?))
+# 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.mk.in %/Subdir.mk.in        \
+                       subdirmk/regen.mk.in                    \
+                       $(top_srcdir)/subdirmk/regen.mk.in      \
+                       , $?),,                                 \
+               $(sort $(patsubst %.mk.in,%.mk,$(filter %.mk.in,$?))))
        touch $@
 
 realclean:: clean