X-Git-Url: https://git.notmuchmail.org/git?a=blobdiff_plain;ds=sidebyside;f=Makefile;h=39f0e62fbb24ed7b240714aa0ea14d57639919b7;hb=d736260385a689b5c77d8121f48e29440e3adfa4;hp=7549b40d171fdde519697e5fe3d67de307ddbf20;hpb=44ea57a0d10ddab514abea319c4d25ec4e36b51e;p=notmuch diff --git a/Makefile b/Makefile index 7549b40d..39f0e62f 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 test +# 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 doc 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.