00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046 #include <sys/types.h>
00047 #include <unistd.h>
00048 #include <errno.h>
00049 #include <stdio.h>
00050 #include <ctype.h>
00051 #include <stdlib.h>
00052 #include <string.h>
00053
00054
00055
00056
00057
00058
00059
00060
00061 #define SYSLOG_NAMES
00062 #include <syslog.h>
00063
00064
00065
00066
00067
00068 void bailout(const char *msg, const char *arg)
00069 {
00070
00071 fprintf(stderr, "logger: %s %s\n", msg, arg);
00072 exit(EXIT_FAILURE);
00073 }
00074
00075
00076
00077
00078
00079 int decode(char *name, const struct _code * codetab)
00080 {
00081 const struct _code *c;
00082
00083 if (isdigit(*name)) return(atoi(name));
00084
00085 for (c = codetab; c->c_name; c++)
00086 if (!strcasecmp(name, c->c_name)) return(c->c_val);
00087
00088 return(-1);
00089 }
00090
00091
00092
00093
00094
00095
00096 int pencode(char *s)
00097 {
00098 char *save;
00099 int fac, lev;
00100
00101 for (save = s; *s && *s != '.'; ++s);
00102 if (*s) {
00103 *s = '\0';
00104 fac = decode(save, FacNames);
00105 if (fac < 0) bailout("unknown facility name:", save);
00106 *s++ = '.';
00107 } else {
00108 fac = 0;
00109 s = save;
00110 }
00111 lev = decode(s, PriNames);
00112 if (lev < 0) bailout("unknown priority name:", save);
00113 return((lev & LOG_PRIMASK) | (fac & LOG_FACMASK));
00114 }
00115
00116
00117
00118
00119
00120 int main(int argc, char **argv)
00121 {
00122 int pri = LOG_NOTICE;
00123 int ch, logflags = 0;
00124 char *tag, buf[200];
00125 static const char usage[] =
00126 "[-i] [-f file] [-p pri] [-t tag] [ message ... ]";
00127
00128 tag = NULL;
00129 while ((ch = getopt(argc, argv, "f:ip:t:")) != EOF) {
00130 switch ((char) ch) {
00131 case 'f':
00132 if (freopen(optarg, "r", stdin) == NULL) {
00133 bailout(strerror(errno), optarg);
00134 }
00135 break;
00136 case 'i':
00137 logflags |= LOG_PID;
00138 break;
00139 case 'p':
00140 pri = pencode(optarg);
00141 break;
00142 case 't':
00143 tag = optarg;
00144 break;
00145 case '?':
00146 default: bailout(usage, ""); break;
00147 }
00148 }
00149 argc -= optind;
00150 argv += optind;
00151
00152
00153 openlog(tag ? tag : getlogin(), logflags, 0);
00154 fclose(stdout);
00155
00156 if (argc > 0) {
00157 char *p, *endp;
00158 int len;
00159
00160 for (p = buf, endp = buf + sizeof(buf) - 1;;) {
00161 len = strlen(*argv);
00162 if (p + len < endp && p > buf) {
00163 *--p = '\0';
00164 syslog(pri, buf);
00165 p = buf;
00166 }
00167 if (len > sizeof(buf) - 1) {
00168 syslog(pri, *argv++);
00169 if (!--argc) break;
00170 } else {
00171 memcpy(p, *argv++, len);
00172 p += len;
00173 if (!--argc) break;
00174 *p++ = ' ';
00175 *--p = '\0';
00176 }
00177 }
00178 if (p != buf) {
00179 *p = '\0';
00180 syslog(pri, buf);
00181 }
00182 } else
00183 while (fgets(buf, sizeof(buf), stdin) != NULL) syslog(pri, buf);
00184
00185 return EXIT_SUCCESS;
00186 }
00187