This is the mail archive of the
cygwin
mailing list for the Cygwin project.
RE: cygwin fork()
- From: "Dave Korn" <dave dot korn at artimi dot com>
- To: <cygwin at cygwin dot com>
- Date: Fri, 1 Sep 2006 18:57:10 +0100
- Subject: RE: cygwin fork()
On 01 September 2006 18:47, clayne@anodized.HIPPO wrote:
> I found the real culprit, which I had also ifdef'd out because it looked
> bogus and crufty:
>
> /* Return 1 if a seek on FD will succeed. */
> #ifndef __CYGWIN__
> # define fd_is_seekable(fd) (lseek ((fd), 0L, SEEK_CUR) >= 0)
> #else
> # define fd_is_seekable(fd) 0
> #endif /* __CYGWIN__ */
Yeeesh. This is a terrible way of dealing with the fact that you can't seek
a stream accurately if you open it in text mode, because of the ambiguity
about whether you've advanced one or two chars through the underlying file
when you see an LF that could perhaps have actually been a CR/LF. What we
really want is
#define fd_is_seekable(fd) fd_is_in_binary_not_text_mode(fd)
...although of course I'm paraphrasing there.
Anyway, congratulations, well tracked down! Definitely one to raise with
upstream...
cheers,
DaveK
--
Can't think of a witty .sigline today....
--
Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple
Problem reports: http://cygwin.com/problems.html
Documentation: http://cygwin.com/docs.html
FAQ: http://cygwin.com/faq/