Better handle the -F case:
o When stat(2) fails (i.e. the file has been moved) there's no new file with the same name yet, so keep showing the file that's open. This yields the same behaviour as -f, for which we don't stat(2). o When a new file with the same name has been created (i.e stat(2) succeeds but the inode or device numbers differ from the opened file), show any new lines in the opened file (i.e. the old or rotated file) before reopening the new file. These changes fix the observed behaviour that tail(1) doesn't show the very last lines of the rotated (log) files. PR: bin/101979 Tested by: Jos Backus <jos@catnook.com> MFC after: 2 months
This commit is contained in:
parent
d56108a43a
commit
d5d2cea180
@ -348,13 +348,11 @@ follow(file_info_t *files, enum STYLE style, off_t off)
|
||||
if (! file->fp)
|
||||
continue;
|
||||
if (Fflag && file->fp && fileno(file->fp) != STDIN_FILENO) {
|
||||
if (stat(file->file_name, &sb2) != 0) {
|
||||
/* file was rotated, skip it until it reappears */
|
||||
continue;
|
||||
}
|
||||
if (sb2.st_ino != file->st.st_ino ||
|
||||
sb2.st_dev != file->st.st_dev ||
|
||||
sb2.st_nlink == 0) {
|
||||
if (stat(file->file_name, &sb2) == 0 &&
|
||||
(sb2.st_ino != file->st.st_ino ||
|
||||
sb2.st_dev != file->st.st_dev ||
|
||||
sb2.st_nlink == 0)) {
|
||||
show(file);
|
||||
file->fp = freopen(file->file_name, "r", file->fp);
|
||||
if (file->fp == NULL) {
|
||||
ierr();
|
||||
|
Loading…
x
Reference in New Issue
Block a user