[Toybox] ls -l broken

enh enh at google.com
Wed Nov 20 14:28:22 PST 2019


[PATCH] dirtree: fix 0b2cfcb8fdea9673f3c2e0940f1b16d5825e16ea.

0b2cfcb8fdea9673f3c2e0940f1b16d5825e16ea broke `ls -l` on files that
don't exist.

We didn't spot this because the corresponding ls test (which did exist)
had accidentally been mangled in a couple of ways.

This patch fixes the test (and extends it to differentiate between a
couple of possible ways it can go wrong), and fixes the broken path in
dirtree_add_node.

Bug: http://b/144698492
---
 lib/dirtree.c | 14 +++++++-------
 tests/ls.test |  5 +++--
 2 files changed, 10 insertions(+), 9 deletions(-)

On Wed, Nov 20, 2019 at 2:04 PM enh <enh at google.com> wrote:
>
> this change broke `ls -l` for non-existent arguments:
>
> /tmp/toybox-dirtree$ ./toybox ls -l /asd
> b--------T 140728898420758 1964107300 476192747 2935, 304972
> 1969-12-31 16:00 /asd
> /tmp/toybox-dirtree$ git revert 0b2cfcb8fdea9673f3c2e0940f1b16d5825e16ea
> [master f83f87fa] Revert "Let "find -L -type -l" find dangling symlinks."
>  1 file changed, 6 insertions(+), 12 deletions(-)
> /tmp/toybox-dirtree$ make
> scripts/make.sh
> Generate headers from toys/*/*.c...
> Library probe...........
> Make generated/config.h from .config.
> Compile toybox......
> /tmp/toybox-dirtree$ ./toybox ls -l /asd
> ls: /asd: No such file or directory
> /tmp/toybox-dirtree$ ./toybox ls -l /asd
> ls: /asd: No such file or directory
> /tmp/toybox-dirtree$ ./toybox ls -l /asd
> ls: /asd: No such file or directory
>
>
>
> commit 0b2cfcb8fdea9673f3c2e0940f1b16d5825e16ea
> Author: Rob Landley <rob at landley.net>
> Date:   Tue Oct 29 10:59:46 2019 -0500
>
>     Let "find -L -type -l" find dangling symlinks.
>
> diff --git a/lib/dirtree.c b/lib/dirtree.c
> index df38b257..beaafd59 100644
> --- a/lib/dirtree.c
> +++ b/lib/dirtree.c
> @@ -32,12 +32,18 @@ struct dirtree *dirtree_add_node(struct dirtree *parent, cha
> r *name, int flags)
>    int len = 0, linklen = 0, statless = 0;
>
>    if (name) {
> -    // open code this because haven't got node to call dirtree_parentfd() on ye
> t
> -    int fd = parent ? parent->dirfd : AT_FDCWD;
> -
> -    if (fstatat(fd, name, &st,AT_SYMLINK_NOFOLLOW*!(flags&DIRTREE_SYMFOLLOW)))
> {
> -      if (flags&DIRTREE_STATLESS) statless++;
> -      else goto error;
> +    // open code fd = because haven't got node to call dirtree_parentfd() on ye
> t
> +    int fd = parent ? parent->dirfd : AT_FDCWD,
> +      sym = AT_SYMLINK_NOFOLLOW*!(flags&DIRTREE_SYMFOLLOW);
> +
> +    // stat dangling symlinks
> +    if (fstatat(fd, name, &st, sym)) {
> +      if (errno != ENOENT
> +        || (!sym && fstatat(fd, name, &st, AT_SYMLINK_NOFOLLOW)))
> +      {
> +        if (flags&DIRTREE_STATLESS) statless++;
> +        else goto error;
> +      }
>      }
>      if (S_ISLNK(st.st_mode)) {
>        if (0>(linklen = readlinkat(fd, name, libbuf, 4095))) goto error;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 0001-dirtree-fix-0b2cfcb8fdea9673f3c2e0940f1b16d5825e16ea.patch
Type: text/x-patch
Size: 2518 bytes
Desc: not available
URL: <http://lists.landley.net/pipermail/toybox-landley.net/attachments/20191120/19fe9940/attachment-0002.bin>


More information about the Toybox mailing list