Date: Mon, 29 Nov 2010 14:16:47 -0800 From: Bakul Shah <bakul@bitblocks.com> To: Matthew Jacob <mj@feral.com> Cc: freebsd-hackers@freebsd.org Subject: Re: find(1): Is this a bug or not? Message-ID: <20101129221648.159C45B18@mail.bitblocks.com> In-Reply-To: Your message of "Mon, 29 Nov 2010 12:39:43 PST." <4CF40F8F.30303@feral.com> References: <86r5e3zye4.fsf@pluton.xbsd.name> <4CF40F8F.30303@feral.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On Mon, 29 Nov 2010 12:39:43 PST Matthew Jacob <mj@feral.com> wrote: > can you report out the actual command line you're using and what release > it's from? > > On 11/29/2010 12:08 PM, Denise H. G. wrote: > > Hi, > > > > I found that, while searching for empty directories, find(1) will not > > continue if it encounters a dir it can't enter (e.g. no privilege). I > > don't know if it's so designed... I've checked NetBSD and OpenBSD's > > implementations (almost identical to that of FreeBSD's). And they behave > > the same way as FreeBSD's find(1) does under the circumstance. > > > > I'm wondering if this is a bug or not. This looks like a long standing bug: % mkdir -p a/{b,c}/d/e/f % find a -empty % chmod 000 a/b/d/ef % find a -empty The fix: % cd /usr/src/usr.bin/find % svn diff Index: function.c =================================================================== --- function.c (revision 212707) +++ function.c (working copy) @@ -560,7 +560,7 @@ empty = 1; dir = opendir(entry->fts_accpath); if (dir == NULL) - err(1, "%s", entry->fts_accpath); + return 0; for (dp = readdir(dir); dp; dp = readdir(dir)) if (dp->d_name[0] != '.' || (dp->d_name[1] != '\0' &&
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20101129221648.159C45B18>