commit: 51ceffb2f69b117cdfbb2dd6f78ec7b5bb03db4e
Author: Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 13 09:38:34 2016 +0000
Commit: Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Dec 18 13:46:49 2016 +0000
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=51ceffb2
scons-utils.eclass: Switch to get_nproc from multiprocessing.eclass
eclass/scons-utils.eclass | 34 +++++-----------------------------
1 file changed, 5 insertions(+), 29 deletions(-)
diff --git a/eclass/scons-utils.eclass b/eclass/scons-utils.eclass
index 0493ec1..d504b65 100644
--- a/eclass/scons-utils.eclass
+++ b/eclass/scons-utils.eclass
@@ -98,6 +98,8 @@ case ${EAPI:-0} in
*) die "EAPI ${EAPI} unsupported."
esac
+inherit multiprocessing
+
# -- ebuild variables setup --
if [[ -n ${SCONS_MIN_VERSION} ]]; then
@@ -149,32 +151,6 @@ escons() {
return ${ret}
}
-# @FUNCTION: _scons_get_default_jobs
-# @INTERNAL
-# @DESCRIPTION:
-# Output the default number of jobs, used if -j is used without
-# argument. Tries to figure out the number of logical CPUs, falling
-# back to hardcoded constant.
-_scons_get_default_jobs() {
- local nproc
-
- if type -P nproc &>/dev/null; then
- # GNU
- nproc=$(nproc)
- elif type -P python &>/dev/null; then
- # fallback to python2.6+
- # note: this may fail (raise NotImplementedError)
- nproc=$(python -c 'import multiprocessing;
print(multiprocessing.cpu_count());' 2>/dev/null)
- fi
-
- if [[ ${nproc} ]]; then
- echo $(( nproc + 1 ))
- else
- # random default
- echo 5
- fi
-}
-
# @FUNCTION: _scons_clean_makeopts
# @INTERNAL
# @USAGE: [makeflags] [...]
@@ -217,8 +193,8 @@ _scons_clean_makeopts() {
new_makeopts+=( ${1} ${2} )
shift
else
- # no value means no limit, let's pass a
random int
- new_makeopts+=(
${1}=$(_scons_get_default_jobs) )
+ # no value means no limit, let's pass a
default instead
+ new_makeopts+=( ${1}=$(( $(get_nproc) +
1 )) )
fi
;;
# strip other long options
@@ -241,7 +217,7 @@ _scons_clean_makeopts() {
new_optstr+="j
${2}"
shift
else
- new_optstr+="j
$(_scons_get_default_jobs)"
+ new_optstr+="j
$(( $(get_nproc) + 1 ))"
fi
;;
# otherwise, everything after
-j is treated as an arg