mirror of
https://github.com/koreader/koreader
synced 2024-11-11 19:11:14 +00:00
ci: improve check script
- don't stop at the first error, report all issues - always run luacheck directly: so a luacheck install for another LUA version or using a shell script launcher works (the docker image wrapper already uses luajit) - don't disable colors in luacheck output - leave the terminal attributes to default at exit
This commit is contained in:
parent
0eb4c2b077
commit
21fd34a445
26
.ci/check.sh
26
.ci/check.sh
@ -4,10 +4,12 @@ CI_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
# shellcheck source=/dev/null
|
||||
source "${CI_DIR}/common.sh"
|
||||
|
||||
echo -e "\n${ANSI_GREEN}shellcheck results"
|
||||
"${CI_DIR}/helper_shellchecks.sh"
|
||||
exit_code=0
|
||||
|
||||
echo -e "\\n${ANSI_GREEN}Checking for unscaled sizes"
|
||||
echo -e "\n${ANSI_GREEN}shellcheck results${ANSI_RESET}"
|
||||
"${CI_DIR}/helper_shellchecks.sh" || exit_code=1
|
||||
|
||||
echo -e "\\n${ANSI_GREEN}Checking for unscaled sizes${ANSI_RESET}"
|
||||
# stick `|| true` at the end to prevent Travis exit on failed command
|
||||
unscaled_size_check=$(grep -nr --include=*.lua --exclude=koptoptions.lua --exclude-dir=base --exclude-dir=luajit-rocks --exclude-dir=install --exclude-dir=keyboardlayouts --exclude-dir=*arm* "\\(padding\\|margin\\|bordersize\\|width\\|height\\|radius\\|linesize\\) = [0-9]\\{1,2\\}" | grep -v '= 0' | grep -v '= [0-9]/[0-9]' | grep -Ev '(default_option_height|default_option_padding)' | grep -v scaleBySize | grep -v 'unscaled_size_check: ignore' || true)
|
||||
# Also check Geom objects; for legibility two regular expressions rather than
|
||||
@ -15,26 +17,28 @@ unscaled_size_check=$(grep -nr --include=*.lua --exclude=koptoptions.lua --exclu
|
||||
unscaled_size_check_geom=$(grep -E -nr --include=*.lua --exclude=gesturerange_spec.lua --exclude-dir=base --exclude-dir=luajit-rocks --exclude-dir=*arm* 'Geom:new{.+ [wh] = [0-9]{1,4}' | grep -Ev '[wh] = 0' | grep -v '= [0-9]/[0-9]' | grep -v scaleBySize || true)
|
||||
|
||||
if [ "${unscaled_size_check}" ] || [ "${unscaled_size_check_geom}" ]; then
|
||||
echo -e "\\n${ANSI_RED}Warning: it looks like you might be using unscaled sizes.\\nIt is almost always preferable to defer to one of the predefined sizes in ui.size in the following files:"
|
||||
echo -e "\\n${ANSI_RED}Warning: it looks like you might be using unscaled sizes.\\nIt is almost always preferable to defer to one of the predefined sizes in ui.size in the following files:${ANSI_RESET}"
|
||||
echo "${unscaled_size_check}"
|
||||
echo "${unscaled_size_check_geom}"
|
||||
exit 1
|
||||
exit_code=1
|
||||
fi
|
||||
|
||||
tab_detected=$(grep -P "\\t" --include \*.lua --exclude={dateparser.lua,xml.lua} --recursive {reader,setupkoenv,datastorage}.lua frontend plugins spec || true)
|
||||
if [ "${tab_detected}" ]; then
|
||||
echo -e "\\n${ANSI_RED}Warning: tab character detected. Please use spaces."
|
||||
echo -e "\\n${ANSI_RED}Warning: tab character detected. Please use spaces.${ANSI_RESET}"
|
||||
echo "${tab_detected}"
|
||||
exit 1
|
||||
exit_code=1
|
||||
fi
|
||||
|
||||
untagged_todo=$(grep -Pin "[^\-]\-\-(\s+)?@?(todo|fixme|warning)" --include \*.lua --exclude={dateparser.lua,xml.lua} --recursive {reader,setupkoenv,datastorage}.lua frontend plugins spec || true)
|
||||
if [ "${untagged_todo}" ]; then
|
||||
echo -e "\\n${ANSI_RED}Warning: possible improperly tagged todo, fixme or warning detected."
|
||||
echo -e "\\n${ANSI_RED} use --- followed by @todo, @fixme or @warning."
|
||||
echo -e "\\n${ANSI_RED} use --- followed by @todo, @fixme or @warning.${ANSI_RESET}"
|
||||
echo "${untagged_todo}"
|
||||
exit 1
|
||||
exit_code=1
|
||||
fi
|
||||
|
||||
echo -e "\n${ANSI_GREEN}Luacheck results"
|
||||
luajit "$(command -v luacheck)" --no-color -q {reader,setupkoenv,datastorage}.lua frontend plugins spec
|
||||
echo -e "\n${ANSI_GREEN}Luacheck results${ANSI_RESET}"
|
||||
luacheck -q {reader,setupkoenv,datastorage}.lua frontend plugins spec || exit_code=1
|
||||
|
||||
exit ${exit_code}
|
||||
|
Loading…
Reference in New Issue
Block a user