Introduce a new out-of-source-utils.eclass to carry run_in_build_dir()
helper function.  This function used to be defined in multibuild.eclass
and indirectly exposed through the eclasses using it.  However, it is
used rather rarely and it is technically also useful for
out-of-source.eclass, so it makes more sense for it to be standalone.
In the end, eclasses are cheap.

Signed-off-by: Michał Górny <[email protected]>
---
 eclass/out-of-source-utils.eclass | 43 +++++++++++++++++++++++++++++++
 1 file changed, 43 insertions(+)
 create mode 100644 eclass/out-of-source-utils.eclass

diff --git a/eclass/out-of-source-utils.eclass 
b/eclass/out-of-source-utils.eclass
new file mode 100644
index 000000000000..450237b224b3
--- /dev/null
+++ b/eclass/out-of-source-utils.eclass
@@ -0,0 +1,43 @@
+# Copyright 2022 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: out-of-source-utils.eclass
+# @MAINTAINER:
+# Michał Górny <[email protected]>
+# @AUTHOR:
+# Michał Górny <[email protected]>
+# @SUPPORTED_EAPIS: 6 7 8
+# @BLURB: Utility functions for building packages out-of-source
+# @DESCRIPTION:
+# This eclass provides a run_in_build_dir() helper that can be used
+# to execute specified command inside BUILD_DIR.
+
+case ${EAPI} in
+       6|7|8) ;;
+       *) die "${ECLASS}: EAPI ${EAPI} unsupported."
+esac
+
+if [[ ! ${_OUT_OF_SOURCE_UTILS_ECLASS} ]]; then
+_OUT_OF_SOURCE_UTILS_ECLASS=1
+
+# @FUNCTION: run_in_build_dir
+# @USAGE: <argv>...
+# @DESCRIPTION:
+# Run the given command in the directory pointed by BUILD_DIR.
+run_in_build_dir() {
+       debug-print-function ${FUNCNAME} "${@}"
+       local ret
+
+       [[ ${#} -eq 0 ]] && die "${FUNCNAME}: no command specified."
+       [[ -z ${BUILD_DIR} ]] && die "${FUNCNAME}: BUILD_DIR not set."
+
+       mkdir -p "${BUILD_DIR}" || die
+       pushd "${BUILD_DIR}" >/dev/null || die
+       "${@}"
+       ret=${?}
+       popd >/dev/null || die
+
+       return ${ret}
+}
+
+fi
-- 
2.39.0


Reply via email to