-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathMakefile
289 lines (228 loc) · 9.34 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
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
# * Utilities -----------------------------------------------------------------
.PHONY: clean clean-test clean-pyc clean-build help
.DEFAULT_GOAL := help
_PY_DEFAULT = $(shell cat .python-version | sed "s/\.//")
UVRUN = uv run --frozen
UVXRUN = $(UVRUN) --no-config tools/uvxrun.py
UVXRUN_OPTS = -r requirements/lock/py$(_PY_DEFAULT)-uvxrun-tools.txt -v
UVXRUN_NO_PROJECT = uv run --with "packaging" --no-project tools/uvxrun.py
NOX=uvx --from "nox>=2024.10.9" nox
PRE_COMMIT = uvx pre-commit
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 := $(UVRUN) --no-config python -c "$$BROWSER_PYSCRIPT"
help:
@$(UVRUN) python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
clean: clean-build clean-pyc clean-test ## remove all build, test, coverage and Python artifacts
clean-build: ## remove build artifacts
rm -fr build/
rm -fr docs/_build/
rm -fr dist/
rm -fr dist-conda/
clean-pyc: ## remove Python file artifacts
find ./src -name '*.pyc' -exec rm -f {} +
find ./src -name '*.pyo' -exec rm -f {} +
find ./src -name '*~' -exec rm -f {} +
find ./src -name '__pycache__' -exec rm -fr {} +
clean-nox: ## remove all nox artifacts
rm -fr .nox
clean-test: ## remove test and coverage artifacts
rm -f .coverage
rm -fr htmlcov/
rm -fr .pytest_cache
# * Pre-commit -----------------------------------------------------------------
.PHONY: pre-commit-init lint codespell typos ruff ruff-format ruff-all checkmake
pre-commit-init: ## install pre-commit
$(PRE_COMMIT) install
_PRE_COMMIT_RUN = $(PRE_COMMIT) run --all-files
_PRE_COMMIT_RUN_MANUAL = $(_PRE_COMMIT_RUN) --hook-stage=manual
lint: ## run pre-commit on all files
$(_PRE_COMMIT_RUN)
codespell: ## run codespell. Note that this imports allowed words from docs/spelling_wordlist.txt
$(_PRE_COMMIT_RUN) codespell
$(_PRE_COMMIT_RUN) nbqa-codespell
typos: ## run typos.
$(_PRE_COMMIT_RUN_MANUAL) typos
$(_PRE_COMMIT_RUN_MANUAL) nbqa-typos
ruff: ## run ruff linters
$(_PRE_COMMIT_RUN) ruff
ruff-format: ## run ruff formatter
$(_PRE_COMMIT_RUN) ruff-format
ruff-all: ## run ruff lint and format
$(_PRE_COMMIT_RUN) ruff-all
checkmake: ## run checkmake
$(_PRE_COMMIT_RUN_MANUAL) checkmake
# * User setup -----------------------------------------------------------------
.PHONY: user-autoenv-zsh dev user-all
user-autoenv-zsh: ## create .autoenv.zsh files
echo source ./.venv/bin/activate > .autoenv.zsh
echo autostash NUMBA_CACHE_DIR=$(PWD)/.numba_cache >> .autoenv.zsh
echo deactivate > .autoenv_leave.zsh
user-all: user-autoenv-zsh ## runs user scripts
# * Testing --------------------------------------------------------------------
.PHONY: test coverage
test: ## run tests quickly with the default Python
$(UVRUN) pytest
test-accept: ## run tests and accept doctest results. (using pytest-accept)
DOCFILLER_SUB=False $(UVRUN) pytest -v --accept
# * Versioning -----------------------------------------------------------------
.PHONY: version-scm version-import version
version-scm: ## check/update version of package from scm
$(NOX) -s build -- ++build version
version-import: ## check version from python import
-$(UVRUN) python -c 'import cmomy; print(cmomy.__version__)'
version: version-scm version-import
# * Requirements/Environment files ---------------------------------------------
.PHONY: requirements
requirements: ## rebuild all requirements/environment files
$(NOX) -s requirements
# * Typing ---------------------------------------------------------------------
.PHONY: mypy pyright pyright-watch pylint _typecheck typecheck
PYLINT_OPTS = --enable-all-extensions
mypy: ## Run mypy
$(UVXRUN) $(UVXRUN_OPTS) -c mypy
pyright: ## Run pyright
$(UVXRUN) $(UVXRUN_OPTS) -c pyright
pyright-watch: ## Run pyright in watch mode
$(UVXRUN) $(UVXRUN_OPTS) -c "pyright -w"
pylint: ## Run pylint
$(UVRUN) pylint $(PYLINT_OPTS) src tests
_typecheck:
$(UVXRUN) $(UVXRUN_OPTS) -c mypy -c pyright
typecheck: _typecheck pylint ## Run mypy and pyright
.PHONY: tools-typecheck
tools-typecheck:
$(UVXRUN) $(UVXRUN_OPTS) -c "mypy --strict" -c pyright -- noxfile.py tools/*.py
$(UVRUN) pylint $(PYLINT_OPTS) noxfile.py tools
# * NOX ------------------------------------------------------------------------
# ** docs
.PHONY: docs-html docs-clean docs-clean-build docs-release
docs-html: ## build html docs
$(NOX) -s docs -- +d html
docs-build: docs-html ## alias to docs-html
docs-clean: ## clean docs
rm -rf docs/_build/*
rm -rf docs/generated/*
rm -rf docs/reference/generated/*
docs-clean-build: docs-clean docs-build ## clean and build
docs-release: ## release docs.
$(UVXRUN_NO_PROJECT) $(UVXRUN_OPTS) -c "ghp-import -o -n -m \"update docs\" -b nist-pages" docs/_build/html
.PHONY: docs-open docs-spelling docs-livehtml docs-linkcheck
docs-open: ## open the build
$(NOX) -s docs -- +d open
docs-spelling: ## run spell check with sphinx
$(NOX) -s docs -- +d spelling
docs-livehtml: ## use autobuild for docs
$(NOX) -s docs -- +d livehtml
docs-linkcheck: ## check links
$(NOX) -s docs -- +d linkcheck
# ** typing
.PHONY: typing-mypy typing-pyright typing-pylint typing-typecheck
typing-mypy: ## run mypy mypy_args=...
$(NOX) -s typing -- +m mypy
typing-pyright: ## run pyright pyright_args=...
$(NOX) -s typing -- +m pyright
typing-pylint: ## run pylint
$(NOX) -s pylint -- +m pylint
typing-typecheck:
$(NOX) -s typing -- +m mypy pyright pylint
# ** dist pypi
.PHONY: build publish publish-test
build: ## build dist
$(NOX) -s build
publish: ## publish to pypi
$(NOX) -s publish -- +p release
publish-test: ## publish to testpypi
$(NOX) -s publish -- +p test
.PHONY: uv-publish uv-publish-test
_UV_PUBLISH = uv publish --username __token__ --keyring-provider subprocess
uv-publish: ## uv release
$(_UV_PUBLISH)
uv-publish-test: ## uv test release on testpypi
$(_UV_PUBLISH) --publish-url https://test.pypi.org/legacy/
# ** dist conda
.PHONY: conda-recipe conda-build
conda-recipe: ## build conda recipe can pass posargs=...
$(NOX) -s conda-recipe
conda-build: ## build conda recipe can pass posargs=...
$(NOX) -s conda-build
# ** list all options
.PHONY: nox-list
nox-list:
$(NOX) --list
# ** sdist/wheel check ---------------------------------------------------------
.PHONY: check-release check-wheel check-dist
check-release: ## run twine check on dist
$(NOX) -s publish -- +p check
check-wheel: ## Run check-wheel-contents (requires check-wheel-contents to be installed)
$(UVXRUN_NO_PROJECT) -c check-wheel-contents dist/*.whl
check-dist: check-release check-wheel ## Run check-release and check-wheel
.PHONY: list-wheel list-sdist list-dist
list-wheel: ## Cat out contents of wheel
unzip -vl dist/*.whl
list-sdist: ## Cat out contents of sdist
tar -tzvf dist/*.tar.gz
list-dist: list-wheel list-sdist ## Cat out sdist and wheel contents
# * NOTEBOOK -------------------------------------------------------------------
NOTEBOOKS ?= examples/usage
# NOTE: use this because nested call back in nox has errors with uv run...
_PYTHON = $(shell which python)
_NBQA_UVXRUN = $(_PYTHON) tools/uvxrun.py
NBQA = $(_NBQA_UVXRUN) $(UVXRUN_OPTS) -c "nbqa --nbqa-shell \"$(_NBQA_UVXRUN)\" $(NOTEBOOKS) $(UVXRUN_OPTS) $(_NBQA)"
.PHONY: notebook-mypy notebook-pyright notebook-pylint notebook-typecheck notebook-test
notebook-mypy: _NBQA = -c mypy
notebook-mypy: ## run nbqa mypy
$(NBQA)
notebook-pyright: _NBQA = -c pyright
notebook-pyright: ## run nbqa pyright
$(NBQA)
notebook-pylint:: ## run nbqa pylint
$(_NBQA_UVXRUN) $(UVXRUN_OPTS) -c "nbqa --nbqa-shell \"$(_PYTHON) -m pylint $(PYLINT_OPTS)\" $(NOTEBOOKS)"
notebook-typecheck: _NBQA = -c mypy -c pyright
notebook-typecheck: notebook-pylint ## run nbqa mypy/pyright
$(NBQA)
notebook-test: ## run pytest --nbval
$(UVRUN) pytest --nbval --nbval-current-env --nbval-sanitize-with=config/nbval.ini --dist loadscope -x $(NOTEBOOKS)
.PHONY: clean-kernelspec
clean-kernelspec: ## cleanup unused kernels (assuming notebooks handled by conda environment notebook)
$(UVRUN) tools/clean_kernelspec.py
.PHONY: install-kernel
install-kernel: ## install kernel
$(UVRUN) python -m ipykernel install --user \
--name cmomy-dev \
--display-name "Python [venv: cmomy-dev]"
# * Other tools ----------------------------------------------------------------
# Note that this requires `auto-changelog`, which can be installed with pip(x)
.PHONY: auto-changelog
auto-changelog: ## autogenerate changelog and print to stdout
uvx auto-changelog -u -r usnistgov -v unreleased --tag-prefix v --stdout --template changelog.d/templates/auto-changelog/template.jinja2
.PHONY:
commitizen-changelog:
uvx --from="commitizen" cz changelog --unreleased-version unreleased --dry-run --incremental
# tuna analyze load time:
.PHONY: tuna-analyze
tuna-import : ## Analyze load time for module
$(UVRUN) python -X importtime -c 'import cmomy' 2> tuna-loadtime.log
uvx tuna tuna-loadtime.log
rm tuna-loadtime.log
.PHONY: test-all-cover
test-all-cover:
nox -s test test-notebook -- ++test-opts --run-slow
nox -s test-3.11 coverage -- ++test-no-numba ++test-opts --run-slow ++test-no-numba
.PHONY: auto-files
auto-files:
uv run ./tools/auto_parallel_files.py
uv run ./tools/auto_test_typing.py