1994-09-30 14:50:09 +00:00
|
|
|
/*
|
1995-05-30 06:41:30 +00:00
|
|
|
* Copyright 1987, 1988 by the Massachusetts Institute of Technology.
|
1994-09-30 14:50:09 +00:00
|
|
|
* For copying and distribution information, please see the file
|
1995-05-30 06:41:30 +00:00
|
|
|
* <Copyright.MIT>.
|
1994-09-30 14:50:09 +00:00
|
|
|
*
|
|
|
|
* from: fgetst.c,v 4.0 89/01/23 10:08:31 jtkohl Exp $
|
1995-08-25 22:52:32 +00:00
|
|
|
* $Id: fgetst.c,v 1.3 1995/07/18 16:38:23 mark Exp $
|
1994-09-30 14:50:09 +00:00
|
|
|
*/
|
|
|
|
|
1995-08-25 22:52:32 +00:00
|
|
|
#if 0
|
1994-09-30 14:50:09 +00:00
|
|
|
#ifndef lint
|
|
|
|
static char rcsid[] =
|
1995-08-25 22:52:32 +00:00
|
|
|
"$Id: fgetst.c,v 1.3 1995/07/18 16:38:23 mark Exp $";
|
1994-09-30 14:50:09 +00:00
|
|
|
#endif /* lint */
|
1995-08-25 22:52:32 +00:00
|
|
|
#endif
|
1994-09-30 14:50:09 +00:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
/*
|
|
|
|
* fgetst takes a file descriptor, a character pointer, and a count.
|
|
|
|
* It reads from the file it has either read "count" characters, or
|
|
|
|
* until it reads a null byte. When finished, what has been read exists
|
|
|
|
* in "s". If "count" characters were actually read, the last is changed
|
|
|
|
* to a null, so the returned string is always null-terminated. fgetst
|
1995-05-30 06:41:30 +00:00
|
|
|
* returns the number of characters read, including the null terminator.
|
1994-09-30 14:50:09 +00:00
|
|
|
*/
|
|
|
|
|
1995-09-07 21:39:00 +00:00
|
|
|
int
|
|
|
|
fgetst(f, s, n)
|
|
|
|
FILE *f;
|
|
|
|
register char *s;
|
|
|
|
int n;
|
1994-09-30 14:50:09 +00:00
|
|
|
{
|
1995-09-07 21:39:00 +00:00
|
|
|
register int count = n;
|
1994-09-30 14:50:09 +00:00
|
|
|
int ch; /* NOT char; otherwise you don't see EOF */
|
|
|
|
|
|
|
|
while ((ch = getc(f)) != EOF && ch && --count) {
|
|
|
|
*s++ = ch;
|
|
|
|
}
|
|
|
|
*s = '\0';
|
|
|
|
return (n - count);
|
|
|
|
}
|