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

AltStyle によって変換されたページ (->オリジナル) /