テストの追加・整理
[makefiles.git] / latex_mk / latex.mk
index bcdb34d..07625dc 100644 (file)
@@ -3,7 +3,7 @@
 #
 # == 使い方 ==
 # 1. texソースファイルと同じディレクトリーに本ファイル(latex.mk)をコピーする
-# 2. Makefileに変数TARGETS と「include latex.mk」を記述する
+# 2. Makefileに変数TEXTARGETS と「include latex.mk」を記述する
 # 3. texソースファイルと同じディレクトリーで、make コマンドを実行する
 #
 # == 機能 ==
@@ -24,9 +24,9 @@
 # - tex-distclean: TeX中間ファイル、バウンディング情報ファイル、ターゲットファイル(PDF、.dvi)を削除
 #
 # === Makefile -- sample ===
-# TARGETS := report.tex
+# TEXTARGETS := report.tex
 #
-# all: $(TARGETS)
+# all: $(TEXTARGETS)
 #
 # include latex.mk
 .PHONY: warning tex-clean tex-distclean
@@ -50,12 +50,12 @@ BIBTEX := pbibtex
 MENDEX := mendex
 
 # TeX中間ファイルの拡張子
-#   .aux: 相互参照
+#   .aux: 相互参照
 #   .fls: tex -recorderで生成されるファイルリスト
-#   .lof: 図リスト(\tableoffigures)
-#   .lot: 表リスト(\tableoftables)
-#   .out: hyperrefパッケージ
-#   .toc: 目次(\tableofcontents)
+#   .lof: 図リスト(\tableoffigures)
+#   .lot: 表リスト(\tableoftables)
+#   .out: hyperrefパッケージ
+#   .toc: 目次(\tableofcontents)
 #   .log: ログ
 TEX_INT := .aux .fls .lof .lot .out .toc .log
 # 索引中間ファイルの拡張子
@@ -68,46 +68,101 @@ IND_INT := .idx .ind .ilg
 #   .blg: BiBTeXログ
 BIB_INT := .bbl .blg
 
+.SECONDARY: $(wildcard $(addsuffix $(TEX_INT) $(IND_INT) $(BIB_INT) .d,*))
+
+# \tableofcontents命令
+toc = $(shell $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\tableofcontents/!s/.*\(\\tableofcontents\).*/\1/p' $<)
+
+# \listoffigures命令
+lof = $(shell $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\listoffigures/!s/.*\(\\listoffigures\).*/\1/p' $<)
+
+# \listoftables命令
+lot = $(shell $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\listoftables/!s/.*\(\\listoftables\).*/\1/p' $<)
+
 # \makeindex命令
-makeindex = $(shell $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\makeindex/!s/\\makeindex/&/p' $<)
+makeindex = $(shell $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\makeindex/!s/.*\(\\makeindex\).*/\1/p' $<)
 
 # \bibliography命令で読み込まれる文献データベースファイル
 bibdb = $(addsuffix .bib,$(basename $(strip $(shell \
-  $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\bibliography/!s/\\bibliography\(\[[^]]*\]\)\{0,1\}{\([^}]*\)}/&\n/gp' $< $(intex) | \
+  $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\bibliography/!s/\\bibliography\(\[[^]]*\]\)\{0,1\}{\([^}]*\)}/&\n/p' $< $(intex) | \
   $(SED) -e 's/.*{\([^}]*\)}.*/\1/' | \
   $(SED) -e 's/,/ /g'))))
 
+# hyperrefパッケージ読み込み
+hyperref = $(shell $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\usepackage\(\[[^]]*\]\)\{0,1\}{hyperref}/!s/.*\(\\usepackage\)\(\[[^]]*\]\)\{0,1\}\({hyperref}\).*/\1\3/p' $<)
+
 # ファイル名から拡張子を除いた部分
 BASE = $(basename $<)
+
 # .texファイル
 TEXFILE = $(addsuffix .tex,$(BASE))
+
 # .auxファイル
 AUXFILE = $(addsuffix .aux,$(BASE))
-# .prev_auxファイル
-PREV_AUXFILE = $(addsuffix .prev_aux,$(BASE))
+# .aux_prevファイル
+AUXFILE_PREV = $(addsuffix .aux_prev,$(BASE))
+
 # .dviファイル
 DVIFILE = $(addsuffix .dvi,$(BASE))
+
 # .dファイル
 DFILE = $(addsuffix .d,$(BASE))
+
 # .logファイル
 LOGFILE = $(addsuffix .log,$(BASE))
+
+# .tocファイル
+TOCFILE = $(addsuffix .toc,$(BASE))
+# .toc_prevファイル。.tocファイルのコピー
+TOCFILE_PREV = $(addsuffix .toc_prev,$(BASE))
+
+# .lofファイル
+LOFFILE = $(addsuffix .lof,$(BASE))
+# .lof_prevファイル。.lofファイルのコピー
+LOFFILE_PREV = $(addsuffix .lof_prev,$(BASE))
+
+# .lotファイル
+LOTFILE = $(addsuffix .lot,$(BASE))
+# .lot_prevファイル。.lotファイルのコピー
+LOTFILE_PREV = $(addsuffix .lot_prev,$(BASE))
+
 # .idxファイル
 IDXFILE = $(addsuffix .idx,$(BASE))
-# .prev_idxファイル。.idxファイルのコピー
-PREV_IDXFILE = $(addsuffix .prev_idx,$(BASE))
+# .idx_prevファイル。.idxファイルのコピー
+IDXFILE_PREV = $(addsuffix .idx_prev,$(BASE))
+
 # .indファイル
 INDFILE = $(addsuffix .ind,$(BASE))
-# .prev_indファイル。.indファイルのコピー
-PREV_INDFILE = $(addsuffix .prev_ind,$(BASE))
+# .ind_prevファイル。.indファイルのコピー
+INDFILE_PREV = $(addsuffix .ind_prev,$(BASE))
+
 # .ilgファイル
 ILGFILE = $(addsuffix .ilg,$(BASE))
+
 # .bblファイル
 BBLFILE = $(addsuffix .bbl,$(BASE))
-# .prev_bblファイル。.bblファイルのコピー
-PREV_BBLFILE = $(addsuffix .prev_bbl,$(BASE))
-# .bblファイル
+# .bbl_prevファイル。.bblファイルのコピー
+BBLFILE_PREV = $(addsuffix .bbl_prev,$(BASE))
+
+# .blgファイル
 BLGFILE = $(addsuffix .blg,$(BASE))
 
+# .outファイル
+OUTFILE = $(addsuffix .out,$(BASE))
+# .out_prevファイル。.outファイルのコピー
+OUTFILE_PREV = $(addsuffix .out_prev,$(BASE))
+
+INTERFILES = $(strip \
+                $(if $(toc),$(TOCFILE)) \
+                $(if $(lof),$(LOFFILE)) \
+                $(if $(lot),$(LOTFILE)) \
+                $(if $(makeindex),$(INDFILE)) \
+                $(if $(bibdb),$(BBLFILE)) \
+                $(if $(hyperref),$(OUTFILE)) \
+              )
+
+INTERFILES_PREV = $(addsuffix _prev,$(INTERFILES))
+
 #LaTeXオプション
 LATEXFLAG ?=
 DVIPDFMXFLAG ?=
@@ -119,13 +174,13 @@ MENDEXFLAG ?=
 LATEXCMD = $(LATEX) -interaction=batchmode $(LATEXFLAG) $(TEXFILE)
 COMPILE.tex = $(ECHO) $(LATEXCMD); $(LATEXCMD) >/dev/null 2>&1 || ($(CAT) $(LOGFILE); exit 1)
 
-# 索引(.indファイル)作成
+# 索引中間ファイル(.ind)作成
 MENDEXCMD = $(MENDEX) $(MENDEXFLAG) $(IDXFILE)
 COMPILE.idx = $(ECHO) $(MENDEXCMD); $(MENDEXCMD) >/dev/null 2>&1 || ($(CAT) $(ILGFILE); exit 1)
 
-# 文献リスト(.bblファイル)作成
+# 文献リスト中間ファイル(.bbl)作成
 BIBTEXCMD = $(BIBTEX) $(BIBTEXFLAG) $(AUXFILE)
-COMPILE.bbl = $(ECHO) $(BIBTEXCMD); $(BIBTEXCMD) >/dev/null 2>&1 || ($(CAT) $(BLGFILE); exit 1)
+COMPILE.bib = $(ECHO) $(BIBTEXCMD); $(BIBTEXCMD) >/dev/null 2>&1 || ($(CAT) $(BLGFILE); exit 1)
 
 # 相互参照未定義の警告
 WARN_UNDEFREF := 'There were undefined references\.'
@@ -133,96 +188,85 @@ WARN_UNDEFREF := 'There were undefined references\.'
 WARN_NOFILE = 'No file $(BASE)\.[a-zA-Z0-9]*\.'
 
 # LaTeX処理
-# 索引ファイルがある場合、1回処理する
 # ログファイルに警告がある場合、警告がなくなるまで最大4回処理する
 COMPILES.tex = \
   @(for f in 1st 2nd 3rd final; do \
       if test -s $@ -a -s $(LOGFILE); then \
-        $(GREP) -e $(WARN_UNDEFREF) -e $(WARN_NOFILE) $(LOGFILE) || exit 0; \
+        $(GREP) -e $(WARN_UNDEFREF) $(LOGFILE) || exit 0; \
       fi; \
       $(COMPILE.tex); \
     done)
 
-# *.*ファイルと *.prev_*ファイルを比較し、*.*ファイルが更新されている場合はその内容を*.prev_* にコピーす
-CMPPREV = $(CMP) $@ $< && $(ECHO) '$< is up to date.'|| $(CP) -v $< $@
+# ターゲットファイルと必須ファイルを比較し、内容が異なる場合はターゲットファイルの内容を必須ファイルに置き換え
+CMPPREV = $(CMP) $@ $< || $(CP) -v -p $< $@
 
 # \include、\input命令で読み込まれるtexファイル
 intex = $(addsuffix .tex,$(basename $(strip $(shell \
-  $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\\(include\|input\)/!s/\\\(include\|input\)\(\[[^]]*\]\)\{0,1\}{[^}]*}/&\n/gp' $< | \
+  $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\\(include\|input\)/!s/\\\(include\|input\)\(\[[^]]*\]\)\{0,1\}{[^}]*}/&\n/p' $< | \
   $(SED) -e 's/.*{\([^}]*\)}.*/\1/'))))
 
 # \includegraphics命令で読み込まれるグラフィックファイル
 ingraphics = $(strip $(shell \
-  $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\includegraphics/!s/\\includegraphics\(\[[^]]*\]\)\{0,1\}\({[^}]*}\)/&\n/gp' $< $(intex) | \
+  $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\includegraphics/!s/\\includegraphics\(\[[^]]*\]\)\{0,1\}\({[^}]*}\)/&\n/p' $< $(intex) | \
   $(SED) -e 's/.*{\([^}]*\)}.*/\1/'))
 
 # 依存関係を.dファイルに書き出す
 %.d: %.tex
        @$(ECHO) '$@ is created by scanning $^.'
 # TeX、.aux、.dvi、.dファイルの依存関係
-       @($(ECHO) '$(AUXFILE) $(DFILE): $(TEXFILE)'; \
-      $(ECHO); \
-      $(ECHO) '$(PREV_AUXFILE): $(AUXFILE)'; \
-      $(ECHO); \
-      $(ECHO) '$(DVIFILE): $(PREV_AUXFILE)' $(if $(makeindex),'$(PREV_INDFILE)') $(if $(bibdb),'$(PREV_BBLFILE)'); \
-    ) >$@
-       $(if $(strip $(makeindex) $(bibdb)),@( \
-      $(ECHO) '        @$$(COMPILE.tex)'; \
-      $(ECHO) '        @$$(COMPILES.tex)'; \
-    ) >>$@)
+       @$(ECHO) '$(DFILE): $(TEXFILE)' >$@
+       $(if $(INTERFILES),@( \
+        $(ECHO); \
+        $(ECHO) '$(DVIFILE): $(TEXFILE)'; \
+        $(ECHO) '      @$$(MAKE) -s $(INTERFILES_PREV)'; \
+        $(ECHO) '      @$$(COMPILE.tex)'; \
+        $(ECHO) '      @$$(COMPILES.tex)'; \
+    )  >>$@)
 # 画像ファイルの依存関係
        $(if $(ingraphics),@( \
         $(ECHO); \
         $(ECHO) '# IncludeGraphic Files - .pdf, .jpeg/.jpg, .png with .xbb'; \
-        $(ECHO) '$(AUXFILE): $(ingraphics)'; \
+        $(ECHO) '$(DVIFILE) $(AUXFILE) $(INTERFILES): $(ingraphics)'; \
         $(ECHO); \
-        $(ECHO) '$(AUXFILE): $(addsuffix .xbb,$(basename $(filter-out %.eps,$(ingraphics))))'; \
+        $(ECHO) '$(strip $(DVIFILE) $(AUXFILE) $(INTERFILES)): $(addsuffix .xbb,$(basename $(filter-out %.eps,$(ingraphics))))'; \
     ) >>$@)
 # \includeまたは\input命令で読み込まれるTeXファイルの依存関係
        $(if $(intex),@( \
         $(ECHO); \
         $(ECHO) '# Files called from \include or \input - .tex'; \
-        $(ECHO) '$(AUXFILE): $(intex)'; \
+        $(ECHO) '$(strip $(DVIFILE) $(AUXFILE) $(INTERFILES)): $(intex)'; \
     ) >>$@)
-# 索引作成用ファイルの依存関係: .aux -> idx -> .ind -> .dvi
-       $(if $(makeindex),@( \
-        $(ECHO); \
-        $(ECHO) '# Index files: .tex -> .idx -> .ind -> .dvi'; \
-        $(ECHO) '$(IDXFILE): $(TEXFILE)'; \
-        $(ECHO); \
-        $(ECHO) '$(PREV_IDXFILE): $(IDXFILE)'; \
-        $(ECHO); \
-        $(ECHO) '$(INDFILE): $(PREV_IDXFILE)'; \
-        $(ECHO); \
-        $(ECHO) '$(PREV_INDFILE): $(INDFILE)'; \
-    ) >>$@)
-  # 文献処理用ファイルの依存関係
+# 文献処理用ファイルの依存関係
        $(if $(bibdb),@( \
         $(ECHO); \
         $(ECHO) '# Bibliography files: .aux, BIBDB -> .bbl -> .div'; \
         $(ECHO) '$(BBLFILE): $(bibdb) $(AUXFILE)'; \
         $(ECHO); \
-        $(ECHO) '$(PREV_BBLFILE): $(BBLFILE)'; \
+        $(ECHO) '$(BBLFILE_PREV): $(BBLFILE)'; \
     ) >>$@)
 
-# 変数TARGETSで指定されたターゲットファイルに対応する
+# 変数TEXTARGETSで指定されたターゲットファイルに対応する
 # .dファイルをインクルードし、依存関係を取得する
 # ターゲットに %clean、%.xbb、%.d が含まれている場合は除く
-ifeq (,$(filter %clean %.xbb %.d,$(MAKECMDGOALS)))
-  -include $(addsuffix .d,$(basename $(TARGETS)))
+ifeq (,$(filter %clean %.xbb %.tex %.d,$(MAKECMDGOALS)))
+  -include $(addsuffix .d,$(basename $(TEXTARGETS)))
 endif
 
 # auxファイル作成
 %.aux: %.tex
        @$(COMPILE.tex)
 
-# prev_auxファイル作成
-%.prev_aux: %.aux
-       @$(CMPPREV)
+%.dvi: %.tex
+       @$(COMPILE.tex)
+       @$(COMPILES.tex)
 
-# dviファイル作成
-%.dvi: %.prev_aux
-       $(COMPILES.tex)
+%.dvi: %.aux
+       $(if $(filter-out aux,$(NOFILES)),@$(COMPILE.tex))
+       @$(COMPILES.tex)
+
+# aux_prevファイル作成
+%.aux_prev: %.aux
+       @$(CMPPREV)
 
 # PDFファイル作成
 %.pdf: %.dvi
@@ -242,30 +286,62 @@ endif
 %.xbb: %.png
        $(EXTRACTBB) $(EXTRACTBBFLAGS) $<
 
-# 索引ファイル作成
+# 目次中間ファイル作成
+%.toc: %.tex
+       @$(COMPILE.tex)
+
+%.toc_prev: %.toc
+       @$(CMPPREV)
+
+# 図リスト中間ファイル作成
+%.lof: %.tex
+       @$(COMPILE.tex)
+
+%.lof_prev: %.lof
+       @$(CMPPREV)
+
+# 表リスト中間ファイル作成
+%.lot: %.tex
+       @$(COMPILE.tex)
+
+%.lot_prev: %.lot
+       @$(CMPPREV)
+
+# 索引中間ファイル作成
 %.idx: %.tex
        @$(COMPILE.tex)
 
-%.prev_idx: %.idx
+%.idx_prev: %.idx
        @$(CMPPREV)
 
-%.ind: %.prev_idx
+%.ind: %.idx_prev
        @$(COMPILE.idx)
 
-%.prev_ind: %.ind
+%.ind_prev: %.ind
+       @$(CMPPREV)
+
+# BiBTeX中間ファイル作成
+%.bbl: %.tex
+       @$(COMPILE.bib)
+
+%.bbl_prev: %.bbl
        @$(CMPPREV)
 
-# 文献処理用ファイル作成
-%.bbl: %.prev_aux
-       @$(COMPILE.bbl)
+# hyperref中間ファイル作成
+%.out: %.tex
+       @$(COMPILE.tex)
 
-%.prev_bbl: %.bbl
+%.out_prev: %.out
        @$(CMPPREV)
 
 # tex-cleanターゲット
 tex-clean:
-       $(RM) $(addprefix *,$(TEX_INT) $(IND_INT) $(BIB_INT) .d .prev_aux .prev_idx .prev_ind .prev_bbl)
-ifeq (,$(filter %.dvi,$(TARGETS)))
+       $(RM) $(addprefix *, \
+      $(TEX_INT) $(IND_INT) $(BIB_INT) .d \
+      .aux_prev .toc_prev .lof_prev .lot_prev \
+      .idx_prev .ind_prev .bbl_prev .out_prev \
+    )
+ifeq (,$(filter %.dvi,$(TEXTARGETS)))
        $(RM) *.dvi
 endif
 
@@ -275,7 +351,7 @@ xbb-clean:
 
 # tex-distcleanターゲット
 tex-distclean: tex-clean xbb-clean
-ifneq (,$(filter %.dvi,$(TARGETS)))
+ifneq (,$(filter %.dvi,$(TEXTARGETS)))
        $(RM) *.dvi
 endif
-       $(RM) $(TARGETS)
+       $(RM) $(TEXTARGETS)