-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
59 lines (46 loc) · 1.7 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
# Makefile with some convenient quick ways to do common things
PROJECT = mutis
help:
@echo ''
@echo ' help Print this help message (the default)'
@echo ''
@echo ' clean Remove generated files'
@echo ' clean-repo Remove all untracked files and directories (use with care!)'
@echo ' black Run black code formatter'
@echo ' isort Run isort code formatter to sort imports'
@echo ' trailing-spaces Remove trailing spaces at the end of lines in *.py files'
@echo ' polish Run trailing-spaces, black, and isort'
@echo ''
@echo ' test Run pytest'
@echo ' test-cov Run pytest with coverage'
@echo ''
@echo ' docs-sphinx Build docs (Sphinx only)'
@echo ' docs-show Open local HTML docs in browser'
@echo ''
clean:
rm -rf build dist docs/_build docs/api temp/ \
htmlcov MANIFEST v mutis.egg-info .eggs .coverage .cache .pytest_cache
find . -name ".ipynb_checkpoints" -prune -exec rm -rf {} \;
find . -name "*.pyc" -exec rm {} \;
find . -name "*.so" -exec rm {} \;
find mutis -name '*.c' -exec rm {} \;
find . -name __pycache__ | xargs rm -fr
clean-repo:
@git clean -f -x -d
test:
python -m pytest -v mutis
test-cov:
python -m pytest -v mutis --cov=mutis --cov-report=html
docs-sphinx:
cd docs && python -m sphinx . _build/html -b html
docs-show:
open docs/_build/html/index.html
black:
black $(PROJECT)/ docs/ \
--exclude="extern/|docs/_static|docs/_build" \
--line-length 100
isort:
isort mutis docs -s docs/conf.py
trailing-spaces:
find $(PROJECT) docs -name "*.py" -exec perl -pi -e 's/[ \t]*$$//' {} \;
polish: black isort trailing-spaces;