From b936ac82a5528407e7945a7be993f5573f1d5af0 Mon Sep 17 00:00:00 2001 From: Kefu Chai Date: Fri, 8 Dec 2017 16:34:59 +0800 Subject: [PATCH] install-deps.sh: use DTS on centos if GCC is too old please note, run-make-check.sh sources install-deps.sh here to import the $PATH and other environmental variables, which could be changed by the the DTS "enable" script. Signed-off-by: Kefu Chai (cherry picked from commit 3f8647a7e80b20079bec97d5be12372909083bb4) --- install-deps.sh | 52 +++++++++++++++++++++++++++++++++++++++++------ run-make-check.sh | 2 +- 2 files changed, 47 insertions(+), 7 deletions(-) diff --git a/install-deps.sh b/install-deps.sh index c6a935a3df2..873323808e7 100755 --- a/install-deps.sh +++ b/install-deps.sh @@ -26,11 +26,11 @@ function munge_ceph_spec_in { sed -e 's/@//g' -e 's/%bcond_with make_check/%bcond_without make_check/g' < ceph.spec.in > $OUTFILE } -function ensure_decent_gcc { +function ensure_decent_gcc_on_deb { # point gcc to the one offered by g++-7 if the used one is not # new enough - old=$(gcc -dumpversion) - new=$1 + local old=$(gcc -dumpversion) + local new=$1 if dpkg --compare-versions $old ge 5.1; then return fi @@ -50,6 +50,38 @@ function ensure_decent_gcc { $SUDO ln -nsf /usr/bin/g++ /usr/bin/x86_64-linux-gnu-g++ } +function version_lt { + test $1 != $(echo -e "$1\n$2" | sort -rV | head -n 1) +} + +function ensure_decent_gcc_on_rh { + local old=$(gcc -dumpversion) + local expected=5.1 + local dts_ver=$1 + if version_lt $old $expected; then + case $- in + *i*) + # interactive shell + cat <&1 | tee $DIR/yum-builddep.out + if [ -n dts_ver ]; then + ensure_decent_gcc_on_rh $dts_ver + fi ! grep -q -i error: $DIR/yum-builddep.out || exit 1 ;; opensuse|suse|sles) diff --git a/run-make-check.sh b/run-make-check.sh index 75e7d92b683..72583a1e841 100755 --- a/run-make-check.sh +++ b/run-make-check.sh @@ -60,7 +60,7 @@ function run() { fi if test -f ./install-deps.sh ; then - $DRY_RUN ./install-deps.sh || return 1 + $DRY_RUN source ./install-deps.sh || return 1 fi # Init defaults after deps are installed. get_processors() depends on coreutils nproc.