latex.mkのコメントを修正
[makefiles.git] / latex_mk / latex.mk
1 # latex.mk
2 # LaTeX処理(コンパイル)を行う
3 #
4 # == 使い方 ==
5 # 1. texソースファイルと同じディレクトリーに本ファイル(latex.mk)をコピーする
6 # 2. Makefileに変数TEXTARGETS と「include latex.mk」を記述する
7 # 3. texソースファイルと同じディレクトリーで、make コマンドを実行する
8 #
9 # == 機能 ==
10 # - 読み込むべき中間ファイルがないことや相互参照未定義の警告がある場合、LaTeX処理を最大4回繰り返す
11 # - \includegraphics命令がTeXファイルに含まれる場合、グラフィックファイルを挿入
12 #   -- 挿入されたグラフィックファイルが更新されたときは、処理を開始
13 #   -- 挿入されたグラフィックファイルがないときは、処理を中止
14 #   -- 挿入されたグラフィックファイルに対するバウンディング情報ファイル(.xbb)を作成
15 # - \include、\input命令がTeXファイルに含まれる場合、TeXファイルを挿入
16 #   -- 挿入されたTeXファイルが更新されたときは、処理を開始
17 #   -- 挿入されたTeXファイルがないときは、処理を中止
18 # - \makeindex命令が含まれる場合、mendexで索引を作成
19 # - \bibliography命令が含まれる場合、BiBTeXで文献一覧を作成
20 #
21 # == 擬似ターゲット ==
22 # - tex-clean: TeX中間ファイル(auxなど)を削除。ターゲットに.dviが含まれていないときは.dviファイルを削除
23 # - xbb-clean: バウンディング情報ファイル(.xbb)を削除
24 # - tex-distclean: TeX中間ファイル、バウンディング情報ファイル、ターゲットファイル(PDF、.dvi)を削除
25 #
26 # === Makefile -- sample ===
27 # TEXTARGETS := report.tex
28 #
29 # all: $(TEXTARGETS)
30 #
31 # include latex.mk
32
33 #debug
34 #SHELL = /bin/sh -x
35
36 .PHONY: tex-warning tex-clean tex-distclean
37
38 # シェルコマンド
39 CAT := cat
40 CMP := cmp -s
41 CP := cp
42 ECHO := /bin/echo
43 GREP := grep
44 SED := sed
45 SEQ := seq
46
47 # LaTeXコマンド
48 LATEX := platex
49 DVIPDFMX := dvipdfmx
50 EXTRACTBB := extractbb
51 BIBTEX := pbibtex
52 MENDEX := mendex
53 KPSEWHICH := kpsewhich
54
55 #LaTeXオプション
56 LATEXFLAG ?=
57 DVIPDFMXFLAG ?=
58 EXTRACTBBFLAGS ?=
59 BIBTEXFLAG ?=
60 MENDEXFLAG ?=
61
62 tex-warning:
63         @$(ECHO) "check current directory, or set TEXTARGET in Makefile."
64
65 # ファイル名から拡張子を除いた部分
66 BASE = $(basename $<)
67
68 # TeX中間ファイルの拡張子
69 #   .aux: 相互参照
70 #   .fls: tex -recorderで生成されるファイルリスト
71 #   .lof: 図リスト(\tableoffigures)
72 #   .lot: 表リスト(\tableoftables)
73 #   .out: hyperrefパッケージ
74 #   .toc: 目次(\tableofcontents)
75 #   .log: ログ
76 TEX_INT := .aux .lof .lot .out .toc .log
77 # 索引中間ファイルの拡張子
78 #   .idx: auxから作成
79 #   .ind: idxから作成
80 #   .ilg: 索引ログ
81 IND_INT := .idx .ind .ilg
82 # BiBTeX中間ファイルの拡張子
83 #   .bbl: auxから作成
84 #   .blg: BiBTeXログ
85 BIB_INT := .bbl .blg
86
87 ALL_INTERFILES = $(addprefix *,$(TEX_INT) $(IND_INT) $(BIB_INT) .fls .d .*_prev)
88
89 .SECONDARY: $(wildcard ALL_INTERFILES)
90
91 # ファイル名から拡張子を除いた部分
92 BASE = $(basename $<)
93
94 # .flsファイルから、INPUT/OUTPUTファイルを取得。ただし、$TEXMFDISTのファイルを除く
95 IOFILES = \
96   $(sort $(filter-out $(BASE).tex $(BASE).aux, \
97     $(shell \
98       $(SED) -n -e 's/^\(INPUT\|OUTPUT\) \(.\{1,\}\)/\2/gp' $(BASE).fls | \
99       $(GREP) -v `$(KPSEWHICH) -expand-var '$$TEXMFROOT'` \
100   )))
101
102 # .flsファイルから、INPUTファイルを取得。ただし、$TEXMFDISTのファイルを除く
103 INPUTFILES = \
104   $(sort $(filter-out $(BASE).tex $(BASE).aux, \
105     $(shell \
106       $(SED) -n -e 's/^INPUT \(.\{1,\}\)/\1/gp' $(BASE).fls | \
107       $(GREP) -v `$(KPSEWHICH) -expand-var '$$TEXMFROOT'` \
108   )))
109
110 # $(BASE).texで使われるLaTeX中間ファイル
111 INTERFILES = \
112   $(sort \
113     $(subst .idx,.ind, \
114       $(filter $(addprefix $(BASE),.lof .lot .out .toc .idx .ind .bbl),$(IOFILES)) \
115   ))
116
117 INTERFILES_PREV = $(addsuffix _prev,$(INTERFILES))
118
119 # TeXファイル - .tex
120 TEXFILES = $(filter %.tex,$(INPUTFILES))
121
122 # 画像ファイル - .pdf、.eps、.jpg/jpeg、.png、および.xbb
123 GRAPHICFILES = \
124   $(sort \
125     $(shell \
126       $(SED) -e '/^\s*%/d' -e 's/\([^\]\)\s*%.*/\1/g' $(BASE).tex $(TEXFILES) | \
127       $(SED) -e '/\\begin{verbatim}/,/\\end{verbatim}/d' | \
128       $(SED) -n -e 's/\\includegraphics\(\[[^]]*\]\)\{0,1\}{[^}]*}/&\n/pg' | \
129       $(SED) -n -e 's/.*{\([^}]*\)}$$/\1/p' \
130     ) \
131     $(filter %.pdf %.eps %.jpeg %.jpg %.png %.bmp,$(INPUTFILES)) \
132   )
133
134 # そのほかの読み込みファイル
135 OTHERFILES = $(filter-out %.aux $(INTERFILES) $(TEXFILES) $(GRAPHICFILES),$(INPUTFILES))
136
137 # \bibliography命令で読み込まれる文献データベースファイルをTeXファイルから検索する
138 bibdb = \
139   $(addsuffix .bib,$(basename $(sort $(shell \
140      $(SED) -e '/^\s*%/d' -e 's/\([^\]\)\s*%.*/\1/g' $(BASE).tex $(TEXFILES) | \
141      $(SED) -e '/\\begin{verbatim}/,/\\end{verbatim}/d' | \
142      $(SED) -n -e 's/\\bibliography\(\[[^]]*\]\)\{0,1\}{[^}]*}/&\n/pg' | \
143      $(SED) -n -e 's/.*{\([^}]*\)}$$/\1/p' | \
144      $(SED) -e 's/,/ /g' \
145    ))))
146
147 # LaTeX処理(コンパイル)
148 LATEXCMD = $(LATEX) -interaction=batchmode $(LATEXFLAG) $(BASE).tex
149 COMPILE.tex = $(ECHO) $(LATEXCMD); $(LATEXCMD) >/dev/null 2>&1 || ($(CAT) $(BASE).log; exit 1)
150
151 FLSCMD = $(LATEX) -interaction=nonstopmode -recorder $(BASE).tex
152 CREATE.fls = $(ECHO) $(FLSCMD); $(FLSCMD) 1>/dev/null 2>&1; $(RM) $(addprefix $(BASE),$(TEX_INT) $(IND_INT) $(BIB_INT) .dvi)
153
154 # 相互参照未定義の警告
155 WARN_UNDEFREF := 'There were undefined references\.'
156
157 # LaTeX処理
158 # ログファイルに警告がある場合は警告がなくなるまで、最大CNTで指定された回数分、処理を実行する
159 CNT := 3
160 COMPILES.tex = \
161   @(for i in `$(SEQ) 1 $(CNT)`; do \
162       if test -s $@ -a -s $(BASE).log; then \
163         $(GREP) -e $(WARN_UNDEFREF) $(BASE).log || exit 0; \
164       else \
165         $(ECHO) '$@ and/or $(BASE).log does not exist.'; \
166       fi; \
167       $(COMPILE.tex); \
168     done)
169
170 # DVI -> PDF
171 # 出力結果は.logファイルへ出力
172 DVIPDFCMD = $(DVIPDFMX) $(DVIPDFMXFLAG) $(BASE).dvi
173 COMPILE.dvi = $(ECHO) $(DVIPDFCMD); $(DVIPDFCMD) >>$(BASE).log 2>&1 || ($(CAT) $(BASE).log; exit 1)
174
175 # 索引中間ファイル(.ind)作成
176 MENDEXCMD = $(MENDEX) $(MENDEXFLAG) $(BASE).idx
177 COMPILE.idx = $(ECHO) $(MENDEXCMD); $(MENDEXCMD) >/dev/null 2>&1 || ($(CAT) $(BASE).ilg; exit 1)
178
179 # 文献リスト中間ファイル(.bbl)作成
180 BIBTEXCMD = $(BIBTEX) $(BIBTEXFLAG) $(BASE).aux
181 COMPILE.bib = $(ECHO) $(BIBTEXCMD); $(BIBTEXCMD) >/dev/null 2>&1 || ($(CAT) $(BASE).blg; exit 1)
182
183 # ターゲットファイルと必須ファイルを比較し、内容が異なる場合はターゲットファイルの内容を必須ファイルに置き換える
184 CMPPREV = $(CMP) $@ $< || $(CP) -p -v $< $@
185
186 # 依存関係を.dファイルに書き出す
187 %.d: %.fls_prev
188         @$(ECHO) '$@ is created by scanning $(subst _prev,,$^).'
189     # .dファイルの依存関係
190         @$(ECHO) '$(BASE).d: $(BASE).fls_prev' >$@
191     # \includeまたは\input命令で読み込まれるTeXファイルの依存関係
192         $(if $(TEXFILES),@( \
193       $(ECHO); \
194       $(ECHO) '# Files called from \include or \input - .tex'; \
195       $(ECHO) '$(BASE).aux: $(TEXFILES)'; \
196     ) >>$@)
197     # そのほかのファイル(TEXMFROOT以外にあるスタイルファイルなど)の依存関係
198         $(if $(OTHERFILES),@( \
199       $(ECHO); \
200       $(ECHO) '# Files other'; \
201       $(ECHO) '$(BASE).aux: $(OTHERFILES)'; \
202     ) >>$@)
203     # 画像ファイルの依存関係
204         $(if $(GRAPHICFILES),@( \
205       $(ECHO); \
206       $(ECHO) '# IncludeGraphic Files - .pdf, .eps, .jpeg/.jpg, .png'; \
207       $(ECHO) '#           .xbb Files - .pdf, .jpeg/.jpg, .png'; \
208       $(ECHO) '$(BASE).aux: $(GRAPHICFILES)'; \
209       $(if $(filter-out %.eps,$(GRAPHICFILES)), \
210         $(ECHO); \
211         $(ECHO) '$(BASE).aux: $(addsuffix .xbb,$(basename $(filter-out %.eps,$(GRAPHICFILES))))'; \
212       ) \
213     ) >>$@)
214     # 文献処理用ファイルの依存関係
215         $(if $(bibdb),@( \
216         $(ECHO); \
217         $(ECHO) '# Bibliography files: .aux, BIBDB -> .bbl -> .div'; \
218         $(ECHO) '$(BASE).bbl: $(bibdb) $(BASE).tex'; \
219       ) >>$@)
220     # 中間ファイルの依存関係
221         $(if $(strip $(INTERFILES) $(bibdb)),@( \
222       $(ECHO); \
223       $(ECHO) '# LaTeX Intermediate Files'; \
224       $(ECHO) '$(BASE).dvi:: $(sort $(INTERFILES_PREV) $(if $(bibdb),$(BASE).bbl_prev))'; \
225       $(ECHO) ' @$$(COMPILE.tex)'; \
226       $(ECHO); \
227       $(ECHO) '$(BASE).dvi:: $(BASE).aux'; \
228       $(ECHO) ' @$$(COMPILES.tex)'; \
229     ) >>$@)
230
231 # 変数TEXTARGETSで指定されたターゲットファイルに対応する
232 # .dファイルをインクルードし、依存関係を取得する
233 # ターゲット末尾に clean、.xbb、.tex、.d が含まれている場合は除く
234 ifeq (,$(filter %clean %.xbb %.tex %.d %.fls %.fls_prev,$(MAKECMDGOALS)))
235   -include $(addsuffix .d,$(basename $(TEXTARGETS)))
236 endif
237
238 # auxファイル作成
239 %.aux: %.tex
240         @$(COMPILE.tex)
241
242 %.dvi: %.aux
243         @$(COMPILES.tex)
244
245 %.dvi: %.tex
246         @$(COMPILE.tex)
247         @$(COMPILES.tex)
248
249 # PDFファイル作成
250 %.pdf: %.dvi
251         @$(COMPILE.dvi)
252
253 # バウンディング情報ファイル作成
254 # pdf、jpeg/jpg、pngファイルに対応
255 extractbb:
256         $(MAKE) -s $(addsuffix .xbb,$(basename $(wildcard $(addprefix *,.pdf .jpg .jpeg .png))))
257
258 %.xbb: %.pdf
259         $(EXTRACTBB) $(EXTRACTBBFLAGS) $<
260
261 %.xbb: %.jpeg
262         $(EXTRACTBB) $(EXTRACTBBFLAGS) $<
263
264 %.xbb: %.jpg
265         $(EXTRACTBB) $(EXTRACTBBFLAGS) $<
266
267 %.xbb: %.png
268         $(EXTRACTBB) $(EXTRACTBBFLAGS) $<
269
270 # ファイル一覧作成
271 %.fls: %.tex
272         @-$(CREATE.fls)
273
274 %.fls_prev: %.fls
275         @$(CMPPREV)
276
277 # 目次中間ファイル作成
278 %.toc: %.tex
279         @$(MAKE) -s $(BASE).aux
280
281 %.toc_prev: %.toc
282         @$(CMPPREV)
283
284 # 図リスト中間ファイル作成
285 %.lof: %.tex
286         @$(MAKE) -s $(BASE).aux
287
288 %.lof_prev: %.lof
289         @$(CMPPREV)
290
291 # 表リスト中間ファイル作成
292 %.lot: %.tex
293         @$(MAKE) -s $(BASE).aux
294
295 %.lot_prev: %.lot
296         @$(CMPPREV)
297
298 # 索引中間ファイル作成
299 %.idx: %.tex
300         @$(MAKE) -s $(BASE).aux
301
302 %.idx_prev: %.idx
303         @$(CMPPREV)
304
305 %.ind: %.idx_prev
306         @$(COMPILE.idx)
307
308 %.ind_prev: %.ind
309         @$(CMPPREV)
310
311 # BiBTeX中間ファイル作成
312 %.bbl: %.tex
313         @$(MAKE) -s $(BASE).aux
314         @$(COMPILE.bib)
315
316 %.bbl_prev: %.bbl
317         @$(CMPPREV)
318
319 # hyperref中間ファイル作成
320 %.out: %.tex
321         @$(MAKE) -s $(BASE).aux
322
323 %.out_prev: %.out
324         @$(CMPPREV)
325
326 # tex-cleanターゲット
327 tex-clean:
328         $(RM) $(ALL_INTERFILES)
329 ifeq (,$(filter %.dvi,$(TEXTARGETS)))
330         $(RM) *.dvi
331 endif
332
333 # xbb-cleanターゲット
334 xbb-clean:
335         $(RM) *.xbb
336
337 # tex-distcleanターゲット
338 tex-distclean: tex-clean xbb-clean
339 ifneq (,$(filter %.dvi,$(TEXTARGETS)))
340         $(RM) *.dvi
341 endif
342         $(RM) $(TEXTARGETS)