]> git.ipfire.org Git - thirdparty/coreutils.git/commitdiff
link,ln: use gnulib's link module to work around Solaris 10 deficiency
authorJim Meyering <meyering@redhat.com>
Thu, 10 Sep 2009 15:51:44 +0000 (17:51 +0200)
committerJim Meyering <meyering@redhat.com>
Thu, 10 Sep 2009 16:52:12 +0000 (18:52 +0200)
Before this change, :>f; ln -T f no-such/ would succeed on Solaris 10.
After it, ln fails, as it should: ln: accessing `z/': Not a directory
The command, link f no-such/, had the same problem on that system.
* bootstrap.conf (gnulib_modules): Add "link".
* tests/ln/slash-decorated-nonexistent-dest: New test.
* tests/Makefile.am (TESTS): Add it.
* NEWS (Portability): Mention the improvement.

NEWS
bootstrap.conf
tests/Makefile.am
tests/ln/slash-decorated-nonexistent-dest [new file with mode: 0755]

diff --git a/NEWS b/NEWS
index 26dcd598fcd794b58759ea0c5016da0fd4a34950..5c23a073299f53019c9ac766e74448409d64881d 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -45,6 +45,14 @@ GNU coreutils NEWS                                    -*- outline -*-
   (i.e., not inotify-based) implementation.
   [bug introduced in coreutils-7.5]
 
+** Portability
+
+  ln, link: link f z/ would mistakenly succeed on Solaris 10, given an
+  existing file, f, and nothing named "z".  ln -T f z/ has the same problem.
+  Each would mistakenly create "z" as a link to "f".  Now, even on such a
+  system, each command reports the error, e.g.,
+  link: cannot create link `z/' to `f': Not a directory
+
 ** New features
 
   cp --reflink accepts a new "auto" parameter which falls back to
index 7ec4b3b473d40d1f2a48303bec91a2bf9fd1d0f7..c2bf753cc163ff233652637a7e57e37c3c34b48b 100644 (file)
@@ -130,6 +130,7 @@ gnulib_modules="
   lchown
   lib-ignore
   linebuffer
+  link
   link-follow
   long-options
   lstat
index 1de53bf0396657a0f0569dfc088a4920288a6c2a..7a20e0c2c3eaf2e642fae3a0cb453a4f512286e6 100644 (file)
@@ -345,6 +345,7 @@ TESTS =                                             \
   ln/hard-backup                               \
   ln/misc                                      \
   ln/sf-1                                      \
+  ln/slash-decorated-nonexistent-dest          \
   ln/target-1                                  \
   ls/abmon-align                               \
   ls/color-clear-to-eol                                \
diff --git a/tests/ln/slash-decorated-nonexistent-dest b/tests/ln/slash-decorated-nonexistent-dest
new file mode 100755 (executable)
index 0000000..afbbd06
--- /dev/null
@@ -0,0 +1,34 @@
+#!/bin/sh
+# ensure that touch f; ln -T f no-such-file/ does not mistakenly succeed
+
+# Copyright (C) 2009 Free Software Foundation, Inc.
+
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+if test "$VERBOSE" = yes; then
+  set -x
+  ln --version
+fi
+
+. $srcdir/test-lib.sh
+
+touch f || framework_failure
+
+fail=0
+
+# Before coreutils-7.6, this would succeed on Solaris 10
+ln -T f no-such-file/ && fail=1
+test -e no-such-file && fail=1
+
+Exit $fail