GNU bug report logs - #61537
[Bug-coreutils] 'cp -au' re-copies (removes and relinks) hard links that are up to date

Previous Next

Package: coreutils;

Reported by: Antonio Diaz Diaz <antonio <at> gnu.org>

Date: Wed, 15 Feb 2023 18:58:02 UTC

Severity: normal

To reply to this bug, email your comments to 61537 AT debbugs.gnu.org.

Toggle the display of automated, internal messages from the tracker.

View this report as an mbox folder, status mbox, maintainer mbox


Report forwarded to bug-coreutils <at> gnu.org:
bug#61537; Package coreutils. (Wed, 15 Feb 2023 18:58:02 GMT) Full text and rfc822 format available.

Acknowledgement sent to Antonio Diaz Diaz <antonio <at> gnu.org>:
New bug report received and forwarded. Copy sent to bug-coreutils <at> gnu.org. (Wed, 15 Feb 2023 18:58:02 GMT) Full text and rfc822 format available.

Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):

From: Antonio Diaz Diaz <antonio <at> gnu.org>
To: bug-coreutils <at> gnu.org
Cc: Antonio Diaz Diaz <antonio <at> gnu.org>
Subject: [Bug-coreutils] 'cp -au' re-copies (removes and relinks) hard links
 that are up to date
Date: Wed, 15 Feb 2023 19:58:22 +0100
Hello.

I have been forced recently to update my coreutils 8.11 (because 'touch' in 
8.11 didn't understand the dates with a 'T' separator passed to it by the 
configure of another GNU package I was installing) and have found that 'cp 
-au' now re-copies (removes and relinks) hard links that are up to date and 
it didn't recopy with 8.11.

I have tried coreutils 8.23 and 9.1, but I think all versions after 8.11 
have this problem.

To illustrate the problem, I first create a directory 'src' containing two 
linked files and then make a copy of 'src' in 'dest':

$ md src
$ echo "foo" > src/a
$ ln src/a src/b
$ cp -auv src dest
'src' -> 'dest'
'src/a' -> 'dest/a'
'src/b' -> 'dest/b'

Now, every time I update 'dest' using 'cp -au', it removes and relinks 
'dest/b' in spite of it already being a link to 'dest/a':

$ cp -auv src/* dest
removed 'dest/b'

But with 'cp' from coreutils 8.11, 'dest/b' was not recopied:

$ /tmp/coreutils-8.11/src/cp -auv src/* dest
$

Can current 'cp' be fixed so that it notices that the destination is already 
updated, and thus avoids removing and relinking it, just as it did in 
coreutils 8.11?

Thanks,
Antonio.




This bug report was last modified 1 year and 64 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.