summaryrefslogtreecommitdiff
path: root/include/path.sh
diff options
context:
space:
mode:
authorLeah Rowe <leah@libreboot.org>2024-12-30 14:10:32 +0000
committerLeah Rowe <leah@libreboot.org>2024-12-30 14:11:45 +0000
commit295463d281e4beeb0ad3aa9d0fe390227e0d5ddc (patch)
treef46c08883aa4b5b1b034b09d1807a2a6a4ed6808 /include/path.sh
parent5b24e0a5a96096273b8b662edf3b2f7ff204c00c (diff)
path.sh: Further cleanup
Remove all symlinks each time, to ensure that no stragglers are left behind, since they are being re-generated each time anyway. The code for determining version numbers has now been unified under gnu_setver() Signed-off-by: Leah Rowe <leah@libreboot.org>
Diffstat (limited to 'include/path.sh')
-rw-r--r--include/path.sh45
1 files changed, 20 insertions, 25 deletions
diff --git a/include/path.sh b/include/path.sh
index 98f536c1..17e58fd7 100644
--- a/include/path.sh
+++ b/include/path.sh
@@ -1,48 +1,43 @@
# 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()
{
- eval `setvars "" gccver gccfull gnatver gnatfull gccdir`
- command -v gcc 1>/dev/null || $err "Command 'gcc' unavailable."
+ rm -f xbmkpath/* || $err "Cannot clear xbmkpath/"
- for _util in gcc gnat; do
- eval "$_util --version 1>/dev/null 2>/dev/null || continue"
- eval "${_util}ver=\"`$_util --version 2>/dev/null | head -n1`\""
- eval "${_util}ver=\"\${${_util}ver##* }\""
- eval "${_util}full=\"\${$_util}ver\""
- eval "${_util}ver=\"\${${_util}ver%%.*}\""
- done
+ 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)")"
- [ -d "$gccdir" ] || $err "gcc PATH dir \"$gccdir\" does not exist."
-
for _gnatbin in "$gccdir/gnat-"*; do
[ -f "$_gnatbin" ] || continue
[ "${_gnatbin#"$gccdir/gnat-"}" = "$gccver" ] || continue
- gnatver="${_gnatbin#"$gccdir/gnat-"}"
- break
+ gnatver="${_gnatbin#"$gccdir/gnat-"}"; break
done
- [ -x "$gccdir/gnat-$gccver" ] || \
- $err "$gccdir/gnat-$gccver not executable"
- gnatfull="`"$gccdir/gnat-$gccver" --version | head -n1`"
- gnatfull="${gnatfull##* }"
- [ "${gnatfull%%.*}" = "$gnatver" ] || \
- $err "$gccdir/gnat-$gccver v${gnatfull%%.*}; expected v$gnatver"
-
+ 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##*/}"
- ln -s "$_gnatbin" "${_gnatutil%"-$gccver"}" || \
- $err "E: ln -s \"$_gnatbin\" \"${_gnatutil%"-$gccver"}\""
+ [ -e "$_gnatbin" ] || continue; _gnatutil="${_gnatbin##*/}"
+ x_ ln -s "$_gnatbin" "${_gnatutil%"-$gccver"}"
done
- ) || $err "Cannot create gnat-$gccver link in $gccdir"
+ ) || $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%%.*}\""; :
}