-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
82 lines (73 loc) · 2.19 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
74
75
76
77
78
79
80
81
82
.PHONY:
coverage
coverage_html
coverage_xml
docs
docs_check_external_links
help
prepare_docs_folder
requirements
.DEFAULT_GOAL := help
## Install the Python requirements for contributors, and install pre-commit hooks
requirements:
python -m pip install -U pip setuptools
python -m pip install -r requirements.txt
pre-commit install
## Create a `docs/_build` folder, if it doesn't exist. Otherwise delete any sub-folders and their contents within it
prepare_docs_folder:
if [ ! -d "./docs/_build" ]; then mkdir ./docs/_build; fi
find ./docs/_build -mindepth 1 -maxdepth 1 -type d -exec rm -rf {} \;
## Compile the Sphinx documentation in HTML format in the docs/_build folder from a clean build
docs: prepare_docs_folder requirements
sphinx-build -b html ./docs ./docs/_build
## Check external links in the Sphinx documentation using linkcheck in the docs/_build folder from a clean build
docs_check_external_links: prepare_docs_folder requirements
sphinx-build -b linkcheck ./docs ./docs/_build
## Run code coverage
coverage: requirements
coverage run -m pytest
## Run code coverage, and produce a HTML output
coverage_html: coverage
coverage html
## Run code coverage, and produce an XML output
coverage_xml: coverage
coverage xml
## Get help on all make commands; referenced from https://github.com/drivendata/cookiecutter-data-science
help:
@echo "$$(tput bold)Available rules:$$(tput sgr0)"
@echo
@sed -n -e "/^## / { \
h; \
s/.*//; \
:doc" \
-e "H; \
n; \
s/^## //; \
t doc" \
-e "s/:.*//; \
G; \
s/\\n## /---/; \
s/\\n/ /g; \
p; \
}" ${MAKEFILE_LIST} \
| LC_ALL='C' sort --ignore-case \
| awk -F '---' \
-v ncol=$$(tput cols) \
-v indent=25 \
-v col_on="$$(tput setaf 6)" \
-v col_off="$$(tput sgr0)" \
'{ \
printf "%s%*s%s ", col_on, -indent, $$1, col_off; \
n = split($$2, words, " "); \
line_length = ncol - indent; \
for (i = 1; i <= n; i++) { \
line_length -= length(words[i]) + 1; \
if (line_length <= 0) { \
line_length = ncol - indent - length(words[i]) - 1; \
printf "\n%*s ", -indent, " "; \
} \
printf "%s ", words[i]; \
} \
printf "\n"; \
}' \
| more $(shell test $(shell uname) = Darwin && echo '--no-init --raw-control-chars')