2
1
Fork 0
mirror of https://git.savannah.gnu.org/git/gnuboot.git synced 2025-01-20 22:36:29 +01:00
gnuboot/update
Denis 'GNUtoo' Carikli c9b194409d
update: rename mode(s) to package(s).
Most GNU Boot users are interested in running GNU/Linux or BSD
operating systems. And the way to install software on these
operating systems is through a package manager. So most users and
contributors already know the package manager abstraction.

So referring to packages instead of options makes it easier to
understand what the script is doing.

Signed-off-by: Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
Acked-by: Adrien 'neox' Bourmault <neox@gnu.org>
2023-12-06 17:13:41 +01:00

102 lines
2.4 KiB
Bash
Executable file

#!/usr/bin/env bash
# generic update scripts for updating configs and such
#
# Copyright (C) 2014, 2015, 2020, 2021 Leah Rowe <info@minifree.org>
# Copyright (C) 2015 Patrick "P. J." McDermott <pj@pehjota.net>
# Copyright (C) 2015, 2016 Klemens Nanni <contact@autoboot.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/>.
#
[ "x${DEBUG+set}" = 'xset' ] && set -v
set -u -e
projectname="$(cat projectname)"
./resources/scripts/misc/versioncheck
update=./resources/scripts/update
list_packages() {
for package in "${update}"/*; do
printf '%s\n' "${package##*/}"
done
}
# Takes exactly one package as parameter
listoptions() {
for option in "${update}"/"${1}"/*; do
printf '%s\n' "${option##*/}"
done
}
help() {
cat <<- EOF
USAGE: ./update <PACKAGE> <OPTION>
possible values for 'package':
$(list_packages)
Example: ./update coreboot configs
Example: ./update coreboot configs x60
Refer to the ${projectname} documentation for more information.
EOF
}
die() {
printf 'Error: %s\n' "${@}" 1>&2
exit 1
}
if [ $# -lt 1 ]; then
die "Wrong number of arguments specified. See './update help'."
fi
package="${1}"
[ "${package}" = help ] && help && exit 0
if [ $# -gt 1 ]; then
option="${2}"
shift 2
case "${option}" in
list)
printf "Available options for package '%s':\n\n" "${package}"
listoptions "${package}"
;;
all)
for option in $(listoptions "${package}"); do
"${update}"/"${package}"/"${option}" $@
done
;;
*)
if [ -d "${update}"/"${package}"/ ]; then
if [ -f "${update}"/"${package}"/"${option}" ]; then
"${update}"/"${package}"/"${option}" $@
else
help
die "Invalid option for '${package}'." \
" See './update ${package} list'."
fi
else
help
die "Invalid package '${package}'. See './update help'."
fi
esac
else
help
exit 0
fi