-
Notifications
You must be signed in to change notification settings - Fork 1
/
Makefile
121 lines (110 loc) · 3.25 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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
## create environment
.PHONY: environment
environment:
pyenv install -s 3.6.8
pyenv virtualenv 3.6.8 quintoandar-kafka
pyenv local quintoandar-kafka
## install all requirements
.PHONY: requirements
requirements:
pip install -Ur requirements.txt -Ur requirements.dev.txt
## check PEP-8 and other standards with flake8
.PHONY: flake-check
flake-check:
@echo ""
@echo "\033[33mFlake 8 Standards\033[0m"
@echo "\033[33m=================\033[0m"
@echo ""
@python -m flake8 && echo "\n\n\033[32mSuccess\033[0m\n" || (echo \
"\n\n\033[31mFailure\033[0m\n\n\033[34mManually fix the offending \
issues\033[0m\n" && exit 1)
## check Black code style
.PHONY: black-check
black-check:
@echo ""
@echo "\033[33mBlack Code Style\033[0m"
@echo "\033[33m================\033[0m"
@echo ""
@python -m black --check --exclude="build/|buck-out/|dist/|_build/\
|pip/|env/|\.pip/|\.git/|\.hg/|\.mypy_cache/|\.tox/|\.venv/" . \
&& echo "\n\n\033[32mSuccess\033[0m\n" || (python -m black --diff \
--exclude="build/|buck-out/|dist/|_build/|pip/|env/|\.pip/|\.git/|\
\.hg/|\.mypy_cache/|\.tox/|\.venv/" . 2>&1 | grep -v -e reformatted -e done \
&& echo "\n\033[31mFailure\033[0m\n\n\
\033[34mRun \"\e[4mmake black\e[24m\" to apply style formatting to your code\
\033[0m\n" && exit 1)
## apply the Black code style to code
.PHONY: black
black:
black --exclude="build/|buck-out/|dist/|_build/|pip/|env/|\.pip/|\.git/|\.hg/|\.mypy_cache/|\.tox/|\.venv/" .
## run tests
.PHONY: tests
tests:
python unit_tests.py
## perform code standards and style checks
.PHONY: checks
checks: flake-check black-check
## delete all compiled python files
.PHONY: clean
clean:
find . -name "*.py[co]" -delete
find . -name "*~" -delete
find . -name "__pycache__" -delete
## initialize project
.PHONY: init
init: environment requirements
.DEFAULT_GOAL := help
# Inspired by <http://marmelab.com/blog/2016/02/29/auto-documented-makefile.html>
# sed script explained:
# /^##/:
# * save line in hold space
# * purge line
# * Loop:
# * append newline + line to hold space
# * go to next line
# * if line starts with doc comment, strip comment character off and loop
# * remove target prerequisites
# * append hold space (+ newline) to line
# * replace newline plus comments by `---`
# * print line
# Separate expressions are necessary because labels cannot be delimited by
# semicolon; see <http://stackoverflow.com/a/11799865/1968>
.PHONY: help
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=19 \
-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')