mirror of
https://github.com/freebsd/freebsd-src
synced 2024-10-14 20:37:06 +00:00
tail: Fix -f with stdin
Based on a patch from swills@. MFC after: 2 weeks Differential Revision: https://reviews.freebsd.org/D31113
This commit is contained in:
parent
02508a3d4e
commit
7e11889959
|
@ -56,7 +56,7 @@ struct mapinfo {
|
|||
|
||||
struct file_info {
|
||||
FILE *fp;
|
||||
char *file_name;
|
||||
const char *file_name;
|
||||
struct stat st;
|
||||
};
|
||||
|
||||
|
|
|
@ -67,8 +67,6 @@ static const char sccsid[] = "@(#)tail.c 8.1 (Berkeley) 6/6/93";
|
|||
int Fflag, fflag, qflag, rflag, rval, no_files;
|
||||
fileargs_t *fa;
|
||||
|
||||
static file_info_t *files;
|
||||
|
||||
static void obsolete(char **);
|
||||
static void usage(void);
|
||||
|
||||
|
@ -88,8 +86,8 @@ main(int argc, char *argv[])
|
|||
FILE *fp;
|
||||
off_t off;
|
||||
enum STYLE style;
|
||||
int i, ch, first;
|
||||
file_info_t *file;
|
||||
int ch, first;
|
||||
file_info_t file, *filep, *files;
|
||||
char *p;
|
||||
cap_rights_t rights;
|
||||
|
||||
|
@ -206,30 +204,24 @@ main(int argc, char *argv[])
|
|||
}
|
||||
|
||||
if (*argv && fflag) {
|
||||
files = (struct file_info *) malloc(no_files *
|
||||
sizeof(struct file_info));
|
||||
if (!files)
|
||||
files = malloc(no_files * sizeof(struct file_info));
|
||||
if (files == NULL)
|
||||
err(1, "Couldn't malloc space for file descriptors.");
|
||||
|
||||
for (file = files; (fn = *argv++); file++) {
|
||||
file->file_name = strdup(fn);
|
||||
if (! file->file_name)
|
||||
errx(1, "Couldn't malloc space for file name.");
|
||||
file->fp = fileargs_fopen(fa, file->file_name, "r");
|
||||
if (file->fp == NULL ||
|
||||
fstat(fileno(file->fp), &file->st)) {
|
||||
if (file->fp != NULL) {
|
||||
fclose(file->fp);
|
||||
file->fp = NULL;
|
||||
for (filep = files; (fn = *argv++); filep++) {
|
||||
filep->file_name = fn;
|
||||
filep->fp = fileargs_fopen(fa, filep->file_name, "r");
|
||||
if (filep->fp == NULL ||
|
||||
fstat(fileno(filep->fp), &filep->st)) {
|
||||
if (filep->fp != NULL) {
|
||||
fclose(filep->fp);
|
||||
filep->fp = NULL;
|
||||
}
|
||||
if (!Fflag || errno != ENOENT)
|
||||
ierr(file->file_name);
|
||||
ierr(filep->file_name);
|
||||
}
|
||||
}
|
||||
follow(files, style, off);
|
||||
for (i = 0, file = files; i < no_files; i++, file++) {
|
||||
free(file->file_name);
|
||||
}
|
||||
free(files);
|
||||
} else if (*argv) {
|
||||
for (first = 1; (fn = *argv++);) {
|
||||
|
@ -266,10 +258,15 @@ main(int argc, char *argv[])
|
|||
fflag = 0; /* POSIX.2 requires this. */
|
||||
}
|
||||
|
||||
if (rflag)
|
||||
if (rflag) {
|
||||
reverse(stdin, fn, style, off, &sb);
|
||||
else
|
||||
} else if (fflag) {
|
||||
file.file_name = fn;
|
||||
file.fp = stdin;
|
||||
follow(&file, style, off);
|
||||
} else {
|
||||
forward(stdin, fn, style, off, &sb);
|
||||
}
|
||||
}
|
||||
fileargs_free(fa);
|
||||
exit(rval);
|
||||
|
|
Loading…
Reference in a new issue