123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183 |
- #!/usr/bin/env bash
- set -eo pipefail
- builtin cd "$(dirname "${BASH_SOURCE:-$0}")"
- ROOT="$(git rev-parse --show-toplevel)"
- builtin cd "$ROOT" || exit 1
- YAPF_VERSION=$(yapf --version | awk '{print $2}')
- RUFF_VERSION=$(ruff --version | awk '{print $2}')
- MYPY_VERSION=$(mypy --version | awk '{print $2}')
- CODESPELL_VERSION=$(codespell --version)
- tool_version_check() {
- if [[ $2 != $3 ]]; then
- echo "Wrong $1 version installed: $3 is required, not $2."
- exit 1
- fi
- }
- tool_version_check "yapf" $YAPF_VERSION "$(grep yapf requirements-dev.txt | cut -d'=' -f3)"
- tool_version_check "ruff" $RUFF_VERSION "$(grep "ruff==" requirements-dev.txt | cut -d'=' -f3)"
- tool_version_check "mypy" "$MYPY_VERSION" "$(grep mypy requirements-dev.txt | cut -d'=' -f3)"
- tool_version_check "codespell" "$CODESPELL_VERSION" "$(grep codespell requirements-dev.txt | cut -d'=' -f3)"
- YAPF_FLAGS=(
- '--recursive'
- '--parallel'
- )
- YAPF_EXCLUDES=(
- '--exclude' 'build/**'
- )
- format() {
- yapf --in-place "${YAPF_FLAGS[@]}" "$@"
- }
- format_changed() {
-
-
-
-
-
-
- MERGEBASE="$(git merge-base origin/main HEAD)"
- if ! git diff --diff-filter=ACM --quiet --exit-code "$MERGEBASE" -- '*.py' '*.pyi' &>/dev/null; then
- git diff --name-only --diff-filter=ACM "$MERGEBASE" -- '*.py' '*.pyi' | xargs -P 5 \
- yapf --in-place "${YAPF_EXCLUDES[@]}" "${YAPF_FLAGS[@]}"
- fi
- }
- format_all() {
- yapf --in-place "${YAPF_FLAGS[@]}" "${YAPF_EXCLUDES[@]}" .
- }
- if [[ "$1" == '--files' ]]; then
- format "${@:2}"
-
-
- elif [[ "$1" == '--all' ]]; then
- format_all
- else
-
- format_changed
- fi
- echo 'Aphrodite yapf: Done'
- CODESPELL_EXCLUDES=(
- '--skip' '*docs/source/_build/**'
- )
- spell_check() {
- codespell "$@"
- }
- spell_check_all(){
- codespell --toml pyproject.toml "${CODESPELL_EXCLUDES[@]}"
- }
- spell_check_changed() {
-
-
-
-
-
-
- MERGEBASE="$(git merge-base origin/main HEAD)"
- if ! git diff --diff-filter=ACM --quiet --exit-code "$MERGEBASE" -- '*.py' '*.pyi' &>/dev/null; then
- git diff --name-only --diff-filter=ACM "$MERGEBASE" -- '*.py' '*.pyi' | xargs \
- codespell "${CODESPELL_EXCLUDES[@]}"
- fi
- }
- if [[ "$1" == '--files' ]]; then
- spell_check "${@:2}"
-
-
- elif [[ "$1" == '--all' ]]; then
- spell_check_all
- else
-
- spell_check_changed
- fi
- echo 'Aphrodite codespell: Done'
- lint() {
- ruff "$@"
- }
- lint_changed() {
-
-
-
-
-
-
- MERGEBASE="$(git merge-base origin/main HEAD)"
- if ! git diff --diff-filter=ACM --quiet --exit-code "$MERGEBASE" -- '*.py' '*.pyi' &>/dev/null; then
- git diff --name-only --diff-filter=ACM "$MERGEBASE" -- '*.py' '*.pyi' | xargs \
- ruff
- fi
- }
- echo 'Aphrodite ruff:'
- if [[ "$1" == '--files' ]]; then
- lint "${@:2}"
-
-
- elif [[ "$1" == '--all' ]]; then
- lint aphrodite tests
- else
-
- lint_changed
- fi
- if ! git diff --quiet &>/dev/null; then
- echo 'Reformatted files. Please review and stage the changes.'
- echo 'Changes not staged for commit:'
- echo
- git --no-pager diff --name-only
- exit 1
- fi
|