Fun with cp -R error when both foo and foo.exe exist

Eric Blake eblake@redhat.com
Tue Oct 9 16:52:00 GMT 2018


On 10/9/18 11:21 AM, Dan Kegel wrote:
> On Tue, Oct 9, 2018 at 5:03 AM Eric Blake <eblake@redhat.com> wrote:
>> whether someone patches the cygwin dll or cp, it seems like some rather
>> hairy code for what is normally a rare corner case, so it probably won't
>> happen unless someone actually contributes a patch.
> 
> Right.  Here's a completely untested guess patch:
> 
> --- a/winsup/cygwin/syscalls.cc
> +++ b/winsup/cygwin/syscalls.cc
> @@ -1363,7 +1363,15 @@ open (const char *unix_path, int flags, ...)
>            opt |= PC_CTTY;
>          }
> 
> -      if (!(fh = build_fh_name (unix_path, opt, stat_suffixes)))
> +      suffix_info *suffices = stat_suffixes;

suffices is a completely different word; did you mean suffixes?

> +      if ((opt & (O_WRONLY|O_BINARY)) == (O_WRONLY|O_BINARY))

O_WRONLY need not be a bitmask; it's better to use O_ACCMODE for the 
bitmask, as in
  opt & (O_ACCMODE|O_BINARY) == O_WRONLY|O_BINARY

> +        {
> +         /* Hack so 'cp foo bar' doesn't abort with
> +             'cp: cannot create regular file bar: File exists'
> +            if bar.exe already exists  */
> +       suffices = NULL;
> +       }
> +      if (!(fh = build_fh_name (unix_path, opt, suffices)))

So, with mistakes corrected, your hack is that cygwin doing auto-suffix 
probing should be suppressed in the case of opening a file O_WRONLY? Why 
does O_BINARY have to fit in the equation?

>          __leave;                /* errno already set */
>         if ((flags & O_NOFOLLOW) && fh->issymlink ())
>          {
> 
> Feel free to throw rotten fruit :-)
> 

-- 
Eric Blake, Principal Software Engineer
Red Hat, Inc.           +1-919-301-3266
Virtualization:  qemu.org | libvirt.org

--
Problem reports:       http://cygwin.com/problems.html
FAQ:                   http://cygwin.com/faq/
Documentation:         http://cygwin.com/docs.html
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple



More information about the Cygwin mailing list