summaryrefslogtreecommitdiffstats
path: root/trunk/testsuite/cxx1.sh
diff options
context:
space:
mode:
Diffstat (limited to 'trunk/testsuite/cxx1.sh')
-rwxr-xr-xtrunk/testsuite/cxx1.sh20
1 files changed, 20 insertions, 0 deletions
diff --git a/trunk/testsuite/cxx1.sh b/trunk/testsuite/cxx1.sh
new file mode 100755
index 0000000..81428c2
--- /dev/null
+++ b/trunk/testsuite/cxx1.sh
@@ -0,0 +1,20 @@
+#!/bin/bash
+. `dirname $0`/functions.sh
+rm -f cxx1 cxx1lib*.so cxx1.log
+rm -f prelink.cache
+$CXX -shared -O2 -fpic -o cxx1lib1.so $srcdir/cxx1lib1.C
+$CXX -shared -O2 -fpic -o cxx1lib2.so $srcdir/cxx1lib2.C cxx1lib1.so
+BINS="cxx1"
+LIBS="cxx1lib1.so cxx1lib2.so"
+$CXXLINK -o cxx1 $srcdir/cxx1.C -Wl,--rpath-link,. cxx1lib2.so
+savelibs
+echo $PRELINK -vvvv ${PRELINK_OPTS--vm} ./cxx1 > cxx1.log
+$PRELINK -vvvv ${PRELINK_OPTS--vm} ./cxx1 >> cxx1.log 2>&1 || exit 1
+grep ^`echo $PRELINK | sed 's/ .*$/: /'` cxx1.log | grep -q -v 'C++ conflict' && exit 2
+if [ "x$CROSS" = "x" ]; then
+ LD_LIBRARY_PATH=. ./cxx1 || exit 3
+fi
+readelf -a ./cxx1 >> cxx1.log 2>&1 || exit 4
+# So that it is not prelinked again
+chmod -x ./cxx1
+comparelibs >> cxx1.log 2>&1 || exit 5