[Toybox] cp.c

enh enh at google.com
Thu Mar 11 08:30:55 PST 2021


i don't understand this code in cp.c, specifically the marked line. because
of the `errno = EXDEV` on the first line of this snippet, and the absence
of any `errno = 0` in between, what was the `if (errno &&` for?

    errno = EXDEV;
    if (CFG_MV && toys.which->name[0] == 'm') {
      int force = FLAG(f), no_clobber = FLAG(n);

      if (!force || no_clobber) {
        struct stat st;
        int exists = !stat(TT.destname, &st);

        // Prompt if -i or file isn't writable.  Technically "is writable"
is
        // more complicated (022 is not writeable by the owner, just
everybody
        // _else_) but I don't care.
        if (exists && (FLAG(i) || (!(st.st_mode & 0222) && isatty(0)))) {
          fprintf(stderr, "%s: overwrite '%s'", toys.which->name,
TT.destname);
          if (!yesno(0)) rc = 0;
          else unlink(TT.destname);
        }
        // if -n and dest exists, don't try to rename() or copy
        if (exists && no_clobber) rc = 0;
      }
      if (rc) rc = rename(src, TT.destname);
!     if (errno && !*trail) *trail = '/';
    }

it seems from the history like the EXDEV assignment was for the later test
of `errno != EXDEV` and is really meant to be a "did we successfully
move?". i don't think that's still valid now the force/clobber code has
been added?
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.landley.net/pipermail/toybox-landley.net/attachments/20210311/fa7a13e4/attachment.htm>


More information about the Toybox mailing list