From 409605d9b7609d83f4b0d414b2e4d26b57aff204 Mon Sep 17 00:00:00 2001 From: jfbu Date: Sun, 23 Oct 2016 12:58:10 +0200 Subject: [PATCH] Use latexmk for pdf (and dvi) targets (on unixen) --- sphinx/texinputs/Makefile_t | 90 +++++++++++++++++++----------------- sphinx/texinputs/latexmkjarc | 7 +++ sphinx/texinputs/latexmkrc | 9 ++++ 3 files changed, 64 insertions(+), 42 deletions(-) create mode 100644 sphinx/texinputs/latexmkjarc create mode 100644 sphinx/texinputs/latexmkrc diff --git a/sphinx/texinputs/Makefile_t b/sphinx/texinputs/Makefile_t index ffec3662c..b1975573c 100644 --- a/sphinx/texinputs/Makefile_t +++ b/sphinx/texinputs/Makefile_t @@ -2,8 +2,13 @@ ALLDOCS = $(basename $(wildcard *.tex)) ALLPDF = $(addsuffix .pdf,$(ALLDOCS)) +{% if latex_engine == 'xelatex' -%} +ALLDVI = +{% else -%} ALLDVI = $(addsuffix .dvi,$(ALLDOCS)) +{% endif -%} ALLPS = $(addsuffix .ps,$(ALLDOCS)) +ALLIMGS = $(wildcard *.png *.gif *.jpg *.jpeg) # Prefix for archive names ARCHIVEPRREFIX = @@ -12,29 +17,52 @@ LATEXOPTS = # format: pdf or dvi FMT = pdf -LATEX = latex -PDFLATEX = {{ latex_engine }} -MAKEINDEX = makeindex +{% if latex_engine == 'platex' -%} +# latexmkrc is read then overridden by latexmkjarc +LATEX = latexmk -r latexmkjarc -dvi +PDFLATEX = latexmk -r latexmkjarc -pdfdvi -dvi- -ps- +{% elif latex_engine == 'pdflatex' -%} +LATEX = latexmk -dvi +PDFLATEX = latexmk -pdf -dvi- -ps- +{% elif latex_engine == 'lualatex' -%} +LATEX = latexmk -lualatex +PDFLATEX = latexmk -pdflua -dvi- -ps- +{% elif latex_engine == 'xelatex' -%} +LATEX = latexmk -pdfxe -dvi- -ps- +PDFLATEX = $(LATEX) +{% endif %} + +%.png %.gif %.jpg %.jpeg: FORCE_MAKE + extractbb '$@' + +{% if latex_engine == 'platex' -%} +%.dvi: %.tex $(ALLIMGS) FORCE_MAKE + for f in *.pdf; do extractbb $$f; done + $(LATEX) $(LATEXOPTS) '$<' + +{% elif latex_engine != 'xelatex' -%} +%.dvi: %.tex FORCE_MAKE + $(LATEX) $(LATEXOPTS) '$<' -{% if latex_engine == 'platex' %} -all: all-pdf-ja -all-pdf: all-pdf-ja -{% else %} -all: $(ALLPDF) -all-pdf: $(ALLPDF) {% endif -%} +%.ps: %.dvi + dvips '$<' + +{% if latex_engine == 'platex' -%} +%.pdf: %.tex $(ALLIMGS) FORCE_MAKE + for f in *.pdf; do extractbb $$f; done +{%- else -%} +%.pdf: %.tex FORCE_MAKE +{%- endif %} + $(PDFLATEX) $(LATEXOPTS) '$<' + all-dvi: $(ALLDVI) + all-ps: $(ALLPS) -all-pdf-ja: - for f in *.pdf *.png *.gif *.jpg *.jpeg; do extractbb $$f; done - for f in *.tex; do platex -kanji=utf8 $(LATEXOPTS) $$f; done - for f in *.tex; do platex -kanji=utf8 $(LATEXOPTS) $$f; done - for f in *.tex; do platex -kanji=utf8 $(LATEXOPTS) $$f; done - -for f in *.idx; do mendex -U -f -d "`basename $$f .idx`.dic" -s python.ist $$f; done - for f in *.tex; do platex -kanji=utf8 $(LATEXOPTS) $$f; done - for f in *.tex; do platex -kanji=utf8 $(LATEXOPTS) $$f; done - for f in *.dvi; do dvipdfmx $$f; done +all-pdf: $(ALLPDF) + +all: $(ALLPDF) zip: all-$(FMT) mkdir $(ARCHIVEPREFIX)docs-$(FMT) @@ -57,30 +85,8 @@ bz2: tar xz: tar xz -9 -k $(ARCHIVEPREFIX)docs-$(FMT).tar -# The number of LaTeX runs is quite conservative, but I don't expect it -# to get run often, so the little extra time won't hurt. -%.dvi: %.tex - $(LATEX) $(LATEXOPTS) '$<' - $(LATEX) $(LATEXOPTS) '$<' - $(LATEX) $(LATEXOPTS) '$<' - -$(MAKEINDEX) -s python.ist '$(basename $<).idx' - $(LATEX) $(LATEXOPTS) '$<' - $(LATEX) $(LATEXOPTS) '$<' - -%.pdf: %.tex - $(PDFLATEX) $(LATEXOPTS) '$<' - $(PDFLATEX) $(LATEXOPTS) '$<' - $(PDFLATEX) $(LATEXOPTS) '$<' - -$(MAKEINDEX) -s python.ist '$(basename $<).idx' - $(PDFLATEX) $(LATEXOPTS) '$<' - $(PDFLATEX) $(LATEXOPTS) '$<' - -%.ps: %.dvi - dvips '$<' - clean: - rm -f *.log *.ind *.aux *.toc *.syn *.idx *.out *.ilg *.pla *.ps *.tar *.tar.gz *.tar.bz2 *.tar.xz $(ALLPDF) $(ALLDVI) + rm -f *.log *.ind *.aux *.toc *.syn *.idx *.out *.ilg *.pla *.ps *.tar *.tar.gz *.tar.bz2 *.tar.xz $(ALLPDF) $(ALLDVI) *.fls *.fdb_latexmk .PHONY: all all-pdf all-dvi all-ps clean zip tar gz bz2 xz -.PHONY: all-pdf-ja - +.PHONY: FORCE_MAKE diff --git a/sphinx/texinputs/latexmkjarc b/sphinx/texinputs/latexmkjarc new file mode 100644 index 000000000..4a6864e44 --- /dev/null +++ b/sphinx/texinputs/latexmkjarc @@ -0,0 +1,7 @@ +$latex = 'platex --halt-on-error --interaction=nonstopmode -kanji=utf8 %O %S'; +$dvipdf = 'dvipdfmx %O -o %D %S'; +$makeindex = 'rm -f %D; mendex -U -f -d %B.dic -s python.ist %S || echo "mendex exited with error code $? (ignoring)" && : >> %D'; +add_cus_dep( "glo", "gls", 0, "makeglo" ); +sub makeglo { + return system( "mendex -J -f -s gglo.ist -o '$_[0].gls' '$_[0].glo'" ); +} diff --git a/sphinx/texinputs/latexmkrc b/sphinx/texinputs/latexmkrc new file mode 100644 index 000000000..ddb165783 --- /dev/null +++ b/sphinx/texinputs/latexmkrc @@ -0,0 +1,9 @@ +$latex = 'latex --halt-on-error --interaction=nonstopmode %O %S'; +$pdflatex = 'pdflatex --halt-on-error --interaction=nonstopmode %O %S'; +$lualatex = 'lualatex --halt-on-error --interaction=nonstopmode %O %S'; +$xelatex = 'xelatex --no-pdf --halt-on-error --interaction=nonstopmode %O %S'; +$makeindex = 'makeindex -s python.ist %O -o %D %S'; +add_cus_dep( "glo", "gls", 0, "makeglo" ); +sub makeglo { + return system( "makeindex -s gglo.ist -o '$_[0].gls' '$_[0].glo'" ); +}