X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fforeign.test.sh;h=bd91bfe5dd3db4d8214a628adec40ab05061aa24;hb=c3334d2307b721cfcea29e6abcd33e48487fb1ea;hp=47f434482c98258f7bfa77fe34abeb82232091c3;hpb=7cec182a00d4143dc7cfd43fc55c6691e356e609;p=sbcl.git diff --git a/tests/foreign.test.sh b/tests/foreign.test.sh index 47f4344..bd91bfe 100644 --- a/tests/foreign.test.sh +++ b/tests/foreign.test.sh @@ -1,6 +1,7 @@ #!/bin/sh -# tests related to foreign function interface and LOAD-FOREIGN +# tests related to foreign function interface and loading of shared +# libraries # This software is part of the SBCL system. See the README file for # more information. @@ -13,36 +14,189 @@ # absolutely no warranty. See the COPYING and CREDITS files for # more information. +echo //entering foreign.test.sh + +# simple way to make sure we're not punting by accident: +# setting PUNT to anything other than 104 will make non-dlopen +# and non-linkage-table platforms fail this +PUNT=104 + testfilestem=${TMPDIR:-/tmp}/sbcl-foreign-test-$$ +## Make a little shared object files to test with. + +build_so() { + echo building $1.so + if [ $(uname -p) = x86_64 ]; then + CFLAGS="$CFLAGS -fPIC" + fi + cc -c $1.c -o $1.o $CFLAGS + ld -shared -o $1.so $1.o +} + echo 'int summish(int x, int y) { return 1 + x + y; }' > $testfilestem.c -make $testfilestem.o -ld -shared -o $testfilestem.so $testfilestem.o - -${SBCL:-sbcl} <> $testfilestem.c +echo 'int nummish(int x) { return numberish + x; }' >> $testfilestem.c +build_so $testfilestem + +echo 'int foo = 13;' > $testfilestem-b.c +echo 'int bar() { return 42; }' >> $testfilestem-b.c +build_so $testfilestem-b + +echo 'int foo = 42;' > $testfilestem-b2.c +echo 'int bar() { return 13; }' >> $testfilestem-b2.c +build_so $testfilestem-b2 + +echo 'int late_foo = 43;' > $testfilestem-c.c +echo 'int late_bar() { return 14; }' >> $testfilestem-c.c +build_so $testfilestem-c + +## Foreign definitions & load + +cat > $testfilestem.def.lisp < $testfilestem.test.lisp <