[PATCH 1/1] emacs: Makefile.local: HAVE_EMACS usage fixes
Tomi Ollila
tomi.ollila at iki.fi
Tue Aug 27 10:43:01 PDT 2013
If we don't have emacs, disable targets that used EMACS while doing
the recipes of that target.
If we do have emacs, make install-emacs depend on *.elc files,
as making the target will attempt to install those.
---
I tested this first by running tests normally.
Next with ./configure --without-emacs (after make distclean).
Then I did this:
diff --git a/configure b/configure
index 6166917..3640b47 100755
--- a/configure
+++ b/configure
@@ -363,3 +363,3 @@ fi
printf "Checking if emacs is available... "
-if emacs --quick --batch > /dev/null 2>&1; then
+if eemacs --quick --batch > /dev/null 2>&1; then
printf "Yes.\n"
@@ -658,3 +658,3 @@ CXX = ${CXX}
# Command to execute emacs from Makefiles
-EMACS = emacs --quick
+EMACS = eemacs --quick
to hide emacs (make distclean; ./configure; make)
All of these worked as expected.
Tested the latest with current master (i.e without this patch):
$ make
Use "make V=1" to see the verbose compile lines.
EMACS emacs/.eldeps
/bin/sh: eemacs: command not found
make: Nothing to be done for `all'.
(although it seems to work, it complains...)
Finally, after applying this patch (and restoring configure),
./configure && make install-emacs DESTDIR=$HOME/DDIR worked fine
(without this patch the above gives:
install: cannot stat ‘emacs/notmuch-lib.elc’: No such file or directory
install: cannot stat ‘emacs/notmuch-parser.elc’: No such file or directory
...)
emacs/Makefile.local | 5 +++++
1 file changed, 5 insertions(+)
diff --git a/emacs/Makefile.local b/emacs/Makefile.local
index a910aff..a7e967e 100644
--- a/emacs/Makefile.local
+++ b/emacs/Makefile.local
@@ -28,19 +28,24 @@ emacs_bytecode = $(emacs_sources:.el=.elc)
# 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 && \
(cmp -s $@.tmp $@ || mv $@.tmp $@)
-include $(dir)/.eldeps
+endif
CLEAN+=$(dir)/.eldeps $(dir)/.eldeps.tmp
+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
--
1.8.0
More information about the notmuch
mailing list