X-Git-Url: https://git.notmuchmail.org/git?a=blobdiff_plain;f=Makefile;h=6a2ecea58a604b2549e8b5330280686a8f6fb82d;hb=e806e723c8ac8f97a3f8ba0e0048708a8f5bb475;hp=5d8f3216028c8237b5ece727ea38290a5c65bcee;hpb=530df68258ea0fbdceafd6e4a0f51889c6ee86d2;p=notmuch diff --git a/Makefile b/Makefile index 5d8f3216..6a2ecea5 100644 --- a/Makefile +++ b/Makefile @@ -1,10 +1,14 @@ -# Default FLAGS, (can be overridden by user such as "make CFLAGS=-O2") -WARN_FLAGS=-Wall -Wextra -Wmissing-declarations -Wwrite-strings -Wswitch-enum +# Default FLAGS, (can be overridden by user such as "make CFLAGS=-g") CFLAGS=-O2 +WARN_CXXFLAGS=-Wall -Wextra -Wwrite-strings -Wswitch-enum +WARN_CFLAGS=$(WARN_CXXFLAGS) -Wmissing-declarations + # Additional programs that are used during the compilation process. EMACS ?= emacs -GZIP ?= gzip +# Lowercase to avoid clash with GZIP environment variable for passing +# arguments to gzip. +gzip = gzip # Additional flags that we will append to whatever the user set. # These aren't intended for the user to manipulate. @@ -17,33 +21,41 @@ ifeq ($(emacs_lispdir),) emacs_lispdir = $(prefix)/share/emacs/site-lisp endif +bash_completion_dir = /etc/bash_completion.d + all_deps = Makefile Makefile.local Makefile.config \ lib/Makefile lib/Makefile.local # Now smash together user's values with our extra values -override CFLAGS += $(WARN_FLAGS) $(extra_cflags) -override CXXFLAGS += $(WARN_FLAGS) $(extra_cflags) $(extra_cxxflags) +override CFLAGS += $(WARN_CFLAGS) $(extra_cflags) +override CXXFLAGS += $(WARN_CXXFLAGS) $(extra_cflags) $(extra_cxxflags) override LDFLAGS += \ $(shell pkg-config --libs glib-2.0 gmime-2.4 talloc) \ $(shell xapian-config --libs) -# Include our local Makefile.local first so that its first target is default -include Makefile.local -include lib/Makefile.local +all: notmuch notmuch.1.gz + +# Before including any other Makefile fragments, get settings from the +# output of configure +Makefile.config: configure + ./configure -# And get user settings from the output of configure include Makefile.config +include lib/Makefile.local +include compat/Makefile.local +include Makefile.local + # The user has not set any verbosity, default to quiet mode and inform the # user how to enable verbose compiles. ifeq ($(V),) quiet_DOC := "Use \"$(MAKE) V=1\" to see the verbose compile lines.\n" -quiet = @echo $(quiet_DOC)$(eval quiet_DOC:=)" $1 $@"; $($1) +quiet = @printf $(quiet_DOC)$(eval quiet_DOC:=)" $1 $@\n"; $($1) endif # The user has explicitly enabled quiet compilation. ifeq ($(V),0) -quiet = @echo " $1 $@"; $($1) +quiet = @printf " $1 $@\n"; $($1) endif # Otherwise, print the full command line. quiet ?= $($1) @@ -73,5 +85,6 @@ DEPS := $(SRCS:%.c=.deps/%.d) DEPS := $(DEPS:%.cc=.deps/%.d) -include $(DEPS) +.PHONY : clean clean: rm -f $(CLEAN); rm -rf .deps