X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=Makefile;h=588f8538eb44d4ab1002390bad7457a47b1e0da1;hp=ae0f99120cc59c459c3b8d0e4819611e7c8b5c62;hb=fcc36df1fa37b940a46a3c14f0ccee8a39875145;hpb=98b93a7d5ad3713a7c408e497065cd0a931d90c7 diff --git a/Makefile b/Makefile index ae0f9912..588f8538 100644 --- a/Makefile +++ b/Makefile @@ -1,54 +1,49 @@ -# 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 # 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. -extra_cflags := $(shell pkg-config --cflags glib-2.0 gmime-2.4 talloc) -extra_cxxflags := $(shell xapian-config --cxxflags) - -emacs_lispdir := $(shell pkg-config emacs --variable sitepkglispdir) -# Hard-code if this system doesn't have an emacs.pc file -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) +extra_cflags := +extra_cxxflags := -override LDFLAGS += \ - $(shell pkg-config --libs glib-2.0 gmime-2.4 talloc) \ - $(shell xapian-config --libs) +# Now smash together user's values with our extra values +override CFLAGS += $(WARN_CFLAGS) $(extra_cflags) +override CXXFLAGS += $(WARN_CXXFLAGS) $(extra_cflags) $(extra_cxxflags) -# 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 -# And get user settings from the output of configure +# Before including any other Makefile fragments, get settings from the +# output of configure Makefile.config: configure ./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)