From: Michael Jeanson Date: Mon, 15 Jul 2019 22:16:14 +0000 (-0400) Subject: jjb: babeltrace: build.sh is now shellcheck clean X-Git-Url: https://git.lttng.org./?a=commitdiff_plain;h=1f620ba015cc9617640fbfcdb9fbe84f323af527;p=lttng-ci.git jjb: babeltrace: build.sh is now shellcheck clean Signed-off-by: Michael Jeanson --- diff --git a/scripts/babeltrace/build.sh b/scripts/babeltrace/build.sh index 9a5a29a..0d8fdaf 100755 --- a/scripts/babeltrace/build.sh +++ b/scripts/babeltrace/build.sh @@ -80,7 +80,10 @@ SRCDIR="$WORKSPACE/src/babeltrace" TMPDIR="$WORKSPACE/tmp" PREFIX="$WORKSPACE/build" -# Create build and tmp directories +# The build dir defaults to the source dir +BUILDDIR="$SRCDIR" + +# Create install and tmp directories rm -rf "$PREFIX" "$TMPDIR" mkdir -p "$PREFIX" "$TMPDIR" @@ -161,6 +164,8 @@ sol10-i386) export CPPFLAGS="-I/opt/csw/include" export LDFLAGS="-L/opt/csw/lib -R/opt/csw/lib" export PKG_CONFIG_PATH="/opt/csw/lib/pkgconfig" + export PYTHON="python3" + export PYTHON_CONFIG="python3-config" ;; sol11-i386) export MAKE=gmake @@ -169,6 +174,8 @@ sol11-i386) export PATH="$PATH:/usr/perl5/bin" export LD_ALTEXEC=/usr/bin/gld export LD=/usr/bin/gld + export PYTHON="python3" + export PYTHON_CONFIG="python3-config" ;; macosx) export MAKE=make @@ -179,11 +186,15 @@ macosx) export PATH="/opt/local/bin:/opt/local/sbin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin" export CFLAGS="$CFLAGS -I/opt/local/include" export LDFLAGS="-L/opt/local/lib" + export PYTHON="python3" + export PYTHON_CONFIG="python3-config" ;; *) export MAKE=make export TAR=tar export NPROC=nproc + export PYTHON="python3" + export PYTHON_CONFIG="python3-config" ;; esac @@ -202,28 +213,30 @@ export BABELTRACE_DEV_MODE=1 export BABELTRACE_MINIMAL_LOG_LEVEL=TRACE # Set configure options for each build configuration -CONF_OPTS="" +CONF_OPTS=() case "$conf" in static) - echo "Static build" - CONF_OPTS="--enable-static --disable-shared" + echo "Static lib only configuration" + + CONF_OPTS+=("--enable-static" "--disable-shared") + if vergte "$PACKAGE_VERSION" "2.0"; then - CONF_OPTS="${CONF_OPTS} --enable-built-in-plugins" + CONF_OPTS+=("--enable-built-in-plugins") fi ;; + python-bindings) - echo "Build with python bindings" - # We only support bindings built with Python 3 - export PYTHON="python3" - export PYTHON_CONFIG="python3-config" - CONF_OPTS="--enable-python-bindings" + echo "Python bindings configuration" + + CONF_OPTS+=("--enable-python-bindings") if vergte "$PACKAGE_VERSION" "2.0"; then - CONF_OPTS="${CONF_OPTS} --enable-python-bindings-doc --enable-python-plugins" + CONF_OPTS+=("--enable-python-bindings-doc" "--enable-python-plugins") fi ;; + prod) - echo "Production build" + echo "Production configuration" # Unset the developper variables unset BABELTRACE_DEBUG_MODE @@ -231,24 +244,20 @@ prod) unset BABELTRACE_MINIMAL_LOG_LEVEL # Enable the python bindings - export PYTHON="python3" - export PYTHON_CONFIG="python3-config" - CONF_OPTS="--enable-python-bindings --enable-python-bindings-doc --enable-python-plugins" + CONF_OPTS+=("--enable-python-bindings" "--enable-python-bindings-doc" "--enable-python-plugins") ;; + min) - echo "Minimal build" - CONF_OPTS="" + echo "Minimal configuration" ;; + *) - echo "Standard build" - CONF_OPTS="" + echo "Standard configuration" - # Enable the python bindings / plugins by default with babeltrace2 + # Enable the python bindings / plugins by default with babeltrace2, # the test suite is mostly useless without it. if vergte "$PACKAGE_VERSION" "2.0"; then - export PYTHON="python3" - export PYTHON_CONFIG="python3-config" - CONF_OPTS="${CONF_OPTS} --enable-python-bindings --enable-python-plugins" + CONF_OPTS+=("--enable-python-bindings" "--enable-python-plugins") fi ;; esac @@ -258,42 +267,45 @@ esac # dist: build via make dist # * : normal tree build # -# Make sure to move to the build_path and configure -# before continuing -BUILD_PATH="$SRCDIR" +# Make sure to move to the build dir and run configure +# before continuing. case "$build" in oot) echo "Out of tree build" - BUILD_PATH="$WORKSPACE/oot" - mkdir -p "$BUILD_PATH" - cd "$BUILD_PATH" - "$SRCDIR/configure" --prefix="$PREFIX" $CONF_OPTS + + BUILDDIR="$WORKSPACE/oot" + mkdir -p "$BUILDDIR" + cd "$BUILDDIR" + + "$SRCDIR/configure" --prefix="$PREFIX" "${CONF_OPTS[@]}" ;; dist) echo "Distribution out of tree build" - BUILD_PATH="$(mktemp -d)" + BUILDDIR="$(mktemp -d)" # Initial configure and generate tarball "$SRCDIR/configure" $MAKE dist - mkdir -p "$BUILD_PATH" - cp ./*.tar.* "$BUILD_PATH/" - cd "$BUILD_PATH" + mkdir -p "$BUILDDIR" + cp ./*.tar.* "$BUILDDIR/" + cd "$BUILDDIR" # Ignore level 1 of tar $TAR xvf ./*.tar.* --strip 1 - "$BUILD_PATH/configure" --prefix="$PREFIX" $CONF_OPTS + ./configure --prefix="$PREFIX" "${CONF_OPTS[@]}" ;; *) echo "Standard in-tree build" - "$SRCDIR/configure" --prefix="$PREFIX" $CONF_OPTS + ./configure --prefix="$PREFIX" "${CONF_OPTS[@]}" ;; esac +# We are now inside a configured build directory + # BUILD! $MAKE -j "$($NPROC)" V=1 $MAKE install @@ -304,7 +316,7 @@ $MAKE --keep-going check ret=$? set -e -# Copy tap logs for the jenkins tap parser +# Copy tap logs for the jenkins tap parser before cleaning the build dir rsync -a --exclude 'test-suite.log' --include '*/' --include '*.log' --exclude='*' tests/ "$WORKSPACE/tap" # Clean the build directory @@ -320,7 +332,7 @@ find "$PREFIX/lib" -name "*.la" -exec rm -f {} \; # Clean temp dir for dist build if [ "$build" = "dist" ]; then cd "$SRCDIR" - rm -rf "$BUILD_PATH" + rm -rf "$BUILDDIR" fi # Exit with the return code of the test suite