(Fbury_buffer): Use braces to follow GNU Coding Standards.
[bpt/emacs.git] / leim / Makefile.in
index 788fec8..6a3e1eb 100644 (file)
@@ -37,12 +37,13 @@ dot = .
 
 # Which Emacs to use to convert TIT files to Emacs Lisp files,
 # byte-compile Emacs Lisp files, and generate the file leim-list.el.
-EMACS = ${dot}${dot}/src/emacs
+BUILT-EMACS = ${dot}${dot}/src/emacs
 
 buildlisppath=${srcdir}/${dot}${dot}/lisp
 
 # How to run Emacs.
-RUN-EMACS = ${EMACS} -batch --no-init-file --no-site-file
+RUN-EMACS = EMACSLOADPATH=$(buildlisppath) \
+       ${BUILT-EMACS} -batch --no-init-file --no-site-file --multibyte
 
 # Subdirectories to be made if ${srcdir} is different from the current
 # directory.
@@ -50,79 +51,102 @@ SUBDIRS=quail
 
 # Files generated from TIT dictionaries for Chinese GB character set.
 TIT-GB=\
-       quail/CTLau.el          \
-       quail/CCDOSPY.el        \
-       quail/Punct.el          \
-       quail/PY.el             \
-       quail/QJ.el             \
-       quail/SW.el             \
-       quail/TONEPY.el         \
-       quail/ZIRANMA.el
+       quail/CCDOSPY.elc       \
+       quail/Punct.elc         \
+       quail/QJ.elc            \
+       quail/SW.elc            \
+       quail/TONEPY.elc
 
 # Files generated from TIT dictionaries for Chinese BIG5 character set.
 TIT-BIG5=\
-       quail/4Corner.el        \
-       quail/ARRAY30.el        \
-       quail/CTLauB.el         \
-       quail/ECDICT.el         \
-       quail/ETZY.el           \
-       quail/Punct-b5.el       \
-       quail/PY-b5.el          \
-       quail/QJ-b5.el          \
-       quail/ZOZY.el
+       quail/4Corner.elc       \
+       quail/ARRAY30.elc       \
+       quail/ECDICT.elc        \
+       quail/ETZY.elc          \
+       quail/Punct-b5.elc      \
+       quail/PY-b5.elc         \
+       quail/QJ-b5.elc         \
+       quail/ZOZY.elc
 
 CHINESE-TIT=${TIT-GB} ${TIT-BIG5}
 
-NON-TIT-GB=quail/py-punct.el
+NON-TIT-GB=${srcdir}/quail/py-punct.elc
 
-NON-TIT-BIG5=quail/quick-b5.el quail/tsang-b5.el quail/pypunct-b5.el
+NON-TIT-BIG5=${srcdir}/quail/pypunct-b5.elc
 
-NON-TIT-CNS=quail/quick-cns.el quail/tsang-cns.el
-
-CHINESE-NON-TIT=${NON-TIT-GB} ${NON-TIT-BIG5} ${NON-TIT-CNS}
+CHINESE-NON-TIT=${NON-TIT-GB} ${NON-TIT-BIG5}
 
 CHINESE-GB=${TIT-GB} ${NON-TIT-GB}
 
 CHINESE-BIG5=${TIT-BIG5} ${NON-TIT-BIG5} 
 
-CHINESE-CNS=${NON-TIT-CNS} 
+JAPANESE=${srcdir}/quail/japanese.elc ${srcdir}/ja-dic/ja-dic.elc
+
+KOREAN=        ${srcdir}/quail/hangul.elc      \
+       ${srcdir}/quail/hangul3.elc     \
+       ${srcdir}/quail/hanja.elc       \
+       ${srcdir}/quail/hanja3.elc      \
+       ${srcdir}/quail/hanja-jis.elc   \
+       ${srcdir}/quail/symbol-ksc.elc
+
+THAI=${srcdir}/quail/thai.elc
 
-JAPANESE=quail/japanese.el skk/skkdic.el
+VIETNAMESE=${srcdir}/quail/viqr.elc
 
-KOREAN=        quail/hangul.el         \
-       quail/hangul3.el        \
-       quail/hanja.el          \
-       quail/hanja-jis.el      \
-       quail/symbol-ksc.el
+LAO=${srcdir}/quail/lao.elc ${srcdir}/quail/lrt.elc
 
-THAI=quail/thai.el
+INDIAN=${srcdir}/quail/devanagari.elc
 
-VIETNAMESE=quail/viqr.el
+TIBETAN=${srcdir}/quail/tibetan.elc
 
-LAO=quail/lao.el quail/lrt.el
+LATIN= ${srcdir}/quail/latin-pre.elc   \
+       ${srcdir}/quail/latin-post.elc  \
+       ${srcdir}/quail/latin-alt.elc   \
+       ${srcdir}/quail/latin-ltx.elc   \
+       ${srcdir}/quail/welsh.elc
 
-INDIAN=quail/devanagari.el
+UNICODE=${srcdir}/quail/sgml-input.elc ${srcdir}/quail/rfc1345.elc \
+       ${srcdir}/quail/uni-input.elc
 
-TIBETAN=quail/tibetan.el
+SLAVIC= \
+       ${srcdir}/quail/czech.elc \
+       ${srcdir}/quail/slovak.elc
 
-LATIN=quail/latin-pre.el quail/latin-post.el
+GREEK=${srcdir}/quail/greek.elc
 
-GREEK=quail/greek.el
+RUSSIAN=${srcdir}/quail/cyrillic.elc ${srcdir}/quail/cyril-jis.elc
 
-RUSSIAN=quail/cyrillic.el quail/cyril-jis.el
+MISC= \
+       ${srcdir}/quail/ethiopic.elc \
+       ${srcdir}/quail/ipa.elc \
+       ${srcdir}/quail/hebrew.elc \
+       ${srcdir}/quail/georgian.elc
 
-MISC=quail/ethiopic.el quail/ipa.el
+MISC-DIC=\
+       quail/tsang-b5.elc      \
+       quail/quick-b5.elc      \
+       quail/tsang-cns.elc     \
+       quail/quick-cns.elc     \
+       quail/PY.elc            \
+       quail/ZIRANMA.elc       \
+       quail/CTLau.elc         \
+       quail/CTLau-b5.elc
 
-CHINESE=${CHINESE-GB} ${CHINESE-BIG5} ${CHINESE-CNS}
+CHINESE=${CHINESE-GB} ${CHINESE-BIG5}
 EASTASIA=${CHINESE} ${JAPANESE} ${KOREAN}
 ASIA=${EASTASIA} ${THAI} ${VIETNAMESE} ${LAO} ${INDIAN} ${TIBETAN}
-EUROPEAN=${LATIN} ${GREEK} ${RUSSIAN}
-WORLD=${ASIA} ${EUROPEAN} ${MISC}
+EUROPEAN=${LATIN} ${SLAVIC} ${GREEK} ${RUSSIAN}
+WORLD=${ASIA} ${EUROPEAN} ${MISC} ${MISC-DIC} ${UNICODE}
 
 TIT=${CHINESE-TIT}
 NON-TIT=${CHINESE-NON-TIT} ${JAPANESE} ${KOREAN} ${EUROPEAN} ${MISC}
 
-all: ${EMACS} ${SUBDIRS} ${TIT} leim-list.el
+.SUFFIXES: .elc .el
+
+.el.elc:
+       ${RUN-EMACS} -f batch-byte-compile $<
+
+all: ${BUILT-EMACS} ${SUBDIRS} ${TIT} ${MISC-DIC} leim-list.el
 
 # To ensure that we can run Emacs.  This target is ignored (never
 # being hit) if a user changes default value of EMACS.
@@ -133,15 +157,39 @@ ${SUBDIRS}:
        mkdir $@
        touch stamp-subdir
 
+# The rules which generate ${TIT} and ${MISC-DIC} files create them all
+# in one go.  So we need to prevent parallel execution for that target,
+# otherwise Emacs complains about files being locked.  .NOTPARALLEL is
+# for GNU Make, .NO_PARALLEL is for other Make's.
+.NOTPARALLEL: ${TIT} ${MISC-DIC}
+
+.NO_PARALLEL: ${TIT} ${MISC-DIC}
+
 # Rule to generate quail/*.el from CXTERM-DIC/*.tit.
+# The "if [ -f $@ ]; then true; " part prevents parallel Make's
+# which don't honor .NOTPARALLEL, such as SGI's Make, from running
+# this rule many times, one each for every file it creates.
 ${TIT}:
-       [ -d quail ] || mkdir quail
-       ${RUN-EMACS} -l ${buildlisppath}/international/titdic-cnv \
-           --eval '(batch-titdic-convert t)' -dir quail ${srcdir}/CXTERM-DIC
-       ${RUN-EMACS} -f batch-byte-compile ${TIT}
-
-leim-list.el: ${SUBDIRS} ${TIT}
-       if [ x`(cd ${srcdir}; /bin/pwd)` = x`(/bin/pwd)` ] ; then \
+       if [ -d quail ]; then true; else make quail; fi
+       if [ -f $@ ]; then true; else \
+        ${RUN-EMACS} -l ${buildlisppath}/international/titdic-cnv \
+         --eval '(batch-titdic-convert t)' -dir quail ${srcdir}/CXTERM-DIC; fi
+       if [ -f $@ ]; then true; else \
+        ${RUN-EMACS}  -l ${buildlisppath}/international/quail \
+         -f batch-byte-compile ${TIT:.elc=.el}; fi
+
+# Rule to generate quail/*.el from MISC-DIC/*.
+${MISC-DIC}:
+       if [ -d quail ]; then true; else make quail; fi
+       if [ -f $@ ]; then true; else \
+        ${RUN-EMACS} -l ${buildlisppath}/international/titdic-cnv \
+           -f batch-miscdic-convert -dir quail ${srcdir}/MISC-DIC; fi
+       if [ -f $@ ]; then true; else \
+        ${RUN-EMACS} -l ${buildlisppath}/international/quail \
+         -f batch-byte-compile ${MISC-DIC:.elc=.el}; fi
+
+leim-list.el: ${SUBDIRS} ${WORLD}
+       if [ x`(cd ${srcdir} && /bin/pwd)` = x`(/bin/pwd)` ] ; then \
          ${RUN-EMACS} -l ${buildlisppath}/international/quail \
            --eval "(update-leim-list-file \".\")" ; \
        else \
@@ -150,26 +198,31 @@ leim-list.el: ${SUBDIRS} ${TIT}
        fi
 
 install: all
-       if [ x`(cd ${INSTALLDIR}; /bin/pwd)` != x`(/bin/pwd)` ] ; then \
+       if [ x`(cd ${INSTALLDIR} && /bin/pwd)` != x`(/bin/pwd)` ] ; then \
          rm -rf ${INSTALLDIR}/leim-list.el; \
-         rm -rf ${INSTALLDIR}/quail ${INSTALLDIR}/skk ; \
+         rm -rf ${INSTALLDIR}/quail ${INSTALLDIR}/ja-dic ; \
          echo "Copying leim files to ${INSTALLDIR} ..." ; \
-         if [ x`(cd ${srcdir}; /bin/pwd)` = x`(/bin/pwd)` ] ; then \
-           tar -cf - leim-list.el quail skk \
+         if [ x`(cd ${srcdir} && /bin/pwd)` = x`(/bin/pwd)` ] ; then \
+           tar -cf - leim-list.el quail ja-dic \
                | (cd ${INSTALLDIR}; umask 0; tar -xvf - && cat > /dev/null) ;\
          else \
            tar -cf - leim-list.el quail \
                | (cd ${INSTALLDIR}; umask 0; tar -xvf - && cat > /dev/null) ;\
            cd ${srcdir}; \
-           tar -cf - quail/* skk \
+           tar -cf - quail/* ja-dic \
                | (cd ${INSTALLDIR}; umask 0; tar -xvf - && cat > /dev/null) ;\
          fi; \
        else true; fi
+       -rm -f ${INSTALLDIR}/.cvsignore ${INSTALLDIR}/*/.cvsignore
+       -chmod -R a+r ${INSTALLDIR}
 
 clean mostlyclean:
-       ELC=`echo ${TIT} | sed 's/\.el/.elc/g'`; \
-       rm -f ${TIT} $$ELC leim-list.el
+       rm -f ${TIT} ${NON-TIT} ${WORLD} ${TIT:.elc=.el} \
+         ${MISC-DIC} ${MISC-DIC:.elc=.el} leim-list.el
 
 distclean maintainer-clean:
        if test -f stamp-subdir; then rm -rf ${SUBDIRS} stamp-subdir; fi
        rm -f Makefile
+
+extraclean: distclean
+       -rm -f *~ \#* m/?*~ s/?*~