2021-01-22 19:44:05 +03:00
|
|
|
#!/usr/bin/env bash
|
2020-11-03 22:11:48 +03:00
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
script_path=$(cd -P -- "$(dirname -- "$0")" && pwd -P)
|
|
|
|
cd "${script_path}/.." || exit 1
|
|
|
|
|
2021-04-30 14:30:04 +03:00
|
|
|
ports=true
|
|
|
|
if [ "$1" == "--no-ports" ]; then
|
|
|
|
ports=false
|
|
|
|
shift
|
|
|
|
fi
|
|
|
|
|
2020-12-24 20:13:24 +03:00
|
|
|
RED='\033[0;31m'
|
|
|
|
GREEN='\033[0;32m'
|
|
|
|
NC='\033[0m' # No Color
|
|
|
|
|
|
|
|
FAILURES=0
|
|
|
|
|
|
|
|
set +e
|
|
|
|
|
2020-11-03 22:11:48 +03:00
|
|
|
for cmd in \
|
2020-12-24 19:39:37 +03:00
|
|
|
Meta/check-ak-test-files.sh \
|
2020-11-28 20:16:38 +03:00
|
|
|
Meta/check-debug-flags.sh \
|
2021-10-04 21:56:33 +03:00
|
|
|
Meta/check-markdown.sh \
|
2021-01-03 21:31:44 +03:00
|
|
|
Meta/check-newlines-at-eof.py \
|
2021-10-27 00:49:28 +03:00
|
|
|
Meta/check-style.py \
|
2020-11-03 22:11:48 +03:00
|
|
|
Meta/lint-executable-resources.sh \
|
2021-01-30 10:39:45 +03:00
|
|
|
Meta/lint-keymaps.py \
|
2020-12-27 17:36:40 +03:00
|
|
|
Meta/lint-shell-scripts.sh \
|
2021-01-04 05:08:26 +03:00
|
|
|
Meta/lint-prettier.sh \
|
|
|
|
Meta/lint-python.sh; do
|
2020-12-27 17:34:06 +03:00
|
|
|
echo "Running ${cmd}... "
|
|
|
|
if "${cmd}" "$@"; then
|
|
|
|
echo -e "[${GREEN}OK${NC}]: ${cmd}"
|
2020-12-24 20:13:24 +03:00
|
|
|
else
|
2020-12-27 17:34:06 +03:00
|
|
|
echo -e "[${RED}FAIL${NC}]: ${cmd}"
|
|
|
|
((FAILURES+=1))
|
2020-12-24 20:13:24 +03:00
|
|
|
fi
|
2020-11-03 22:11:48 +03:00
|
|
|
done
|
|
|
|
|
2021-11-01 19:20:54 +03:00
|
|
|
if [ -x ./Build/lagom/Tools/IPCMagicLinter/IPCMagicLinter ]; then
|
|
|
|
if git ls-files '*.ipc' | xargs ./Build/lagom/Tools/IPCMagicLinter/IPCMagicLinter; then
|
|
|
|
echo -e "[${GREEN}OK${NC}]: IPCMagicLinter (in Meta/lint-ci.sh)"
|
|
|
|
else
|
|
|
|
echo -e "[${RED}FAIL${NC}]: IPCMagicLinter (in Meta/lint-ci.sh)"
|
|
|
|
((FAILURES+=1))
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo -e "[${GREEN}SKIP${NC}]: IPCMagicLinter (in Meta/lint-ci.sh)"
|
|
|
|
fi
|
|
|
|
|
2020-11-03 22:11:48 +03:00
|
|
|
echo "Running Meta/lint-clang-format.sh"
|
2020-12-27 17:34:06 +03:00
|
|
|
if Meta/lint-clang-format.sh --overwrite-inplace "$@" && git diff --exit-code; then
|
2020-12-24 20:13:24 +03:00
|
|
|
echo -e "[${GREEN}OK${NC}]: Meta/lint-clang-format.sh"
|
|
|
|
else
|
|
|
|
echo -e "[${RED}FAIL${NC}]: Meta/lint-clang-format.sh"
|
|
|
|
((FAILURES+=1))
|
|
|
|
fi
|
|
|
|
|
2021-04-30 14:30:04 +03:00
|
|
|
# lint-ports.py is handled separately as it scans all Ports/ all the time.
|
|
|
|
# This is fine when running lint-ci.sh from the PR validation workflow.
|
|
|
|
# However when running from the pre-commit workflow it takes an excessive
|
|
|
|
# amount of time. This condition allows the pre-commit program to detect
|
|
|
|
# when Ports/ files have changed and only invoke lint-ports.py when needed.
|
|
|
|
#
|
|
|
|
if [ "$ports" = true ]; then
|
|
|
|
if Meta/lint-ports.py; then
|
|
|
|
echo -e "[${GREEN}OK${NC}]: Meta/lint-ports.py"
|
|
|
|
else
|
|
|
|
echo -e "[${RED}FAIL${NC}]: Meta/lint-ports.py"
|
|
|
|
((FAILURES+=1))
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-11-03 22:11:48 +03:00
|
|
|
echo "(Not running lint-missing-resources.sh due to high false-positive rate.)"
|
|
|
|
echo "(Also look out for check-symbols.sh, which can only be executed after the build!)"
|
2020-12-24 20:13:24 +03:00
|
|
|
|
2020-12-26 11:26:32 +03:00
|
|
|
exit "${FAILURES}"
|