X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=Makefile;h=faaaec6419b9ae7ec4d96b1b0d28ceac00739446;hp=4af5a2ebfa5de2d38506e2dfd2e772bc30fe2ea0;hb=c10085c77b407d9ea704f8b4f9e0a805f63e72cb;hpb=10c176ba0e6d71e920b72a3165c0e56f26b5e4b3 diff --git a/Makefile b/Makefile index 4af5a2eb..faaaec64 100644 --- a/Makefile +++ b/Makefile @@ -1,26 +1,21 @@ -PROGS=notmuch notmuch-index-message xapian-dump +# We want the all target to be the implicit target (if no target is +# given explicitly on the command line) so mention it first. +all: -MYCFLAGS=-Wall -O0 -g `pkg-config --cflags gmime-2.4` -MYCXXFLAGS=$(MYCFLAGS) `xapian-config --cxxflags` +# List all subdirectories here. Each contains its own Makefile.local +subdirs = compat completion emacs lib -MYLDFLAGS=`pkg-config --libs gmime-2.4` `xapian-config --libs` +# We make all targets depend on the Makefiles themselves. +global_deps = Makefile Makefile.local \ + $(subdirs:%=%/Makefile) $(subdirs:%=%/Makefile.local) -all: $(PROGS) +# Sub-directory Makefile.local fragments can append to these variables +# to have directory-specific cflags as necessary. -%.o: %.cc - $(CXX) -c $(CXXFLAGS) $(MYCXXFLAGS) $^ -o $@ +extra_cflags := +extra_cxxflags := -%.o: %.c - $(CC) -c $(CFLAGS) $(MYCFLAGS) $^ -o $@ +# Finally, include all of the Makefile.local fragments where all the +# real work is done. -notmuch: notmuch.o database.o xutil.o - $(CC) $(MYLDFLAGS) $^ -o $@ - -notmuch-index-message: notmuch-index-message.cc - $(CXX) $(CXXFLAGS) $(MYCXXFLAGS) notmuch-index-message.cc `pkg-config --cflags --libs gmime-2.4` `xapian-config --cxxflags --libs` -o notmuch-index-message - -xapian-dump: xapian-dump.cc - $(CXX) $(CXXFLAGS) $(MYCXXFLAGS) xapian-dump.cc `xapian-config --libs --cxxflags` -o xapian-dump - -clean: - rm -f $(PROGS) *.o +include $(subdirs:%=%/Makefile.local) Makefile.local