Merge branch 'master' into 25.06_branch
commit
a3b4b36564
|
@ -15,7 +15,6 @@ fetch_targets()
|
||||||
printf "Creating %s tree %s\n" "$project" "$tree"
|
printf "Creating %s tree %s\n" "$project" "$tree"
|
||||||
git_prep "$url" "$bkup_url" "$xbmkpwd/$configdir/$tree/patches" \
|
git_prep "$url" "$bkup_url" "$xbmkpwd/$configdir/$tree/patches" \
|
||||||
"src/$project/$tree" with_submodules
|
"src/$project/$tree" with_submodules
|
||||||
( fx_ nuke find "$xbmkpwd/config" -type f -name "nuke.list" ) || exit 1
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fetch_project()
|
fetch_project()
|
||||||
|
@ -31,7 +30,6 @@ fetch_project()
|
||||||
x_ ./mk -f $d
|
x_ ./mk -f $d
|
||||||
done
|
done
|
||||||
clone_project
|
clone_project
|
||||||
( fx_ nuke find "$xbmkpwd/config" -type f -name "nuke.list" ) || exit 1
|
|
||||||
}
|
}
|
||||||
|
|
||||||
clone_project()
|
clone_project()
|
||||||
|
@ -150,27 +148,15 @@ try_git()
|
||||||
|
|
||||||
bad_checksum()
|
bad_checksum()
|
||||||
{
|
{
|
||||||
[ ! -f "$2" ] && printf "File '%s' missing (sha512sum '%s')\n" \
|
[ ! -f "$2" ] && printf "'%s' missing, %s\n" "$2" "$1" 1>&2 && return 0
|
||||||
"$2" "$1" 1>&2 && return 0
|
csum="$(x_ sha512sum "$2" | awk '{print $1}')" || err "!sha512 '$2' $1"
|
||||||
fchksum="$(x_ sha512sum "$2" | awk '{print $1}')" || \
|
[ "$csum" != "$1" ] && printf "BAD SHA512, '%s'; need '%s', got %s\n" \
|
||||||
err "Can't get sha512sum on '$2' (checking for sha512sum '$1')"
|
"$2" "$1" "$csum" 1>&2 && x_ rm -f "$2" && return 0; return 1
|
||||||
[ "$fchksum" != "$1" ] || return 1
|
|
||||||
printf "WARNING: BAD checksum for '%s' - expected '%s', got '%s'\n" \
|
|
||||||
"$2" "$1" "$fchksum" 1>&2
|
|
||||||
x_ rm -f "$2"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
tmpclone()
|
tmpclone()
|
||||||
{
|
{
|
||||||
printf "Creating git clone '%s' from '%s'\n" "$2" "$1"
|
|
||||||
( x_ git clone "$1" "$2" ) || return 1
|
( x_ git clone "$1" "$2" ) || return 1
|
||||||
( x_ git -C "$2" reset --hard "$3" ) || return 1
|
( x_ git -C "$2" reset --hard "$3" ) || return 1
|
||||||
( fx_ "eval x_ git -C \"$2\" am" find "$4" -type f ) || return 1; :
|
( fx_ "eval x_ git -C \"$2\" am" find "$4" -type f ) || return 1; :
|
||||||
}
|
}
|
||||||
|
|
||||||
nuke()
|
|
||||||
{
|
|
||||||
rdir="${1#"$xbmkpwd/config/"}" && [ -d "$xbmkpwd/src/${rdir%/*}" ] && \
|
|
||||||
x_ cd "$xbmkpwd/src/${rdir%/*}" && \
|
|
||||||
dx_ "eval [ -L \"\$fx\" ] || x_ rm -Rf" "$1"; :
|
|
||||||
}
|
|
||||||
|
|
193
include/init.sh
193
include/init.sh
|
@ -12,11 +12,10 @@ projectsite="https://canoeboot.org/"
|
||||||
|
|
||||||
[ -z "${PATH+x}" ] && \
|
[ -z "${PATH+x}" ] && \
|
||||||
export PATH="/usr/local/bin:/usr/bin:/bin:/usr/local/games:/usr/games"
|
export PATH="/usr/local/bin:/usr/bin:/bin:/usr/local/games:/usr/games"
|
||||||
xbmkpath="$PATH"
|
|
||||||
|
|
||||||
eval "`setvars "" _nogit board reinstall versiondate aur_notice configdir \
|
eval "`setvars "" _nogit board reinstall versiondate aur_notice configdir \
|
||||||
datadir version xbmkpwd relname xbmkpwd xbmktmp python pyver xbmklocal \
|
datadir version xbmkpwd relname xbmkpwd xbmktmp python pyver xbmklocal \
|
||||||
xbmklock cvxbmk cvchk`"
|
xbmklock cvxbmk cvchk xbmkpath`"
|
||||||
|
|
||||||
xbmk_init()
|
xbmk_init()
|
||||||
{
|
{
|
||||||
|
@ -31,8 +30,7 @@ xbmk_init()
|
||||||
id -u 1>/dev/null 2>/dev/null || err "suid check failed (id -u)"
|
id -u 1>/dev/null 2>/dev/null || err "suid check failed (id -u)"
|
||||||
[ "$(id -u)" != "0" ] || err "this command as root is not permitted"
|
[ "$(id -u)" != "0" ] || err "this command as root is not permitted"
|
||||||
|
|
||||||
for init_cmd in set_pyver set_version set_env git_init create_tmpdir \
|
for init_cmd in get_version set_env git_init child_exec; do
|
||||||
lock create_pathdirs child_exec; do
|
|
||||||
xbmk_$init_cmd "$@" || break
|
xbmk_$init_cmd "$@" || break
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
@ -51,6 +49,95 @@ xbmkpkg()
|
||||||
printf "You need AUR packages: %s\n" "$aur_notice" 1>&2; :
|
printf "You need AUR packages: %s\n" "$aur_notice" 1>&2; :
|
||||||
}
|
}
|
||||||
|
|
||||||
|
xbmk_get_version()
|
||||||
|
{
|
||||||
|
[ ! -f ".version" ] || read -r version < ".version" || err
|
||||||
|
[ ! -f ".versiondate" ] || read -r versiondate < ".versiondate" || err
|
||||||
|
[ ! -f ".version" ] || chkvars version
|
||||||
|
[ ! -f ".versiondate" ] || chkvars versiondate
|
||||||
|
|
||||||
|
[ ! -e ".git" ] && [ ! -f ".version" ] && version="unknown"
|
||||||
|
[ ! -e ".git" ] && [ ! -f ".versiondate" ] && versiondate="1716415872"
|
||||||
|
|
||||||
|
[ -n "$version" ] && relname="$projectname-$version"; :
|
||||||
|
}
|
||||||
|
|
||||||
|
xbmk_set_env()
|
||||||
|
{
|
||||||
|
is_child="n"
|
||||||
|
|
||||||
|
xbmkpath="$PATH"
|
||||||
|
|
||||||
|
# unify all temporary files/directories in a single TMPDIR
|
||||||
|
[ -z "${TMPDIR+x}" ] || [ "${TMPDIR%_*}" = "/tmp/xbmk" ] || \
|
||||||
|
unset TMPDIR
|
||||||
|
[ -n "${TMPDIR+x}" ] && export TMPDIR="$TMPDIR" && xbmktmp="$TMPDIR"
|
||||||
|
[ -z "${TMPDIR+x}" ] || is_child="y" # child instance, so return
|
||||||
|
|
||||||
|
if [ "$is_child" = "y" ]; then
|
||||||
|
[ -z "${XBMK_CACHE+x}" ] && err "XBMK_CACHE unset on child"
|
||||||
|
[ -z "${XBMK_THREADS+x}" ] && err "XBMK_THREADS unset on child"
|
||||||
|
e "lock" f missing && err "lock file absent on child"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
[ -f "$xbmklock" ] && err "'$xbmklock' exists. Is a build running?"
|
||||||
|
touch "$xbmklock" || err "cannot create '$xbmklock'"; :
|
||||||
|
|
||||||
|
# parent instance of xbmk, so don't return. set up TMPDIR
|
||||||
|
export TMPDIR="/tmp"
|
||||||
|
export TMPDIR="$(mktemp -d -t xbmk_XXXXXXXX)"
|
||||||
|
xbmktmp="$TMPDIR"
|
||||||
|
|
||||||
|
# XBMK_CACHE is a directory, for caching downloads and git repon
|
||||||
|
[ -z "${XBMK_CACHE+x}" ] && export XBMK_CACHE="$xbmkpwd/cache"
|
||||||
|
[ -z "$XBMK_CACHE" ] && export XBMK_CACHE="$xbmkpwd/cache"
|
||||||
|
[ -L "$XBMK_CACHE" ] && [ "$XBMK_CACHE" = "$xbmkpwd/cache" ] && \
|
||||||
|
err "cachedir '$xbmkpwd/cache' is a symlink"
|
||||||
|
[ -L "$XBMK_CACHE" ] && export XBMK_CACHE="$xbmkpwd/cache"
|
||||||
|
xbmkcache="`findpath "$XBMK_CACHE"`" || \
|
||||||
|
err "Can't resolve cachedir: '$XBMK_CACHE'"
|
||||||
|
export XBMK_CACHE="$xbmkcache"
|
||||||
|
[ ! -e "$XBMK_CACHE" ] || \
|
||||||
|
[ -d "$XBMK_CACHE" ] || err "cachedir '$XBMK_CACHE' is a file"; :
|
||||||
|
|
||||||
|
export PATH="$XBMK_CACHE/xbmkpath:$XBMK_CACHE/gnupath:$PATH"
|
||||||
|
xbmkpath="$PATH"
|
||||||
|
|
||||||
|
# if "y": a coreboot target won't be built if target.cfg says release="n"
|
||||||
|
# (this is used to exclude certain build targets from releases)
|
||||||
|
[ -z "${XBMK_RELEASE+x}" ] && export XBMK_RELEASE="n"
|
||||||
|
[ "$XBMK_RELEASE" = "Y" ] && export XBMK_RELEASE="y"
|
||||||
|
[ "$XBMK_RELEASE" = "y" ] || export XBMK_RELEASE="n"
|
||||||
|
|
||||||
|
[ -z "${XBMK_THREADS+x}" ] && export XBMK_THREADS=1
|
||||||
|
expr "X$XBMK_THREADS" : "X-\{0,1\}[0123456789][0123456789]*$" \
|
||||||
|
1>/dev/null 2>/dev/null || export XBMK_THREADS=1
|
||||||
|
|
||||||
|
xbmk_set_version
|
||||||
|
export LOCALVERSION="-$projectname-${version%%-*}"
|
||||||
|
|
||||||
|
remkdir "$xbmktmp" "$xbmklocal"
|
||||||
|
remkdir "$XBMK_CACHE/gnupath" "$XBMK_CACHE/xbmkpath"
|
||||||
|
|
||||||
|
xbmk_set_pyver
|
||||||
|
}
|
||||||
|
|
||||||
|
xbmk_set_version()
|
||||||
|
{
|
||||||
|
version_="$version"
|
||||||
|
[ ! -e ".git" ] || version="$(git describe --tags HEAD 2>&1)" || \
|
||||||
|
version="git-$(git rev-parse HEAD 2>&1)" || version="$version_"
|
||||||
|
versiondate_="$versiondate"
|
||||||
|
[ ! -e ".git" ] || versiondate="$(git show --no-patch --no-notes \
|
||||||
|
--pretty='%ct' HEAD)" || versiondate="$versiondate_"
|
||||||
|
|
||||||
|
chkvars version versiondate
|
||||||
|
update_xbmkver "."
|
||||||
|
|
||||||
|
relname="$projectname-$version"
|
||||||
|
}
|
||||||
|
|
||||||
xbmk_set_pyver()
|
xbmk_set_pyver()
|
||||||
{
|
{
|
||||||
pyv="import sys; print(sys.version_info[:])"
|
pyv="import sys; print(sys.version_info[:])"
|
||||||
|
@ -63,7 +150,14 @@ xbmk_set_pyver()
|
||||||
[ -n "$pyver" ] && \
|
[ -n "$pyver" ] && \
|
||||||
pyver="$("$(pybin "$python")" -c "$pyv" | awk '{print $1}')" && \
|
pyver="$("$(pybin "$python")" -c "$pyv" | awk '{print $1}')" && \
|
||||||
pyver="${pyver#(}" && pyver="${pyver%,}"
|
pyver="${pyver#(}" && pyver="${pyver%,}"
|
||||||
[ "${pyver%%.*}" = "3" ] || err "Bad python version (must by 3.x)"; :
|
[ "${pyver%%.*}" = "3" ] || err "Bad python version (must by 3.x)"
|
||||||
|
|
||||||
|
(
|
||||||
|
# set up python v3.x in PATH, in case it's not set up correctly.
|
||||||
|
# see code above that detected the correct python3 command.
|
||||||
|
x_ cd "$XBMK_CACHE/xbmkpath"
|
||||||
|
x_ ln -s "`pybin "$python"`" python
|
||||||
|
) || err "Can't set up python symlink in $XBMK_CACHE/xbmkpath"; :
|
||||||
}
|
}
|
||||||
|
|
||||||
# Use direct path, to prevent a hang if Python is using a virtual environment,
|
# Use direct path, to prevent a hang if Python is using a virtual environment,
|
||||||
|
@ -97,57 +191,6 @@ pybin()
|
||||||
command -v "$1" 2>/dev/null || return 1
|
command -v "$1" 2>/dev/null || return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
xbmk_set_version()
|
|
||||||
{
|
|
||||||
[ ! -f ".version" ] || read -r version < ".version" || :; :
|
|
||||||
[ ! -f ".versiondate" ] || read -r versiondate < ".versiondate" || :; :
|
|
||||||
|
|
||||||
[ -e ".git" ] || [ -f ".version" ] || printf "unknown\n" > ".version" \
|
|
||||||
|| err "Cannot generate unknown .version file"
|
|
||||||
[ -e ".git" ] || [ -f ".versiondate" ] || printf "1716415872\n" > \
|
|
||||||
".versiondate" || err "Can't generate unknown versiondate file"; :
|
|
||||||
|
|
||||||
version_="$version"
|
|
||||||
[ ! -e ".git" ] || version="$(git describe --tags HEAD 2>&1)" || \
|
|
||||||
version="git-$(git rev-parse HEAD 2>&1)" || version="$version_"
|
|
||||||
versiondate_="$versiondate"
|
|
||||||
[ ! -e ".git" ] || versiondate="$(git show --no-patch --no-notes \
|
|
||||||
--pretty='%ct' HEAD)" || versiondate="$versiondate_"
|
|
||||||
|
|
||||||
chkvars version versiondate
|
|
||||||
printf "%s\n" "$version" > ".version" || err "can't save version"
|
|
||||||
printf "%s\n" "$versiondate" > ".versiondate" || err "can't save date"
|
|
||||||
|
|
||||||
relname="$projectname-$version"
|
|
||||||
}
|
|
||||||
|
|
||||||
xbmk_set_env()
|
|
||||||
{
|
|
||||||
export LOCALVERSION="-$projectname-${version%%-*}"
|
|
||||||
|
|
||||||
# XBMK_CACHE is a directory, for caching downloads and git repon
|
|
||||||
[ -z "${XBMK_CACHE+x}" ] && export XBMK_CACHE="$xbmkpwd/cache"
|
|
||||||
[ -z "$XBMK_CACHE" ] && export XBMK_CACHE="$xbmkpwd/cache"
|
|
||||||
[ -L "$XBMK_CACHE" ] && [ "$XBMK_CACHE" = "$xbmkpwd/cache" ] && \
|
|
||||||
err "cachedir '$xbmkpwd/cache' is a symlink"
|
|
||||||
[ -L "$XBMK_CACHE" ] && export XBMK_CACHE="$xbmkpwd/cache"
|
|
||||||
xbmkcache="`findpath "$XBMK_CACHE"`" || \
|
|
||||||
err "Can't resolve cachedir: '$XBMK_CACHE'"
|
|
||||||
export XBMK_CACHE="$xbmkcache"
|
|
||||||
[ ! -e "$XBMK_CACHE" ] || \
|
|
||||||
[ -d "$XBMK_CACHE" ] || err "cachedir '$XBMK_CACHE' is a file"; :
|
|
||||||
|
|
||||||
# if "y": a coreboot target won't be built if target.cfg says release="n"
|
|
||||||
# (this is used to exclude certain build targets from releases)
|
|
||||||
[ -z "${XBMK_RELEASE+x}" ] && export XBMK_RELEASE="n"
|
|
||||||
[ "$XBMK_RELEASE" = "Y" ] && export XBMK_RELEASE="y"
|
|
||||||
[ "$XBMK_RELEASE" = "y" ] || export XBMK_RELEASE="n"
|
|
||||||
|
|
||||||
[ -z "${XBMK_THREADS+x}" ] && export XBMK_THREADS=1
|
|
||||||
expr "X$XBMK_THREADS" : "X-\{0,1\}[0123456789][0123456789]*$" \
|
|
||||||
1>/dev/null 2>/dev/null || export XBMK_THREADS=1; :
|
|
||||||
}
|
|
||||||
|
|
||||||
xbmk_git_init()
|
xbmk_git_init()
|
||||||
{
|
{
|
||||||
for gitarg in "--global user.name" "--global user.email"; do
|
for gitarg in "--global user.name" "--global user.email"; do
|
||||||
|
@ -167,44 +210,6 @@ xbmk_git_init()
|
||||||
2>/dev/null; :
|
2>/dev/null; :
|
||||||
}
|
}
|
||||||
|
|
||||||
xbmk_create_tmpdir()
|
|
||||||
{
|
|
||||||
x_ mkdir -p "$xbmklocal"
|
|
||||||
|
|
||||||
# unify all temporary files/directories in a single TMPDIR
|
|
||||||
[ -z "${TMPDIR+x}" ] || [ "${TMPDIR%_*}" = "/tmp/xbmk" ] || \
|
|
||||||
unset TMPDIR
|
|
||||||
[ -n "${TMPDIR+x}" ] && export TMPDIR="$TMPDIR" && xbmktmp="$TMPDIR"
|
|
||||||
[ -z "${TMPDIR+x}" ] || return 1 # child instance, so return
|
|
||||||
|
|
||||||
# parent instance of xbmk, so don't return. set up TMPDIR
|
|
||||||
export TMPDIR="/tmp"
|
|
||||||
export TMPDIR="$(mktemp -d -t xbmk_XXXXXXXX)"
|
|
||||||
xbmktmp="$TMPDIR"
|
|
||||||
|
|
||||||
# /tmp might be a tmpfs, so for large files we use ./tmp,
|
|
||||||
# not to be confused with xbmktmp (xbmktmp points to /tmp)
|
|
||||||
remkdir "$xbmktmp" "$xbmklocal"
|
|
||||||
}
|
|
||||||
|
|
||||||
xbmk_lock()
|
|
||||||
{
|
|
||||||
[ -f "$xbmklock" ] && err "'$xbmklock' exists. Is a build running?"
|
|
||||||
touch "$xbmklock" || err "cannot create '$xbmklock'"; :
|
|
||||||
}
|
|
||||||
|
|
||||||
xbmk_create_pathdirs()
|
|
||||||
{
|
|
||||||
remkdir "$XBMK_CACHE/gnupath" "$XBMK_CACHE/xbmkpath"
|
|
||||||
export PATH="$XBMK_CACHE/xbmkpath:$XBMK_CACHE/gnupath:$PATH"
|
|
||||||
(
|
|
||||||
# set up python v3.x in PATH, in case it's not set up correctly.
|
|
||||||
# see code above that detected the correct python3 command.
|
|
||||||
x_ cd "$XBMK_CACHE/xbmkpath"
|
|
||||||
x_ ln -s "`pybin "$python"`" python
|
|
||||||
) || err "Can't set up python symlink in $XBMK_CACHE/xbmkpath"; :
|
|
||||||
}
|
|
||||||
|
|
||||||
xbmk_child_exec()
|
xbmk_child_exec()
|
||||||
{
|
{
|
||||||
xbmk_rval=0
|
xbmk_rval=0
|
||||||
|
|
|
@ -21,7 +21,7 @@ inject()
|
||||||
|
|
||||||
set +u +e
|
set +u +e
|
||||||
[ $# -lt 1 ] && err "No options specified"
|
[ $# -lt 1 ] && err "No options specified"
|
||||||
eval "`setvars "" nukemode new_mac xchanged`"
|
eval "`setvars "" nuke new_mac xchanged`"
|
||||||
|
|
||||||
archive="$1";
|
archive="$1";
|
||||||
new_mac="xx:xx:xx:xx:xx:xx"
|
new_mac="xx:xx:xx:xx:xx:xx"
|
||||||
|
@ -29,7 +29,7 @@ inject()
|
||||||
[ $# -gt 1 ] && case "$2" in
|
[ $# -gt 1 ] && case "$2" in
|
||||||
nuke)
|
nuke)
|
||||||
new_mac=""
|
new_mac=""
|
||||||
nukemode="nuke" ;;
|
nuke="nuke" ;;
|
||||||
setmac)
|
setmac)
|
||||||
[ $# -gt 2 ] && new_mac="$3" && \
|
[ $# -gt 2 ] && new_mac="$3" && \
|
||||||
[ -z "$new_mac" ] && err "Empty MAC address specified" ;;
|
[ -z "$new_mac" ] && err "Empty MAC address specified" ;;
|
||||||
|
|
|
@ -15,13 +15,17 @@ remkdir()
|
||||||
|
|
||||||
mkrom_tarball()
|
mkrom_tarball()
|
||||||
{
|
{
|
||||||
printf "%s\n" "$version" > "$1/.version" || err "$1 !version"
|
update_xbmkver "$1"
|
||||||
printf "%s\n" "$versiondate" > "$1/.versiondate" || err "$1 !vdate"
|
|
||||||
|
|
||||||
mktarball "$1" "${1%/*}/${relname}_${1##*/}.tar.xz"
|
mktarball "$1" "${1%/*}/${relname}_${1##*/}.tar.xz"
|
||||||
x_ rm -Rf "$1"
|
x_ rm -Rf "$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
update_xbmkver()
|
||||||
|
{
|
||||||
|
printf "%s\n" "$version" > "$1/.version" || err "$1 !version"; :
|
||||||
|
printf "%s\n" "$versiondate" > "$1/.versiondate" || err "$1 !vdate"; :
|
||||||
|
}
|
||||||
|
|
||||||
mktarball()
|
mktarball()
|
||||||
{
|
{
|
||||||
printf "Creating tar archive '%s' from directory '%s'\n" "$2" "$1"
|
printf "Creating tar archive '%s' from directory '%s'\n" "$2" "$1"
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
# Copyright (c) 2023-2025 Leah Rowe <leah@libreboot.org>
|
# Copyright (c) 2023-2025 Leah Rowe <leah@libreboot.org>
|
||||||
|
|
||||||
eval "`setvars "" reldir reldest vdir relsrcdir relmode`"
|
eval "`setvars "" reldir reldest vdir rsrc relmode`"
|
||||||
|
|
||||||
release()
|
release()
|
||||||
{
|
{
|
||||||
|
@ -23,15 +23,15 @@ release()
|
||||||
err "already exists: \"$reldest\""
|
err "already exists: \"$reldest\""
|
||||||
|
|
||||||
vdir="$XBMK_CACHE/relpwd/${xbmktmp##*/}/$version"
|
vdir="$XBMK_CACHE/relpwd/${xbmktmp##*/}/$version"
|
||||||
relsrcdir="$vdir/${relname}_src"
|
rsrc="$vdir/${relname}_src"
|
||||||
|
|
||||||
remkdir "$vdir"
|
remkdir "$vdir"
|
||||||
x_ git clone . "$relsrcdir"
|
x_ git clone . "$rsrc"
|
||||||
|
|
||||||
prep_release src
|
prep_release src
|
||||||
prep_release tarball
|
prep_release tarball
|
||||||
prep_release bin
|
[ "$relmode" = "src" ] || prep_release bin
|
||||||
x_ rm -Rf "$relsrcdir"
|
x_ rm -Rf "$rsrc"
|
||||||
|
|
||||||
x_ mkdir -p "$reldir"
|
x_ mkdir -p "$reldir"
|
||||||
x_ mv "$vdir" "$reldir"
|
x_ mv "$vdir" "$reldir"
|
||||||
|
@ -42,9 +42,9 @@ release()
|
||||||
|
|
||||||
prep_release()
|
prep_release()
|
||||||
{
|
{
|
||||||
x_ touch "$relsrcdir/lock"
|
x_ touch "$rsrc/lock"
|
||||||
(
|
(
|
||||||
[ "$1" = "tarball" ] || x_ cd "$relsrcdir"
|
[ "$1" = "tarball" ] || x_ cd "$rsrc"
|
||||||
prep_release_$1
|
prep_release_$1
|
||||||
) || err "can't prep release $1"
|
) || err "can't prep release $1"
|
||||||
}
|
}
|
||||||
|
@ -54,24 +54,30 @@ prep_release_src()
|
||||||
x_ ./mk -f
|
x_ ./mk -f
|
||||||
fx_ "x_ rm -Rf" x_ find . -name ".git"
|
fx_ "x_ rm -Rf" x_ find . -name ".git"
|
||||||
fx_ "x_ rm -Rf" x_ find . -name ".gitmodules"
|
fx_ "x_ rm -Rf" x_ find . -name ".gitmodules"
|
||||||
x_ mv src/docs docs
|
( fx_ nuke x_ find config -type f -name "nuke.list" ) || err; :
|
||||||
|
}
|
||||||
|
|
||||||
|
nuke()
|
||||||
|
{
|
||||||
|
r="$rsrc/src/${1#config/}"
|
||||||
|
[ -d "${r%/*}" ] && x_ cd "${r%/*}" && \
|
||||||
|
dx_ "eval [ -L \"\$fx\" ] || x_ rm -Rf" "$rsrc/$1"; :
|
||||||
}
|
}
|
||||||
|
|
||||||
prep_release_tarball()
|
prep_release_tarball()
|
||||||
{
|
{
|
||||||
git log --graph --pretty=format:'%Cred%h%Creset %s %Creset' \
|
git log --graph --pretty=format:'%Cred%h%Creset %s %Creset' \
|
||||||
--abbrev-commit > "$relsrcdir/CHANGELOG" || err "!log $relsrcdir"
|
--abbrev-commit > "$rsrc/CHANGELOG" || err "!log $rsrc"
|
||||||
x_ rm -f "$relsrcdir/lock"
|
x_ rm -f "$rsrc/lock"
|
||||||
x_ rm -Rf "$relsrcdir/cache" "$relsrcdir/tmp"
|
x_ rm -Rf "$rsrc/cache" "$rsrc/tmp"
|
||||||
(
|
(
|
||||||
x_ cd "${relsrcdir%/*}"
|
x_ cd "${rsrc%/*}"
|
||||||
x_ mktarball "${relsrcdir##*/}" "${relsrcdir##*/}.tar.xz"
|
x_ mktarball "${rsrc##*/}" "${rsrc##*/}.tar.xz"
|
||||||
) || err "can't create src tarball"; :
|
) || err "can't create src tarball"; :
|
||||||
}
|
}
|
||||||
|
|
||||||
prep_release_bin()
|
prep_release_bin()
|
||||||
{
|
{
|
||||||
[ "$relmode" = "src" ] && return 0
|
|
||||||
fx_ "x_ ./mk -b" printf \
|
fx_ "x_ ./mk -b" printf \
|
||||||
"coreboot\npico-serprog\nstm32-vserprog\npcsx-redux\n"
|
"coreboot\npico-serprog\nstm32-vserprog\npcsx-redux\n"
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue