Avoid EMACSDATA in user environment interfering with building
[bpt/emacs.git] / leim / Makefile.in
index 7c3f3ca..293b052 100644 (file)
@@ -1,6 +1,6 @@
 ### @configure_input@
 
-# Copyright (C) 1997-2013 Free Software Foundation, Inc.
+# Copyright (C) 1997-2014 Free Software Foundation, Inc.
 # Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
 #   2006, 2007, 2008, 2009, 2010, 2011
 #   National Institute of Advanced Industrial Science and Technology (AIST)
@@ -26,59 +26,57 @@ SHELL = @SHELL@
 # Here are the things that we expect ../configure to edit.
 srcdir=@srcdir@
 
+# Where the generated files go.
+leimdir = ${srcdir}/../lisp/leim
+
+# Prevent any settings in the user environment causing problems.
+unexport EMACSDATA EMACSDOC EMACSPATH
+
 # Which Emacs to use to convert TIT files to Emacs Lisp files,
-# byte-compile Emacs Lisp files, and generate the file leim-list.el.
+# and generate the file leim-list.el.
 EMACS = ../src/emacs
 
-buildlisppath=${srcdir}/../lisp
-
 # How to run Emacs.
-RUN_EMACS = EMACSLOADPATH=$(buildlisppath) LC_ALL=C \
-       ${EMACS} -batch --no-site-file --no-site-lisp
+# Prevent any setting of EMACSLOADPATH in user environment causing problems.
+RUN_EMACS = EMACSLOADPATH= '$(EMACS)' -batch --no-site-file --no-site-lisp
 
 MKDIR_P = @MKDIR_P@
 
 # Files generated from TIT dictionaries for Chinese GB character set.
 TIT_GB=\
-       quail/CCDOSPY.el        \
-       quail/Punct.el          \
-       quail/QJ.el             \
-       quail/SW.el             \
-       quail/TONEPY.el
+       ${leimdir}/quail/CCDOSPY.el     \
+       ${leimdir}/quail/Punct.el       \
+       ${leimdir}/quail/QJ.el          \
+       ${leimdir}/quail/SW.el          \
+       ${leimdir}/quail/TONEPY.el
 
 # Files generated from TIT dictionaries for Chinese BIG5 character set.
 TIT_BIG5=\
-       quail/4Corner.el        \
-       quail/ARRAY30.el        \
-       quail/ECDICT.el \
-       quail/ETZY.el           \
-       quail/Punct-b5.el       \
-       quail/PY-b5.el          \
-       quail/QJ-b5.el          \
-       quail/ZOZY.el
+       ${leimdir}/quail/4Corner.el     \
+       ${leimdir}/quail/ARRAY30.el     \
+       ${leimdir}/quail/ECDICT.el      \
+       ${leimdir}/quail/ETZY.el        \
+       ${leimdir}/quail/Punct-b5.el    \
+       ${leimdir}/quail/PY-b5.el       \
+       ${leimdir}/quail/QJ-b5.el       \
+       ${leimdir}/quail/ZOZY.el
 
 CHINESE_TIT=${TIT_GB} ${TIT_BIG5}
 
 MISC= \
-       quail/tsang-b5.el       \
-       quail/quick-b5.el       \
-       quail/tsang-cns.el      \
-       quail/quick-cns.el      \
-       quail/PY.el             \
-       quail/ZIRANMA.el        \
-       quail/CTLau.el          \
-       quail/CTLau-b5.el
+       ${leimdir}/quail/tsang-b5.el    \
+       ${leimdir}/quail/quick-b5.el    \
+       ${leimdir}/quail/tsang-cns.el   \
+       ${leimdir}/quail/quick-cns.el   \
+       ${leimdir}/quail/PY.el          \
+       ${leimdir}/quail/ZIRANMA.el     \
+       ${leimdir}/quail/CTLau.el       \
+       ${leimdir}/quail/CTLau-b5.el
 
 ## The generated .el files.
 TIT_MISC=${CHINESE_TIT} ${MISC}
 
-.SUFFIXES: .elc .el
-
-.el.elc:
-       @echo Compiling $<
-       @${RUN_EMACS} -l ${buildlisppath}/international/quail -f batch-byte-compile $<
-
-all: leim-list.el compile-main
+all: ${leimdir}/leim-list.el ${leimdir}/ja-dic/ja-dic.el
 .PHONY: all
 
 TIT_SOURCES= \
@@ -108,10 +106,10 @@ ${CHINESE_TIT}: changed.tit
 ## quail/%.el: CXTERM-DIC/%.tit
 ## It doesn't seem possible to do this with VPATH and suffix rules.
 changed.tit: ${TIT_SOURCES}
-       @${MKDIR_P} quail
-       ${RUN_EMACS} -l ${buildlisppath}/international/titdic-cnv \
-         -f batch-titdic-convert -dir quail ${srcdir}/CXTERM-DIC; \
-         echo "changed" > $@
+       @${MKDIR_P} ${leimdir}/quail
+       ${RUN_EMACS} -l titdic-cnv \
+         -f batch-titdic-convert -dir ${leimdir}/quail ${srcdir}/CXTERM-DIC
+       echo "changed" > $@
 
 MISC_SOURCES= \
        ${srcdir}/MISC-DIC/CTLau-b5.html \
@@ -125,75 +123,41 @@ ${MISC}: changed.misc
        @true
 
 changed.misc: ${MISC_SOURCES}
-       @${MKDIR_P} quail
-       ${RUN_EMACS} -l ${buildlisppath}/international/titdic-cnv \
-         -f batch-miscdic-convert -dir quail ${srcdir}/MISC-DIC; \
-         echo "changed" > $@
-
-leim-list.el: ${TIT_MISC} ${srcdir}/leim-ext.el
-       rm -f leim-list.el
-       if [ x`cd ${srcdir} && /bin/pwd` = x`/bin/pwd` ] ; then \
-         ${RUN_EMACS} -l ${buildlisppath}/international/quail \
-           --eval "(update-leim-list-file \".\")" ; \
-       else \
-         ${RUN_EMACS} -l ${buildlisppath}/international/quail \
-           --eval "(update-leim-list-file \".\" (unmsys--file-name \"${srcdir}\"))" ; \
-       fi
-       sed -n '/^[^;]/ p' < ${srcdir}/leim-ext.el >> $@
-
-$(srcdir)/ja-dic/ja-dic.el: $(srcdir)/SKK-DIC/SKK-JISYO.L
-       @$(MKDIR_P) $(srcdir)/ja-dic
-       $(RUN_EMACS) -batch -l $(buildlisppath)/international/ja-dic-cnv \
-         -f batch-skkdic-convert -dir "$(srcdir)/ja-dic" \
+       @${MKDIR_P} ${leimdir}/quail
+       ${RUN_EMACS} -l titdic-cnv \
+         -f batch-miscdic-convert -dir ${leimdir}/quail ${srcdir}/MISC-DIC
+       echo "changed" > $@
+
+.PHONY: leim-list.el
+leim-list.el: ${leimdir}/leim-list.el
+
+${leimdir}/leim-list.el: ${TIT_MISC} ${srcdir}/leim-ext.el
+       rm -f $@
+       ${RUN_EMACS} -l international/quail \
+         --eval "(update-leim-list-file (unmsys--file-name \"${leimdir}\"))"
+       sed -n -e '/^[^;]/p' -e 's/^;\(;*\)inc /;\1 /p' < ${srcdir}/leim-ext.el >> $@
+
+${leimdir}/ja-dic/ja-dic.el: $(srcdir)/SKK-DIC/SKK-JISYO.L
+       @$(MKDIR_P) $(leimdir)/ja-dic
+       $(RUN_EMACS) -batch -l ja-dic-cnv \
+         -f batch-skkdic-convert -dir "$(leimdir)/ja-dic" \
          "$(srcdir)/SKK-DIC/SKK-JISYO.L"
 
-## Following adapted from lisp/Makefile.in.
-setwins=wins="${srcdir}/ja-dic quail"; \
-       [ `cd ${srcdir} && /bin/pwd` != `/bin/pwd` ] && \
-       wins="$$wins ${srcdir}/quail"
-
-.PHONY: compile-targets
-# TARGETS is set dynamically in the recursive call from `compile-main'.
-compile-targets: $(TARGETS)
-
-# Compile all the Elisp files that need it.  Beware: it approximates
-# `no-byte-compile', so watch out for false-positives!
-.PHONY: compile-main
-compile-main: ${TIT_MISC} $(srcdir)/ja-dic/ja-dic.el
-       @($(setwins); \
-       els=`echo "$$wins " | sed -e 's| |/*.el |g'`; \
-       for el in $$els; do \
-         test -f $$el || continue; \
-         test ! -f $${el}c && GREP_OPTIONS= grep '^;.*no-byte-compile: t' $$el > /dev/null && continue; \
-         echo "$${el}c"; \
-       done | xargs echo) | \
-       while read chunk; do \
-         $(MAKE) $(MFLAGS) compile-targets EMACS="$(EMACS)" TARGETS="$$chunk"; \
-       done
-
-.PHONY: clean mostlyclean bootstrap-clean distclean maintainer-clean extraclean
-
-clean mostlyclean:
-       rm -f ${TIT_MISC} ${TIT_MISC:.el=.elc} \
-               leim-list.el changed.tit changed.misc
-
-# The following target is needed because the `clean' target only removes
-# TIT-generated files and doesn't touch compiled Quail packages.  But
-# bootstrapping should not leave non-fresh .elc files behind.
-bootstrap-clean: clean
-       $(setwins); for w in $$wins; do rm -f $$w/*.elc; done
-
-distclean: clean
-       -[ `cd ${srcdir} && /bin/pwd` != `/bin/pwd` ] && rm -rf quail
+.PHONY: bootstrap-clean distclean maintainer-clean extraclean
+
+bootstrap-clean:
+       rm -f ${TIT_MISC} ${leimdir}/leim-list.el changed.tit changed.misc
+
+distclean:
        rm -f Makefile
 
 maintainer-clean: distclean bootstrap-clean
 
-extraclean: maintainer-clean
-       -rm -f *~ \#* */*~ */\#*
-
-.PHONY: check-declare
+## We do not delete ja-dic, even in a bootstrap, because it rarely
+## changes and is slow to regenerate.
+## TODO? Could consider doing the same with TIT_MISC, though those
+## are much faster to generate.
+extraclean:
+       rm -rf ${leimdir}/ja-dic
 
-check-declare:
-       $(RUN_EMACS) -l $(buildlisppath)/emacs-lisp/check-declare \
-         --eval '(check-declare-directory (unmsys--file-name "$(srcdir)"))'
+### Makefile.in ends here