-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
129 lines (96 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
122
123
124
125
126
127
128
129
.PHONY: clean clean-test clean-pyc clean-build docs help
.DEFAULT_GOAL := help
define BROWSER_PYSCRIPT
import os, webbrowser, sys
try:
from urllib import pathname2url
except:
from urllib.request import pathname2url
webbrowser.open("file://" + pathname2url(os.path.abspath(sys.argv[1])))
endef
export BROWSER_PYSCRIPT
define PRINT_HELP_PYSCRIPT
import re, sys
for line in sys.stdin:
match = re.match(r'^([a-zA-Z_-]+):.*?## (.*)$$', line)
if match:
target, help = match.groups()
print("%-20s %s" % (target, help))
endef
export PRINT_HELP_PYSCRIPT
BROWSER := python -c "$$BROWSER_PYSCRIPT"
help:
@python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
clean: clean-build clean-pyc clean-test clean-docs ## remove all build, test, coverage and Python artifacts
clean-build: ## remove build artifacts
rm -fr build/
rm -fr dist/
rm -fr .eggs/
find . -name '*.egg-info' -exec rm -fr {} +
find . -name '*.egg' -exec rm -f {} +
clean-pyc: ## remove Python file artifacts
find . -name '*.pyc' -exec rm -f {} +
find . -name '*.pyo' -exec rm -f {} +
find . -name '*~' -exec rm -f {} +
find . -name '__pycache__' -exec rm -fr {} +
clean-docs: ## remove MkDocs products.
mkdocs build --clean
rm -fr site/
clean-test: ## remove test and coverage artifacts
rm -fr .tox/
rm -f .coverage
rm -fr htmlcov/
rm -fr .pytest_cache
rm -fr .mypy_cache
rm -fr coverage.xml
lint-all: black isort lint static bandit safety vulture pylint ## run all linters
lint: ## check style with flake8
flake8 src/pdfa_learning tests scripts
static: ## static type checking with mypy
mypy src/pdfa_learning tests scripts
isort: ## sort import statements with isort
isort src/pdfa_learning tests scripts
isort-check: ## check import statements order with isort
isort --check-only src/pdfa_learning tests scripts
black: ## apply black formatting
black src/pdfa_learning tests scripts
black-check: ## check black formatting
black --check --verbose src/pdfa_learning tests scripts
bandit: ## run bandit
bandit src/pdfa_learning tests scripts
safety: ## run safety
safety
pylint: ## run pylint
pylint src/pdfa_learning tests scripts
vulture: ## run vulture
vulture src/pdfa_learning scripts/whitelist.py
test: ## run tests quickly with the default Python
pytest tests --doctest-modules \
src/pdfa_learning tests/ \
--cov=src/pdfa_learning \
--cov-report=xml \
--cov-report=html \
--cov-report=term
test-all: ## run tests on every Python version with tox
tox
coverage: ## check code coverage quickly with the default Python
coverage run --source src/pdfa_learning -m pytest
coverage report -m
coverage html
$(BROWSER) htmlcov/index.html
docs: ## generate MkDocs HTML documentation, including API docs
mkdocs build --clean
$(BROWSER) site/index.html
servedocs: docs ## compile the docs watching for changes
mkdocs build --clean
python -c 'print("###### Starting local server. Press Control+C to stop server ######")'
mkdocs serve
release: dist ## package and upload a release
twine upload dist/*
dist: clean ## builds source and wheel package
poetry build
ls -l dist
install: clean ## install the package to the active Python's site-packages
poetry install
develop: clean ## install the package in development mode
echo "Not supported by Poetry yet!"