summaryrefslogtreecommitdiff
path: root/build
diff options
context:
space:
mode:
Diffstat (limited to 'build')
-rwxr-xr-xbuild177
1 files changed, 57 insertions, 120 deletions
diff --git a/build b/build
index 61836eb5..985bbe9e 100755
--- a/build
+++ b/build
@@ -1,195 +1,132 @@
#!/usr/bin/env sh
# SPDX-License-Identifier: GPL-3.0-or-later
-# SPDX-FileCopyrightText: 2014,2015,2020-2024 Leah Rowe <leah@libreboot.org>
-# SPDX-FileCopyrightText: 2015 Patrick "P. J." McDermott <pj@pehjota.net>
-# SPDX-FileCopyrightText: 2015, 2016 Klemens Nanni <contact@autoboot.org>
-# SPDX-FileCopyrightText: 2022, Caleb La Grange <thonkpeasant@protonmail.com>
+# Copyright (c) 2014-2015,2020-2024 Leah Rowe <leah@libreboot.org>
+# Copyright (c) 2015 Patrick "P. J." McDermott <pj@pehjota.net>
+# Copyright (c) 2015-2016 Klemens Nanni <contact@autoboot.org>
+# Copyright (c) 2022 Caleb La Grange <thonkpeasant@protonmail.com>
set -u -e
if [ "./${0##*/}" != "${0}" ] || [ ! -f "build" ] || [ -L "build" ]; then
- printf "You must run this in the lbmk work directory.\n" 1>&2
+ printf "You must run this in the proper work directory.\n" 1>&2
exit 1
fi
-. "include/option.sh"
+. "include/lib.sh"
. "include/vendor.sh"
. "include/mrc.sh"
-eval "$(setvars "" script_path aur_notice vdir src_dirname srcdir _xm mode xp)"
+eval `setvars "" vdir src_dirname srcdir mode xp ser`
err="fail"
-linkpath="${0}"
-linkname="${linkpath##*/}"
-
main()
{
- x_ id -u 1>/dev/null 2>/dev/null
- [ $# -lt 1 ] && $err "Check $projectname documentation for help."
-
- [ "$1" = "dependencies" ] && x_ install_packages $@ && lbmk_exit 0
-
- which git 1>/dev/null 2>/dev/null || \
- git_err "git not installed. please install git-scm."
- git config --global user.name 1>/dev/null 2>/dev/null || \
- git_err "git config --global user.name \"John Doe\""
- git config --global user.email 1>/dev/null 2>/dev/null || \
- git_err "git config --global user.email \"john.doe@example.com\""
+ [ $# -lt 1 ] && $err "bad command"
+ spath="script/$1"; shcmd="shift 1"
+ [ "${1#-*}" != "$1" ] && spath="script/trees" && shcmd=":"
- for cmd in initcmd git_init excmd; do
- eval "${cmd} \$@"
+ for g in "which git" "git config --global user.name" \
+ "git config --global user.email" "git_init"; do
+ eval "$g 1>/dev/null 2>/dev/null || $err \"Unconfigured: $g\""
done
- lbmk_exit 0
-}
-
-initcmd()
-{
- [ "$(id -u)" != "0" ] || $err "this command as root is not permitted"
- case "${1}" in
- version) printf "%s\n" "$relname" ;;
+ case "${spath#script/}" in
+ version) printf "%s\nWebsite: %s\n" "$relname" "$projectsite" ;;
release) shift 1; mkrelease $@ ;;
inject) shift 1; vendor_inject $@ ;;
download) shift 1; vendor_download $@ ;;
+ roms)
+ [ $# -gt 1 ] && [ "$2" = "serprog" ] && \
+ mk -b stm32-vserprog pico-serprog && return 0
+ shift 1; x_ ./mk -b coreboot $@ ;;
*)
- script_path="script/${1}"
- return 0 ;;
+ [ -f "$spath" ] || $err "bad command"
+ $shcmd; "$spath" $@ || $err "excmd: $spath $(echo "$@")" ;;
esac
set -u -e # some commands disable them. turn them on!
- lbmk_exit 0
-}
-
-install_packages()
-{
- if [ $# -lt 2 ]; then
- printf "You must specify a distro, namely:\n" 1>&2
- printf "Look at files under config/dependencies/\n" 1>&2
- printf "Example: ./build dependencies debian\n" 1>&2
- $err "install_packages: target not specified"
- fi
-
- [ -f "config/dependencies/${2}" ] || $err "Unsupported target"
-
- . "config/dependencies/${2}"
-
- x_ ${pkg_add} ${pkglist}
- [ -z "${aur_notice}" ] && return 0
- printf "You must install AUR packages: %s\n" "$aur_notice" 1>&2
}
-# release archives contain .gitignore, but not .git.
-# lbmk can be run from lbmk.git, or an archive.
git_init()
{
- [ -L ".git" ] && $err "Reference .git is a symlink"
+ [ -L ".git" ] && return 1
[ -e ".git" ] && return 0
- eval "$(setvars "$(date -Rud @${versiondate})" cdate _nogit)"
-
- git init || $err "${PWD}: cannot initialise Git repository"
- git add -A . || $err "${PWD}: cannot add files to Git repository"
- git commit -m "${projectname} ${version}" --date "${cdate}" \
- --author="lbmk <lbmk@libreboot.org>" || \
- $err "$PWD: can't commit ${projectname}/${version}, date $cdate"
- git tag -a "${version}" -m "${projectname} ${version}" || \
- $err "${PWD}: cannot git-tag ${projectname}/${version}"
-}
+ eval `setvars "$(date -Rud @$versiondate)" cdate _nogit`
-excmd()
-{
- [ -f "${script_path}" ] || $err "Bad command. Check $projectname docs."
- shift 1; "$script_path" $@ || $err "excmd: ${script_path} ${@}"
+ git init || return 1
+ git add -A . || return 1
+ git commit -m "$projectname $version" --date "$cdate" \
+ --author="xbmk <xbmk@example.com>" || return 1
+ git tag -a "$version" -m "$projectname $version" || return 1
}
mkrelease()
{
- export LBMK_RELEASE="y"
+ export XBMK_RELEASE="y"
vdir="release"
while getopts d:m: option; do
- [ -z "${OPTARG}" ] && $err "Empty argument not allowed"
- case "${option}" in
- d) vdir="${OPTARG}" ;;
- m) mode="${OPTARG}" ;;
- *) $err "Invalid option" ;;
+ [ -z "$OPTARG" ] && $err "empty argument not allowed"
+ case "$option" in
+ d) vdir="$OPTARG" ;;
+ m) mode="$OPTARG" ;;
+ *) $err "invalid option '-$option'" ;;
esac
done
- vdir="${vdir}/${version}"
+ vdir="$vdir/$version"
src_dirname="${relname}_src"
- srcdir="${vdir}/${src_dirname}"
+ srcdir="$vdir/$src_dirname"
- [ -e "${vdir}" ] && $err "already exists: \"${vdir}\""
- mkdir -p "${vdir}" || $err "mkvdir: !mkdir -p \"${vdir}\""
- git clone . "${srcdir}" || $err "mkdir: !gitclone \"${srcdir}\""
+ [ -e "$vdir" ] && $err "already exists: \"$vdir\""
+ mkdir -p "$vdir" || $err "mkvdir: !mkdir -p \"$vdir\""
+ git clone . "$srcdir" || $err "mkdir: !gitclone \"$srcdir\""
+ touch "$srcdir/lock" || $err "can't make lock file in $srcdir/"
build_release
- printf "\n\nDONE! Check release files under %s\n" "${vdir}"
+ printf "\n\nDONE! Check release files under %s\n" "$vdir"
}
build_release()
{
- _xm="build_release ${vdir}"
(
- cd "${srcdir}" || $err "${_xm}: !cd \"${srcdir}\""
- fetch_trees
+ cd "$srcdir" || $err "$vdir: !cd \"$srcdir\""
+ ./mk -f; x_ rm -Rf tmp; rmgit .
x_ mv src/docs docs
) || $err "can't create release files"
git log --graph --pretty=format:'%Cred%h%Creset %s %Creset' \
- --abbrev-commit > "${srcdir}/CHANGELOG" || \
- $err "build_release $srcdir: couldn't generate changelog"
+ --abbrev-commit > "$srcdir/CHANGELOG" || $err "!gitlog $srcdir"
+ rm -f "$srcdir/lock" || $err "can't remove lock file in $srcdir"
(
- cd "${srcdir%/*}" || $err "${_xm}: mktarball \"${srcdir}\""
- mktarball "${srcdir##*/}" "${srcdir##*/}.tar.xz" || \
- $err "$_xm: mksrc"
+ cd "${srcdir%/*}" || $err "$vdir: mktarball \"$srcdir\""
+ mktarball "${srcdir##*/}" "${srcdir##*/}.tar.xz" || $err "$vdir: mksrc"
) || $err "can't create src tarball"
- [ "${mode}" = "src" ] && return 0
+ [ "$mode" = "src" ] && return 0
+ touch "$srcdir/lock" || $err "can't make lock file in $srcdir/"
(
- cd "${srcdir}" || $err "${_xm}: 2 !cd \"${srcdir}\""
- ./build roms all || $err "${_xm}: roms-all"
- ./build roms serprog rp2040 || $err "${_xm}: rp2040"
- ./build roms serprog stm32 || $err "${_xm}: stm32"
+ cd "$srcdir" || $err "$vdir: 2 !cd \"$srcdir\""
+ mk -b coreboot pico-serprog stm32-vserprog pcsx-redux
x_ mv bin ../roms
) || $err "can't build rom images"
- rm -Rf "${srcdir}" || $err "!rm -Rf ${srcdir}"
-}
-
-fetch_trees()
-{
- for x in $(items config/git); do
- ./update trees -f "$x" || $err "$_xm: fetch $x"
- done
-
- for x in config/*/build.list; do
- [ -f "$x" ] && xp="${x#*/}" && xp="${xp%/*}"
- [ ! -f "$x" ] || [ -L "$xp" ] || x_ rm -Rf "src/$xp/$xp"
- done
-
- find . -name ".git" -exec rm -Rf {} + || $err "$_xm: rm .git"
- find . -name ".gitmodules" -exec rm -Rf {} + || $err "$_xm: rm .gitmod"
- rm -Rf tmp .git src/u-boot/*/test/lib/strlcat.c || $err "$_xm !rm"
-}
-
-lbmk_exit()
-{
- tmp_cleanup || err_ "lbmk_exit: can't rm tmpdir upon exit $1: $tmpdir"
- exit $1
+ rm -Rf "$srcdir" || $err "!rm -Rf $srcdir"
}
fail()
{
- tmp_cleanup || printf "WARNING: can't rm tmpdir: %s\n" "$tmpdir" 1>&2
+ tmp_cleanup || printf "WARNING: can't rm tmpfiles: %s\n" "$TMPDIR" 1>&2
err_ "${1}"
}
tmp_cleanup()
{
- [ "${tmpdir_was_set}" = "n" ] || return 0
- rm -Rf "${tmpdir}" || return 1
+ [ "$xbmk_parent" = "y" ] || return 0
+ [ "$TMPDIR" = "/tmp" ] || rm -Rf "$TMPDIR" || return 1
+ rm -f lock || return 1
}
main $@
+tmp_cleanup || err_ "can't rm TMPDIR upon non-zero exit: $TMPDIR"