]> git.ipfire.org Git - thirdparty/coreutils.git/commitdiff
mv: consistently warn about multiply specified source dirs
authorPádraig Brady <P@draigBrady.com>
Sat, 16 Jan 2016 11:35:50 +0000 (11:35 +0000)
committerPádraig Brady <P@draigBrady.com>
Sat, 16 Jan 2016 11:40:54 +0000 (11:40 +0000)
* src/copy.c (copy internal): Remember directories irrespective
of their link count, because on some file systems like BTRFS,
directories always have a link count of 1.

src/copy.c

index db2ce737741297dfdca88b0598070e594130cd23..191ccaaab5c5c7dd098950fbeb9023d83a61b924 100644 (file)
@@ -2232,7 +2232,14 @@ copy_internal (char const *src_name, char const *dst_name,
      Also, with --recursive, record dev/ino of each command-line directory.
      We'll use that info to detect this problem: cp -R dir dir.  */
 
-  if (x->move_mode && src_sb.st_nlink == 1)
+  if (x->recursive && S_ISDIR (src_mode))
+    {
+      if (command_line_arg)
+        earlier_file = remember_copied (dst_name, src_sb.st_ino, src_sb.st_dev);
+      else
+        earlier_file = src_to_dest_lookup (src_sb.st_ino, src_sb.st_dev);
+    }
+  else if (x->move_mode && src_sb.st_nlink == 1)
     {
       earlier_file = src_to_dest_lookup (src_sb.st_ino, src_sb.st_dev);
     }
@@ -2245,13 +2252,6 @@ copy_internal (char const *src_name, char const *dst_name,
     {
       earlier_file = remember_copied (dst_name, src_sb.st_ino, src_sb.st_dev);
     }
-  else if (x->recursive && S_ISDIR (src_mode))
-    {
-      if (command_line_arg)
-        earlier_file = remember_copied (dst_name, src_sb.st_ino, src_sb.st_dev);
-      else
-        earlier_file = src_to_dest_lookup (src_sb.st_ino, src_sb.st_dev);
-    }
 
   /* Did we copy this inode somewhere else (in this command line argument)
      and therefore this is a second hard link to the inode?  */