From 684b918941a0b5d2a7646e66c262442e08f6166e Mon Sep 17 00:00:00 2001
From: j8takagi <j8takagi@nifty.com>
Date: Sun, 10 Nov 2013 12:47:12 +0900
Subject: [PATCH] =?utf8?q?latex.mk=E3=81=A7=E3=80=81=E7=B4=A2=E5=BC=95?=
 =?utf8?q?=E3=82=84=E6=96=87=E7=8C=AE=E3=83=AA=E3=82=B9=E3=83=88=E3=82=92?=
 =?utf8?q?=E4=BD=9C=E6=88=90=E3=81=99=E3=82=8B=E3=81=A8=E3=81=8D=E3=81=AE?=
 =?utf8?q?=E5=8B=95=E4=BD=9C=E3=82=92=E4=BF=AE=E6=AD=A3?=
MIME-Version: 1.0
Content-Type: text/plain; charset=utf8
Content-Transfer-Encoding: 8bit

索引中間ファイル(.ind)と文献リスト中間ファイル(.bbl)が更新されたあとは、
TeXログファイルに警告がなくてもコンパイルを実行するよう仕様変更
---
 latex_mk/latex.mk | 204 +++++++++++++++++++++++++++-------------------
 1 file changed, 118 insertions(+), 86 deletions(-)

diff --git a/latex_mk/latex.mk b/latex_mk/latex.mk
index 05b8673..bcdb34d 100644
--- a/latex_mk/latex.mk
+++ b/latex_mk/latex.mk
@@ -17,7 +17,7 @@
 #   -- 挿入されたTeXファイルがないときは、処理を中止
 # - \makeindex命令が含まれる場合、mendexで索引を作成
 # - \bibliography命令が含まれる場合、BiBTeXで文献一覧を作成
-
+#
 # == 擬似ターゲット ==
 # - tex-clean: TeX中間ファイル(auxなど)を削除。ターゲットに.dviが含まれていないときは.dviファイルを削除
 # - xbb-clean: バウンディング情報ファイル(.xbb)を削除
@@ -29,8 +29,7 @@
 # all: $(TARGETS)
 #
 # include latex.mk
-
-.PHONY: tex-clean tex-distclean
+.PHONY: warning tex-clean tex-distclean
 
 # シェルコマンド
 CAT := cat
@@ -40,6 +39,9 @@ ECHO := echo
 GREP := grep
 SED := sed
 
+warning:
+	@$(ECHO) "check current directory, or set TARGET in Makefile."
+
 # LaTeXコマンド
 LATEX := platex
 DVIPDFMX := dvipdfmx
@@ -56,40 +58,55 @@ MENDEX := mendex
 #   .toc: 目次(\tableofcontents)用
 #   .log: ログ
 TEX_INT := .aux .fls .lof .lot .out .toc .log
-
 # 索引中間ファイルの拡張子
 #   .idx: auxから作成
 #   .ind: idxから作成
 #   .ilg: 索引ログ
 IND_INT := .idx .ind .ilg
-
 # BiBTeX中間ファイルの拡張子
 #   .bbl: auxから作成
 #   .blg: BiBTeXログ
 BIB_INT := .bbl .blg
 
+# \makeindex命令
+makeindex = $(shell $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\makeindex/!s/\\makeindex/&/p' $<)
+
+# \bibliography命令で読み込まれる文献データベースファイル
+bibdb = $(addsuffix .bib,$(basename $(strip $(shell \
+  $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\bibliography/!s/\\bibliography\(\[[^]]*\]\)\{0,1\}{\([^}]*\)}/&\n/gp' $< $(intex) | \
+  $(SED) -e 's/.*{\([^}]*\)}.*/\1/' | \
+  $(SED) -e 's/,/ /g'))))
+
 # ファイル名から拡張子を除いた部分
-FILEBASE = $(basename $<)
+BASE = $(basename $<)
 # .texファイル
-TEXFILE = $(addsuffix .tex,$(FILEBASE))
+TEXFILE = $(addsuffix .tex,$(BASE))
 # .auxファイル
-AUXFILE = $(addsuffix .aux,$(FILEBASE))
-# .prev_auxファイル。.auxファイルのコピー
-PREV_AUXFILE = $(addsuffix .prev_aux,$(FILEBASE))
+AUXFILE = $(addsuffix .aux,$(BASE))
+# .prev_auxファイル
+PREV_AUXFILE = $(addsuffix .prev_aux,$(BASE))
 # .dviファイル
-DVIFILE = $(addsuffix .dvi,$(FILEBASE))
+DVIFILE = $(addsuffix .dvi,$(BASE))
 # .dファイル
-DFILE = $(addsuffix .d,$(FILEBASE))
+DFILE = $(addsuffix .d,$(BASE))
 # .logファイル
-LOGFILE = $(addsuffix .log,$(FILEBASE))
+LOGFILE = $(addsuffix .log,$(BASE))
 # .idxファイル
-IDXFILE = $(addsuffix .idx,$(FILEBASE))
+IDXFILE = $(addsuffix .idx,$(BASE))
 # .prev_idxファイル。.idxファイルのコピー
-PREV_IDXFILE = $(addsuffix .prev_idx,$(FILEBASE))
+PREV_IDXFILE = $(addsuffix .prev_idx,$(BASE))
 # .indファイル
-INDFILE = $(addsuffix .ind,$(FILEBASE))
+INDFILE = $(addsuffix .ind,$(BASE))
+# .prev_indファイル。.indファイルのコピー
+PREV_INDFILE = $(addsuffix .prev_ind,$(BASE))
+# .ilgファイル
+ILGFILE = $(addsuffix .ilg,$(BASE))
 # .bblファイル
-BBLFILE = $(addsuffix .bbl,$(FILEBASE))
+BBLFILE = $(addsuffix .bbl,$(BASE))
+# .prev_bblファイル。.bblファイルのコピー
+PREV_BBLFILE = $(addsuffix .prev_bbl,$(BASE))
+# .bblファイル
+BLGFILE = $(addsuffix .blg,$(BASE))
 
 #LaTeXオプション
 LATEXFLAG ?=
@@ -99,86 +116,94 @@ BIBTEXFLAG ?=
 MENDEXFLAG ?=
 
 # LaTeX処理(コンパイル)
-COMPILE.tex = $(LATEX) -interaction=batchmode $(LATEXFLAG) $(TEXFILE) || $(CAT) $(LOGFILE)
+LATEXCMD = $(LATEX) -interaction=batchmode $(LATEXFLAG) $(TEXFILE)
+COMPILE.tex = $(ECHO) $(LATEXCMD); $(LATEXCMD) >/dev/null 2>&1 || ($(CAT) $(LOGFILE); exit 1)
+
+# 索引(.indファイル)作成
+MENDEXCMD = $(MENDEX) $(MENDEXFLAG) $(IDXFILE)
+COMPILE.idx = $(ECHO) $(MENDEXCMD); $(MENDEXCMD) >/dev/null 2>&1 || ($(CAT) $(ILGFILE); exit 1)
+
+# 文献リスト(.bblファイル)作成
+BIBTEXCMD = $(BIBTEX) $(BIBTEXFLAG) $(AUXFILE)
+COMPILE.bbl = $(ECHO) $(BIBTEXCMD); $(BIBTEXCMD) >/dev/null 2>&1 || ($(CAT) $(BLGFILE); exit 1)
 
 # 相互参照未定義の警告
 WARN_UNDEFREF := 'There were undefined references\.'
-
 # 読み込むべき中間ファイルがないことの警告
-WARN_NOFILE = 'No file $(FILEBASE)\.[a-zA-Z0-9]*\.'
+WARN_NOFILE = 'No file $(BASE)\.[a-zA-Z0-9]*\.'
 
-# ログファイルに警告がある場合、LaTeX処理を最大4回繰り返す
+# LaTeX処理
+# 索引ファイルがある場合、1回処理する
+# ログファイルに警告がある場合、警告がなくなるまで最大4回処理する
 COMPILES.tex = \
-  if test -s $(INDFILE); then \
-    $(ECHO) "---------- for index ----------"; \
-    $(COMPILE.tex); \
-  fi; \
-  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; \
-    fi; \
-    $(ECHO) "---------- $$f try ----------"; \
-    $(COMPILE.tex); \
-  done
+  @(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; \
+      fi; \
+      $(COMPILE.tex); \
+    done)
 
-# \includegraphics命令で読み込まれるグラフィックファイル
-ingraphics = $(strip $(shell \
-  $(SED) -n -e '/^%/!s/\\includegraphics\(\[[^]]*\]\)\{0,1\}\({[^}]*}\)/&\n/gp' $< $(intex) | \
-  $(SED) -e 's/.*{\([^}]*\)}.*/\1/'))
+# *.*ファイルと *.prev_*ファイルを比較し、*.*ファイルが更新されている場合はその内容を*.prev_* にコピーする
+CMPPREV = $(CMP) $@ $< && $(ECHO) '$< is up to date.'|| $(CP) -v $< $@
 
 # \include、\input命令で読み込まれるtexファイル
 intex = $(addsuffix .tex,$(basename $(strip $(shell \
-  $(SED) -n -e '/^%/!s/\\\(include\|input\)\(\[[^]]*\]\)\{0,1\}{[^}]*}/&\n/gp' $< | \
+  $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\\(include\|input\)/!s/\\\(include\|input\)\(\[[^]]*\]\)\{0,1\}{[^}]*}/&\n/gp' $< | \
   $(SED) -e 's/.*{\([^}]*\)}.*/\1/'))))
 
-# \makeindex命令
-makeindex = $(SED) -n -e '/^%/!s/\\makeindex/&/p' $<
-
-# \bibliography命令で読み込まれる文献データベースファイル
-bibdb = $(addsuffix .bib,$(basename $(strip $(shell \
-  $(SED) -n -e '/^%/!s/\\bibliography\(\[[^]]*\]\)\{0,1\}{\([^}]*\)}/&\n/gp' $< $(intex) | \
-  $(SED) -e 's/.*{\([^}]*\)}.*/\1/' | \
-  $(SED) -e 's/,/ /g'))))
+# \includegraphics命令で読み込まれるグラフィックファイル
+ingraphics = $(strip $(shell \
+  $(SED) -n -e '/^.*[^\]\{0,1\}%.*\\includegraphics/!s/\\includegraphics\(\[[^]]*\]\)\{0,1\}\({[^}]*}\)/&\n/gp' $< $(intex) | \
+  $(SED) -e 's/.*{\([^}]*\)}.*/\1/'))
 
 # 依存関係を.dファイルに書き出す
 %.d: %.tex
 	@$(ECHO) '$@ is created by scanning $^.'
-  # texファイルの依存関係
-	@($(ECHO) '$(AUXFILE) $(DFILE): $<'; \
+# TeX、.aux、.dvi、.dファイルの依存関係
+	@($(ECHO) '$(AUXFILE) $(DFILE): $(TEXFILE)'; \
       $(ECHO); \
-      $(ECHO) '$(DVIFILE): $(AUXFILE)') >$@
-  # 画像ファイルの依存関係
-	$(if $(ingraphics),@( \
-      $(ECHO); \
-      $(ECHO) '# IncludeGraphic Files - .pdf, .jpeg/.jpg, .png with .xbb'; \
-      $(ECHO) '$(DVIFILE) $(AUXFILE): $(ingraphics)'; \
+      $(ECHO) '$(PREV_AUXFILE): $(AUXFILE)'; \
       $(ECHO); \
-      $(ECHO) '$(DVIFILE) $(AUXFILE): $(addsuffix .xbb,$(basename $(ingraphics)))') >>$@)
-  # Include/Inputファイルの依存関係
+      $(ECHO) '$(DVIFILE): $(PREV_AUXFILE)' $(if $(makeindex),'$(PREV_INDFILE)') $(if $(bibdb),'$(PREV_BBLFILE)'); \
+    ) >$@
+	$(if $(strip $(makeindex) $(bibdb)),@( \
+      $(ECHO) '	@$$(COMPILE.tex)'; \
+      $(ECHO) '	@$$(COMPILES.tex)'; \
+    ) >>$@)
+# 画像ファイルの依存関係
+	$(if $(ingraphics),@( \
+        $(ECHO); \
+        $(ECHO) '# IncludeGraphic Files - .pdf, .jpeg/.jpg, .png with .xbb'; \
+        $(ECHO) '$(AUXFILE): $(ingraphics)'; \
+        $(ECHO); \
+        $(ECHO) '$(AUXFILE): $(addsuffix .xbb,$(basename $(filter-out %.eps,$(ingraphics))))'; \
+    ) >>$@)
+# \includeまたは\input命令で読み込まれるTeXファイルの依存関係
 	$(if $(intex),@( \
-      $(ECHO); \
-      $(ECHO) '# Include / Input Files - .tex'; \
-      $(ECHO) '$(DVIFILE) $(AUXFILE): $(intex)') >>$@)
-  # 索引作成用ファイルの依存関係
+        $(ECHO); \
+        $(ECHO) '# Files called from \include or \input - .tex'; \
+        $(ECHO) '$(AUXFILE): $(intex)'; \
+    ) >>$@)
+# 索引作成用ファイルの依存関係: .aux -> idx -> .ind -> .dvi
 	$(if $(makeindex),@( \
-      $(ECHO); \
-      $(ECHO) '# Index Files: .aux -> idx -> .ind -> .dvi'; \
-      $(ECHO) '$(IDXFILE): $<'; \
-      $(ECHO); \
-      $(ECHO) '$(PREV_IDXFILE): $(IDXFILE)'; \
-      $(ECHO); \
-      $(ECHO) '$(INDFILE): $(PREV_IDXFILE)'; \
-      $(ECHO); \
-      $(ECHO) '$(DVIFILE): $(INDFILE)') >>$@)
+        $(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 - .bbl, .bib'; \
-      $(ECHO) '$(PREV_AUXFILE): $(AUXFILE)'; \
-      $(ECHO); \
-      $(ECHO) '$(DVIFILE): $(BBLFILE)'; \
-      $(ECHO); \
-      $(ECHO) '$(BBLFILE): $(bibdb)') >>$@)
+        $(ECHO); \
+        $(ECHO) '# Bibliography files: .aux, BIBDB -> .bbl -> .div'; \
+        $(ECHO) '$(BBLFILE): $(bibdb) $(AUXFILE)'; \
+        $(ECHO); \
+        $(ECHO) '$(PREV_BBLFILE): $(BBLFILE)'; \
+    ) >>$@)
 
 # 変数TARGETSで指定されたターゲットファイルに対応する
 # .dファイルをインクルードし、依存関係を取得する
@@ -187,16 +212,17 @@ ifeq (,$(filter %clean %.xbb %.d,$(MAKECMDGOALS)))
   -include $(addsuffix .d,$(basename $(TARGETS)))
 endif
 
-# dviファイル作成
-%.dvi: %.tex
-	$(COMPILES.tex)
-
 # auxファイル作成
 %.aux: %.tex
-	$(COMPILE.tex)
+	@$(COMPILE.tex)
 
+# prev_auxファイル作成
 %.prev_aux: %.aux
-	-$(CMP) $@ $< || $(CP) $< $@
+	@$(CMPPREV)
+
+# dviファイル作成
+%.dvi: %.prev_aux
+	$(COMPILES.tex)
 
 # PDFファイル作成
 %.pdf: %.dvi
@@ -218,21 +244,27 @@ endif
 
 # 索引ファイル作成
 %.idx: %.tex
-	$(COMPILE.tex)
+	@$(COMPILE.tex)
 
 %.prev_idx: %.idx
-	-$(CMP) $@ $< || $(CP) $< $@
+	@$(CMPPREV)
 
 %.ind: %.prev_idx
-	$(MENDEX) $(MENDEXFLAG) $(IDXFILE)
+	@$(COMPILE.idx)
+
+%.prev_ind: %.ind
+	@$(CMPPREV)
 
 # 文献処理用ファイル作成
 %.bbl: %.prev_aux
-	$(BIBTEX) $(BIBTEXFLAG) $(AUXFILE)
+	@$(COMPILE.bbl)
+
+%.prev_bbl: %.bbl
+	@$(CMPPREV)
 
 # tex-cleanターゲット
 tex-clean:
-	$(RM) $(addprefix *,$(TEX_INT) $(IND_INT) $(BIB_INT) .d .prev_aux .prev_idx)
+	$(RM) $(addprefix *,$(TEX_INT) $(IND_INT) $(BIB_INT) .d .prev_aux .prev_idx .prev_ind .prev_bbl)
 ifeq (,$(filter %.dvi,$(TARGETS)))
 	$(RM) *.dvi
 endif
-- 
2.18.0