# absolutely no warranty. See the COPYING and CREDITS files for
# more information.
+original_pwd=`pwd`
+
# LOADing and COMPILEing files with logical pathnames
testdir=`pwd`"/side-effectful-pathnames-test-$$"
testfilestem="load-test"
(sb-ext:quit :unix-status 52)
EOF
if [ $? != 52 ]; then
- echo test failed: $?
+ echo LOAD/COMPILE test failed, unexpected Lisp return code=$?
exit 1
fi
+# We don't need the test directory any more.
+rm -r $testdir
+
+# In the flaky1 branch, Dan Barlow pointed out that
+# ENSURE-DIRECTORIES-EXIST failed for these relative pathname
+# operations when the mysterious special case handling of "" pathnames
+# was removed from UNIX-STAT. Let's make sure that it works now.
+#
+# Set up an empty directory to work with.
+testdir=$TMPDIR/sbcl-mkdir-test-$$
+if ! rm -rf $testdir ; then
+ echo "$testdir already exists and could not be deleted"
+ exit 1;
+fi
+mkdir $testdir
+cd $testdir
+#
+# Provoke failure.
+$SBCL <<EOF
+(let ((rel-name #p"foo/bar/")
+ (abs-name (merge-pathnames #p"baz/quux/" (truename "."))))
+ (and
+ (ensure-directories-exist abs-name)
+ (ensure-directories-exist rel-name)
+ (sb-ext:quit :unix-status 52)))
+EOF
+if [ $? != 52 ]; then
+ echo ENSURE-DIRECTORIES-EXIST test failed, unexpected SBCL return code=$?
+ find $testdir -print
+ exit 1
+fi
+if [ ! -d $testdir/foo/bar ] ; then
+ echo test failed: $testdir/foo/bar is not a directory
+ find $testdir -print
+ exit 1
+fi;
+if [ ! -d $testdir/baz/quux ] ; then
+ echo test failed: $testdir/baz/quux is not a directory
+ find $testdir -print
+ exit 1
+fi;
+#
+# We succeeded, life is good. Now we don't need the test directory
+# any more; and come back home.
rm -r $testdir
+cd $original_pwd
-# success
+# success convention for script
exit 104