summaryrefslogtreecommitdiff
path: root/include/release.sh
diff options
context:
space:
mode:
Diffstat (limited to 'include/release.sh')
-rw-r--r--include/release.sh84
1 files changed, 53 insertions, 31 deletions
diff --git a/include/release.sh b/include/release.sh
index 4741b44a..c13be2c3 100644
--- a/include/release.sh
+++ b/include/release.sh
@@ -1,65 +1,87 @@
# SPDX-License-Identifier: GPL-3.0-or-later
# Copyright (c) 2023-2025 Leah Rowe <leah@libreboot.org>
-eval "`setvars "" vdir src_dirname relsrcdir relmode`"
+eval "`setvars "" reldir reldest vdir rsrc relmode`"
release()
{
export XBMK_RELEASE="y"
- vdir="release"
+ reldir="release"
+
while getopts d:m: option; do
[ -z "$OPTARG" ] && err "empty argument not allowed"
case "$option" in
- d) vdir="$OPTARG" ;;
+ d) reldir="$OPTARG" ;;
m) relmode="$OPTARG" ;;
*) err "invalid option '-$option'" ;;
esac
done
- vdir="$vdir/$version"
- src_dirname="${relname}_src"
- relsrcdir="$vdir/$src_dirname"
+ reldest="$reldir/$version"
+ [ -e "$reldest" ] && err "already exists: \"$reldest\""
+
+ vdir="$XBMK_CACHE/relpwd/${xbtmp##*/}/$version"
+ rsrc="$vdir/${relname}_src"
- [ -e "$vdir" ] && err "already exists: \"$vdir\""
- x_ mkdir -p "$vdir"
- x_ git clone . "$relsrcdir"
- x_ touch "$relsrcdir/lock"
+ remkdir "$vdir"
+ x_ git clone . "$rsrc"
+ update_xbmkver "$rsrc"
- build_release
+ prep_release src
+ prep_release tarball
+ [ "$relmode" = "src" ] || prep_release bin
+ x_ rm -Rf "$rsrc"
- printf "\n\nDONE! Check release files under %s\n" "$vdir"
+ x_ mkdir -p "$reldir"
+ x_ mv "$vdir" "$reldir"
+ x_ rm -Rf "${vdir%"/$version"}"
+
+ printf "\n\nDONE! Check release files under %s\n" "$reldest"
}
-build_release()
+prep_release()
{
+ x_ touch "$rsrc/lock"
(
- x_ cd "$relsrcdir"
+ [ "$1" = "tarball" ] || x_ cd "$rsrc"
+ prep_release_$1
+ ) || err "can't prep release $1"
+}
+prep_release_src()
+{
x_ ./mk -f
- rmgit .
- x_ mv src/docs docs
- ) || err "can't create release files"
+ 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; :
+}
- git log --graph --pretty=format:'%Cred%h%Creset %s %Creset' \
- --abbrev-commit > "$relsrcdir/CHANGELOG" || err "!log $relsrcdir"
- x_ rm -f "$relsrcdir/lock"
+nuke()
+{
+ r="$rsrc/src/${1#config/}"
+ [ -d "${r%/*}" ] && x_ cd "${r%/*}" && \
+ dx_ "eval [ -L \"\$fx\" ] || x_ rm -Rf" "$rsrc/$1"; :
+}
+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"
(
- x_ cd "${relsrcdir%/*}"
- x_ mktarball "${relsrcdir##*/}" "${relsrcdir##*/}.tar.xz"
- ) || err "can't create src tarball"
- [ "$relmode" = "src" ] && return 0
+ x_ cd "${rsrc%/*}"
+ x_ mktarball "${rsrc##*/}" "${rsrc##*/}.tar.xz"
+ ) || err "can't create src tarball"; :
+}
- x_ touch "$relsrcdir/lock"
- (
- x_ cd "$relsrcdir"
+prep_release_bin()
+{
x_ ./mk -d coreboot
- mk -b coreboot pico-serprog stm32-vserprog pcsx-redux
+ fx_ "x_ ./mk -b" printf \
+ "coreboot\npico-serprog\nstm32-vserprog\npcsx-redux\n"
fx_ mkrom_tarball x_ find bin -maxdepth 1 -type d -name "serprog_*"
x_ mv bin ../roms
- ) || err "can't build rom images"
-
- x_ rm -Rf "$relsrcdir"
}