X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?a=blobdiff_plain;ds=sidebyside;f=latex_mk%2Flatex.mk;h=07625dc6ef911744a1184a9c06bd397a842522fa;hb=119ed2bf50db8ad221b1fe82756259bebe2757e5;hp=bcdb34d7b6df79e143121a246e877bdb1705bcf8;hpb=684b918941a0b5d2a7646e66c262442e08f6166e;p=makefiles.git diff --git a/latex_mk/latex.mk b/latex_mk/latex.mk index bcdb34d..07625dc 100644 --- a/latex_mk/latex.mk +++ b/latex_mk/latex.mk @@ -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)