Hi brian,
On Wed, 24 Oct 2018, brian m. carlson wrote:
> On Tue, Oct 23, 2018 at 03:23:21AM -0700, Karsten Blees via GitGitGadget
> wrote:
> > - if (!get_file_info_by_handle(fh, buf))
> > + case FILE_TYPE_CHAR:
> > + case FILE_TYPE_PIPE:
> > + /* initialize stat fields */
> > + memset(buf, 0, sizeof(*buf));
> > + buf->st_nlink = 1;
> > +
> > + if (type == FILE_TYPE_CHAR) {
> > + buf->st_mode = _S_IFCHR;
> > + } else {
> > + buf->st_mode = _S_IFIFO;
> > + if (PeekNamedPipe(fh, NULL, 0, NULL, &avail, NULL))
> > + buf->st_size = avail;
>
> These lines strike me as a bit odd. As far as I'm aware, Unix systems
> don't return anything useful in this field when calling fstat on a pipe.
> Is there a reason we fill this in on Windows? If so, could the commit
> message explain what that is?
AFAICT the idea was to imitate MSVCRT's fstat() in these cases.
But a quick web search suggests that you are right:
https://bugzilla.redhat.com/show_bug.cgi?id=58768#c4 (I could not find any
official documentation talking about fstat() and pipes, but I trust Alan
to know their stuff).
Do note, please, that according to the issue described in that link, at
least *some* glibc/Linux combinations behave in exactly the way this patch
implements it.
At this point, I am wary of changing this, too, as the code in question
has been in production (read: tested thoroughly) in the current form for
*years*, and I am really loathe to introduce a bug where even
Windows-specific code in compat/ might rely on this behavior. (And no, I
do not trust our test suite to find all of those use cases.)
Ciao,
Dscho