X-Git-Url: http://git.lttng.org./?a=blobdiff_plain;ds=inline;f=scripts%2Fliburcu%2Fbuild.sh;h=ef97773b7ba84b4895251126eecf497d46e172d8;hb=72f4f0c1881d89d5dc8e1a7887500cc6b365aace;hp=042cdf5151688489170b212ecf95f15835aee556;hpb=f12f1d66b108047330ad7f7d6e611be3645925b4;p=lttng-ci.git diff --git a/scripts/liburcu/build.sh b/scripts/liburcu/build.sh index 042cdf5..ef97773 100755 --- a/scripts/liburcu/build.sh +++ b/scripts/liburcu/build.sh @@ -1,4 +1,4 @@ -#!/bin/sh -exu +#!/bin/bash -exu # # Copyright (C) 2015 - Jonathan Rajotte-Julien # @@ -22,25 +22,55 @@ mkdir -p $WORKSPACE/build PREFIX="$WORKSPACE/build" -./bootstrap +# Set platform variables +case "$arch" in +solaris10) + MAKE=gmake + TAR=gtar + NPROC=gnproc + CFLAGS="-D_XOPEN_SOURCE=1 -D_XOPEN_SOURCE_EXTENDED=1 -D__EXTENSIONS__=1" + ;; -CONF_OPTS="" +solaris11) + MAKE=gmake + TAR=gtar + NPROC=nproc + CFLAGS="-D_XOPEN_SOURCE=1 -D_XOPEN_SOURCE_EXTENDED=1 -D__EXTENSIONS__=1" + export PATH="$PATH:/usr/perl5/bin" + ;; + +*) + MAKE=make + TAR=tar + NPROC=nproc + CFLAGS="" + ;; +esac +# Set configure options for each build configuration +CONF_OPTS="" case "$conf" in static) echo "Static build" CONF_OPTS="--enable-static --disable-shared" ;; + tls_fallback) echo "Using pthread_getspecific() to emulate TLS" CONF_OPTS="--disable-compiler-tls" ;; + *) echo "Standard build" CONF_OPTS="" ;; esac + +# Run bootstrap prior to configure +./bootstrap + + # Build type # oot : out-of-tree build # dist: build via make dist @@ -48,49 +78,64 @@ esac # # Make sure to move to the build_path and configure # before continuing - BUILD_PATH=$WORKSPACE case "$build" in - oot) - echo "Out of tree build" - BUILD_PATH=$WORKSPACE/oot - mkdir -p $BUILD_PATH - cd $BUILD_PATH - $WORKSPACE/configure --prefix=$PREFIX $CONF_OPTS - ;; - dist) - echo "Distribution out of tree build" - BUILD_PATH=`mktemp -d` - - # Initial configure and generate tarball - ./configure - make dist - - mkdir -p $BUILD_PATH - cp *.tar.* $BUILD_PATH/ - cd $BUILD_PATH - - # Ignore level 1 of tar - tar xvf *.tar.* --strip 1 - - $BUILD_PATH/configure --prefix=$PREFIX $CONF_OPTS - ;; - *) - BUILD_PATH=$WORKSPACE - echo "Standard tree build" - $WORKSPACE/configure --prefix=$PREFIX $CONF_OPTS - ;; +oot) + echo "Out of tree build" + BUILD_PATH=$WORKSPACE/oot + mkdir -p $BUILD_PATH + cd $BUILD_PATH + MAKE=$MAKE CFLAGS="$CFLAGS" $WORKSPACE/configure --prefix=$PREFIX $CONF_OPTS + ;; + +dist) + echo "Distribution out of tree build" + BUILD_PATH=`mktemp -d` + + # Initial configure and generate tarball + MAKE=$MAKE ./configure + $MAKE dist + + mkdir -p $BUILD_PATH + cp *.tar.* $BUILD_PATH/ + cd $BUILD_PATH + + # Ignore level 1 of tar + $TAR xvf *.tar.* --strip 1 + + MAKE=$MAKE CFLAGS="$CFLAGS" $BUILD_PATH/configure --prefix=$PREFIX $CONF_OPTS + ;; +*) + BUILD_PATH=$WORKSPACE + echo "Standard tree build" + MAKE=$MAKE CFLAGS="$CFLAGS" $WORKSPACE/configure --prefix=$PREFIX $CONF_OPTS + ;; esac -make -make install -make clean +# BUILD! +$MAKE -j `$NPROC` +$MAKE install + +# Run tests +$MAKE check +#if [ "$version" >=" 0.9" ]; then + $MAKE regtest +#fi -# Cleanup rpath and libtool .la files +# Cleanup +$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 {} \; + +# Remove libtool .la files find $WORKSPACE/build/lib -name "*.la" -exec rm -f {} \; # Cleanup temp directory of dist build -if [ $build = "dist" ]; then - rm -rf $BUILD_PATH +if [ "$build" = "dist" ]; then + cd $WORKSPACE + rm -rf $BUILD_PATH fi + +# EOF