-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathjustfile
More file actions
81 lines (66 loc) · 2.32 KB
/
justfile
File metadata and controls
81 lines (66 loc) · 2.32 KB
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
@_default:
just --list --unsorted
# Run all build-related recipes in the justfile
run-all: install-deps format-python check-python check-spelling check-commits build
# List all TODO items in the repository
list-todos:
grep -R -n --exclude="*.code-snippets" --exclude="justfile" "TODO" *
# Install the pre-commit hooks
install-precommit:
# Install pre-commit hooks
uvx pre-commit install
# Run pre-commit hooks on all files
uvx pre-commit run --all-files
# Update versions of pre-commit hooks
uvx pre-commit autoupdate
# Install Python package dependencies
install-deps:
uv sync --upgrade --dev --all-extras
# Check Python code with the linter for any errors that need manual attention
check-python:
uv run ruff check .
# Reformat Python code to match coding style and general structure
format-python:
uv run ruff check --fix .
uv run ruff format .
# Check the commit messages on the current branch that are not on the main branch
check-commits:
#!/usr/bin/env bash
branch_name=$(git rev-parse --abbrev-ref HEAD)
number_of_commits=$(git rev-list --count HEAD ^main)
if [[ ${branch_name} != "main" && ${number_of_commits} -gt 0 ]]
then
# If issue happens, try `uv tool update-shell`
uvx --from commitizen cz check --rev-range main..HEAD
else
echo "On 'main' or current branch doesn't have any commits."
fi
# Check for spelling errors in files
check-spelling:
uv run typos
# Re-build the data package
build:
uv run main.py
# Check for and apply updates from the template
update-from-template:
uvx copier update --trust --defaults
# Reset repo changes to match the template
reset-from-template:
uvx copier recopy --trust --defaults
# Build the Python docstrings as a section in the website using quartodoc
build-quartodoc:
# To let Quarto know where python is.
export QUARTO_PYTHON=.venv/bin/python3
# Delete any previously built files from quartodoc.
# -f is to not give an error if the files don't exist yet.
rm -rf docs/reference
uv run quartodoc build
# Build the documentation website using Quarto
build-website: build-quartodoc
uv run quarto render --execute
# Preview the documentation website with automatic reload on changes
preview-website: build-quartodoc
uv run quarto preview --execute
# Download data dictionary from REDCap
download-data-dict:
uv run python scripts/redcap.py