-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathMakefile
124 lines (103 loc) · 3.63 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
# Use qvm to manage quarto, also update:
# * `quarto.path` in .vscode/settings.json
# * quarto version in .github/workflows/docs-publish.yml
QUARTO_VERSION ?= v1.6.37
QVM_QUARTO_PATH = ~/.local/share/qvm/versions/${QUARTO_VERSION}/bin/quarto
.PHONY: install-quarto
install-quarto:
@echo "🔵 Installing quarto"
@if ! [ -z $(command -v qvm)]; then \
@echo "Error: qvm is not installed. Please visit https://github.com/dpastoor/qvm/releases/ to install it." >&2 \
exit 1; \
fi
qvm install ${QUARTO_VERSION}
.PHONY: docs
docs: ## [docs] Build the documentation
${QVM_QUARTO_PATH} render docs
.PHONY: docs-preview
docs-preview: ## [docs] Preview the documentation
${QVM_QUARTO_PATH} preview docs
.PHONY: pre-commit-all
pre-commit-all:
uv run pre-commit run --files $$(git ls-files | grep -E "[.]([qR]?md|py|R|ya?ml|[jt]s|toml)$$")
.PHONY: py-setup
py-setup: ## [py] Setup python environment
uv sync --all-extras
uv run pre-commit install
.PHONY: py-check
py-check: py-check-tests py-check-format py-check-types ## [py] Run python checks
.PHONY: py-check-tox
py-check-tox: ## [py] Run python 3.9 - 3.12 checks with tox
@echo ""
@echo "🔄 Running tests and type checking with tox for Python 3.9--3.12"
uv run tox run-parallel
.PHONY: py-check-tests
py-check-tests: ## [py] Run python tests
@echo ""
@echo "🧪 Running tests with pytest"
uv run pytest
.PHONY: py-check-types
py-check-types: ## [py] Run python type checks
@echo ""
@echo "📝 Checking types with pyright"
uv run pyright
.PHONY: py-check-format
py-check-format:
@echo ""
@echo "📐 Checking format with ruff"
uv run ruff check pkg-py --config pyproject.toml
.PHONY: py-format
py-format: ## [py] Format python code
uv run ruff check --fix pkg-py --config pyproject.toml
uv run ruff format pkg-py --config pyproject.toml
.PHONY: py-coverage
py-coverage: ## [py] Generate coverage report
@echo "📔 Generating coverage report"
uv run coverage run -m pytest
uv run coverage report
.PHONY: py-coverage-report
py-coverage-report: py-coverage ## [py] Generate coverage report and open it in browser
uv run coverage html
@echo ""
@echo "📡 Serving coverage report at http://localhost:8081/"
@npx http-server htmlcov --silent -p 8081
.PHONY: py-update-snaps
py-update-snaps: ## [py] Update python test snapshots
@echo "📸 Updating pytest snapshots"
uv run pytest --snapshot-update
.PHONY: py-docs
py-docs: ## [py] Generate python docs
@echo "📖 Generating python docs with quartodoc"
@$(eval export IN_QUARTODOC=true)
cd docs && uv run quartodoc build
cd docs && uv run quartodoc interlinks
.PHONY: py-docs-watch
py-docs-watch: ## [py] Generate python docs
@echo "📖 Generating python docs with quartodoc"
@$(eval export IN_QUARTODOC=true)
uv run quartodoc build --config docs/_quarto.yml --watch
.PHONY: py-docs-clean
py-docs-clean: ## [py] Clean python docs
@echo "🧹 Cleaning python docs"
find docs/pkg/py -name '*.qmd' ! -name 'index.qmd' -delete
find docs/pkg/py -name '*.quarto_ipynb' -delete
.PHONY: py-build
py-build: ## [py] Build python package
@echo "🧳 Building python package"
@[ -d dist ] && rm -r dist || true
uv build
.PHONY: help
help: ## Show help messages for make targets
@grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; { \
printf "\033[32m%-18s\033[0m", $$1; \
if ($$2 ~ /^\[docs\]/) { \
printf "\033[34m[docs]\033[0m%s\n", substr($$2, 7); \
} else if ($$2 ~ /^\[py\]/) { \
printf " \033[33m[py]\033[0m%s\n", substr($$2, 5); \
} else if ($$2 ~ /^\[r\]/) { \
printf " \033[31m[r]\033[0m%s\n", substr($$2, 4); \
} else { \
printf " %s\n", $$2; \
} \
}'
.DEFAULT_GOAL := help