-
Notifications
You must be signed in to change notification settings - Fork 6
Expand file tree
/
Copy pathMakefile
More file actions
42 lines (34 loc) · 1.27 KB
/
Makefile
File metadata and controls
42 lines (34 loc) · 1.27 KB
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
41
42
# Minimal makefile for Sphinx documentation
#
# You can set these variables from the command line, and also
# from the environment for the first two.
SPHINXOPTS ?=
SPHINXBUILD ?= sphinx-build
SOURCEDIR = .
BUILDDIR = _build
VENVDIR := .venv
PYTHON := python3
# only fish and bash/zsh supported
VENV_CMD := if [ "x${FISH_VERSION}" != "x" ]; then . $(VENVDIR)/bin/activate.fish; else . $(VENVDIR)/bin/activate; fi
RUN_VENV := if [ -d $(VENVDIR) ]; then $(VENV_CMD); fi
$(VENVDIR):
$(PYTHON) -m virtualenv $(VENVDIR)
$(VENV_CMD) && pip install -r requirements.txt
# Put it first so that "make" without argument is like "make help".
help:
@$(SPHINXBUILD) -M help "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O)
@echo
@echo 'Non-Sphinx targets'
@echo ' .venv create python3 virtualenv with Sphinx requirements'
@echo ' clean remove output files'
@echo ' distclean remove output files and virtualenv'
clean:
rm -rf "$(BUILDDIR)" "$(VENVDIR)"
distclean: clean
rm -rf "$(VENVDIR)"
.PHONY: clean distclean help Makefile
# Catch-all target: route all unknown targets to Sphinx using the new
# "make mode" option. $(O) is meant as a shortcut for $(SPHINXOPTS).
%: Makefile
$(RUN_VENV); \
$(SPHINXBUILD) -M $@ "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O)