freebsd-nq/eBones/krb/fgetst.c

40 lines
1.1 KiB
C
Raw Normal View History

/*
* Copyright 1987, 1988 by the Massachusetts Institute of Technology.
* For copying and distribution information, please see the file
* <Copyright.MIT>.
*
* from: fgetst.c,v 4.0 89/01/23 10:08:31 jtkohl Exp $
* $Id: fgetst.c,v 1.2 1994/07/19 19:25:10 g89r4222 Exp $
*/
#ifndef lint
static char rcsid[] =
"$Id: fgetst.c,v 1.2 1994/07/19 19:25:10 g89r4222 Exp $";
#endif /* lint */
#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
* returns the number of characters read, including the null terminator.
*/
fgetst(f, s, n)
FILE *f;
register char *s;
int n;
{
register count = n;
int ch; /* NOT char; otherwise you don't see EOF */
while ((ch = getc(f)) != EOF && ch && --count) {
*s++ = ch;
}
*s = '\0';
return (n - count);
}