CI - Fix change detection (#7038)
* Fix travis change detection * Fix travis change detection - add back python ignorerefactor_process_record_kb_user 0.7.60
parent
efa28d0f5c
commit
d382eeeb9d
@ -1,57 +1,42 @@ |
|||||||
#!/bin/bash |
#!/bin/bash |
||||||
|
|
||||||
# if docker is installed - patch calls to within the qmk docker image |
source util/travis_utils.sh |
||||||
if command -v docker >/dev/null; then |
|
||||||
function make() { |
|
||||||
docker run --rm -e MAKEFLAGS="$MAKEFLAGS" -w /qmk_firmware/ -v "$PWD":/qmk_firmware --user $(id -u):$(id -g) qmkfm/base_container make "$@" |
|
||||||
} |
|
||||||
fi |
|
||||||
|
|
||||||
# test force push |
NUM_CORE_CHANGES=$(echo "$QMK_CHANGES" | grep -Ecv -e '^(docs/)' -e '^(keyboards/)' -e '^(layouts/)' -e '^(util/)' -e '^(lib/python/)' -e '^(bin/qmk)' -e '^(requirements.txt)' -e '(.travis.yml)') |
||||||
#TRAVIS_COMMIT_RANGE="c287f1bfc5c8...81f62atc4c1d" |
|
||||||
|
|
||||||
TRAVIS_COMMIT_MESSAGE="${TRAVIS_COMMIT_MESSAGE:-none}" |
if [[ "$TRAVIS_COMMIT_MESSAGE" == *"[skip build]"* ]]; then |
||||||
TRAVIS_COMMIT_RANGE="${TRAVIS_COMMIT_RANGE:-HEAD~1..HEAD}" |
echo "Skipping due to commit message" |
||||||
MAKE_ALL="make all:default" |
exit 0 |
||||||
|
fi |
||||||
|
|
||||||
if [[ "$TRAVIS_COMMIT_MESSAGE" != *"[skip build]"* ]] ; then |
if [ "$LOCAL_BRANCH" == "master" ] || [ "$NUM_CORE_CHANGES" != "0" ]; then |
||||||
exit_code=0 |
|
||||||
git diff --name-only -n 1 ${TRAVIS_COMMIT_RANGE} |
|
||||||
if [ $? -eq 128 ]; then |
|
||||||
# We don't know what changed so just build the default keymaps |
|
||||||
echo "Making default keymaps for all keyboards (fallback)" |
|
||||||
eval $MAKE_ALL |
|
||||||
: $((exit_code = $exit_code + $?)) |
|
||||||
else |
|
||||||
NEFM=$(git diff --name-only -n 1 ${TRAVIS_COMMIT_RANGE} | grep -Ev '^(keyboards/)' | grep -Ev '^(docs/)' | grep -Ev '^(lib/python/)' | grep -Ev '^(bin/qmk)' | grep -Ev '^(requirements.txt)' | grep -Ev '^(util/)' | wc -l) |
|
||||||
BRANCH=$(git rev-parse --abbrev-ref HEAD) |
|
||||||
# is this branch master or a "non docs, non keyboards" change |
|
||||||
if [ $NEFM -gt 0 -o "$BRANCH" = "master" ]; then |
|
||||||
echo "Making default keymaps for all keyboards" |
echo "Making default keymaps for all keyboards" |
||||||
eval $MAKE_ALL |
make all:default |
||||||
: $((exit_code = $exit_code + $?)) |
exit $? |
||||||
else |
fi |
||||||
# keyboards project format |
|
||||||
# /keyboards/board1/rev/keymaps/ |
exit_code=0 |
||||||
# /keyboards/board2/keymaps/ |
|
||||||
# ensure we strip everything off after and including the keymaps folder to get board and/or revision |
for KB in $(make list-keyboards); do |
||||||
MKB=$(git diff --name-only -n 1 ${TRAVIS_COMMIT_RANGE} | grep -oP '(?<=keyboards\/)([a-zA-Z0-9_\/]+)(?=\/)' | sed 's^/keymaps/.*^^' | sort -u) |
KEYBOARD_CHANGES=$(echo "$QMK_CHANGES" | grep -E '^(keyboards/'${KB}'/)') |
||||||
for KB in $MKB ; do |
if [[ -z "$KEYBOARD_CHANGES" ]]; then |
||||||
KEYMAP_ONLY=$(git diff --name-only -n 1 ${TRAVIS_COMMIT_RANGE} | grep -Ev '^(keyboards/'${KB}'/keymaps/)' | wc -l) |
# skip as no changes for this keyboard |
||||||
|
continue |
||||||
|
fi |
||||||
|
|
||||||
|
KEYMAP_ONLY=$(echo "$KEYBOARD_CHANGES" | grep -cv /keymaps/) |
||||||
if [[ $KEYMAP_ONLY -gt 0 ]]; then |
if [[ $KEYMAP_ONLY -gt 0 ]]; then |
||||||
echo "Making all keymaps for $KB" |
echo "Making all keymaps for $KB" |
||||||
make ${KB}:all |
make ${KB}:all |
||||||
: $((exit_code = $exit_code + $?)) |
: $((exit_code = $exit_code + $?)) |
||||||
else |
else |
||||||
MKM=$(git diff --name-only -n 1 ${TRAVIS_COMMIT_RANGE} | grep -oP '(?<=keyboards/'${KB}'/keymaps/)([a-zA-Z0-9_]+)(?=\/)' | sort -u) |
CHANGED_KEYMAPS=$(echo "$KEYBOARD_CHANGES" | grep -oP '(?<=keyboards/'${KB}'/keymaps/)([a-zA-Z0-9_-]+)(?=\/)') |
||||||
for KM in $MKM ; do |
for KM in $CHANGED_KEYMAPS ; do |
||||||
echo "Making $KM for $KB" |
echo "Making $KM for $KB" |
||||||
make ${KB}:${KM} |
make ${KB}:${KM} |
||||||
: $((exit_code = $exit_code + $?)) |
: $((exit_code = $exit_code + $?)) |
||||||
done |
done |
||||||
fi |
fi |
||||||
done |
done |
||||||
fi |
|
||||||
fi |
exit $exit_code |
||||||
exit $exit_code |
|
||||||
fi |
|
||||||
|
@ -0,0 +1,24 @@ |
|||||||
|
# Use this by sourcing it in your script. |
||||||
|
|
||||||
|
# Provide sane defaults for travis environment |
||||||
|
TRAVIS_BRANCH="${TRAVIS_BRANCH:master}" |
||||||
|
TRAVIS_PULL_REQUEST="${TRAVIS_PULL_REQUEST:false}" |
||||||
|
TRAVIS_COMMIT_MESSAGE="${TRAVIS_COMMIT_MESSAGE:-none}" |
||||||
|
TRAVIS_COMMIT_RANGE="${TRAVIS_COMMIT_RANGE:-HEAD~1..HEAD}" |
||||||
|
|
||||||
|
# test force push |
||||||
|
#TRAVIS_COMMIT_RANGE="c287f1bfc5c8...81f62atc4c1d" |
||||||
|
|
||||||
|
# Extra variables |
||||||
|
LOCAL_BRANCH=${TRAVIS_PULL_REQUEST_BRANCH:-${TRAVIS_BRANCH}} |
||||||
|
QMK_CHANGES=$(git diff --name-only HEAD ${TRAVIS_BRANCH}) |
||||||
|
|
||||||
|
# if docker is installed - patch calls to within the qmk docker image |
||||||
|
if command -v docker >/dev/null; then |
||||||
|
function make() { |
||||||
|
docker run --rm -e MAKEFLAGS="$MAKEFLAGS" -w /qmk_firmware/ -v "$PWD":/qmk_firmware --user $(id -u):$(id -g) qmkfm/base_container make "$@" |
||||||
|
} |
||||||
|
function qmk() { |
||||||
|
docker run --rm -w /qmk_firmware/ -v "$PWD":/qmk_firmware --user $(id -u):$(id -g) qmkfm/base_container bin/qmk "$@" |
||||||
|
} |
||||||
|
fi |
Loading…
Reference in new issue