diff options
Diffstat (limited to 'build')
-rwxr-xr-x | build | 177 |
1 files changed, 57 insertions, 120 deletions
@@ -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" |