mirror of
https://git.savannah.gnu.org/git/gnuboot.git
synced 2025-01-12 18:39:15 +01:00
Denis 'GNUtoo' Carikli
7bf153a207
Without that fix, running 'shellcheck -x build' produces the following errors/warnings: In update line 81: case "${option}" in ^-- SC1009 (info): The mentioned syntax error was in this case expression. In update line 82: list) ^-- SC1073 (error): Couldn't parse this case item. Fix to allow more checks. In update line 92: all) ^-- SC1072 (error): Fix any mentioned problems and try again. ^-- SC1074 (error): Did you forget the ;; after the previous case item? After fixing these and rerunning 'shellcheck -x build', we then have the following errors/warnings: In update line 23: [ "x${DEBUG+set}" = 'xset' ] && set -v ^-------------^ SC2268 (style): Avoid x-prefix in comparisons as it no longer serves a purpose. In update line 32: ls -d resources/packages/*/update/ | \ ^-- SC2012 (info): Use find instead of ls to better handle non-alphanumeric filenames. In update line 40: ls -d resources/packages/"${package}"/update/* | \ ^-- SC2012 (info): Use find instead of ls to better handle non-alphanumeric filenames. In update line 95: resources/packages/"${package}"/update/"${option}" $@ ^-- SC2068 (error): Double quote array expansions to avoid re-splitting elements. In update line 102: "${pkg_dir}"/update/"${option}" $@ ^-- SC2068 (error): Double quote array expansions to avoid re-splitting elements. so we fix them as well. Signed-off-by: Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org> Acked-by: Adrien 'neox' Bourmault <neox@gnu.org>
67 lines
1.9 KiB
Bash
Executable file
67 lines
1.9 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
#
|
|
# Various code quality tests to avoid regressions in code quality.
|
|
#
|
|
# Copyright (C) 2023 Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
report()
|
|
{
|
|
ret=$?
|
|
message="$1"
|
|
|
|
if [ ${ret} -eq 0 ] ; then
|
|
echo "[ OK ] ${message}"
|
|
else
|
|
echo "[ !! ] ${message} failed"
|
|
exit ${ret}
|
|
fi
|
|
}
|
|
|
|
run_shellcheck()
|
|
{
|
|
for path in "$@" ; do
|
|
shellcheck -x "${path}" ; report "${path}"
|
|
done
|
|
}
|
|
|
|
printf "+---------------------+\n"
|
|
printf "| Running lint tests: |\n"
|
|
printf "+---------------------+\n"
|
|
run_shellcheck \
|
|
build \
|
|
download \
|
|
modify \
|
|
update \
|
|
resources/packages/descriptors/distclean \
|
|
resources/packages/flashrom/distclean \
|
|
resources/packages/grub/distclean \
|
|
resources/packages/ich9utils/distclean \
|
|
resources/packages/memtest86plus/distclean \
|
|
resources/packages/payloads/distclean \
|
|
resources/packages/rom_images/distclean \
|
|
resources/packages/roms/distclean \
|
|
resources/packages/seabios/distclean \
|
|
resources/packages/src/distclean \
|
|
resources/packages/u-boot-libre/distclean \
|
|
resources/packages/u-boot/distclean \
|
|
resources/packages/coreboot/distclean \
|
|
resources/scripts/tasks/distclean.sh \
|
|
tests/distclean \
|
|
tests/lint
|
|
|
|
printf "+---------------------+\n"
|
|
printf "| Lint tests done |\n"
|
|
printf "+---------------------+\n"
|