summaryrefslogtreecommitdiff
path: root/include/release.sh
diff options
context:
space:
mode:
Diffstat (limited to 'include/release.sh')
-rw-r--r--include/release.sh95
1 files changed, 69 insertions, 26 deletions
diff --git a/include/release.sh b/include/release.sh
index 5d6da466..e9017a05 100644
--- a/include/release.sh
+++ b/include/release.sh
@@ -1,7 +1,12 @@
# SPDX-License-Identifier: GPL-3.0-or-later
+
# Copyright (c) 2023-2025 Leah Rowe <leah@libreboot.org>
-eval "`setvars "" reldir reldest vdir rsrc relmode`"
+reldest=""
+reldir=""
+relmode=""
+rsrc=""
+vdir=""
release()
{
@@ -9,31 +14,45 @@ release()
reldir="release"
- while getopts d:m: option; do
- [ -z "$OPTARG" ] && err "empty argument not allowed"
+ while getopts m: option
+ do
+ if [ -z "$OPTARG" ]; then
+ err "empty argument not allowed" "release" "$@"
+ fi
+
case "$option" in
- d) reldir="$OPTARG" ;;
- m) relmode="$OPTARG" ;;
- *) err "invalid option '-$option'" ;;
+ m)
+ relmode="$OPTARG"
+ ;;
+ *)
+ err "invalid option '-$option'" "release" "$@"
+ ;;
esac
done
reldest="$reldir/$version"
- [ -e "$reldest" ] && \
- err "already exists: \"$reldest\""
+ if [ -e "$reldest" ]; then
+ err "already exists: \"$reldest\"" "release" "$@"
+ fi
+
+ vdir="`mktemp -d || err "can't make vdir"`" || \
+ err "can't make tmp vdir" "release" "$@"
+ vdir="$vdir/$version"
- vdir="$XBMK_CACHE/relpwd/${xbmktmp##*/}/$version"
rsrc="$vdir/${relname}_src"
remkdir "$vdir"
x_ git clone . "$rsrc"
+ update_xbmkver "$rsrc"
prep_release src
prep_release tarball
- [ "$relmode" = "src" ] || prep_release bin
+ if [ "$relmode" != "src" ]; then
+ prep_release bin
+ fi
x_ rm -Rf "$rsrc"
- x_ mkdir -p "$reldir"
+ x_ xbmkdir "$reldir"
x_ mv "$vdir" "$reldir"
x_ rm -Rf "${vdir%"/$version"}"
@@ -42,46 +61,70 @@ release()
prep_release()
{
- x_ touch "$rsrc/lock"
(
- [ "$1" = "tarball" ] || x_ cd "$rsrc"
- prep_release_$1
- ) || err "can't prep release $1"
+ if [ "$1" != "tarball" ]; then
+ x_ cd "$rsrc"
+ if [ ! -e "cache" ]; then
+ x_ ln -s "$XBMK_CACHE" "cache"
+ fi
+ fi
+
+ prep_release_$1
+
+ ) || err "can't prep release $1" "prep_release" "$@"
}
prep_release_src()
{
+ x_ cp -R "util/sbase" "util/sbase2"
+
x_ ./mk -f
+
fx_ "x_ rm -Rf" x_ find . -name ".git"
fx_ "x_ rm -Rf" x_ find . -name ".gitmodules"
- ( fx_ nuke x_ find config -type f -name "nuke.list" ) || err; :
+
+ ( fx_ nuke x_ find config -type f -name "nuke.list" ) || \
+ err "can't prune project files" "prep_release_src" "$@"; :
}
nuke()
{
r="$rsrc/src/${1#config/}"
- [ -d "${r%/*}" ] && x_ cd "${r%/*}" && \
- dx_ "eval [ -L \"\$fx\" ] || x_ rm -Rf" "$rsrc/$1"; :
+
+ if [ -d "${r%/*}" ]; then
+ x_ cd "${r%/*}"
+
+ dx_ "x_ rm -Rf" "$rsrc/$1"
+ fi
}
prep_release_tarball()
{
git log --graph --pretty=format:'%Cred%h%Creset %s %Creset' \
- --abbrev-commit > "$rsrc/CHANGELOG" || err "!log $rsrc"
- x_ rm -f "$rsrc/lock"
- x_ rm -Rf "$rsrc/cache" "$rsrc/tmp"
+ --abbrev-commit > "$rsrc/CHANGELOG" || \
+ err "can't create '$rsrc/CHANGELOG'" "prep_release_tarball" "$@"
+
+ x_ rm -f "$rsrc/lock" "$rsrc/cache"
+ x_ rm -Rf "$rsrc/xbmkwd" "$rsrc/util/sbase"
+ x_ mv "$rsrc/util/sbase2" "$rsrc/util/sbase"
+
(
- x_ cd "${rsrc%/*}"
- x_ mktarball "${rsrc##*/}" "${rsrc##*/}.tar.xz"
- ) || err "can't create src tarball"; :
+ x_ cd "${rsrc%/*}"
+ x_ mktarball "${rsrc##*/}" "${rsrc##*/}.tar.xz"
+
+ ) || err "can't create src tarball" "prep_release_tarball" "$@"; :
}
prep_release_bin()
{
x_ ./mk -d coreboot
- fx_ "x_ ./mk -b" printf \
- "coreboot\npico-serprog\nstm32-vserprog\npcsx-redux\n"
+
+ x_ ./mk -b coreboot
+ x_ ./mk -b pico-serprog
+ x_ ./mk -b stm32-vserprog
+ x_ ./mk -b pcsx-redux
fx_ mkrom_tarball x_ find bin -maxdepth 1 -type d -name "serprog_*"
+
x_ mv bin ../roms
}