X-Git-Url: http://git.lttng.org./?a=blobdiff_plain;f=scripts%2Fbabeltrace%2Fbuild.sh;h=8666e1bfcfd1bbcfede9ab21a3ada8a93ffbfe14;hb=de41e5b536a225c4cd6f8f0ac90363af5c9a3814;hp=f007acfb50a621bf0ef7843197e7408809bbc4a2;hpb=1d9e7aaad1f72016eb5ddbaa89082a160d66a7f2;p=lttng-ci.git diff --git a/scripts/babeltrace/build.sh b/scripts/babeltrace/build.sh index f007acf..8666e1b 100755 --- a/scripts/babeltrace/build.sh +++ b/scripts/babeltrace/build.sh @@ -1,6 +1,7 @@ #!/bin/bash -exu # # Copyright (C) 2015 - Jonathan Rajotte-Julien +# 2016 - Michael Jeanson # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -16,12 +17,16 @@ # along with this program. If not, see . -# Create build directory -rm -rf $WORKSPACE/build -mkdir -p $WORKSPACE/build - +SRCDIR="$WORKSPACE/src/babeltrace" +TMPDIR="$WORKSPACE/tmp" PREFIX="$WORKSPACE/build" +# Create build and tmp directories +rm -rf "$PREFIX" "$TMPDIR" +mkdir -p "$PREFIX" "$TMPDIR" + +export TMPDIR + # Set platform variables case "$arch" in solaris10) @@ -78,8 +83,10 @@ python-bindings) ;; esac +# Enter the source directory +cd "$SRCDIR" -# Run bootstrap prior to configure +# Run bootstrap in the source directory prior to configure ./bootstrap @@ -90,15 +97,14 @@ esac # # Make sure to move to the build_path and configure # before continuing -BUILD_PATH=$WORKSPACE -TEST_PLAN_PATH=$WORKSPACE +BUILD_PATH="$SRCDIR" case "$build" in oot) echo "Out of tree build" BUILD_PATH=$WORKSPACE/oot mkdir -p $BUILD_PATH cd $BUILD_PATH - MAKE=$MAKE BISON="$BISON" YACC="$YACC" $WORKSPACE/configure --prefix=$PREFIX $CONF_OPTS + MAKE=$MAKE BISON="$BISON" YACC="$YACC" "$SRCDIR/configure" --prefix=$PREFIX $CONF_OPTS ;; dist) @@ -106,7 +112,7 @@ case "$build" in BUILD_PATH=`mktemp -d` # Initial configure and generate tarball - MAKE=$MAKE BISON="$BISON" YACC="$YACC" ./configure + MAKE=$MAKE BISON="$BISON" YACC="$YACC" "$SRCDIR/configure" $MAKE dist mkdir -p $BUILD_PATH @@ -117,20 +123,17 @@ case "$build" in $TAR xvf *.tar.* --strip 1 MAKE=$MAKE BISON="$BISON" YACC="$YACC" $BUILD_PATH/configure --prefix=$PREFIX $CONF_OPTS - - # Set test plan to dist tar - TEST_PLAN_PATH=$BUILD_PATH ;; clang) echo "LLVM clang build" export CC=clang clang -v - MAKE=$MAKE BISON="$BISON" YACC="$YACC" $WORKSPACE/configure --prefix=$PREFIX $CONF_OPTS + MAKE=$MAKE BISON="$BISON" YACC="$YACC" "$SRCDIR/configure" --prefix=$PREFIX $CONF_OPTS ;; *) - echo "Standard tree build" - MAKE=$MAKE BISON="$BISON" YACC="$YACC" $WORKSPACE/configure --prefix=$PREFIX $CONF_OPTS + echo "Standard in-tree build" + MAKE=$MAKE BISON="$BISON" YACC="$YACC" "$SRCDIR/configure" --prefix=$PREFIX $CONF_OPTS ;; esac @@ -141,19 +144,22 @@ $MAKE install # Run tests $MAKE check -# Remove global test suite log file, it confuses the tap parser -rm -f tests/test-suite.log +# Copy tap logs for the jenkins tap parser +rsync -a --exclude 'test-suite.log' --include '*/' --include '*.log' --exclude='*' tests/ "$WORKSPACE/tap" + +# Clean the build directory +$MAKE clean # Cleanup rpath in executables and shared libraries -find $WORKSPACE/build/bin -type f -perm -0500 -exec chrpath --delete {} \; -find $WORKSPACE/build/lib -name "*.so" -exec chrpath --delete {} \; +find $PREFIX/bin -type f -perm -0500 -exec chrpath --delete {} \; +find $PREFIX/lib -name "*.so" -exec chrpath --delete {} \; # Remove libtool .la files -find $WORKSPACE/build/lib -name "*.la" -exec rm -f {} \; +find $PREFIX/lib -name "*.la" -exec rm -f {} \; # Clean temp dir for dist build if [ "$build" = "dist" ]; then - cd $WORKSPACE + cd $SRCDIR rm -rf $BUILD_PATH fi