diff options
Diffstat (limited to 'include/release.sh')
-rw-r--r-- | include/release.sh | 95 |
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 } |