summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLeah Rowe <leah@libreboot.org>2024-12-30 14:13:49 +0000
committerLeah Rowe <leah@libreboot.org>2024-12-30 14:14:19 +0000
commitf64b59962790936f49399b13f9a940d5e6230d32 (patch)
tree463a9b29c25ba9da5261bce07e7ea75e7837ccec
parent295463d281e4beeb0ad3aa9d0fe390227e0d5ddc (diff)
Merge path.sh into script/trees
The code is simple enough now that I'm happy for it to just be part of the main script. Signed-off-by: Leah Rowe <leah@libreboot.org>
-rw-r--r--include/path.sh43
-rwxr-xr-xscript/trees43
2 files changed, 41 insertions, 45 deletions
diff --git a/include/path.sh b/include/path.sh
deleted file mode 100644
index 17e58fd7..00000000
--- a/include/path.sh
+++ /dev/null
@@ -1,43 +0,0 @@
-# SPDX-License-Identifier: MIT
-# Copyright (c) 2024 Leah Rowe <leah@libreboot.org>
-
-eval `setvars "" gccver gccfull gnatver gnatfull gccdir`
-
-# fix mismatching gcc/gnat versions on debian trixie/sid
-check_gnat_path()
-{
- rm -f xbmkpath/* || $err "Cannot clear xbmkpath/"
-
- eval `setvars "" gccver gccfull gnatver gnatfull gccdir`
- gnu_setver gcc gcc || $err "Command 'gcc' unavailable."
- gnu_setver gnat gnat || :
-
- [ -z "$gccver" ] && $err "Cannot detect host GCC version"
- [ "$gnatfull" = "$gccfull" ] && return 0
-
- gccdir="$(dirname "$(command -v gcc)")"
- for _gnatbin in "$gccdir/gnat-"*; do
- [ -f "$_gnatbin" ] || continue
- [ "${_gnatbin#"$gccdir/gnat-"}" = "$gccver" ] || continue
- gnatver="${_gnatbin#"$gccdir/gnat-"}"; break
- done
- gnu_setver "gnat" "$gccdir/gnat-$gccver" || $err "Unknown gnat version"
- [ "$gnatfull" = "$gccfull" ] || $err "GCC/GNAT versions do not match."
-
- (
- x_ cd xbmkpath
- for _gnatbin in "$gccdir/gnat"*"-$gccver"; do
- [ -e "$_gnatbin" ] || continue; _gnatutil="${_gnatbin##*/}"
- x_ ln -s "$_gnatbin" "${_gnatutil%"-$gccver"}"
- done
- ) || $err "Cannot create gnat-$gccver link in $gccdir"; :
-}
-
-gnu_setver()
-{
- eval "$2 --version 1>/dev/null 2>/dev/null || return 1"
- eval "${1}ver=\"`$2 --version 2>/dev/null | head -n1`\""
- eval "${1}ver=\"\${${1}ver##* }\""
- eval "${1}full=\"\${$1}ver\""
- eval "${1}ver=\"\${${1}ver%%.*}\""; :
-}
diff --git a/script/trees b/script/trees
index 57e19b63..786461dc 100755
--- a/script/trees
+++ b/script/trees
@@ -8,14 +8,14 @@ set -u -e
. "include/lib.sh"
. "include/git.sh"
-. "include/path.sh"
XBMKPATH="$PATH"
eval `setvars "" xarch srcdir premake cmakedir xlang mode makeargs elfdir cmd \
project target target_dir targets xtree _f release bootstrapargs mkhelper \
autoconfargs listfile autogenargs btype tree rev tree_depend build_depend \
- defconfig postmake mkhelpercfg dry dest_dir mdir cleanargs`; badhash="n"
+ defconfig postmake mkhelpercfg dry dest_dir mdir cleanargs gccver gccfull \
+ gnatver gnatfull gccdir`; badhash="n"
main()
{
@@ -215,6 +215,45 @@ check_cross_compiler()
done; return 0
}
+# fix mismatching gcc/gnat versions on debian trixie/sid
+check_gnat_path()
+{
+ rm -f xbmkpath/* || $err "Cannot clear xbmkpath/"
+
+ eval `setvars "" gccver gccfull gnatver gnatfull gccdir`
+ gnu_setver gcc gcc || $err "Command 'gcc' unavailable."
+ gnu_setver gnat gnat || :
+
+ [ -z "$gccver" ] && $err "Cannot detect host GCC version"
+ [ "$gnatfull" = "$gccfull" ] && return 0
+
+ gccdir="$(dirname "$(command -v gcc)")"
+ for _gnatbin in "$gccdir/gnat-"*; do
+ [ -f "$_gnatbin" ] || continue
+ [ "${_gnatbin#"$gccdir/gnat-"}" = "$gccver" ] || continue
+ gnatver="${_gnatbin#"$gccdir/gnat-"}"; break
+ done
+ gnu_setver "gnat" "$gccdir/gnat-$gccver" || $err "Unknown gnat version"
+ [ "$gnatfull" = "$gccfull" ] || $err "GCC/GNAT versions do not match."
+
+ (
+ x_ cd xbmkpath
+ for _gnatbin in "$gccdir/gnat"*"-$gccver"; do
+ [ -e "$_gnatbin" ] || continue; _gnatutil="${_gnatbin##*/}"
+ x_ ln -s "$_gnatbin" "${_gnatutil%"-$gccver"}"
+ done
+ ) || $err "Cannot create gnat-$gccver link in $gccdir"; :
+}
+
+gnu_setver()
+{
+ eval "$2 --version 1>/dev/null 2>/dev/null || return 1"
+ eval "${1}ver=\"`$2 --version 2>/dev/null | head -n1`\""
+ eval "${1}ver=\"\${${1}ver##* }\""
+ eval "${1}full=\"\${$1}ver\""
+ eval "${1}ver=\"\${${1}ver%%.*}\""; :
+}
+
check_defconfig()
{
[ -f "$defconfig" ] || $dry $err "$project/$target: missing defconfig"