Blame subr/ex_pkg_env.subr

Lucio Andrés Illanes Albornoz (arab, vxp) 570129
#
Lucio Andrés Illanes Albornoz e1d469
# set +o errexit -o noglob -o nounset is assumed.
Lucio Andrés Illanes Albornoz (arab, vxp) 570129
#
Lucio Andrés Illanes Albornoz (arab, vxp) 570129
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
# exp_pkg_env_defaults() - set package variable defaults for single named package
Lucio Andrés Illanes Albornoz c6d6e0
# @_build_steps_default:	list of default build steps
Lucio Andrés Illanes Albornoz c6d6e0
# @_pkg_name:			single package name
Lucio Andrés Illanes Albornoz c6d6e0
# @_workdir:			pathname to build-specific temporary directory
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz ccd354
# Return:			zero (0) on success, non-zero (>0) on failure
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
exp_pkg_env_defaults() {
Lucio Andrés Illanes Albornoz c6d6e0
	local _build_steps_default="${1}" _pkg_name="${2}" _workdir="${3}";
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
	: ${PKG_NAME:="${_pkg_name}"};
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
	: ${MIDIPIX_BUILD_PWD:="$(pwd)"};
Lucio Andrés Illanes Albornoz c6d6e0
	: ${PKG_BASE_DIR:="${_workdir}/${_pkg_name}-${PKG_BUILD_TYPE}-${PKG_TARGET}"};
Lucio Andrés Illanes Albornoz e1d469
	if [ -n "${PKG_BUILD_STEPS_DISABLE:-}" ]; then
Lucio Andrés Illanes Albornoz e1d469
		: ${PKG_BUILD_STEPS:="$(rtl_lfilter "${_build_steps_default}" "${PKG_BUILD_STEPS_DISABLE:-}")"};
Lucio Andrés Illanes Albornoz e1d469
	else
Lucio Andrés Illanes Albornoz e1d469
		: ${PKG_BUILD_STEPS:="${_build_steps_default}"};
Lucio Andrés Illanes Albornoz e1d469
	fi;
Lucio Andrés Illanes Albornoz e1d469
	if [ -n "${PKG_URL:-}" ]; then
Lucio Andrés Illanes Albornoz e1d469
		: ${PKG_FNAME:="${PKG_URL##*/}"};
Lucio Andrés Illanes Albornoz e1d469
	fi;
Lucio Andrés Illanes Albornoz e1d469
	if [ -z "${PKG_SUBDIR:-}" ]; then
Lucio Andrés Illanes Albornoz 2c5ce2
		if [ -n "${PKG_URLS_GIT:-}" ]\
Lucio Andrés Illanes Albornoz 2c5ce2
		&& [ -n "${PKG_FNAME:-}" ]; then
Lucio Andrés Illanes Albornoz b1d432
			rtl_log_msg "fatalexit" "Error: \${PKG_SUBDIR} must be specified given both \${PKG_FNAME} and \${PKG_URLS_GIT}.";
Lucio Andrés Illanes Albornoz 2c5ce2
		elif [ -n "${PKG_URLS_GIT:-}" ]; then
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
			PKG_SUBDIR="${PKG_URLS_GIT%%=*}";
Lucio Andrés Illanes Albornoz e1d469
		else case "${PKG_FNAME:-}" in
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
		*.t*)	PKG_SUBDIR="${PKG_FNAME%%.t*}"; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
		*)	PKG_SUBDIR="${_pkg_name}"; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
		esac; fi;
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
	fi;
Lucio Andrés Illanes Albornoz e1d469
	if [ -z "${PKG_BUILD_DIR:-}" ]; then
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
		case "${PKG_IN_TREE:-0}" in
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
		0) PKG_BUILD_DIR="obj"; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) fce0a9
		1) PKG_BUILD_DIR="${PKG_SUBDIR}"; ;;
Lucio Andrés Illanes Albornoz (arab, vxp) d18b1a
		esac;
Lucio Andrés Illanes Albornoz (arab, vxp) c27bea
	fi;
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
	PKG_BUILD_DIR="${PKG_BASE_DIR}/${PKG_BUILD_DIR}";
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
	PKG_CONFIGURE="${PKG_BASE_DIR}/${PKG_CONFIGURE:-${PKG_SUBDIR}/configure}";
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
	PKG_DESTDIR="${PKG_BASE_DIR}/${PKG_DESTDIR:-destdir}";
Lucio Andrés Illanes Albornoz 8a4e16
	PKG_DESTDIR_HOST="${PKG_BASE_DIR}/${PKG_DESTDIR_HOST:-destdir_host}";
Lucio Andrés Illanes Albornoz 2b85d0
};
Lucio Andrés Illanes Albornoz 2b85d0
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
# exp_pkg_env_set() - set package variables for single named package
Lucio Andrés Illanes Albornoz c6d6e0
# @_build_vars_default:	list of default build variables
Lucio Andrés Illanes Albornoz 2b85d0
# @_group_name:		build group name
Lucio Andrés Illanes Albornoz 60fba6
# @_nounset:		don't clear package variable namespace
Lucio Andrés Illanes Albornoz 2b85d0
# @_pkg_name:		single package name
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
# Sets package variables from either defaults, defaults specific to build type,
Lucio Andrés Illanes Albornoz 2b85d0
# build group, package to inherit from if any, or package for a single named
Lucio Andrés Illanes Albornoz 2b85d0
# package, exports variables optionally named in ${PKG_ENV_VARS_EXTRA}, and
Lucio Andrés Illanes Albornoz 2b85d0
# clears the package variable namespace.
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
# Return:		zero (0) on success, non-zero (>0) on failure
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
exp_pkg_env_set() {
Lucio Andrés Illanes Albornoz b9a715
	local	_build_vars_default="${1}" _group_name="${2}" _nounset="${3}"		\
Lucio Andrés Illanes Albornoz b9a715
		_pkg_name="${4}" _cmd_name="" _var_prefixes="" _vars_set=""		\
Lucio Andrés Illanes Albornoz b9a715
		_vname="" IFS IFS0;
Lucio Andrés Illanes Albornoz b9a715
Lucio Andrés Illanes Albornoz c6d6e0
	rtl_set_vars _vars_set BUILD_TYPE "DEFAULT ${_group_name} PKG_${_pkg_name}";
Lucio Andrés Illanes Albornoz c6d6e0
	rtl_set_vars _vars_set INHERIT_FROM "PKG_${_pkg_name}";
Lucio Andrés Illanes Albornoz c6d6e0
	_var_prefixes="$(rtl_toupper "DEFAULT DEFAULT_${PKG_BUILD_TYPE} ${_group_name}")";
Lucio Andrés Illanes Albornoz c6d6e0
	for _vname in $(rtl_lfilter "${_build_vars_default}" BUILD_TYPE); do
Lucio Andrés Illanes Albornoz e1d469
		if [ -n "${PKG_INHERIT_FROM:-}" ]; then
Lucio Andrés Illanes Albornoz ada809
			rtl_set_vars _vars_set "${_vname}"				\
Lucio Andrés Illanes Albornoz ada809
				"$(rtl_lconcat "${_var_prefixes}"			\
Lucio Andrés Illanes Albornoz a6970c
				"$(rtl_toupper "PKG_${PKG_INHERIT_FROM} PKG_${PKG_INHERIT_FROM}_${BUILD_KIND} PKG_${_pkg_name} PKG_${_pkg_name}_${BUILD_KIND}")")";
Lucio Andrés Illanes Albornoz 2b85d0
		else
Lucio Andrés Illanes Albornoz ada809
			rtl_set_vars _vars_set "${_vname}"				\
Lucio Andrés Illanes Albornoz ada809
				"$(rtl_lconcat "${_var_prefixes}"			\
Lucio Andrés Illanes Albornoz a6970c
				"$(rtl_toupper "PKG_${_pkg_name} PKG_${_pkg_name}_${BUILD_KIND}")")";
Lucio Andrés Illanes Albornoz 2b85d0
		fi;
Lucio Andrés Illanes Albornoz 2b85d0
	done;
Lucio Andrés Illanes Albornoz e58399
	IFS0="${IFS:- }"; IFS=":"; for _vname in ${PKG_ENV_VARS_EXTRA:-}; do
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
		export "${_vname}";
Lucio Andrés Illanes Albornoz b6a9a1
	done; IFS="${IFS0}";
Lucio Andrés Illanes Albornoz 60fba6
	if [ "${_nounset:-0}" -eq 0 ]; then
Lucio Andrés Illanes Albornoz ada809
		rtl_unset_vars $(rtl_lfilter						\
Lucio Andrés Illanes Albornoz ada809
			"$(set | sed -ne '/^PKG_[^=]*=/s/=.*$//p' | paste -s -d " ")"	\
Lucio Andrés Illanes Albornoz 60fba6
			"${_vars_set}");
Lucio Andrés Illanes Albornoz 60fba6
	fi;
Lucio Andrés Illanes Albornoz 2b85d0
Lucio Andrés Illanes Albornoz b9a715
	for _vname in AR CC CXX PKG_CONFIG RANLIB; do
Lucio Andrés Illanes Albornoz b9a715
		if eval [ '"${PKG_'"${_vname}"':+1}"' = 1 ]\
Lucio Andrés Illanes Albornoz b9a715
		&& eval [ '"${PKG_'"${_vname}"'#/}"' = '"${_cmd_name:=${PKG_'"${_vname}"'}}"' ]; then
Lucio Andrés Illanes Albornoz b9a715
			eval PKG_${_vname}='$(which "${_cmd_name}")';
Lucio Andrés Illanes Albornoz b9a715
		fi; _cmd_name="";
Lucio Andrés Illanes Albornoz b9a715
	done;
Lucio Andrés Illanes Albornoz 168e55
};
Lucio Andrés Illanes Albornoz 168e55
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
# ex_pkg_env() - set package variables for single named package
Lucio Andrés Illanes Albornoz c6d6e0
# @_build_steps_default:	list of default build steps
Lucio Andrés Illanes Albornoz c6d6e0
# @_build_vars_default:		list of default build variables
Lucio Andrés Illanes Albornoz c6d6e0
# @_group_name:			build group name
Lucio Andrés Illanes Albornoz 60fba6
# @_nounset:			don't clear package variable namespace
Lucio Andrés Illanes Albornoz c6d6e0
# @_pkg_name:			single package name
Lucio Andrés Illanes Albornoz 370e98
# @_restart_at:			optional comma-separated list of build steps at which to rebuild or ALL or LAST
Lucio Andrés Illanes Albornoz c6d6e0
# @_workdir:			pathname to build-specific temporary directory
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz ccd354
# Return:			zero (0) on success, non-zero (>0) on failure
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
ex_pkg_env() {
Lucio Andrés Illanes Albornoz c6d6e0
	local	_build_steps_default="${1}" _build_vars_default="${2}" _group_name="${3}"	\
Lucio Andrés Illanes Albornoz 925e14
		_nounset="${4}" _pkg_name="${5}" _restart_at="${6}" _workdir="${7}"		\
Lucio Andrés Illanes Albornoz 7751df
		_inherit_from="" _vars_file="" _vname="";
Lucio Andrés Illanes Albornoz 925e14
Lucio Andrés Illanes Albornoz 7751df
	if _inherit_from="$(rtl_get_var_unsafe -u "PKG_${_pkg_name}_INHERIT_FROM")"\
Lucio Andrés Illanes Albornoz 7751df
	&& [ "${#_inherit_from}" -gt 0 ]; then
Lucio Andrés Illanes Albornoz 7751df
		_vars_file="$(rtl_get_var_unsafe -u "PKG_${_inherit_from}_VARS_FILE")";
Lucio Andrés Illanes Albornoz 7751df
	else
Lucio Andrés Illanes Albornoz 7751df
		_vars_file="$(rtl_get_var_unsafe -u "PKG_${_pkg_name}_VARS_FILE")";
Lucio Andrés Illanes Albornoz 7751df
	fi;
Lucio Andrés Illanes Albornoz 7751df
	if [ "${#_vars_file}" -eq 0 ]; then
Lucio Andrés Illanes Albornoz 925e14
		_vars_file="vars/${_pkg_name}.vars";
Lucio Andrés Illanes Albornoz 925e14
	fi;
Lucio Andrés Illanes Albornoz 7751df
Lucio Andrés Illanes Albornoz 925e14
	rtl_fileop source_opt "${_vars_file}" "${_group_name}/${_pkg_name}.${_group_name}";
Lucio Andrés Illanes Albornoz 60fba6
	if ! exp_pkg_env_set "${_build_vars_default}" "${_group_name}" "${_nounset}" "${_pkg_name}"\
Lucio Andrés Illanes Albornoz b9a715
	|| ! exp_pkg_env_defaults "${_build_steps_default}" "${_pkg_name}" "${_workdir}"; then
Lucio Andrés Illanes Albornoz bf9edf
		return 1;
Lucio Andrés Illanes Albornoz 2b85d0
	fi;
Lucio Andrés Illanes Albornoz 2b85d0
};
Lucio Andrés Illanes Albornoz 2b85d0
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
# ex_pkg_state_set() - update build step status for single named package
Lucio Andrés Illanes Albornoz 2b85d0
# @_pkg_name:		single package name
Lucio Andrés Illanes Albornoz 370e98
# @_build_step:		build step set status of
Lucio Andrés Illanes Albornoz 370e98
# [@${@}]:		optional list of build steps to invalidate status of
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
# Return:		zero (0) on success, non-zero (>0) on failure
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
ex_pkg_state_set() {
Lucio Andrés Illanes Albornoz c6d6e0
	rtl_state_set "${_workdir}" "${@}";
Lucio Andrés Illanes Albornoz (arab, vxp) 570129
};
Lucio Andrés Illanes Albornoz (arab, vxp) 570129
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
# ex_pkg_state_test() - test build step status of single named package
Lucio Andrés Illanes Albornoz 2b85d0
# @_pkg_name:		single package name
Lucio Andrés Illanes Albornoz 2b85d0
# @_build_step:		build step to test status of
Lucio Andrés Illanes Albornoz 370e98
# @_restart_at:		optional comma-separated list of build steps at which to rebuild or ALL or LAST
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
# Return:		zero (0) on success, non-zero (>0) on failure
Lucio Andrés Illanes Albornoz 2b85d0
#
Lucio Andrés Illanes Albornoz 2b85d0
ex_pkg_state_test() {
Lucio Andrés Illanes Albornoz c6d6e0
	rtl_state_test "${_workdir}" "${@}";
Lucio Andrés Illanes Albornoz 2b85d0
};
Lucio Andrés Illanes Albornoz (arab, vxp) ec19f0
Lucio Andrés Illanes Albornoz (arab, vxp) 570129
# vim:filetype=sh