summaryrefslogtreecommitdiff
path: root/config/mkinstalldirs
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>2004-03-11 18:58:29 +0000
committerJim Meyering <jim@meyering.net>2004-03-11 18:58:29 +0000
commit04975d25921447c96db51fc76b02bc31d8848f0a (patch)
tree00206da19a0284dce0d960d853950a5d759ad07f /config/mkinstalldirs
parent98ea4dad08aff07502615c473336ef3787e2a730 (diff)
downloadcoreutils-04975d25921447c96db51fc76b02bc31d8848f0a.tar.xz
.
Diffstat (limited to 'config/mkinstalldirs')
-rw-r--r--config/mkinstalldirs17
1 files changed, 12 insertions, 5 deletions
diff --git a/config/mkinstalldirs b/config/mkinstalldirs
index 6504b744b..6fbe5e117 100644
--- a/config/mkinstalldirs
+++ b/config/mkinstalldirs
@@ -1,7 +1,7 @@
#! /bin/sh
# mkinstalldirs --- make directory hierarchy
-scriptversion=2003-11-08.23
+scriptversion=2004-02-15.20
# Original author: Noah Friedman <friedman@prep.ai.mit.edu>
# Created: 1993-05-16
@@ -66,9 +66,15 @@ case $# in
0) exit 0 ;;
esac
+# Solaris 8's mkdir -p isn't thread-safe. If you mkdir -p a/b and
+# mkdir -p a/c at the same time, both will detect that a is missing,
+# one will create a, then the other will try to create a and die with
+# a "File exists" error. This is a problem when calling mkinstalldirs
+# from a parallel make. We use --version in the probe to restrict
+# ourselves to GNU mkdir, which is thread-safe.
case $dirmode in
'')
- if mkdir -p -- . 2>/dev/null; then
+ if mkdir -p --version . >/dev/null 2>&1 && test ! -d ./--version; then
echo "mkdir -p -- $*"
exec mkdir -p -- "$@"
else
@@ -77,16 +83,17 @@ case $dirmode in
# directories to create, and then abort because `.' already
# exists.
test -d ./-p && rmdir ./-p
- test -d ./-- && rmdir ./--
+ test -d ./--version && rmdir ./--version
fi
;;
*)
- if mkdir -m "$dirmode" -p -- . 2>/dev/null; then
+ if mkdir -m "$dirmode" -p --version . >/dev/null 2>&1 &&
+ test ! -d ./--version; then
echo "mkdir -m $dirmode -p -- $*"
exec mkdir -m "$dirmode" -p -- "$@"
else
# Clean up after NextStep and OpenStep mkdir.
- for d in ./-m ./-p ./-- "./$dirmode";
+ for d in ./-m ./-p ./--version "./$dirmode";
do
test -d $d && rmdir $d
done