+# In sbcl-0.9.8 saving cores with callbacks didn't work on gencgc platforms
+$SBCL <<EOF
+ (defun bar ()
+ (format t "~&Callbacks not supported, skipping~%")
+ (quit :unix-status 42))
+ #+alien-callbacks
+ (progn
+ (sb-alien::define-alien-callback foo int () 42)
+ (defun bar () (quit :unix-status (alien-funcall foo))))
+ (save-lisp-and-die "$tmpcore")
+EOF
+$SBCL_ALLOWING_CORE --core "$tmpcore" \
+--userinit /dev/null --sysinit /dev/null <<EOF
+ (bar)
+EOF
+if [ $? = 42 ]; then
+ echo "/Callbacks after SAVE-LISP-AND-DIE worked, good."
+else
+ echo "failure in basic SAVE-LISP-AND-DIE: $?"
+ exit 1
+fi
+
+# test suppression of banner in executable cores
+$SBCL <<EOF
+ (save-lisp-and-die "$tmpcore" :executable t)
+EOF
+chmod u+x "$tmpcore"
+./"$tmpcore" >"$tmpoutput" \
+ --no-userinit --no-sysinit --eval '(quit :unix-status 71)'
+if [ $? != 71 ]; then
+ echo "failure in banner suppression: $?"
+ exit 1
+elif [ -s "$tmpoutput" ]; then
+ echo "failure in banner suppression: nonempty output:"
+ echo ---
+ cat "$tmpoutput"
+ echo ---
+ exit 1
+elif [ -f "$tmpoutput" ]; then
+ echo "/Executable suppressed banner, good."
+else
+ echo "failure in banner suppression: $tmpoutput was not created or something funny happened."
+ exit 1
+fi
+
+rm -f "$tmpcore"
+rm -f "$tmpoutput"