-include ../../../petscdir.mk .PHONY: default default: build package = petsc4py MODULE = PETSc PYTHON = python$(py) MPIEXEC = mpiexec # ---- .PHONY: config build test config: ${PYTHON} setup.py config ${CONFIGOPT} ${opt} build: ${PYTHON} setup.py build ${BUILDOPT} ${opt} test: ${VALGRIND} ${PYTHON} ${PWD}/test/runtests.py ${TESTOPT} ${opt} test-%: ${MPIEXEC} -n $* ${VALGRIND} ${PYTHON} ${PWD}/test/runtests.py ${TESTOPT} ${opt} .PHONY: srcbuild srcclean srcbuild: ${PYTHON} setup.py build_src ${SRCOPT} ${opt} srcclean: -${RM} src/${package}/${MODULE}.c -${RM} src/${package}/${MODULE}.h -${RM} src/${package}/${MODULE}_api.h .PHONY: clean distclean fullclean clean: ${PYTHON} setup.py clean --all distclean: clean -${RM} -r build _configtest.* *.py[co] -${RM} -r MANIFEST dist ${package}.egg-info -${RM} -r `find . -name '__pycache__'` -${RM} `find . -name '*.py[co]'` fullclean: distclean srcclean docsclean -find . -name '*~' -exec rm -f {} ';' # ---- .PHONY: install uninstall install: build ${PYTHON} setup.py install --prefix='' --user ${INSTALLOPT} uninstall: -${RM} -r $(shell ${PYTHON} -m site --user-site)/${package} -${RM} -r $(shell ${PYTHON} -m site --user-site)/${package}-*-py*.egg-info # ---- website: virtualenv -p ${PYTHON2} petsc-doc-env && . petsc-doc-env/bin/activate && ${PYTHON2} -m pip install -r docs/source/requirements.txt && make epydoc-website && deactivate .PHONY: docs docs-html docs-pdf docs-misc docs: docs-html docs-pdf docs-misc docs-html: rst2html sphinx-html epydoc-html docs-pdf: sphinx-pdf epydoc-pdf docs-misc: sphinx-man sphinx-info #it appears some of the documentation requires a python2 installation to build PYTHON2 = python2 checkdocutils: @${PYTHON} -c $$'try:\n import docutils\nexcept:\n print("Run `python -m pip install docutils` and then try this command again");exit(1)' @${PYTHON2} -c $$'try:\n import docutils\nexcept:\n print("Run `python2 -m pip install docutils` or `pip2 install docutils` or `[sudo] easy_install docutils` and then try the command again");exit(1)' @${PYTHON2} -c $$'try:\n import epydoc\nexcept:\n print("Run `python2 -m pip install epydoc` or `pip2 install epydoc` or `[sudo] easy_install epydoc` and then try the command again");exit(1)' RST2HTML = $(shell command -v rst2html || command -v rst2html.py || false) RST2HTMLOPTS = --input-encoding=utf-8 RST2HTMLOPTS += --no-compact-lists RST2HTMLOPTS += --cloak-email-addresses .PHONY: rst2html rst2html: checkdocutils ${RST2HTML} ${RST2HTMLOPTS} ./LICENSE.rst > docs/LICENSE.html ${RST2HTML} ${RST2HTMLOPTS} ./CHANGES.rst > docs/CHANGES.html ${RST2HTML} ${RST2HTMLOPTS} docs/index.rst > docs/index.html SPHINXBUILD = sphinx-build SPHINXOPTS = .PHONY: sphinx sphinx-html sphinx-pdf sphinx-man sphinx-info sphinx: sphinx-html sphinx-pdf sphinx-man sphinx-info sphinx-html: mkdir -p build/doctrees docs/usrman ${SPHINXBUILD} -b html -d build/doctrees ${SPHINXOPTS} \ docs/source docs/usrman ${RM} docs/usrman/.buildinfo sphinx-pdf: mkdir -p build/doctrees build/latex ${SPHINXBUILD} -b latex -d build/doctrees ${SPHINXOPTS} \ docs/source build/latex ${MAKE} -C build/latex all-pdf > /dev/null mv build/latex/*.pdf docs/ sphinx-man: mkdir -p build/doctrees build/man ${SPHINXBUILD} -b man -d build/doctrees ${SPHINXOPTS} \ docs/source build/man mv build/man/*.[137] docs/ sphinx-info: mkdir -p build/doctrees build/texinfo ${SPHINXBUILD} -b texinfo -d build/doctrees ${SPHINXOPTS} \ docs/source build/texinfo ${MAKE} -C build/texinfo info > /dev/null mv build/texinfo/*.info docs/ EPYDOCBUILD = ${PYTHON2} ./conf/epydocify.py EPYDOCOPTS = .PHONY: epydoc epydoc-html epydoc-pdf epydoc: epydoc-html epydoc-pdf epydoc-html: srcbuild mkdir -p docs/apiref env CFLAGS=-O0 ${PYTHON2} setup.py -q build --build-lib build/lib.py2 env PYTHONPATH=$$PWD/build/lib.py2 ${PYTHON2} -c 'import ${package}.${MODULE}' env PYTHONPATH=$$PWD/build/lib.py2 ${EPYDOCBUILD} ${EPYDOCOPTS} --html -o docs/apiref epydoc-pdf: epydoc-website: env CFLAGS=-O0 ${PYTHON2} setup.py -q build --build-lib build/lib.py2 env PYTHONPATH=$$PWD/build/lib.py2 ${PYTHON2} -c 'import ${package}.${MODULE}' env PYTHONPATH=$$PWD/build/lib.py2 ${EPYDOCBUILD} ${EPYDOCOPTS} -q -q -q --html -o ${LOC}/petsc4py .PHONY: docsclean docsclean: -${RM} docs/*.info docs/*.[137] -${RM} docs/*.html docs/*.pdf -${RM} -r docs/usrman docs/apiref # ---- .PHONY: sdist sdist: ${PYTHON} setup.py sdist ${SDISTOPT} # ----