-
Notifications
You must be signed in to change notification settings - Fork 76
/
Copy pathMakefile
40 lines (32 loc) · 1.3 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# Minimal makefile for Sphinx documentation
#
# You can set these variables from the command line
SPHINXBUILD = sphinx-build
SPHINXOPTS = -j auto -n
SOURCEDIR = source
BUILDDIR = build
DOCNAME = GMT_docs
HTML = dirhtml
# Put it first so that "make" without argument is like "make help"
help:
@$(SPHINXBUILD) -M help "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O)
.PHONY: help Makefile build build_html build_pdf optimize_pdf serve
# Catch-all target: route all unknown targets to Sphinx using the new
# "make mode" option. $(O) is meant as a shortcut for $(SPHINXOPTS)
%: Makefile
@$(SPHINXBUILD) -M $@ "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O)
htmlzip: html
cp -r $(BUILDDIR)/html $(BUILDDIR)/$(DOCNAME)
cd $(BUILDDIR); zip -r $(DOCNAME).zip $(DOCNAME); rm -r $(DOCNAME); cd ..
pdf: latex
tectonic $(BUILDDIR)/latex/$(DOCNAME).tex
mv $(BUILDDIR)/latex/$(DOCNAME).pdf $(BUILDDIR)/$(DOCNAME).pdf
# reduce file size of the final PDF documentation
optimize_pdf: pdf
gs -sDEVICE=pdfwrite -dCompatibilityLevel=1.4 -dPDFSETTINGS=/prepress \
-dNOPAUSE -dQUIET -dBATCH \
-sOutputFile=$(BUILDDIR)/$(DOCNAME).optimized.pdf \
$(BUILDDIR)/$(DOCNAME).pdf
mv $(BUILDDIR)/$(DOCNAME).optimized.pdf $(BUILDDIR)/$(DOCNAME).pdf
serve: $(HTML)
cd $(BUILDDIR)/$(HTML) && python -m http.server