bug-coreutils
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

bug#12339: Bug: rm -fr . doesn't dir depth first deletion yet it is docu


From: Jim Meyering
Subject: bug#12339: Bug: rm -fr . doesn't dir depth first deletion yet it is documented to do so.
Date: Wed, 05 Sep 2012 17:18:21 +0200

Paul Eggert wrote:

> On 09/05/2012 07:56 AM, Jim Meyering wrote:
>> +  /* When failing to rmdir an unreadable directory, the typical errno value
>> +     is EISDIR or ENOTDIR, but that would be meaningless in a diagnostic.
>> +     When that happens and the errno value from the failed open is EPERM
>> +     or EACCES, use the earlier, more descriptive errno value.  */
>> +  if (ent->fts_info == FTS_DNR
>> +      && (errno == ENOTEMPTY || errno == EISDIR || errno == ENOTDIR)
>> +      && (ent->fts_errno == EPERM || ent->fts_errno == EACCES))
>
> Thanks for doing all that.  I did notice that the code mentions
> ENOTEMPTY but the comment doesn't -- is that intentional?

Yes.  I considered whether to remove explicit mention of those errno
values in the comment for precisely that reason, but didn't bother.
Good point.  I've relaxed the comment wording enough to permit other
explicit E* names:

diff --git a/src/remove.c b/src/remove.c
index 0c25462..a141718 100644
--- a/src/remove.c
+++ b/src/remove.c
@@ -392,8 +392,8 @@ excise (FTS *fts, FTSENT *ent, struct rm_options const *x, 
bool is_dir)
   if (ignorable_missing (x, errno))
     return RM_OK;

-  /* When failing to rmdir an unreadable directory, the typical errno value
-     is EISDIR or ENOTDIR, but that would be meaningless in a diagnostic.
+  /* When failing to rmdir an unreadable directory, we see errno values
+     like EISDIR or ENOTDIR, but they would be meaningless in a diagnostic.
      When that happens and the errno value from the failed open is EPERM
      or EACCES, use the earlier, more descriptive errno value.  */
   if (ent->fts_info == FTS_DNR





reply via email to

[Prev in Thread] Current Thread [Next in Thread]