Blame doc/Makefile

Packit 7a8e5e
# Makefile for Sphinx documentation
Packit 7a8e5e
#
Packit 7a8e5e
Packit 7a8e5e
PYVER = 2.7
Packit 7a8e5e
PYTHON = python$(PYVER)
Packit 7a8e5e
Packit 7a8e5e
# You can set these variables from the command line.
Packit 7a8e5e
SPHINXOPTS    =
Packit 7a8e5e
SPHINXBUILD   = LANG=C sphinx-build
Packit 7a8e5e
PAPER         =
Packit 7a8e5e
Packit 7a8e5e
FILES=
Packit 7a8e5e
Packit 7a8e5e
# Internal variables.
Packit 7a8e5e
PAPEROPT_a4     = -D latex_paper_size=a4
Packit 7a8e5e
PAPEROPT_letter = -D latex_paper_size=letter
Packit 7a8e5e
ALLSPHINXOPTS   = -d build/doctrees $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) source
Packit 7a8e5e
Packit 7a8e5e
.PHONY: help clean html web pickle htmlhelp latex changes linkcheck \
Packit 7a8e5e
        dist dist-build gitwash-update
Packit 7a8e5e
Packit 7a8e5e
#------------------------------------------------------------------------------
Packit 7a8e5e
Packit 7a8e5e
help:
Packit 7a8e5e
	@echo "Please use \`make <target>' where <target> is one of"
Packit 7a8e5e
	@echo "  html      to make standalone HTML files"
Packit 7a8e5e
	@echo "  html-scipyorg  to make standalone HTML files with scipy.org theming"
Packit 7a8e5e
	@echo "  pickle    to make pickle files (usable by e.g. sphinx-web)"
Packit 7a8e5e
	@echo "  htmlhelp  to make HTML files and a HTML help project"
Packit 7a8e5e
	@echo "  latex     to make LaTeX files, you can set PAPER=a4 or PAPER=letter"
Packit 7a8e5e
	@echo "  changes   to make an overview over all changed/added/deprecated items"
Packit 7a8e5e
	@echo "  linkcheck to check all external links for integrity"
Packit 7a8e5e
	@echo "  dist PYVER=... to make a distribution-ready tree"
Packit 7a8e5e
	@echo "  gitwash-update GITWASH=path/to/gitwash  update gitwash developer docs"
Packit 7a8e5e
	@echo "  upload USERNAME=... RELEASE=... to upload built docs to docs.scipy.org"
Packit 7a8e5e
Packit 7a8e5e
clean:
Packit 7a8e5e
	-rm -rf build/* source/reference/generated
Packit 7a8e5e
Packit 7a8e5e
gitwash-update:
Packit 7a8e5e
	rm -rf source/dev/gitwash
Packit 7a8e5e
	install -d source/dev/gitwash
Packit 7a8e5e
	python $(GITWASH)/gitwash_dumper.py source/dev NumPy \
Packit 7a8e5e
	    --repo-name=numpy \
Packit 7a8e5e
	    --github-user=numpy
Packit 7a8e5e
	cat source/dev/gitwash_links.txt >> source/dev/gitwash/git_links.inc
Packit 7a8e5e
Packit 7a8e5e
#------------------------------------------------------------------------------
Packit 7a8e5e
# Automated generation of all documents
Packit 7a8e5e
#------------------------------------------------------------------------------
Packit 7a8e5e
Packit 7a8e5e
# Build the current numpy version, and extract docs from it.
Packit 7a8e5e
# We have to be careful of some issues:
Packit 7a8e5e
# 
Packit 7a8e5e
# - Everything must be done using the same Python version
Packit 7a8e5e
# - We must use eggs (otherwise they might override PYTHONPATH on import).
Packit 7a8e5e
# - Different versions of easy_install install to different directories (!)
Packit 7a8e5e
#
Packit 7a8e5e
Packit 7a8e5e
Packit 7a8e5e
INSTALL_DIR = $(CURDIR)/build/inst-dist/
Packit 7a8e5e
INSTALL_PPH = $(INSTALL_DIR)/lib/python$(PYVER)/site-packages:$(INSTALL_DIR)/local/lib/python$(PYVER)/site-packages:$(INSTALL_DIR)/lib/python$(PYVER)/dist-packages:$(INSTALL_DIR)/local/lib/python$(PYVER)/dist-packages
Packit 7a8e5e
UPLOAD_DIR=/srv/docs_scipy_org/doc/numpy-$(RELEASE)
Packit 7a8e5e
Packit 7a8e5e
DIST_VARS=SPHINXBUILD="LANG=C PYTHONPATH=$(INSTALL_PPH) python$(PYVER) `which sphinx-build`" PYTHON="PYTHONPATH=$(INSTALL_PPH) python$(PYVER)" SPHINXOPTS="$(SPHINXOPTS)"
Packit 7a8e5e
Packit 7a8e5e
dist:
Packit 7a8e5e
	make $(DIST_VARS) real-dist
Packit 7a8e5e
Packit 7a8e5e
real-dist: dist-build html html-scipyorg
Packit 7a8e5e
	test -d build/latex || make latex
Packit 7a8e5e
	make -C build/latex all-pdf
Packit 7a8e5e
	-test -d build/htmlhelp || make htmlhelp-build
Packit 7a8e5e
	-rm -rf build/dist
Packit 7a8e5e
	cp -r build/html-scipyorg build/dist
Packit 7a8e5e
	cd build/html && zip -9r ../dist/numpy-html.zip .
Packit 7a8e5e
	cp build/latex/numpy-ref.pdf build/dist
Packit 7a8e5e
	cp build/latex/numpy-user.pdf build/dist
Packit 7a8e5e
	cd build/dist && tar czf ../dist.tar.gz *
Packit 7a8e5e
	chmod ug=rwX,o=rX -R build/dist
Packit 7a8e5e
	find build/dist -type d -print0 | xargs -0r chmod g+s
Packit 7a8e5e
Packit 7a8e5e
dist-build:
Packit 7a8e5e
	rm -f ../dist/*.egg
Packit 7a8e5e
	cd .. && $(PYTHON) setup.py bdist_egg
Packit 7a8e5e
	install -d $(subst :, ,$(INSTALL_PPH))
Packit 7a8e5e
	$(PYTHON) `which easy_install` --prefix=$(INSTALL_DIR) ../dist/*.egg
Packit 7a8e5e
Packit 7a8e5e
upload:
Packit 7a8e5e
	# SSH must be correctly configured for this to work.
Packit 7a8e5e
	# Assumes that ``make dist`` was already run
Packit 7a8e5e
	# Example usage: ``make upload USERNAME=rgommers RELEASE=1.10.1``
Packit 7a8e5e
	ssh $(USERNAME)@docs.scipy.org mkdir $(UPLOAD_DIR)
Packit 7a8e5e
	scp build/dist.tar.gz $(USERNAME)@docs.scipy.org:$(UPLOAD_DIR)
Packit 7a8e5e
	ssh $(USERNAME)@docs.scipy.org tar xvC $(UPLOAD_DIR) \
Packit 7a8e5e
	    -zf $(UPLOAD_DIR)/dist.tar.gz
Packit 7a8e5e
	ssh $(USERNAME)@docs.scipy.org mv $(UPLOAD_DIR)/numpy-ref.pdf \
Packit 7a8e5e
	    $(UPLOAD_DIR)/numpy-ref-$(RELEASE).pdf
Packit 7a8e5e
	ssh $(USERNAME)@docs.scipy.org mv $(UPLOAD_DIR)/numpy-user.pdf \
Packit 7a8e5e
	    $(UPLOAD_DIR)/numpy-user-$(RELEASE).pdf
Packit 7a8e5e
	ssh $(USERNAME)@docs.scipy.org mv $(UPLOAD_DIR)/numpy-html.zip \
Packit 7a8e5e
	    $(UPLOAD_DIR)/numpy-html-$(RELEASE).zip
Packit 7a8e5e
	ssh $(USERNAME)@docs.scipy.org rm $(UPLOAD_DIR)/dist.tar.gz
Packit 7a8e5e
	ssh $(USERNAME)@docs.scipy.org ln -snf numpy-$(RELEASE) /srv/docs_scipy_org/doc/numpy
Packit 7a8e5e
Packit 7a8e5e
#------------------------------------------------------------------------------
Packit 7a8e5e
# Basic Sphinx generation rules for different formats
Packit 7a8e5e
#------------------------------------------------------------------------------
Packit 7a8e5e
Packit 7a8e5e
generate: build/generate-stamp
Packit 7a8e5e
build/generate-stamp: $(wildcard source/reference/*.rst)
Packit 7a8e5e
	mkdir -p build
Packit 7a8e5e
	touch build/generate-stamp
Packit 7a8e5e
Packit 7a8e5e
html: generate
Packit 7a8e5e
	mkdir -p build/html build/doctrees
Packit 7a8e5e
	$(SPHINXBUILD) -b html $(ALLSPHINXOPTS) build/html $(FILES)
Packit 7a8e5e
	$(PYTHON) postprocess.py html build/html/*.html
Packit 7a8e5e
	@echo
Packit 7a8e5e
	@echo "Build finished. The HTML pages are in build/html."
Packit 7a8e5e
Packit 7a8e5e
html-scipyorg:
Packit 7a8e5e
	mkdir -p build/html build/doctrees
Packit 7a8e5e
	$(SPHINXBUILD) -t scipyorg -b html $(ALLSPHINXOPTS) build/html-scipyorg $(FILES)
Packit 7a8e5e
	@echo
Packit 7a8e5e
	@echo "Build finished. The HTML pages are in build/html."
Packit 7a8e5e
Packit 7a8e5e
pickle: generate
Packit 7a8e5e
	mkdir -p build/pickle build/doctrees
Packit 7a8e5e
	$(SPHINXBUILD) -b pickle $(ALLSPHINXOPTS) build/pickle $(FILES)
Packit 7a8e5e
	@echo
Packit 7a8e5e
	@echo "Build finished; now you can process the pickle files or run"
Packit 7a8e5e
	@echo "  sphinx-web build/pickle"
Packit 7a8e5e
	@echo "to start the sphinx-web server."
Packit 7a8e5e
Packit 7a8e5e
web: pickle
Packit 7a8e5e
Packit 7a8e5e
htmlhelp: generate
Packit 7a8e5e
	mkdir -p build/htmlhelp build/doctrees
Packit 7a8e5e
	$(SPHINXBUILD) -b htmlhelp $(ALLSPHINXOPTS) build/htmlhelp $(FILES)
Packit 7a8e5e
	@echo
Packit 7a8e5e
	@echo "Build finished; now you can run HTML Help Workshop with the" \
Packit 7a8e5e
	      ".hhp project file in build/htmlhelp."
Packit 7a8e5e
Packit 7a8e5e
htmlhelp-build: htmlhelp build/htmlhelp/numpy.chm
Packit 7a8e5e
%.chm: %.hhp
Packit 7a8e5e
	-hhc.exe $^
Packit 7a8e5e
Packit 7a8e5e
qthelp: generate
Packit 7a8e5e
	mkdir -p build/qthelp build/doctrees
Packit 7a8e5e
	$(SPHINXBUILD) -b qthelp $(ALLSPHINXOPTS) build/qthelp $(FILES)
Packit 7a8e5e
Packit 7a8e5e
latex: generate
Packit 7a8e5e
	mkdir -p build/latex build/doctrees
Packit 7a8e5e
	$(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) build/latex $(FILES)
Packit 7a8e5e
	$(PYTHON) postprocess.py tex build/latex/*.tex
Packit 7a8e5e
	perl -pi -e 's/\t(latex.*|pdflatex) (.*)/\t-$$1 -interaction batchmode $$2/' build/latex/Makefile
Packit 7a8e5e
	@echo
Packit 7a8e5e
	@echo "Build finished; the LaTeX files are in build/latex."
Packit 7a8e5e
	@echo "Run \`make all-pdf' or \`make all-ps' in that directory to" \
Packit 7a8e5e
	      "run these through (pdf)latex."
Packit 7a8e5e
Packit 7a8e5e
coverage: build
Packit 7a8e5e
	mkdir -p build/coverage build/doctrees
Packit 7a8e5e
	$(SPHINXBUILD) -b coverage $(ALLSPHINXOPTS) build/coverage $(FILES)
Packit 7a8e5e
	@echo "Coverage finished; see c.txt and python.txt in build/coverage"
Packit 7a8e5e
Packit 7a8e5e
changes: generate
Packit 7a8e5e
	mkdir -p build/changes build/doctrees
Packit 7a8e5e
	$(SPHINXBUILD) -b changes $(ALLSPHINXOPTS) build/changes $(FILES)
Packit 7a8e5e
	@echo
Packit 7a8e5e
	@echo "The overview file is in build/changes."
Packit 7a8e5e
Packit 7a8e5e
linkcheck: generate
Packit 7a8e5e
	mkdir -p build/linkcheck build/doctrees
Packit 7a8e5e
	$(SPHINXBUILD) -b linkcheck $(ALLSPHINXOPTS) build/linkcheck $(FILES)
Packit 7a8e5e
	@echo
Packit 7a8e5e
	@echo "Link check complete; look for any errors in the above output " \
Packit 7a8e5e
	      "or in build/linkcheck/output.txt."
Packit 7a8e5e
Packit 7a8e5e
texinfo:
Packit 7a8e5e
	$(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) build/texinfo
Packit 7a8e5e
	@echo
Packit 7a8e5e
	@echo "Build finished. The Texinfo files are in build/texinfo."
Packit 7a8e5e
	@echo "Run \`make' in that directory to run these through makeinfo" \
Packit 7a8e5e
	      "(use \`make info' here to do that automatically)."
Packit 7a8e5e
Packit 7a8e5e
info:
Packit 7a8e5e
	$(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) build/texinfo
Packit 7a8e5e
	@echo "Running Texinfo files through makeinfo..."
Packit 7a8e5e
	make -C build/texinfo info
Packit 7a8e5e
	@echo "makeinfo finished; the Info files are in build/texinfo."