X-Git-Url: https://git.notmuchmail.org/git?a=blobdiff_plain;ds=sidebyside;f=Makefile;h=faaaec6419b9ae7ec4d96b1b0d28ceac00739446;hb=c10085c77b407d9ea704f8b4f9e0a805f63e72cb;hp=ef8d6410ad26a2202fbc2fd44fcd7493d145b4ac;hpb=fa562fa22b214a7d253e80c62d4f4c97138a6155;p=notmuch diff --git a/Makefile b/Makefile index ef8d6410..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 glib-2.0` -MYCXXFLAGS=$(MYCFLAGS) `xapian-config --cxxflags` +# List all subdirectories here. Each contains its own Makefile.local +subdirs = compat completion emacs lib -MYLDFLAGS=`pkg-config --libs glib-2.0` `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 date.o message.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