-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathMakefile
97 lines (77 loc) · 2.74 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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
# Main targets:
# * install: Install Python virtual environment and project dependencies
# * test: Run all checks on project resources
# * serve, serve-en: Start local server for English documentation
# * serve-fr: Start local server for French documentation
check-format: check-format-admonitions check-format-prettier
check-format-admonitions:
@if grep -IoPrz --exclude-dir='images' \
'(?<!<!-- prettier-ignore -->)\n(?:\?\?\?|!!!).*?(?:\n|$$)' docs/; then \
echo && echo 'Above admonitions need <!-- prettier-ignore -->.' 1>&2; \
exit 1; \
fi; \
if grep -IoPrz --exclude-dir='images' \
'(?<=^|\n)(?:\?\?\?|!!!).*?\n(?! ).*?(?:\n|$$)' docs/; then \
echo && echo 'Above admonitions are malformed.' 1>&2; \
exit 1; \
fi
check-format-prettier:
@yarn run prettier -c . || \
(echo && read -r -p "Would you like to run prettier to resolve the fromatting errors detected in the files above [y/N] ? " REPLY; \
if [ $$REPLY = "Y" ] || [ $$REPLY = "y" ]; then \
echo "\e[2mrunning prettier...\033[0m"; \
yarn prettier --write . ; \
fi)
check-prerequisites:
@if ! which node npm yarn python3 > /dev/null 2>&1 \
|| ! python3 -m venv --help > /dev/null 2>&1; then \
echo -n 'Please ensure the following prerequisites are installed:\n' \
' * Node.js (https://github.com/nvm-sh/nvm)\n' \
' * npm (comes with Node.js)\n' \
' * Yarn (npm install --global yarn)' \
' * Python 3.x (apt install python3)\n' \
' * Python venv module (apt install python3-venv)\n' 1>&2; \
exit 1; \
fi
check-spelling: check-spelling-en check-spelling-fr
check-spelling-en:
yarn run mdspell --en-gb -trax 'docs/en/*.md' 'docs/en/**/*.md' -n -a
check-spelling-fr:
yarn run mdspell --fr-fr -trax 'docs/fr/*.md' 'docs/fr/**/*.md' -n -a
fix-spelling-en:
yarn run mdspell --en-gb 'docs/en/*.md' 'docs/en/**/*.md' -n -a
fix-spelling-fr:
yarn run mdspell --fr-fr 'docs/fr/*.md' 'docs/fr/**/*.md' -n -a
install: install-yarn install-venv
install-venv: check-prerequisites
python3 -m venv --prompt "$$(pwd | rev | cut -d / -f 1 | rev)" .venv
. .venv/bin/activate; pip install -Ur requirements.txt
install-yarn: check-prerequisites
yarn install
make install-prettier
install-prettier: check-prerequisites
yarn add --dev --exact prettier
serve: serve-en
serve-en:
. .venv/bin/activate && mkdocs serve -f mkdocs-en.yml
serve-fr:
. .venv/bin/activate && mkdocs serve -f mkdocs-fr.yml
serve-dev:
bash build-dev-docs.sh
. .venv/bin/activate && mkdocs serve -f mkdocs-dev.yml
# test: check-format check-spelling
.PHONY: \
check-format \
check-format-admonitions \
check-format-prettier \
check-prerequisites \
check-spelling \
check-spelling-en \
check-spelling-fr \
install \
install-venv \
install-yarn \
serve \
serve-en \
serve-fr \
test