summaryrefslogtreecommitdiff
path: root/script/build/roms
diff options
context:
space:
mode:
authorLeah Rowe <leah@libreboot.org>2024-04-26 21:23:09 +0100
committerLeah Rowe <leah@libreboot.org>2024-04-26 21:49:27 +0100
commitd88783b7341656c26186e967425cf33341841dee (patch)
tree509a8e6fe89d5e127fa5edaf6abf33bb6188cd93 /script/build/roms
parentb6014a65acc786bee37590214c6af46d554d19a0 (diff)
build/roms: let "list" specify status types
for example: ./build roms list this will list every now, still. same behaviour. now see: ./build roms list stable this will list all stable roms ./build roms list untested this lists untested roms. but wait! ./build roms list untested broken unstable ./build roms list broken unstable yes. it works this way. now you can use lbmk to easily see what rom status are, during maintenance. Signed-off-by: Leah Rowe <leah@libreboot.org>
Diffstat (limited to 'script/build/roms')
-rwxr-xr-xscript/build/roms38
1 files changed, 33 insertions, 5 deletions
diff --git a/script/build/roms b/script/build/roms
index 1d36ad8a..03310315 100755
--- a/script/build/roms
+++ b/script/build/roms
@@ -24,20 +24,33 @@ v="romdir cbrom initmode displaymode cbcfg targetdir tree keymaps release"
v="${v} grub_timeout ubdir board grub_scan_disk uboot_config status"
eval "$(setvars "n" ${pv})"
eval "$(setvars "" ${v} boards _displaymode _payload _keyboard all targets \
- skipped)"
+ skipped listboards list_type)"
main()
{
check_project
while [ $# -gt 0 ]; do
+
+ if [ "$listboards" = "y" ]; then
+ [ "$1" = "stable" ] || [ "$1" = "unstable" ] || \
+ [ "$1" = "broken" ] || [ "$1" = "untested" ] || \
+ [ "$1" = "unknown" ] || \
+ $err "invalid list type '$1'"
+ list_type="$list_type $1"
+ list_type="${list_type# }"
+ shift 1; continue
+ fi
+
case ${1} in
help)
usage
exit 0 ;;
list)
- items config/coreboot || :
- exit 0 ;;
+ boards=$(items config/coreboot) || \
+ $err "Cannot generate list of boards for list"
+ listboards="y"
+ shift 1; continue ;;
-d) _displaymode="${2}" ;;
-p) _payload="${2}" ;;
-k) _keyboard="${2}" ;;
@@ -49,6 +62,9 @@ main()
shift 2
done
+ [ "$listboards" = "y" ] && [ -z "$list_type" ] && \
+ list_type="stable unstable broken untested unknown"
+
[ "${all}" != "y" ] || boards=$(items config/coreboot) || \
$err "Cannot generate list of boards for building"
@@ -63,6 +79,14 @@ main()
handle_status
+ if [ "$listboards" = "y" ]; then
+ for _list_type in $list_type; do
+ [ "$status" != "$_list_type" ] && continue
+ printf "%s\n" "$board"
+ done
+ continue
+ fi
+
# exclude certain targets from the release
skip_board && \
printf "Skip target %s(%s)\n" "$board" "$status" && \
@@ -75,6 +99,8 @@ main()
targets="* bin/${board}\n${targets}"
done
+ [ "$listboards" = "y" ] && return 0
+
if [ -n "$skipped" ]; then
printf "\nThese targets were skipped:\n"
eval "printf \"${skipped}\""
@@ -143,13 +169,15 @@ handle_status()
[ "$status" = "broken" ] || [ "$status" = "untested" ] || \
status="unknown"
- printf "Handling target: %s (status=%s)\n" "$board" "$status"
+ [ "$listboards" != "y" ] && \
+ printf "Handling target: %s (status=%s)\n" "$board" "$status"
[ "$status" = "broken" ] && release="n"
[ "$status" = "unknown" ] && release="n"
[ "$status" = "untested" ] && release="n"
- [ "$status" != "stable" ] && [ "$status" != "$release_type" ] && \
+ [ "$listboards" != "y" ] && \
+ [ "$status" != "stable" ] && [ "$status" != "$release_type" ] && \
printf "WARNING: %s not marked stable (status=%s):\n\n" \
"$board" "$status"; return 0
}