From 00b3b32a561d3e18025c1a0548ccf11b7763521a Mon Sep 17 00:00:00 2001 From: Thomas Debesse Date: Tue, 31 Mar 2020 02:40:34 +0200 Subject: [PATCH] easy-builder: improvements - handle arguments with spaces properly - provide fallback for nproc - replace cmake undocumented -H with -S - do not require to change directory --- easy-builder | 88 ++++++++++++++++++++++++++++------------------------ 1 file changed, 47 insertions(+), 41 deletions(-) diff --git a/easy-builder b/easy-builder index 7966bd26..983485ae 100755 --- a/easy-builder +++ b/easy-builder @@ -8,93 +8,99 @@ set -o pipefail # Will return the exit status of make if it fails project_source_dir="$(cd "$(dirname "${BASH_SOURCE[0]}")" >/dev/null 2>&1 && pwd)" -job_count='4' -if command -v nproc >/dev/null -then - job_count="$(nproc)" -fi - build_dir="${project_source_dir}/build${SUBDIR:+/${SUBDIR}}" install_dir="${project_source_dir}/install${SUBDIR:+/${SUBDIR}}" build_type='Release' -cmake_user_opts='' -while [ ! -z ${1} ] -do - case "${1}" in - '-j'*) - job_count="${1:2}" - shift - ;; - '--debug') - build_type='Debug' - shift - ;; - *) - cmake_user_opts+=" ${1}" - shift - ;; - esac -done - -cmake_opts='' +declare -a cmake_opts case "$(uname -s)" in 'Linux') - # no tweak required + nproc='egrep "^processor" /proc/cpuinfo | wc -l' ;; 'FreeBSD') + nproc='sysctl -n hw.ncpu' + if [ -f "$(ls '/usr/local/bin/g++'* | sort | tail -n1)" ] then gcc_version="$(ls '/usr/local/bin/g++'* | sort | tail -n1 | sed -e 's/.*[^0-9]\([0-9][0-9]*\)$/\1/')" - cmake_opts+=" -DCMAKE_C_COMPILER=/usr/local/bin/gcc${gcc_version}" - cmake_opts+=" -DCMAKE_CXX_COMPILER=/usr/local/bin/g++${gcc_version}" + cmake_opts[${#cmake_opts[@]}]="-DCMAKE_C_COMPILER=/usr/local/bin/gcc${gcc_version}" + cmake_opts[${#cmake_opts[@]}]="-DCMAKE_CXX_COMPILER=/usr/local/bin/g++${gcc_version}" else printf "WARNING: GCC is recommended: if build fails, install GCC and retry\n" >&2 fi ;; 'Darwin') + nproc='sysctl -n hw.ncpu' + if [ -f "$(ls '/usr/local/bin/g++-'* | sort | tail -n1)" ] then gcc_version="$(ls '/usr/local/bin/g++-'* | sort | tail -n1 | sed -e 's/.*[^0-9]\([0-9][0-9]*\)$/\1/')" - cmake_opts+=" -DCMAKE_C_COMPILER=/usr/local/bin/gcc-${gcc_version}" - cmake_opts+=" -DCMAKE_CXX_COMPILER=/usr/local/bin/g++-${gcc_version}" + cmake_opts[${#cmake_opts[@]}]="-DCMAKE_C_COMPILER=/usr/local/bin/gcc-${gcc_version}" + cmake_opts[${#cmake_opts[@]}]="-DCMAKE_CXX_COMPILER=/usr/local/bin/g++-${gcc_version}" else printf "WARNING: GCC is recommended: if build fails, install GCC and retry\n" >&2 fi ;; 'MSYS_NT-'*) - # no tweak required + nproc='echo "${NUMBER_OF_PROCESSORS}"' ;; 'CYGWIN_NT-'*|'MINGW'*'_NT-'*) + nproc='echo "${NUMBER_OF_PROCESSORS}"' printf "WARNING: system is not tested: if build fails, use MSYS2 instead\n" >&2 ;; *) + nproc='true' printf "WARNING: system is not tested\n" >&2 ;; esac -fetch_submodules_cmd='' +if command -v 'nproc' >/dev/null +then + job_count="$(nproc)" +else + job_count="$(sh -c "${nproc}")" +fi + +job_count="${job_count:-4}" + +declare -a cmake_user_opts +while [ ! -z "${1}" ] +do + case "${1}" in + '-j'*) + job_count="${1:2}" + shift + ;; + '--debug') + build_type='Debug' + shift + ;; + *) + cmake_user_opts[${#cmake_user_opts[@]}]="${1}" + shift + ;; + esac +done + +declare -a fetch_submodules_cmd if ! [ -f "${project_source_dir}/libs/crunch/inc/crn_decomp.h" ] then - fetch_submodules_cmd='git submodule update --init --recursive' + fetch_submodules_cmd=(git -C "${project_source_dir}" submodule update --init --recursive) fi set -x -cd "${project_source_dir}" - -${fetch_submodules_cmd} +"${fetch_submodules_cmd[@]}" cmake \ -G'Unix Makefiles' \ - -H'.' \ + -S"${project_source_dir}" \ -B"${build_dir}" \ -D'CMAKE_INSTALL_PREFIX'="${install_dir}" \ -D'CMAKE_BUILD_TYPE'="${build_type}" \ - ${cmake_opts} \ - ${cmake_user_opts} \ - ${@} + "${cmake_opts[@]}" \ + "${cmake_user_opts[@]}" cmake \ --build "${build_dir}" \ -- 2.39.5