Date: Mon, 20 Apr 2020 10:16:27 +0200 From: Matthias Apitz <guru@unixarea.de> To: freebsd-questions@freebsd.org Subject: find(1) removes as it should a directory, but after this it complains about Message-ID: <20200420081627.GA30229@sh4-5.1blu.de>
next in thread | raw e-mail | index | archive | help
Hello, I've stumbled over something with find(1) which I would call a bug: $ mkdir foo $ find foo -type d -execdir rm -rv {} \; foo find: foo: No such file or directory $ ls -ld foo ls: foo: No such file or directory I truss'ed the find(1) and it starts as it should a child process like 'rm -rv foo', but when this ends correctly, find tries to open again the dir foo: $ truss -f -o find.tr find foo -type d -execdir rm -rv {} \; foo find: foo: No such file or directory $ grep foo find.tr 2107: fstatat(AT_FDCWD,"foo",{ mode=drwxr-xr-x ,inode=4099842,size=512,blksize=32768 },AT_SYMLINK_NOFOLLOW) = 0 (0x0) 2108: fstatat(AT_FDCWD,"foo",{ mode=drwxr-xr-x ,inode=4099842,size=512,blksize=32768 },AT_SYMLINK_NOFOLLOW) = 0 (0x0) 2108: access("foo",W_OK) = 0 (0x0) 2108: open("foo",O_RDONLY|O_NONBLOCK|O_DIRECTORY|O_CLOEXEC,03) = 4 (0x4) 2108: rmdir("foo") = 0 (0x0) 2108: write(1,"foo\n",4) = 4 (0x4) 2107: open("foo",O_RDONLY|O_NONBLOCK|O_DIRECTORY|O_CLOEXEC,03) ERR#2 'No such file or directory' 2107: write(2,"foo: No such file or directory",30) = 30 (0x1e) Is this by intention? matthias -- Matthias Apitz, ✉ guru@unixarea.de, http://www.unixarea.de/ +49-176-38902045 Public GnuPG key: http://www.unixarea.de/key.pub May, 9: Спаси́бо освободители! Thank you very much, Russian liberators!
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20200420081627.GA30229>