|
lalbornoz |
340f4c |
#!/bin/sh
|
|
Lucio Andrés Illanes Albornoz |
e3e4f9 |
# Copyright (c) 2016, 2017, 2018, 2019, 2020, 2021 Lucio Andrés Illanes Albornoz <lucio@lucioillanes.de>
|
|
Lucio Andrés Illanes Albornoz (arab, vxp) |
1d0876 |
#
|
|
Lucio Andrés Illanes Albornoz (arab, vxp) |
090fd4 |
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
buildp_ast() {
|
|
Lucio Andrés Illanes Albornoz |
e381c3 |
trap '' HUP INT TERM USR1 USR2;
|
|
Lucio Andrés Illanes Albornoz |
725770 |
local _param="${1}" _pids="" _pids_niter=0 _pkg_name="" RTL_KILL_TREE_PIDS="";
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
if [ "${_param}" = "abort" ]; then
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg fatalexit "Build aborted.";
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
a97175 |
while [ "${_pids_niter}" -lt 8 ]; do
|
|
Lucio Andrés Illanes Albornoz |
a97175 |
_pids="$(rtl_lconcat "${_pids}" "${RTL_KILL_TREE_PIDS}")"; RTL_KILL_TREE_PIDS="";
|
|
Lucio Andrés Illanes Albornoz |
a97175 |
if ! rtl_kill_tree "${$}" "TERM"\
|
|
Lucio Andrés Illanes Albornoz |
a97175 |
|| [ -z "${RTL_KILL_TREE_PIDS}" ]; then
|
|
Lucio Andrés Illanes Albornoz |
647a12 |
break;
|
|
Lucio Andrés Illanes Albornoz |
a97175 |
else
|
|
Lucio Andrés Illanes Albornoz |
a97175 |
: $((_pids_niter+=1));
|
|
Lucio Andrés Illanes Albornoz |
647a12 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
647a12 |
done;
|
|
Lucio Andrés Illanes Albornoz |
a97175 |
if [ -n "${_pids}" ]; then
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg notice "Killed PID(s): %s" "$(rtl_uniq ${_pids})";
|
|
Lucio Andrés Illanes Albornoz |
a97175 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
370e98 |
if [ -n "${EX_PKG_DISPATCH_WAIT}" ]\
|
|
Lucio Andrés Illanes Albornoz |
370e98 |
&& [ "${ARG_RESET_PKG}" -eq 1 ]; then
|
|
Lucio Andrés Illanes Albornoz |
725770 |
for _pkg_name in ${EX_PKG_DISPATCH_WAIT}; do
|
|
Lucio Andrés Illanes Albornoz |
725770 |
rtl_state_clear "${BUILD_WORKDIR}" "${_pkg_name}";
|
|
Lucio Andrés Illanes Albornoz |
725770 |
done;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg notice "Reset package state for: %s" "${EX_PKG_DISPATCH_WAIT}";
|
|
Lucio Andrés Illanes Albornoz |
725770 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
8cae5b |
if [ -n "${DEFAULT_BUILD_STATUS_IN_PROGRESS_FNAME}" ]; then
|
|
Lucio Andrés Illanes Albornoz |
8cae5b |
rtl_fileop rm "${DEFAULT_BUILD_STATUS_IN_PROGRESS_FNAME}";
|
|
Lucio Andrés Illanes Albornoz |
8cae5b |
fi;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
};
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
buildp_dispatch_fail_pkg() {
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
local _group_name="${1}" _pkg_name="${2}";
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
: $((BUILD_NFAIL+=1)); BUILD_PKGS_FAILED="$(rtl_lconcat "${BUILD_PKGS_FAILED}" "${_pkg_name}")";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
if [ "${ARG_RELAXED:-0}" -eq 0 ]; then
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg fatal "${BUILD_WORKDIR}/${_pkg_name}_stderrout.log:";
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
cat "${BUILD_WORKDIR}/${_pkg_name}_stderrout.log";
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
if [ -n "${DEFAULT_BUILD_LAST_FAILED_PKG_FNAME}" ]; then
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
printf "%s" "${_pkg_name}" > "${DEFAULT_BUILD_LAST_FAILED_PKG_FNAME}";
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg fatal "Build failed in \`%s', check \`%s' for details." "${_pkg_name}" "${BUILD_WORKDIR}/${_pkg_name}_stderrout.log";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
else rtl_log_msg warning "Build failed in \`%s', check \`%s' for details." "${_pkg_name}" "${BUILD_WORKDIR}/${_pkg_name}_stderrout.log";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
if [ "${ARG_DUMP_ON_ABORT:-0}" -eq 1 ]; then
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg info "Logged environment dump for failed package \`%s' to \`%s'." "${_pkg_name}" "${BUILD_WORKDIR}/${_pkg_name}.dump";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg info "Enter an interactive package build shell w/ the command line: ./pkgtool.sh -a %s -b %s \"%s\" PREFIX=\"%s\""\
|
|
Lucio Andrés Illanes Albornoz |
a6970c |
"${ARCH}" "${BUILD_KIND}" "${_pkg_name}" "${PREFIX}";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
if [ "${ARG_RELAXED:-0}" -eq 0 ]; then
|
|
Lucio Andrés Illanes Albornoz |
8a27f9 |
exit 1;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
};
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
buildp_dispatch_group_state() {
|
|
Lucio Andrés Illanes Albornoz |
1c6c04 |
local _msg="${1}" _group_name="${2}";
|
|
Lucio Andrés Illanes Albornoz (arab, vxp) |
ec19f0 |
case "${_msg}" in
|
|
Lucio Andrés Illanes Albornoz |
71825c |
finish_group) rtl_log_msg success_end "[%3d%% ] [%03d/%03d] Finished \`%s' build group." "${6}" "${4}" "${5}" "${_group_name}"; ;;
|
|
Lucio Andrés Illanes Albornoz |
71825c |
start_group) rtl_log_msg success "[%3d%% ] [%03d/%03d] Starting \`%s' build group..." "${6}" "${4}" "${5}" "${_group_name}"; ;;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
esac;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
};
|
|
Lucio Andrés Illanes Albornoz (arab, vxp) |
fc9417 |
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
buildp_dispatch_pkg_state() {
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
local _msg="${1}" _group_name="${2}" _pkg_name="${3}";
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
case "${_msg}" in
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
disabled_pkg) : $((BUILD_NSKIP+=1)); rtl_log_msg verbose "Skipping disabled package \`%s'." "${_pkg_name}"; ;;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
missing_pkg) rtl_log_msg fatalexit "Error: unknown package \`%s'." "${_pkg_name}"; ;;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
msg_pkg) shift 3; rtl_log_msg verbose "%s/%s: %s" "${_group_name}" "${_pkg_name}" "${*}"; ;;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
skipped_pkg) : $((BUILD_NSKIP+=1)); rtl_log_msg verbose "Skipping finished package \`%s'." "${_pkg_name}"; ;;
|
|
Lucio Andrés Illanes Albornoz |
71825c |
start_pkg) rtl_log_msg info "[%3d%%/%3d%%] [%03d/%03d] Starting \`%s' build..." "${7}" "${6}" "${4}" "${5}" "${_pkg_name}"; ;;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
step_pkg) rtl_log_msg verbose "Finished build step %s of package \`%s'." "${4}" "${_pkg_name}"; ;;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
finish_pkg)
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
: $((BUILD_NFINI+=1));
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
if [ "${ARG_VERBOSE:-0}" -ge 2 ]; then
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
cat "${BUILD_WORKDIR}/${_pkg_name}_stderrout.log";
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
71825c |
rtl_log_msg info_end "[%3d%%/%3d%%] [%03d/%03d] Finished \`%s' build." "${7}" "${6}" "${4}" "${5}" "${_pkg_name}"; ;;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
start_pkg_child)
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
if [ "${PKG_NO_LOG_VARS:-0}" -eq 0 ]; then
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_env_vars "build" $(rtl_get_vars_fast "^PKG_");
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
if [ "${ARG_VERBOSE:-0}" -ge 3 ]; then
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
set -o xtrace;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
fi; ;;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
esac;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
};
|
|
Lucio Andrés Illanes Albornoz (arab, vxp) |
fc9417 |
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
buildp_dispatch() {
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
local _msg="${1}"; shift;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
case "${_msg}" in
|
|
Lucio Andrés Illanes Albornoz |
2960a4 |
disabled_pkg|finish_pkg|missing_pkg|msg_pkg|skipped_pkg|start_pkg|start_pkg_child|step_pkg)
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
buildp_dispatch_pkg_state "${_msg}" "${@}"; ;;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
finish_group|start_group)
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
buildp_dispatch_group_state "${_msg}" "${@}"; ;;
|
|
Lucio Andrés Illanes Albornoz |
dda17d |
*) if command -v "buildp_dispatch_${_msg}" >/dev/null 2>&1; then
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
"buildp_dispatch_${_msg}" "${@}";
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
fi; ;;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
esac;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
};
|
|
Lucio Andrés Illanes Albornoz (arab, vxp) |
ec19f0 |
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
buildp_time_init() {
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
BUILD_DATE_START="$(rtl_date %Y-%m-%d-%H-%M-%S)";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
_build_time_secs="$(rtl_date %s)";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
};
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
buildp_time_update() {
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
: $((_build_time_secs=$(rtl_date %s)-${_build_time_secs}));
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
: $((_build_time_hours=${_build_time_secs}/3600));
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
: $((_build_time_minutes=(${_build_time_secs}%3600)/60));
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
: $((_build_time_secs=(${_build_time_secs}%3600)%60));
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
};
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
build() {
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
local _build_time_hours=0 _build_time_mins=0 _build_time_secs=0 _pkg_name="" _rc=0 _status="" \
|
|
Lucio Andrés Illanes Albornoz |
bbb50c |
BUILD_DATE_START="" BUILD_GROUPS="" BUILD_GROUPS_INHIBIT_DEPS=0 BUILD_HNAME BUILD_IS_PARENT=1 \
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
BUILD_NFAIL=0 BUILD_NFINI=0 BUILD_NSKIP=0 BUILD_PKGS_FAILED="" BUILD_TARGET="" BUILD_USER="" \
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
DEFAULT_BUILD_CPUS=1 DEFAULT_BUILD_LAST_FAILED_PKG_FNAME="" DEFAULT_BUILD_LOG_FNAME="" \
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
DEFAULT_BUILD_STEPS="" DEFAULT_BUILD_VARS="" DEFAULT_CLEAR_PREFIX_PATHS="" DEFAULT_GIT_ARGS="" \
|
|
Lucio Andrés Illanes Albornoz |
7bede2 |
DEFAULT_GITROOT_HEAD="${DEFAULT_GITROOT_HEAD:-}" DEFAULT_LOG_ENV_VARS="" DEFAULT_MIRRORS="" \
|
|
Lucio Andrés Illanes Albornoz |
7bede2 |
DEFAULT_TARGET="" DEFAULT_WGET_ARGS="" MIDIPIX_BUILD_PWD="";
|
|
Lucio Andrés Illanes Albornoz |
7bede2 |
DEFAULT_BUILD_STATUS_IN_PROGRESS_FNAME=""; EX_PKG_DISPATCH_WAIT="";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
if ! . "${0%/*}/subr/build_init.subr"; then
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
_rc=1; printf "Error: failed to source \`${0%/*}/subr/build_init.subr'." >&2;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
elif ! build_init "${@}"; then
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
_rc=1; _status="${_status}";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
elif [ -n "${_status}" ]; then
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
_rc=0; _status="${_status}";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
else trap "buildp_ast exit" EXIT; trap "buildp_ast abort" HUP INT TERM USR1 USR2;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
buildp_time_init;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg info "Build started by %s@%s at %s." "${BUILD_USER}" "${BUILD_HNAME}" "${BUILD_DATE_START}";
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
rtl_log_env_vars "build (global)" ${DEFAULT_LOG_ENV_VARS};
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
ex_pkg_dispatch "${DEFAULT_BUILD_STEPS}" "${DEFAULT_BUILD_VARS}" \
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
buildp_dispatch "${BUILD_GROUPS}" "${BUILD_GROUPS_INHIBIT_DEPS}" \
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
"${ARG_PARALLEL}" "${BUILD_WORKDIR}/build.fifo" "${ARG_RESTART}" \
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
"${ARG_RESTART_AT}" "${ARG_RESTART_RECURSIVE}" "${BUILD_WORKDIR}";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
buildp_time_update;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg info "%s finished, %s skipped, and %s failed package(s)." "${BUILD_NFINI:-0}" "${BUILD_NSKIP:-0}" "${BUILD_NFAIL:-0}";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg info "Build time: %s hour(s), %s minute(s), and %s second(s)." "${_build_time_hours:-0}" "${_build_time_minutes:-0}" "${_build_time_secs:-0}";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
if [ -n "${BUILD_PKGS_FAILED}" ]; then
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
_rc=1; _status="Build script failure(s) in: ${BUILD_PKGS_FAILED}.";
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
c6d6e0 |
fi;
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
if [ "${_rc}" -ne 0 ]; then
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg fatalexit "${_status}";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
elif [ -n "${_status}" ]; then
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
rtl_log_msg info "${_status}";
|
|
Lucio Andrés Illanes Albornoz |
b6a9a1 |
fi;
|
|
Lucio Andrés Illanes Albornoz (arab, vxp) |
ec19f0 |
};
|
|
Lucio Andrés Illanes Albornoz (arab, vxp) |
ec19f0 |
|
|
Lucio Andrés Illanes Albornoz |
e1d469 |
set +o errexit -o noglob -o nounset; build "${@}";
|
|
lalbornoz |
340f4c |
|
|
Lucio Andrés Illanes Albornoz |
fc9bdb |
# vim:filetype=sh textwidth=0
|