diff options
Diffstat (limited to 'toys/pending/logger.c')
-rw-r--r-- | toys/pending/logger.c | 64 |
1 files changed, 0 insertions, 64 deletions
diff --git a/toys/pending/logger.c b/toys/pending/logger.c deleted file mode 100644 index 8a458b58..00000000 --- a/toys/pending/logger.c +++ /dev/null @@ -1,64 +0,0 @@ -/* logger.c - Log messages. - * - * Copyright 2013 Ilya Kuzmich <ilya.kuzmich@gmail.com> - * - * See http://pubs.opengroup.org/onlinepubs/9699919799/utilities/logger.html - -USE_LOGGER(NEWTOY(logger, "st:p:", TOYFLAG_USR|TOYFLAG_BIN)) - -config LOGGER - bool "logger" - default n - help - usage: logger [-s] [-t tag] [-p [facility.]priority] [message] - - Log message (or stdin) to syslog. -*/ - -#define FOR_logger -#include "toys.h" - -GLOBALS( - char *priority; - char *ident; -) - -void logger_main(void) -{ - int facility = LOG_USER, priority = LOG_NOTICE, len; - char *s1, *s2, **arg; - CODE *code; - - if (!TT.ident) TT.ident = xstrdup(xgetpwuid(geteuid())->pw_name); - if (toys.optflags & FLAG_p) { - if (!(s1 = strchr(TT.priority, '.'))) s1 = TT.priority; - else { - *s1++ = 0; - for (code = facilitynames; code->c_name; code++) - if (!strcasecmp(TT.priority, code->c_name)) break; - if (!code->c_name) error_exit("bad facility: %s", TT.priority); - facility = code->c_val; - } - - for (code = prioritynames; code->c_name; code++) - if (!strcasecmp(s1, code->c_name)) break; - if (!code->c_name) error_exit("bad priority: %s", s1); - } - - - if (toys.optc) { - for (len = 0, arg = toys.optargs; *arg; arg++) len += strlen(*arg)+1; - s1 = s2 = xmalloc(len); - for (arg = toys.optargs; *arg; arg++) { - if (arg != toys.optargs) *s2++ = ' '; - s2 = stpcpy(s2, *arg); - } - } else { - toybuf[readall(0, toybuf, sizeof(toybuf)-1)] = 0; - s1 = toybuf; - } - - openlog(TT.ident, LOG_PERROR*!!(toys.optflags&FLAG_s), facility); - syslog(priority, "%s", s1); - closelog(); -} |