Mail Archives: cygwin/2001/03/30/02:42:21
Thanks Mumit and Rob! The explicit test to EOF does the trick.
I replaced the direct call of the fscanf function in my code with the
following:
int readline(FILE *inputfile,char *linetxt)
{
int k;
k=fscanf(inputfile," %[^\r]",linetxt);
if ((k==0)&&(feof(inputfile)!=0)) k=EOF;
return(k);
}
This seems to work fine.
Uwe
At 02:53 PM 3/30/01 +1000, Robert Collins wrote:
>----- Original Message -----
>From: "Mumit Khan" <khan AT NanoTech DOT Wisc DOT EDU>
>To: "Uwe Pahner" <uwe DOT pahner AT esat DOT kuleuven DOT ac DOT be>
>Cc: <cygwin AT cygwin DOT com>
>Sent: Friday, March 30, 2001 2:31 PM
>Subject: Re: fscanf does not return EOF
>
>
> > On Thu, 29 Mar 2001, Uwe Pahner wrote:
> >
> > > Hi,
> > >
> >
> > I suggest portable coding, where you read the lines one by one using
> > fgets, checking for EOF, and if not, pass the line buffer it to
>sscanf.
> > Or, use fscanf, but check explicitly for eof on the stream when you
> > see a return value of 0.
> >
> > I may of course be reading the specification wrong.
> >
> > Regards,
> > Mumit
> >
>
>I think you're right: I am using fscanf in my fifo tests, and the first
>iteration was written without checking the specs:].. as soon as I ran
>man 3 fscanf on my opsnBSD machine (best man pages ever) I saw the same
>point of confusion. Coding to the spec worked fine on cygwin.
>
>Rob
--
Want to unsubscribe from this list?
Check out: http://cygwin.com/ml/#unsubscribe-simple
- Raw text -