X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fforeign.test.sh;h=bd91bfe5dd3db4d8214a628adec40ab05061aa24;hb=c3334d2307b721cfcea29e6abcd33e48487fb1ea;hp=10bc61378ea11b8520052ea48a794a10ce48e661;hpb=192731b882467a9014b64b1eb097c8000441da31;p=sbcl.git diff --git a/tests/foreign.test.sh b/tests/foreign.test.sh index 10bc613..bd91bfe 100644 --- a/tests/foreign.test.sh +++ b/tests/foreign.test.sh @@ -16,39 +16,186 @@ 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 file to test with. +## 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 -cc -c $testfilestem.c -o $testfilestem.o -ld -shared -o $testfilestem.so $testfilestem.o +echo 'int numberish = 42;' >> $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 -# Test interaction with the shared object file. -${SBCL:-sbcl} < $testfilestem.def.lisp < $testfilestem.test.lisp <