git: 7e863cb9893b - stable/11 - newsyslog(8): Implement a new 'E' flag to not rotate empty log files

Juraj Lutter otis at FreeBSD.org
Sun May 23 13:40:50 UTC 2021


The branch stable/11 has been updated by otis (ports committer):

URL: https://cgit.FreeBSD.org/src/commit/?id=7e863cb9893b96f4ca6e0597572e3df218dd3830

commit 7e863cb9893b96f4ca6e0597572e3df218dd3830
Author:     Juraj Lutter <otis at FreeBSD.org>
AuthorDate: 2021-02-28 22:07:14 +0000
Commit:     Juraj Lutter <otis at FreeBSD.org>
CommitDate: 2021-05-23 13:35:51 +0000

    newsyslog(8): Implement a new 'E' flag to not rotate empty log files
    
    Based on an idea from dvl's coworker, László DANIELISZ, implement
    a new flag, 'E', that prevents newsyslog(8) from rotating the empty
    log files. This 'E' flag ist mostly usable in conjunction with 'B'
    flag that instructs newsyslog(8) to not insert an informational
    message into the log file after rotation, keeping it still empty.
    
    Reviewed by:    markj, ian, manpages (rpokala)
    Approved by:    markj, ian, manpages (rpokala)
    MFC after:      2 weeks
    Differential Revision:  https://reviews.freebsd.org/D28940
    
    (cherry picked from commit c7d27b225df8d7fb36a31a21737d4309593c4604)
---
 usr.sbin/newsyslog/newsyslog.c      | 11 ++++++++++-
 usr.sbin/newsyslog/newsyslog.conf.5 | 14 +++++++++++++-
 2 files changed, 23 insertions(+), 2 deletions(-)

diff --git a/usr.sbin/newsyslog/newsyslog.c b/usr.sbin/newsyslog/newsyslog.c
index d850b0af9f53..c20a36cf31c0 100644
--- a/usr.sbin/newsyslog/newsyslog.c
+++ b/usr.sbin/newsyslog/newsyslog.c
@@ -129,7 +129,8 @@ __FBSDID("$FreeBSD$");
 #define	CE_PID2CMD	0x0400	/* Replace PID file with a shell command.*/
 #define	CE_PLAIN0	0x0800	/* Do not compress zero'th history file */
 #define	CE_RFC5424	0x1000	/* Use RFC5424 format rotation message */
-
+#define CE_NOEMPTY	0x2000	/* Do not rotate the file when its size */
+				/* is zero */
 #define	MIN_PID         5	/* Don't touch pids lower than this */
 #define	MAX_PID		99999	/* was lower, see /usr/include/sys/proc.h */
 
@@ -538,6 +539,11 @@ do_entry(struct conf_entry * ent)
 			printf("does not exist, skipped%s.\n", temp_reason);
 		}
 	} else {
+		if (ent->flags & CE_NOEMPTY && ent->fsize == 0) {
+			if (verbose)
+				printf("--> Not rotating empty file\n");
+			return (free_or_keep);
+		}
 		if (ent->flags & CE_TRIMAT && !force && !rotatereq &&
 		    !oversized) {
 			diffsecs = ptimeget_diff(timenow, ent->trim_at);
@@ -1292,6 +1298,9 @@ no_trimat:
 			case 'd':
 				working->flags |= CE_NODUMP;
 				break;
+			case 'e':
+				working->flags |= CE_NOEMPTY;
+				break;
 			case 'g':
 				working->flags |= CE_GLOB;
 				break;
diff --git a/usr.sbin/newsyslog/newsyslog.conf.5 b/usr.sbin/newsyslog/newsyslog.conf.5
index e307375c766e..ec21cfdaca2a 100644
--- a/usr.sbin/newsyslog/newsyslog.conf.5
+++ b/usr.sbin/newsyslog/newsyslog.conf.5
@@ -21,7 +21,7 @@
 .\" the suitability of this software for any purpose.  It is
 .\" provided "as is" without express or implied warranty.
 .\"
-.Dd January 15, 2018
+.Dd February 26, 2021
 .Dt NEWSYSLOG.CONF 5
 .Os
 .Sh NAME
@@ -281,6 +281,18 @@ this log file.
 This option would affect how the
 .Xr dump 8
 command treats the log file when making a file system backup.
+.It Cm E
+indicates that the log file should not be rotated when its
+size is zero.
+The
+.Cm E
+flag is mostly useful in conjunction with
+.Cm B
+flag to prevent
+.Xr newsyslog 8
+from inserting an informational 
+.Tn ASCII
+message into the new file.
 .It Cm G
 indicates that the specified
 .Ar logfile_name


More information about the dev-commits-src-all mailing list