ubase/dmesg.c

85 lines
1.4 KiB
C
Raw Normal View History

2013-08-06 19:08:41 +00:00
/* See LICENSE file for copyright and license details. */
#include <sys/klog.h>
2013-08-06 19:08:41 +00:00
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "grabmntinfo.h"
2013-08-06 19:08:41 +00:00
#include "util.h"
static int dmesg_show(int fd, const void *buf, size_t n);
enum {
SYSLOG_ACTION_READ_ALL = 3,
2013-08-14 13:34:57 +00:00
SYSLOG_ACTION_CLEAR = 5,
SYSLOG_ACTION_SIZE_BUFFER = 10
};
2013-08-06 19:08:41 +00:00
static void
usage(void)
{
2013-08-14 13:34:57 +00:00
eprintf("usage: [-C] %s\n", argv0);
2013-08-06 19:08:41 +00:00
}
int
main(int argc, char *argv[])
{
int n;
char *buf;
ARGBEGIN {
2013-08-14 13:34:57 +00:00
case 'C':
if (klogctl(SYSLOG_ACTION_CLEAR, NULL, 0) < 0)
eprintf("klogctl:");
return 0;
2013-08-06 19:08:41 +00:00
default:
usage();
} ARGEND;
n = klogctl(SYSLOG_ACTION_SIZE_BUFFER, NULL, 0);
2013-08-06 19:08:41 +00:00
if (n < 0)
eprintf("klogctl:");
2013-08-12 10:29:21 +00:00
2013-08-06 19:08:41 +00:00
buf = malloc(n);
if (!buf)
eprintf("malloc:");
2013-08-12 10:29:21 +00:00
n = klogctl(SYSLOG_ACTION_READ_ALL, buf, n);
2013-08-06 19:08:41 +00:00
if (n < 0)
eprintf("klogctl:");
2013-08-12 10:29:21 +00:00
n = dmesg_show(STDOUT_FILENO, buf, n);
2013-08-09 18:05:38 +00:00
if (n < 0)
eprintf("dmesg_show:");
2013-08-12 10:29:21 +00:00
2013-08-06 19:08:41 +00:00
free(buf);
return 0;
}
static int
dmesg_show(int fd, const void *buf, size_t n)
{
int last = '\n';
char newbuf[n], *q = newbuf;
const char *p = buf;
size_t i;
memset(newbuf, 0, n);
for (i = 0; i < n; ) {
if (last == '\n' && p[i] == '<') {
i += 2;
if (i + 1 < n && p[i + 1] == '>')
i++;
} else {
*q++ = p[i];
}
last = p[i++];
}
if (write(fd, newbuf, n) != n)
return -1;
if (last != '\n')
if (write(fd, "\n", 1) != 1)
return -1;
return 0;
}