# Makefile for Sphinx documentation # # PYVER needs to be major.minor, just "3" doesn't work - it will result in # issues with the amendments to PYTHONPATH and install paths (see DIST_VARS). # Use explicit "version_info" indexing since make cannot handle colon characters, and # evaluate it now to allow easier debugging when printing the variable PYVER:=$(shell python3 -c 'from sys import version_info as v; print("{0}.{1}".format(v[0], v[1]))') PYTHON = python$(PYVER) # You can set these variables from the command line. SPHINXOPTS ?= SPHINXBUILD ?= LANG=C sphinx-build PAPER ?= DOXYGEN ?= doxygen # For merging a documentation archive into a git checkout of numpy/doc # Turn a tag like v1.18.0 into 1.18 # Use sed -n -e 's/patttern/match/p' to return a blank value if no match TAG ?= $(shell git describe --tag | sed -n -e's,v\([1-9]\.[0-9]*\)\.[0-9].*,\1,p') FILES= # Internal variables. PAPEROPT_a4 = -D latex_paper_size=a4 PAPEROPT_letter = -D latex_paper_size=letter ALLSPHINXOPTS = -WT --keep-going -d build/doctrees $(PAPEROPT_$(PAPER)) \ $(SPHINXOPTS) source .PHONY: help clean html web htmlhelp latex changes linkcheck \ dist dist-build gitwash-update version-check html-build latex-build \ merge-doc show docenv #------------------------------------------------------------------------------ help: @echo "Please use \`make ' where is one of" @echo " clean to remove generated doc files and start fresh" @echo " docenv make a virtual environment in which to build docs" @echo " html to make standalone HTML files" @echo " htmlhelp to make HTML files and a HTML help project" @echo " latex to make LaTeX files, you can set PAPER=a4 or PAPER=letter" @echo " changes to make an overview over all changed/added/deprecated items" @echo " linkcheck to check all external links for integrity" @echo " dist PYVER=... to make a distribution-ready tree" @echo " gitwash-update GITWASH=path/to/gitwash update gitwash developer docs" @echo " merge-doc TAG=... to clone numpy/doc and archive documentation into it" @echo " show to show the html output in a browser" clean: -rm -rf build/* find . -name generated -type d -prune -exec rm -rf "{}" ";" docenv: $(PYTHON) -mvenv docenv ( \ . docenv/bin/activate; \ pip install -q --upgrade pip; \ pip install -q -r ../test_requirements.txt; \ pip install -q -r ../doc_requirements.txt; \ pip install -q ..; \ ) gitwash-update: rm -rf source/dev/gitwash install -d source/dev/gitwash python $(GITWASH)/gitwash_dumper.py source/dev NumPy \ --repo-name=numpy \ --github-user=numpy cat source/dev/gitwash_links.txt >> source/dev/gitwash/git_links.inc #------------------------------------------------------------------------------ # Automated generation of all documents #------------------------------------------------------------------------------ # Build the current numpy version, and extract docs from it. # We have to be careful of some issues: # # - Everything must be done using the same Python version # #SPHINXBUILD="LANG=C sphinx-build" NUMPYVER:=$(shell $(PYTHON) -c "import numpy; print(numpy.version.git_revision[:10])" 2>/dev/null) GITVER ?= $(shell cd ..; $(PYTHON) -c "import versioneer as v; print(v.get_versions()['full-revisionid'][:10])") version-check: ifeq "$(GITVER)" "Unknown" # @echo sdist build with unlabeled sources else ifeq ("", "$(NUMPYVER)") @echo numpy not found, cannot build documentation without successful \"import numpy\" @echo Try overriding the makefile PYTHON variable with '"make PYTHON=python $(MAKECMDGOALS)"' @exit 1 else ifneq ($(NUMPYVER),$(GITVER)) @echo installed numpy $(NUMPYVER) != current repo git version \'$(GITVER)\' @echo use '"make dist"' or '"GITVER=$(NUMPYVER) make $(MAKECMDGOALS) ..."' @exit 1 else # for testing # @echo installed numpy $(NUMPYVER) matches git version $(GITVER); exit 1 endif dist: build/dist.tar.gz build/dist.tar.gz: real-dist real-dist: html-build cp -r build/html build/dist cd build/html && zip -9r ../dist/numpy-html.zip . cd build/dist && tar czf ../dist.tar.gz * chmod ug=rwX,o=rX -R build/dist find build/dist -type d -print0 | xargs -0r chmod g+s merge-doc: build/dist.tar.gz ifeq "$(TAG)" "" echo tag "$(TAG)" not of the form 1.18; exit 1; endif @# Only clone if the directory does not exist @if ! test -d build/merge; then \ git clone https://github.com/numpy/doc build/merge; \ fi; @# Remove any old content and copy in the new, add it to git -rm -rf build/merge/$(TAG)/* -mkdir -p build/merge/$(TAG) @# -C changes working directory tar -C build/merge/$(TAG) -xf build/dist.tar.gz git -C build/merge add $(TAG) @# For now, the user must do this. If it is onerous, automate it and change @# the instructions in doc/HOWTO_RELEASE.rst @echo " " @echo New documentation archive added to ./build/merge. @echo Now add/modify the appropriate section after @echo " " @echo in build/merge/index.html, @echo then \"git commit\", \"git push\" #------------------------------------------------------------------------------ # Basic Sphinx generation rules for different formats #------------------------------------------------------------------------------ generate: build/generate-stamp build/generate-stamp: $(wildcard source/reference/*.rst) mkdir -p build touch build/generate-stamp html: version-check html-build html-build: generate mkdir -p build/html build/doctrees $(PYTHON) preprocess.py ifeq (, $(shell which $(DOXYGEN))) @echo "Unable to find 'Doxygen:$(DOXYGEN)', skip generating C/C++ API from comment blocks." else $(DOXYGEN) build/doxygen/Doxyfile endif $(SPHINXBUILD) -b html $(ALLSPHINXOPTS) build/html $(FILES) $(PYTHON) postprocess.py html build/html/*.html @echo @echo "Build finished. The HTML pages are in build/html." htmlhelp: generate version-check mkdir -p build/htmlhelp build/doctrees $(SPHINXBUILD) -b htmlhelp $(ALLSPHINXOPTS) build/htmlhelp $(FILES) @echo @echo "Build finished; now you can run HTML Help Workshop with the" \ ".hhp project file in build/htmlhelp." htmlhelp-build: htmlhelp build/htmlhelp/numpy.chm %.chm: %.hhp -hhc.exe $^ qthelp: generate version-check mkdir -p build/qthelp build/doctrees $(SPHINXBUILD) -b qthelp $(ALLSPHINXOPTS) build/qthelp $(FILES) latex: version-check latex-build latex-build: generate mkdir -p build/latex build/doctrees $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) build/latex $(FILES) $(PYTHON) postprocess.py tex build/latex/*.tex perl -pi -e 's/LATEXOPTS =/LATEXOPTS ?= --halt-on-error/' build/latex/Makefile @echo @echo "Build finished; the LaTeX files are in build/latex." @echo "Run \`make all-pdf' or \`make all-ps' in that directory to" \ "run these through (pdf)latex." coverage: build version-check mkdir -p build/coverage build/doctrees $(SPHINXBUILD) -b coverage $(ALLSPHINXOPTS) build/coverage $(FILES) @echo "Coverage finished; see c.txt and python.txt in build/coverage" changes: generate version-check mkdir -p build/changes build/doctrees $(SPHINXBUILD) -b changes $(ALLSPHINXOPTS) build/changes $(FILES) @echo @echo "The overview file is in build/changes." linkcheck: generate version-check mkdir -p build/linkcheck build/doctrees $(SPHINXBUILD) -b linkcheck $(ALLSPHINXOPTS) build/linkcheck $(FILES) @echo @echo "Link check complete; look for any errors in the above output " \ "or in build/linkcheck/output.txt." texinfo: $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) build/texinfo @echo @echo "Build finished. The Texinfo files are in build/texinfo." @echo "Run \`make' in that directory to run these through makeinfo" \ "(use \`make info' here to do that automatically)." info: $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) build/texinfo @echo "Running Texinfo files through makeinfo..." make -C build/texinfo info @echo "makeinfo finished; the Info files are in build/texinfo." show: @python -c "import webbrowser; webbrowser.open_new_tab('file://$(PWD)/build/html/index.html')"