X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=Makefile;h=588f8538eb44d4ab1002390bad7457a47b1e0da1;hp=e42584b294bf7bce344cbaa37fd7279127b8f96c;hb=fcc36df1fa37b940a46a3c14f0ccee8a39875145;hpb=7c2c26bc4ec5fdab5c6fa72ea325d846b46929e3 diff --git a/Makefile b/Makefile index e42584b2..588f8538 100644 --- a/Makefile +++ b/Makefile @@ -1,56 +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 +extra_cflags := +extra_cxxflags := + # 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) +all: notmuch notmuch.1.gz -# Include our local Makefile.local first so that its first target is default -include Makefile.local -include lib/Makefile.local - -# 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)