X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=Makefile;h=0428160b80c23c5e65900b7c9a346508550bc85e;hp=619392d39562aa1f6553e762b91b01106f689061;hb=730b8f61e0cf4b2e8c0f123c0914d472d6df38fc;hpb=7d06e14e79f41c485f6cb448994498c5581dc69d diff --git a/Makefile b/Makefile index 619392d3..0428160b 100644 --- a/Makefile +++ b/Makefile @@ -2,8 +2,10 @@ # given explicitly on the command line) so mention it first. all: -# List all subdirectories here. Each contains its own Makefile.local -subdirs = compat completion emacs lib +# List all subdirectories here. Each contains its own Makefile.local. +# Use of '=', without '+=', seems to be required for out-of-tree +# builds to work. +subdirs = compat completion emacs lib man parse-time-string performance-test util test # We make all targets depend on the Makefiles themselves. global_deps = Makefile Makefile.config Makefile.local \ @@ -16,17 +18,24 @@ extra_cflags := extra_cxxflags := # Get settings from the output of configure by running it to generate -# Makefile.config if it doesn't exist yet. And add Makefile.config to -# our global dependency list. +# Makefile.config if it doesn't exist yet. + +# If Makefile.config doesn't exist, then srcdir won't be +# set. Conditionally set it (assuming a plain srcdir build) so that +# the rule to generate Makefile.config can actually work. +srcdir ?= . + include Makefile.config -Makefile.config: configure +Makefile.config: $(srcdir)/configure +ifeq ($(configure_options),) @echo "" @echo "Note: Calling ./configure with no command-line arguments. This is often fine," @echo " but if you want to specify any arguments (such as an alternate prefix" @echo " into which to install), call ./configure explicitly and then make again." @echo " See \"./configure --help\" for more details." @echo "" - ./configure +endif + $(srcdir)/configure $(configure_options) # Finally, include all of the Makefile.local fragments where all the # real work is done.