-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathMakefile
130 lines (101 loc) · 4.58 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
130
.PHONY: clean clean-build clean-pyc clean-test docs help install lint lint/flake8 lint/black
.DEFAULT_GOAL := help
define BROWSER_PYSCRIPT
import os, webbrowser, sys
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"
LOCALES := docs/locales
help:
@python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
clean: clean-build clean-docs clean-pyc clean-test ## remove all build, test, docs, 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-docs: ## remove documentation artifacts
rm -fr docs/notebooks/_data/
rm -fr docs/notebooks/.ipynb_checkpoints/
rm -f docs/apidoc/xscen*.rst
rm -f docs/apidoc/modules.rst
rm -f docs/locales/fr/LC_MESSAGES/*.mo
$(MAKE) -C docs clean
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-test: ## remove test and coverage artifacts
rm -fr .tox/
rm -fr htmlcov/
rm -fr .pytest_cache
lint/flake8: ## check style with flake8
python -m ruff check src/xscen tests
python -m flake8 --config=.flake8 src/xscen tests
# python -m numpydoc lint src/xscen/**.py # FIXME: disabled until the codebase is fully numpydoc compliant
lint/black: ## check style with black
python -m black --check src/xscen tests
python -m blackdoc --check src/xscen docs
python -m isort --check src/xscen tests
lint: lint/black lint/flake8 ## check style
test: ## run tests quickly with the default Python
python -m pytest
test-all: ## run tests on every Python version with tox
python -m tox
initialize-translations: clean-docs ## initialize translations, ignoring autodoc-generated files
${MAKE} -C docs gettext
sphinx-intl update -p docs/_build/gettext -d docs/locales -l fr
autodoc: clean-docs ## create sphinx-apidoc files
sphinx-apidoc -o docs/apidoc --module-first src/xscen
linkcheck: autodoc ## run checks over all external links found throughout the documentation
env SKIP_NOTEBOOKS=1 $(MAKE) -C docs linkcheck
docs: autodoc ## generate Sphinx HTML documentation, including API docs
$(MAKE) -C docs html
$(MAKE) -C docs html BUILDDIR="_build/html/en"
ifneq ("$(wildcard $(LOCALES))","")
${MAKE} -C docs gettext
$(MAKE) -C docs html BUILDDIR="_build/html/fr" SPHINXOPTS="-D language='fr'"
endif
ifndef READTHEDOCS
$(BROWSER) docs/_build/html/index.html
$(BROWSER) docs/_build/html/en/html/index.html
endif
servedocs: docs ## compile the docs watching for changes
watchmedo shell-command -p '*.rst' -c '$(MAKE) -C docs html' -R -D .
dist: clean ## builds source and wheel package
python -m flit build
ls -l dist
release: dist ## package and upload a release
python -m flit publish dist/*
install: clean ## install the package to the active Python's site-packages
python -m pip install .
dev: clean ## install the package in editable mode with all development dependencies
python -m pip install --editable ".[all]"
pre-commit install
findfrench: ## Extract phrases and update the French translation catalog (this doesn't translate)
pybabel extract -o src/xscen/data/messages.pot --omit-header --input-dirs=src/xscen/
pybabel update -l fr -D xscen -i src/xscen/data/messages.pot -d src/xscen/data/ --omit-header --no-location
translate: ## Compile the translation catalogs.
pybabel compile -f -D xscen -d src/xscen/data/
MO_LAST_COMMIT = $(shell git log -n 1 --pretty=format:%H -- src/xscen/data/fr/LC_MESSAGES/xscen.mo)
PO_LAST_COMMIT = $(shell git log -n 1 --pretty=format:%H -- src/xscen/data/fr/LC_MESSAGES/xscen.po)
checkfrench: ## Error if the catalog could be update or if the compilation is older than the catalog.
rm -f .check_messages.pot
pybabel extract -o .check_messages.pot --omit-header --input-dirs=src/xscen/ --no-location
pybabel update -l fr -D xscen -i .check_messages.pot -d src/xscen/data/ --omit-header --check
rm -f .check_messages.pot
# Last commit that touched the PO file must be an ancestor of the last that touched the MO
if git merge-base --is-ancestor $(PO_LAST_COMMIT) $(MO_LAST_COMMIT); then echo "ok"; else echo "Compilation is older than translations. Please compile with 'make translate'."; exit 1; fi