--- ray/src/common/fgetline.c 2003/06/27 06:53:21 2.4 +++ ray/src/common/fgetline.c 2016/03/04 00:21:21 2.9 @@ -1,5 +1,5 @@ #ifndef lint -static const char RCSid[] = "$Id: fgetline.c,v 2.4 2003/06/27 06:53:21 greg Exp $"; +static const char RCSid[] = "$Id: fgetline.c,v 2.9 2016/03/04 00:21:21 greg Exp $"; #endif /* * fgetline.c - read line with escaped newlines. @@ -13,22 +13,25 @@ static const char RCSid[] = "$Id: fgetline.c,v 2.4 200 char * -fgetline(s, n, fp) /* read in line with escapes, elide final newline */ -char *s; -int n; -register FILE *fp; +fgetline( /* read in line with escapes, elide final newline */ + char *s, + int n, + FILE *fp +) { - register char *cp = s; - register int c = EOF; + char *cp = s; + int c = EOF; while (--n > 0 && (c = getc(fp)) != EOF) { - if (c == '\r') - continue; + if (c == '\r' && (c = getc(fp)) != '\n') { + ungetc(c, fp); /* must be Apple file */ + c = '\n'; + } if (c == '\n' && (cp == s || cp[-1] != '\\')) break; *cp++ = c; } - if (cp == s && c == EOF) + if ((cp == s) & (c == EOF)) return(NULL); *cp = '\0'; return(s);