summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichał Górny <mgorny@gentoo.org>2016-12-13 10:38:34 +0100
committerMichał Górny <mgorny@gentoo.org>2016-12-18 14:46:49 +0100
commit51ceffb2f69b117cdfbb2dd6f78ec7b5bb03db4e (patch)
treeb147b01b3caf10b5434d01c740144ea7f065292d /eclass/scons-utils.eclass
parentmultiprocessing.eclass: Support passing custom inf values for getters (diff)
downloadgentoo-51ceffb2f69b117cdfbb2dd6f78ec7b5bb03db4e.tar.gz
gentoo-51ceffb2f69b117cdfbb2dd6f78ec7b5bb03db4e.tar.bz2
gentoo-51ceffb2f69b117cdfbb2dd6f78ec7b5bb03db4e.zip
scons-utils.eclass: Switch to get_nproc from multiprocessing.eclass
Diffstat (limited to 'eclass/scons-utils.eclass')
-rw-r--r--eclass/scons-utils.eclass34
1 files changed, 5 insertions, 29 deletions
diff --git a/eclass/scons-utils.eclass b/eclass/scons-utils.eclass
index 0493ec1dec5a..d504b659df2a 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