logger: add support for -I PID to log, e.g., $$ from a shell script
Signed-off-by: Joachim Wiberg <troglobit@gmail.com>
This commit is contained in:
@@ -238,6 +238,7 @@ static int usage(int code)
|
||||
" -h HOST Send (UDP) message to this remote syslog server (IP or DNS name)\n"
|
||||
" -H NAME Use NAME instead of system hostname in message header\n"
|
||||
" -i Log process ID of the logger process with each line (LOG_PID)\n"
|
||||
" -I PID Log process ID using PID, recommed using PID $$ for shell scripts\n"
|
||||
#ifdef __linux__
|
||||
" -k Log to kernel /dev/kmsg if /dev/log doesn't exist yet\n"
|
||||
#endif
|
||||
@@ -278,7 +279,7 @@ int main(int argc, char *argv[])
|
||||
int c, num = 5;
|
||||
int rotate = 0;
|
||||
|
||||
while ((c = getopt(argc, argv, "46?bcd:f:h:H:ikm:np:P:r:st:u:v")) != EOF) {
|
||||
while ((c = getopt(argc, argv, "46?bcd:f:h:H:iI:km:np:P:r:st:u:v")) != EOF) {
|
||||
switch (c) {
|
||||
case '4':
|
||||
family = AF_INET;
|
||||
@@ -316,6 +317,11 @@ int main(int argc, char *argv[])
|
||||
log_opts |= LOG_PID;
|
||||
break;
|
||||
|
||||
case 'I':
|
||||
log_opts |= LOG_PID;
|
||||
log.log_pid = atoi(optarg);
|
||||
break;
|
||||
|
||||
case 'k':
|
||||
#ifdef __linux__
|
||||
allow_kmsg = 1;
|
||||
|
@@ -299,7 +299,9 @@ vsyslogp_r(int pri, struct syslog_data *data, const char *msgid,
|
||||
DEC();
|
||||
|
||||
if (data->log_stat & LOG_PID) {
|
||||
prlen = snprintf(p, tbuf_left, "[%d]", getpid());
|
||||
if (data->log_pid == -1)
|
||||
data->log_pid = getpid();
|
||||
prlen = snprintf(p, tbuf_left, "[%d]", data->log_pid);
|
||||
DEC();
|
||||
}
|
||||
strlcat(p, ":", tbuf_left);
|
||||
@@ -368,7 +370,9 @@ vsyslogp_r(int pri, struct syslog_data *data, const char *msgid,
|
||||
DEC();
|
||||
|
||||
if (data->log_stat & LOG_PID) {
|
||||
prlen = snprintf(p, tbuf_left, "%d ", getpid());
|
||||
if (data->log_pid == -1)
|
||||
data->log_pid = getpid();
|
||||
prlen = snprintf(p, tbuf_left, "%d ", data->log_pid);
|
||||
if (data->log_stat & (LOG_PERROR|LOG_CONS|LOG_NLOG)) {
|
||||
iov[iovcnt].iov_base = __UNCONST("[");
|
||||
iov[iovcnt].iov_len = 1;
|
||||
|
@@ -208,6 +208,7 @@ struct syslog_data {
|
||||
int log_fac;
|
||||
int log_mask;
|
||||
void *log_host; /* struct sockaddr* */
|
||||
int log_pid;
|
||||
};
|
||||
|
||||
#define SYSLOG_DATA_INIT { \
|
||||
@@ -222,6 +223,7 @@ struct syslog_data {
|
||||
.log_fac = LOG_USER, \
|
||||
.log_mask = 0xff, \
|
||||
.log_host = NULL, \
|
||||
.log_pid = -1, \
|
||||
}
|
||||
|
||||
#ifdef __cplusplus
|
||||
|
Reference in New Issue
Block a user