forked from clayrisser/sphinx-markdown-builder
-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathMakefile
73 lines (52 loc) · 2.38 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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
# You can set these variables from the command line, and also
# from the environment for the first two.
SPHINX_OPTS ?=
SPHINX_BUILD ?= sphinx-build
DIFFTOOL ?= meld
TESTS_DIR = tests
SOURCE_DIR = $(TESTS_DIR)/source
BUILD_DIR = $(TESTS_DIR)/docs-build
EXPECTED_DIR = $(TESTS_DIR)/expected
.PHONY: help clean test test-diff diff meld release
# Put it first so that "make" without argument is like "make help".
help:
@$(SPHINX_BUILD) -M help "$(SOURCE_DIR)" "$(BUILD_DIR)" $(SPHINX_OPTS) $(O)
clean:
rm -rf "$(BUILD_DIR)" "$(SOURCE_DIR)/library"
# Catch-all target: route all unknown targets to Sphinx using the new "make mode" option.
# $(O) is meant as a shortcut for $(SPHINX_OPTS).
doc-%:
@$(SPHINX_BUILD) -M $* "$(SOURCE_DIR)" "$(BUILD_DIR)" $(SPHINX_OPTS) $(O) -a -t Partners
docs: doc-markdown
test-diff:
@echo "Building markdown..."
@$(SPHINX_BUILD) -M markdown "$(SOURCE_DIR)" "$(BUILD_DIR)" $(SPHINX_OPTS) $(O) -a -t Partners
@echo "Building markdown with configuration overrides..."
@$(SPHINX_BUILD) -M markdown "$(SOURCE_DIR)" "$(BUILD_DIR)/overrides" $(SPHINX_OPTS) $(O) -a \
-D markdown_http_base="https://localhost" -D markdown_uri_doc_suffix=".html" \
-D markdown_docinfo=True -D markdown_anchor_sections=True -D markdown_anchor_signatures=True \
-D autodoc_typehints=signature -D markdown_bullet=-
@# Copy just the files for verification
@cp "$(BUILD_DIR)/overrides/markdown/auto-summery.md" "$(BUILD_DIR)/markdown/overrides-auto-summery.md"
@cp "$(BUILD_DIR)/overrides/markdown/auto-module.md" "$(BUILD_DIR)/markdown/overrides-auto-module.md"
@echo "Verifies outputs..."
@diff --recursive --color=always --side-by-side --text --suppress-common-lines \
"$(BUILD_DIR)/markdown" "$(EXPECTED_DIR)"
test: test-diff
@echo "Unit testing and coverage report..."
@pytest --cov=sphinx_markdown_builder
diff:
$(DIFFTOOL) "$(BUILD_DIR)/markdown" "$(EXPECTED_DIR)" &
lint:
@echo "Validate coding conventions with black"
black sphinx_markdown_builder --check --diff
@echo "Lint with flake8"
flake8 . --count --select=E,F,W,C --show-source \
--max-complexity=10 --max-line-length=120 --statistics \
--exclude "venv*,.venv,.git"
@ echo "Lint with pylint"
pylint sphinx_markdown_builder -v --disable C0116,C0115
release:
@rm -rf dist/*
python3 -m build || exit
python3 -m twine upload --repository sphinx-markdown-builder dist/*