X-Git-Url: http://git.liburcu.org/?a=blobdiff_plain;f=scripts%2Fbabeltrace%2Fbuild.sh;h=ddb9162a4a351840444f33a551b2c9463eb1bcfa;hb=6871000cbd00b2dd074a3bd313e8dfba24c83ffc;hp=d9fb96912144ff1eb34a5fe9f1e2f1a45d8243d0;hpb=00f7bb3f2d250b474696e87da357554d2ae5868f;p=lttng-ci.git diff --git a/scripts/babeltrace/build.sh b/scripts/babeltrace/build.sh index d9fb969..ddb9162 100755 --- a/scripts/babeltrace/build.sh +++ b/scripts/babeltrace/build.sh @@ -25,6 +25,8 @@ vercomp () { return 0 fi local IFS=. + # Ignore the shellcheck warning, we want splitting to happen based on IFS. + # shellcheck disable=SC2206 local i ver1=($1) ver2=($2) # fill empty fields in ver1 with zeros for ((i=${#ver1[@]}; i<${#ver2[@]}; i++)); do @@ -46,26 +48,35 @@ vercomp () { return 0 } +# Shellcheck flags the following functions that are unused as "unreachable", +# ignore that. + +# shellcheck disable=SC2317 verlte() { - vercomp "$1" "$2"; local res="$?" + vercomp "$1" "$2" + local res="$?" [ "$res" -eq "0" ] || [ "$res" -eq "2" ] } +# shellcheck disable=SC2317 verlt() { vercomp "$1" "$2"; local res="$?" [ "$res" -eq "2" ] } +# shellcheck disable=SC2317 vergte() { vercomp "$1" "$2"; local res="$?" [ "$res" -eq "0" ] || [ "$res" -eq "1" ] } +# shellcheck disable=SC2317 vergt() { vercomp "$1" "$2"; local res="$?" [ "$res" -eq "1" ] } +# shellcheck disable=SC2317 verne() { vercomp "$1" "$2"; local res="$?" [ "$res" -ne "0" ] @@ -94,6 +105,15 @@ BABELTRACE_RUN_TESTS="${BABELTRACE_RUN_TESTS:=yes}" SRCDIR="$WORKSPACE/src/babeltrace" TMPDIR="$WORKSPACE/tmp" PREFIX="/build" +LIBDIR="lib" + +# RHEL and SLES both use lib64 but don't bother shipping a default autoconf +# site config that matches this. +if [[ ( -f /etc/redhat-release || -f /etc/SuSE-release ) && ( "$(uname -m)" == "x86_64" ) ]]; then + LIBDIR_ARCH="${LIBDIR}64" +else + LIBDIR_ARCH="$LIBDIR" +fi # Create tmp directory rm -rf "$TMPDIR" @@ -188,7 +208,7 @@ export BABELTRACE_MINIMAL_LOG_LEVEL=TRACE # Set configure options and environment variables for each build # configuration. -CONF_OPTS=("--prefix=$PREFIX") +CONF_OPTS=("--prefix=$PREFIX" "--libdir=$PREFIX/$LIBDIR_ARCH") # -Werror is enabled by default in stable-2.0 but won't be in 2.1 # Explicitly disable it for consistency. @@ -235,6 +255,14 @@ doc) CONF_OPTS+=("--enable-python-bindings" "--enable-python-bindings-doc" "--enable-python-plugins" "--enable-api-doc") ;; +asan) + echo "Address Sanitizer configuration" + + # --enable-asan was introduced after 2.0 but don't check the version, we + # want this configuration to fail if ASAN is unavailable. + CONF_OPTS+=("--enable-asan" "--enable-python-bindings" "--enable-python-plugins") + ;; + min) echo "Minimal configuration" ;; @@ -247,6 +275,11 @@ min) if vergte "$PACKAGE_VERSION" "2.0"; then CONF_OPTS+=("--enable-python-bindings" "--enable-python-plugins") fi + + # Something is broken in docbook-xml on yocto + if [[ "$platform" = yocto* ]]; then + CONF_OPTS+=("--disable-man-pages") + fi ;; esac @@ -351,10 +384,10 @@ $MAKE clean # Cleanup rpath in executables and shared libraries find "$WORKSPACE/$PREFIX/bin" -type f -perm -0500 -exec chrpath --delete {} \; -find "$WORKSPACE/$PREFIX/lib" -name "*.so" -exec chrpath --delete {} \; +find "$WORKSPACE/$PREFIX/$LIBDIR_ARCH" -name "*.so" -exec chrpath --delete {} \; # Remove libtool .la files -find "$WORKSPACE/$PREFIX/lib" -name "*.la" -exec rm -f {} \; +find "$WORKSPACE/$PREFIX/$LIBDIR_ARCH" -name "*.la" -exec rm -f {} \; # Exit with failure if any of the tests failed exit $failed_tests