X-Git-Url: https://rtime.felk.cvut.cz/gitweb/notmuch.git/blobdiff_plain/33d5cc415ec31d14f126dbb19f8538b04d2c1b49..80220f7d4645ec4a6a39c713985ec59b2385f5b6:/emacs/Makefile.local diff --git a/emacs/Makefile.local b/emacs/Makefile.local index bda3997a..6c93e739 100644 --- a/emacs/Makefile.local +++ b/emacs/Makefile.local @@ -1,21 +1,86 @@ +# -*- makefile -*- + dir := emacs -emacs_sources := $(dir)/notmuch.el - -emacs_bytecode := $(subst .el,.elc,$(emacs_sources)) - -emacs: $(emacs_bytecode) - -install-emacs: install emacs - $(call quiet_mkdir, $(DESTDIR)/$(emacs_lispdir)) - $(call quiet_install_data, $(emacs_sources) $(emacs_bytecode) $(DESTDIR)$(emacs_lispdir)) - @echo "" - @echo "The notmuch emacs client is now installed." - @echo "" - @echo "To run this, each user should add the following line to the ~/.emacs file:" - @echo "" - @echo " (require 'notmuch)" - @echo "" - @echo "And should then run \"M-x notmuch\" from within emacs or run \"emacs -f notmuch\"" - @echo "" - -CLEAN := $(CLEAN) $(emacs_bytecode) +emacs_sources := \ + $(dir)/notmuch-lib.el \ + $(dir)/notmuch-parser.el \ + $(dir)/notmuch.el \ + $(dir)/notmuch-query.el \ + $(dir)/notmuch-show.el \ + $(dir)/notmuch-tree.el \ + $(dir)/notmuch-wash.el \ + $(dir)/notmuch-hello.el \ + $(dir)/notmuch-mua.el \ + $(dir)/notmuch-address.el \ + $(dir)/notmuch-maildir-fcc.el \ + $(dir)/notmuch-message.el \ + $(dir)/notmuch-crypto.el \ + $(dir)/notmuch-tag.el \ + $(dir)/coolj.el \ + $(dir)/notmuch-print.el \ + $(dir)/notmuch-version.el \ + $(dir)/notmuch-jump.el \ + $(dir)/notmuch-company.el + +$(dir)/notmuch-version.el: $(dir)/Makefile.local version.stamp +$(dir)/notmuch-version.el: $(srcdir)/$(dir)/notmuch-version.el.tmpl + @sed -e 's/%AG%/Generated file (from $( $@ + + +emacs_images := \ + $(srcdir)/$(dir)/notmuch-logo.png + +# Do not try to install files that are not byte-compiled. +emacs_no_byte_compile := $(dir)/notmuch-company.el + +emacs_bytecode = $(patsubst %.el,%.elc,$(filter-out $(emacs_no_byte_compile),$(emacs_sources))) + +# Because of defmacro's and defsubst's, we have to account for load +# dependencies between Elisp files when byte compiling. Otherwise, +# the byte compiler may load an old .elc file when processing a +# "require" or we may fail to rebuild a .elc that depended on a macro +# from an updated file. +ifeq ($(HAVE_EMACS),1) +$(dir)/.eldeps: $(dir)/Makefile.local $(dir)/make-deps.el $(emacs_sources) + $(call quiet,EMACS) --directory emacs -batch -l make-deps.el \ + -f batch-make-deps $(emacs_sources) > $@.tmp && \ + mv $@.tmp $@ +# We could include .eldeps directly, but that would cause a make +# restart whenever any .el file was modified, even if dependencies +# didn't change, because the mtime of .eldeps will change. Instead, +# we include a second file, .eldeps.x, which we ensure always has the +# same content as .eldeps, but its mtime only changes when dependency +# information changes, in which case a make restart is necessary +# anyway. +$(dir)/.eldeps.x: $(dir)/.eldeps + @cmp -s $^ $@ || cp $^ $@ +-include $(dir)/.eldeps.x +endif +CLEAN+=$(dir)/.eldeps $(dir)/.eldeps.tmp $(dir)/.eldeps.x + +ifeq ($(HAVE_EMACS),1) +%.elc: %.el $(global_deps) + $(call quiet,EMACS) --directory emacs -batch -f batch-byte-compile $< +endif + +ifeq ($(WITH_EMACS),1) +ifeq ($(HAVE_EMACS),1) +all: $(emacs_bytecode) +install-emacs: $(emacs_bytecode) +endif + +install: install-emacs +endif + +.PHONY: install-emacs +install-emacs: $(emacs_sources) $(emacs_images) + mkdir -p "$(DESTDIR)$(emacslispdir)" + install -m0644 $(emacs_sources) "$(DESTDIR)$(emacslispdir)" +ifeq ($(HAVE_EMACS),1) + install -m0644 $(emacs_bytecode) "$(DESTDIR)$(emacslispdir)" +endif + mkdir -p "$(DESTDIR)$(emacsetcdir)" + install -m0644 $(emacs_images) "$(DESTDIR)$(emacsetcdir)" + +CLEAN := $(CLEAN) $(emacs_bytecode) $(dir)/notmuch-version.el