update/*/*: unified scanning of revisions/sources

update/blobs/download and update/project/repo both use
the same logic, for setting variables with awk and a
specially formatted configuration file.

unify this logic under include/option.sh, and use that.

Signed-off-by: Leah Rowe <leah@libreboot.org>
btrfsvols
Leah Rowe 2023-09-30 01:31:40 +01:00
parent 9f5a5450af
commit 385eb90c8c
3 changed files with 51 additions and 64 deletions

View File

@ -1,4 +1,6 @@
# SPDX-License-Identifier: MIT # SPDX-License-Identifier: GPL-3.0-only
# SPDX-FileCopyrightText: 2022 Caleb La Grange <thonkpeasant@protonmail.com>
# SPDX-FileCopyrightText: 2022 Ferass El Hafidi <vitali64pmemail@protonmail.com>
# SPDX-FileCopyrightText: 2023 Leah Rowe <leah@libreboot.org> # SPDX-FileCopyrightText: 2023 Leah Rowe <leah@libreboot.org>
listitems() listitems()
@ -16,3 +18,26 @@ listitems()
done done
return ${rval} return ${rval}
} }
scan_config()
{
awkstr=" /\{.*${1}.*}{/ {flag=1;next} /\}/{flag=0} flag { print }"
confdir="${2}"
_fail="${3}"
revfile="$(mktemp -t sources.XXXXXXXXXX)" || \
"${_fail}" "scan_config: Cannot initialise tmpfile"
cat "${confdir}/"* > "${revfile}" || \
"${_fail}" "scan_config: Cannot concatenate files"
while read -r line ; do
set ${line} 1>/dev/null 2>/dev/null || :
if [ "${1%:}" = "depend" ]; then
depend="${depend} ${2}"
else
eval "${1%:}=\"${2}\""
fi
done << EOF
$(eval "awk '${awkstr}' \"${revfile}\"")
EOF
rm -f "${revfile}" || \
"${_fail}" "scan_config: Cannot remove tmpfile"
}

View File

@ -7,6 +7,7 @@
. "include/err.sh" . "include/err.sh"
. "include/blobutil.sh" . "include/blobutil.sh"
. "include/mrc.sh" . "include/mrc.sh"
. "include/option.sh"
export PATH="${PATH}:/sbin" export PATH="${PATH}:/sbin"
@ -15,10 +16,11 @@ main()
[ $# -gt 0 ] || err "No argument given" [ $# -gt 0 ] || err "No argument given"
board="${1}" board="${1}"
boarddir="${cbcfgsdir}/${board}" boarddir="${cbcfgsdir}/${board}"
_b="${board%%_*mb}" # shorthand (avoid duplicating config per rom size)
check_defconfig "${boarddir}" || exit 0 check_defconfig "${boarddir}" || exit 0
detect_firmware && exit 0 detect_firmware && exit 0
scan_sources_config scan_config "${_b}" "config/blobs" "err"
build_dependencies build_dependencies
download_blobs download_blobs
@ -36,29 +38,19 @@ detect_firmware()
printf "Blobs not needed for: %s\n" "${board}" 1>&2 printf "Blobs not needed for: %s\n" "${board}" 1>&2
} }
scan_sources_config()
{
_b=${board%%_*mb} # shorthand to avoid duplicating config per rom size
awkstr=" /\{.*${_b}.*}{/ {flag=1;next} /\}/{flag=0} flag { print }"
while read -r line ; do
set ${line} 1>/dev/null 2>/dev/null
eval "${1}=\"${2}\""
done << EOF
$(eval "awk '${awkstr}' config/blobs/sources")
EOF
}
build_dependencies() build_dependencies()
{ {
[ -d ${cbdir} ] || ./update project trees coreboot ${cbdir##*/} || \ [ -d ${cbdir} ] || \
err "build_dependencies: can't fetch ${cbdir}" ./update project trees coreboot ${cbdir##*/} || \
err "build_dependencies: can't fetch ${cbdir}"
for d in uefitool biosutilities bios_extract me_cleaner; do for d in uefitool biosutilities bios_extract me_cleaner; do
[ -d "${d}" ] && continue [ -d "${d}" ] && continue
./update project repo "${d}" || \ ./update project repo "${d}" || \
err "build_dependencies: can't fetch ${d}" err "build_dependencies: can't fetch ${d}"
done done
[ -f uefitool/uefiextract ] || ./handle make file -b uefitool || \ [ -f uefitool/uefiextract ] || \
err "build_dependencies: can't build uefitool" ./handle make file -b uefitool || \
err "build_dependencies: can't build uefitool"
[ -f "${cbdir}/util/kbc1126/kbc1126_ec_dump" ] || \ [ -f "${cbdir}/util/kbc1126/kbc1126_ec_dump" ] || \
make -C "${cbdir}/util/kbc1126" || \ make -C "${cbdir}/util/kbc1126" || \
err "build_dependencies: can't build kbc1126_ec_dump" err "build_dependencies: can't build kbc1126_ec_dump"

View File

@ -6,10 +6,11 @@
. "include/err.sh" . "include/err.sh"
. "include/git.sh" . "include/git.sh"
. "include/option.sh"
name="" name=""
revision="" rev=""
location="" loc=""
url="" url=""
bkup_url="" bkup_url=""
tmp_dir="${PWD}/tmp/gitclone" tmp_dir="${PWD}/tmp/gitclone"
@ -22,7 +23,7 @@ main()
[ -z "${1+x}" ] && fail 'main(): name not set' [ -z "${1+x}" ] && fail 'main(): name not set'
name=${1} name=${1}
read_config scan_config "${name}" "config/git" "fail"
verify_config verify_config
clone_project clone_project
@ -34,41 +35,10 @@ main()
rm -Rf "${tmp_dir}" || fail "cannot remove tmpdir, ${tmp_dir}" rm -Rf "${tmp_dir}" || fail "cannot remove tmpdir, ${tmp_dir}"
} }
read_config()
{
revfile="$(mktemp -t gitrevisions.XXXXXXXXXX)" || \
fail "read_config: Cannot initialise tmpfile"
cat config/git/* > "${revfile}" || \
fail "read_config: Cannot concatenate revision files"
awkstr=" /\{.*${name}.*}{/ {flag=1;next} /\}/{flag=0} flag { print }"
while read -r line ; do
set ${line} || fail "read_config: set line"
case ${line} in
rev:*)
revision=${2} ;;
loc:*)
location=${2} ;;
url:*)
url=${2} ;;
bkup_url:*)
bkup_url=${2} ;;
depend:*)
depend="${depend} ${2} " ;;
esac
done << EOF
$(eval "awk \"${awkstr}\" \"${revfile}\"")
EOF
rm -f "${revfile}" || \
fail "read_config: can't remove tmp revfile"
}
verify_config() verify_config()
{ {
[ -z "${revision+x}" ] && fail 'verify_config: revision not set' [ -z "${rev+x}" ] && fail 'verify_config: rev not set'
[ -z "${location+x}" ] && fail 'verify_config: location not set' [ -z "${loc+x}" ] && fail 'verify_config: loc not set'
[ -z "${url+x}" ] && fail 'verify_config: url not set' [ -z "${url+x}" ] && fail 'verify_config: url not set'
} }
@ -79,24 +49,24 @@ clone_project()
git clone ${url} "${tmp_dir}" || git clone ${bkup_url} "${tmp_dir}" || \ git clone ${url} "${tmp_dir}" || git clone ${bkup_url} "${tmp_dir}" || \
fail "clone_project: could not download ${name}" fail "clone_project: could not download ${name}"
git_reset_rev "${tmp_dir}" "${revision}" "fail" || \ git_reset_rev "${tmp_dir}" "${rev}" "fail" || \
fail "clone_project ${location}/: cannot reset <- ${revision}" fail "clone_project ${loc}/: cannot reset <- ${rev}"
git_am_patches "${tmp_dir}" "${PWD}/config/${name}/patches" "fail" || \ git_am_patches "${tmp_dir}" "${PWD}/config/${name}/patches" "fail" || \
fail "clone_project ${location}/: cannot apply patches" fail "clone_project ${loc}/: cannot apply patches"
[ ! -d "${location}" ] || \ [ ! -d "${loc}" ] || \
rm -Rf "${location}" || \ rm -Rf "${loc}" || \
fail "clone_project: Can't remove directory '${location}'" fail "clone_project: Can't remove directory '${loc}'"
[ "${location}" = "${location%/*}" ] || mkdir -p ${location%/*} || \ [ "${loc}" = "${loc%/*}" ] || mkdir -p ${loc%/*} || \
fail "clone_project: cannot make directory for ${name}" fail "clone_project: cannot make directory for ${name}"
mv "${tmp_dir}" "${location}" || \ mv "${tmp_dir}" "${loc}" || \
fail "clone_project: could not copy temp file to destination" fail "clone_project: could not copy temp file to destination"
} }
fail() fail()
{ {
for x in "${location}" "${tmp_dir}"; do for x in "${loc}" "${tmp_dir}"; do
[ -z "${x}" ] || [ ! -d "${x}" ] || rm -Rf "${location}" || : [ -z "${x}" ] || [ ! -d "${x}" ] || rm -Rf "${loc}" || :
done done
usage usage
err "${1}" err "${1}"