midipix / build / midipix_build

Forked from build/midipix_build 4 years ago
Clone

Blame subr/ex_pkg_dispatch.subr

Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
#
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
# set -o errexit -o noglob are assumed.
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
#
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
Lucio Andrés Illanes Albornoz (arab, vxp) 32ad21
ex_pkg_dispatch() {
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
	local _tgt_name="${1}" _pkg_name="${2}"		\
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
		_restart="${3}" _restart_at="${4}"	\
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		_pkg_step_cmds _pkg_step_cmd_args	\
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		_stdout_path _stderr_path		\
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		_pipe_path _pipe_path2 _pipe_msg _script_rc;
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
	if [ "${_pkg_name#*_flavour_*}" != "${_pkg_name}" ]; then
Lucio Andrés Illanes Albornoz (arab, vxp) d7620f
		PKG_NAME_PARENT="${_pkg_name%_flavour_*}";
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
	fi;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
	if ex_pkg_state_test "${_pkg_name}" finish; then
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		if [ -z "${_restart}" ]\
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		&& [ "${_tgt_name}" != "INVARIANTS" ]; then
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			return 0;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		fi;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
	fi;
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	_pipe_path="${WORKDIR}/${_pkg_name}_build.fifo";
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	ex_build_fileop rm "${_pipe_path}"; mkfifo "${_pipe_path}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	_pipe2_path="${WORKDIR}/${_pkg_name}_build2.fifo";
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	ex_build_fileop rm "${_pipe2_path}"; mkfifo "${_pipe2_path}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	_stderr_path="${WORKDIR}/${_pkg_name}_stderr.log";
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	_stdout_path="${WORKDIR}/${_pkg_name}_stdout.log";
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	ex_build_fileop rm "${_stderr_path}" "${_stdout_path}";
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
	(set -o errexit -o noglob;
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	ex_pkg_vars;
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	if [ -z "${PKG_URL}" ]\
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	&& [ -z "${PKG_URLS_GIT}" ]\
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	&& [ -z "${PKG_VERSION}" ]\
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	&& ! ex_test_cmd "pkg_${PKG_NAME}_all"; then
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		ex_log_msg failexit "Error: package \`${PKG_NAME}' missing in build.vars.";
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		exit 1;
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	elif [ "${PKG_DISABLED:-0}" -eq 1 ]; then
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		ex_log_msg vnfo "Skipping disabled package \`${PKG_NAME}.'";
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		echo "done ${PKG_BASE_DIR}" >&3; exit 0;
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	else
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		ex_pkg_env;
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		ex_build_fileop mkdir "${PKG_BASE_DIR}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		ex_build_fileop cd "${PKG_BASE_DIR}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	fi;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
	set -- $(ex_lfilter -not "${BUILD_STEPS}"	\
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			"$(ex_get_var_unsafe PKG_$(ex_toupper "${_pkg_name}")_BUILD_STEPS_DISABLE)");
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
	while [ ${#} -gt 0 ]; do
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		_pkg_step_cmds=""; _pkg_step_cmd_args="";
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		case "${1#*:}" in
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		dynamic)
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			if [ "${_tgt_name}" = "INVARIANTS" ]; then
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				_pkg_step_cmds="pkg_${_pkg_name}_${1%:*} pkg_${1%:*}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			elif [ -n "${_restart}" ]; then
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				if [ -z "${_restart_at}" ]\
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				|| ex_lmatch "${_restart_at}" , "${1%:*}"; then
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
					_pkg_step_cmds="pkg_${_pkg_name}_${1%:*} pkg_${1%:*}";
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
				fi;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			elif ! ex_pkg_state_test "${_pkg_name}" "${1%:*}"; then
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				_pkg_step_cmds="pkg_${_pkg_name}_${1%:*} pkg_${1%:*}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			fi; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		invariant)
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			_pkg_step_cmds="pkg_${1%:*}"; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		variant)
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			if ex_lmatch "${_restart_at}" "," "${1%:*}"; then
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				_pkg_step_cmds="pkg_${_pkg_name}_${1%:*} pkg_${1%:*}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			fi; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		virtual)
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			_pkg_step_cmds="pkg_${_pkg_name}_${1%:*}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			_pkg_step_cmd_args="${_restart_at:-ALL}"; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		all)
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			if ex_test_cmd "pkg_${_pkg_name}_${1%:*}"; then
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				"pkg_${_pkg_name}_${1%:*}" "${_restart_at:-ALL}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				break;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			fi; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		finish)	ex_pkg_state_push "${_pkg_name}" finish; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		*)	;;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		esac;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		for __ in ${_pkg_step_cmds}; do
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			if ex_test_cmd "${__}"; then
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				ex_test_cmd "pkg_${_pkg_name}_${1%:*}_pre"	\
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
					&& "pkg_${_pkg_name}_${1%:*}_pre"
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				"${__}" ${_pkg_step_cmd_args};
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				ex_test_cmd "pkg_${_pkg_name}_${1%:*}_post"	\
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
					&& "pkg_${_pkg_name}_${1%:*}_post"
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				if [ "${1#*:}" != "invariant" ]\
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				&& [ ${#} -ge 2 ]; then
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
					ex_pkg_state_push "${_pkg_name}" "${1%:*}" "-${2#*:}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				else
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
					ex_pkg_state_push "${_pkg_name}" "${1%:*}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
				fi; break;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
			fi;
Lucio Andrés Illanes Albornoz (arab, vxp) fc24fa
		done;
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	shift; done; set -o xtrace
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	echo "done ${PKG_BASE_DIR}" >&3; read __ <&4;)	\
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		1>"${_stdout_path}" 2>"${_stderr_path}"	\
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
		3<>"${_pipe_path}" 4<>"${_pipe2_path}" &
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	_script_rc=1; while read _pipe_msg <"${_pipe_path}"; do
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	case "${_pipe_msg%% *}" in
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	done)	echo >"${_pipe2_path}"; _script_rc=0; break; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	*)	break; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	esac; done;
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	ex_build_fileop rm "${_pipe_path}";
Lucio Andrés Illanes Albornoz (arab, vxp) fc9417
	return "${_script_rc:-0}";
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
};
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
Lucio Andrés Illanes Albornoz (arab, vxp) 1da591
# vim:filetype=sh