Makefile: Magic silent rules.
authorChris Wilson <chris@chris-wilson.co.uk>
Sat, 21 Nov 2009 20:32:20 +0000 (20:32 +0000)
committerCarl Worth <cworth@cworth.org>
Sun, 22 Nov 2009 03:29:29 +0000 (04:29 +0100)
Use the facilities of GNU make to create a magic function that will
on the first invocation print a description of how to enable verbose
compile lines and then print the quiet rule.

Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Carl Worth <cworth@cworth.org>
Cc: Mikhail Gusarov <dottedmag@dottedmag.net>
[ickle: Rebased, and duplicate command string eliminated.]
[ickle: Fixed verbose bug pointed out by Mikhail]

Makefile
Makefile.local
lib/Makefile.local

index 3fedcf12e87c4cb26005d09953c36f90f2ed12e2..5d8f3216028c8237b5ece727ea38290a5c65bcee 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -2,6 +2,10 @@
 WARN_FLAGS=-Wall -Wextra -Wmissing-declarations -Wwrite-strings -Wswitch-enum
 CFLAGS=-O2
 
+# Additional programs that are used during the compilation process.
+EMACS ?= emacs
+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)
@@ -31,14 +35,27 @@ include lib/Makefile.local
 # And get user settings from the output of configure
 include Makefile.config
 
+# 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)
+endif
+# The user has explicitly enabled quiet compilation.
+ifeq ($(V),0)
+quiet = @echo "  $1    $@"; $($1)
+endif
+# Otherwise, print the full command line.
+quiet ?= $($1)
+
 %.o: %.cc $(all_deps)
-       $(CXX) -c $(CXXFLAGS) $< -o $@
+       $(call quiet,CXX) -c $(CXXFLAGS) $< -o $@
 
 %.o: %.c $(all_deps)
-       $(CC) -c $(CFLAGS) $< -o $@
+       $(call quiet,CC) -c $(CFLAGS) $< -o $@
 
 %.elc: %.el
-       emacs -batch -f batch-byte-compile $<
+       $(call quiet,EMACS) -batch -f batch-byte-compile $<
 
 .deps/%.d: %.c $(all_deps)
        @set -e; rm -f $@; mkdir -p $$(dirname $@) ; \
index 3c9962409b60390eefbe5b04becb4f99f00a6a2f..5fd5d4f4c792888800e3d22707b527629495282c 100644 (file)
@@ -20,10 +20,10 @@ notmuch_client_srcs =               \
 
 notmuch_client_modules = $(notmuch_client_srcs:.c=.o)
 notmuch: $(notmuch_client_modules) lib/notmuch.a
-       $(CXX) $^ $(LDFLAGS) -o $@
+       $(call quiet,CXX) $^ $(LDFLAGS) -o $@
 
 notmuch.1.gz: notmuch.1
-       gzip --stdout notmuch.1 > notmuch.1.gz
+       $(call quiet,GZIP) --stdout $^ > $@
 
 install: all notmuch.1.gz
        for d in $(DESTDIR)$(prefix)/bin/ $(DESTDIR)$(prefix)/share/man/man1 \
index 79f7b0b7cb34a9ec8c1b8764800eec42a5047035..a7562c9bd28a3ee18c6c29ed38348070b3cd9f12 100644 (file)
@@ -18,7 +18,7 @@ libnotmuch_cxx_srcs =         \
 
 libnotmuch_modules = $(libnotmuch_c_srcs:.c=.o) $(libnotmuch_cxx_srcs:.cc=.o)
 $(dir)/notmuch.a: $(libnotmuch_modules)
-       $(AR) rcs $@ $^
+       $(call quiet,AR) rcs $@ $^
 
 SRCS  := $(SRCS) $(libnotmuch_c_srcs) $(libnotmuch_cxx_srcs)
 CLEAN := $(CLEAN) $(libnotmuch_modules) $(dir)/notmuch.a