set -e
+# ensure that the locales are set, so that perl keeps its nerves
+export LC_ALL=C
+
echo "XXXX Cleanup previous attempts. Remaining content of /tmp:"
rm -rf /tmp/simgrid-java*
rm -rf /tmp/jvm-*
#test -e /bin/tar || die 1 "I need tar to compile. Please fix your slave."
#test -e /bin/gzip || die 1 "I need gzip to compile. Please fix your slave."
#test -e /usr/include/libunwind.h || die 1 "I need libunwind to compile. Please fix your slave."
-#test -e /usr/include/valgrind/valgrind.h || die 1 "I need valgrind to compile. Please fix your slave."
+#test -e /usr/include/valgrind/valgrind.h || die 1 "I need valgrind to compile. Please fix your slave."
build_mode="$1"
echo "Build mode $build_mode on $(uname -np)" >&2
ulimit -c 0 || true
-if test "$(uname -o)" != "Msys"; then
- echo "XX"
- echo "XX Get out of the tree"
- echo "XX"
- if [ -d $WORKSPACE/build ]
- then
- rm -rf $WORKSPACE/build
- fi
- mkdir $WORKSPACE/build
- cd $WORKSPACE/build
+echo "XX"
+echo "XX Get out of the tree"
+echo "XX"
+if [ -d $WORKSPACE/build ]
+then
+ # Windows cannot remove the directory if it's still used by the previous build
+ rm -rf $WORKSPACE/build || sleep 10 && rm -rf $WORKSPACE/build || sleep 10 && rm -rf $WORKSPACE/build
+fi
+mkdir $WORKSPACE/build
+cd $WORKSPACE/build
+# This is for Windows:
+PATH="$WORKSPACE/build/lib:$PATH"
+
+if test "$(uname -o)" != "Msys"; then
echo "XX"
echo "XX Build the archive out of the tree"
- echo "XX pwd: `pwd`"
+ echo "XX pwd: "$(pwd)
echo "XX"
cmake -G"$GENERATOR" -Denable_documentation=OFF $WORKSPACE
echo "XX"
echo "XX Open the resulting archive"
echo "XX"
- tar xzf `cat VERSION`.tar.gz
- cd `cat VERSION`
+ gunzip $(cat VERSION).tar.gz
+ tar xf $(cat VERSION).tar
+ cd $(cat VERSION)
+ mkdir build
+ cd build
+ SRCFOLDER=".."
+else
+#for windows we don't make dist, but we still want to build out of source
+ SRCFOLDER=$WORKSPACE
fi
echo "XX"
echo "XX Configure and build SimGrid"
-echo "XX pwd: `pwd`"
+echo "XX pwd: "$(pwd)
echo "XX"
cmake -G"$GENERATOR"\
-Denable_debug=ON -Denable_documentation=OFF -Denable_coverage=OFF \
-Denable_smpi_MPICH3_testsuite=$(onoff test "$build_mode" != "DynamicAnalysis") \
-Denable_mallocators=$(onoff test "$build_mode" != "DynamicAnalysis") \
-Denable_memcheck=$(onoff test "$build_mode" = "DynamicAnalysis") \
- -Denable_compile_warnings=ON -Denable_smpi=ON \
- -Denable_latency_bound_tracking=OFF -Denable_jedule=OFF \
- -Denable_tracing=ON -Denable_java=ON -Denable_lua=OFF
+ -Denable_compile_warnings=$(onoff test "$GENERATOR" != "MSYS Makefiles") -Denable_smpi=ON \
+ -Denable_jedule=OFF -Denable_java=ON -Denable_lua=OFF $SRCFOLDER
# -Denable_lua=$(onoff test "$build_mode" != "DynamicAnalysis") \
-
make -j$NUMBER_OF_PROCESSORS VERBOSE=1
if test "$(uname -o)" != "Msys"; then
cd $WORKSPACE/build
- cd `cat VERSION`
+ cd $(cat VERSION)/build
fi
-TRES=0
-
echo "XX"
echo "XX Run the tests"
-echo "XX pwd: `pwd`"
+echo "XX pwd: "$(pwd)
echo "XX"
ctest -T test --output-on-failure --no-compress-output || true
if [ -f Testing/TAG ] ; then
- xsltproc $WORKSPACE/tools/jenkins/ctest2junit.xsl Testing/`head -n 1 < Testing/TAG`/Test.xml > CTestResults.xml
+ xsltproc $WORKSPACE/tools/jenkins/ctest2junit.xsl Testing/$( head -n 1 < Testing/TAG )/Test.xml > CTestResults.xml
mv CTestResults.xml $WORKSPACE
fi
echo "XX"
echo "XX Done. Return the results to cmake"
echo "XX"
-
-if [ "$build_mode" = "DynamicAnalysis" ]
-then
- ctest -D ContinuousStart
- ctest -D ContinuousConfigure
- ctest -D ContinuousBuild
- ctest -D ContinuousMemCheck
- ctest -D ContinuousSubmit
-fi
-
-ctest -D ContinuousStart
-ctest -D ContinuousConfigure
-ctest -D ContinuousBuild
-ctest -D ContinuousTest
-ctest -D ContinuousSubmit
-
-rm -rf `cat VERSION`