Added new tool (readbootlog) which will read the /var/log/boot file
produced by bootlogd. The output is displayed cleaned up so there are no control characters. This avoids the need to use sed or related tools to try to clean up the contents of the log.
This commit is contained in:
parent
aa6873b85b
commit
7c1a8d932a
@ -137,7 +137,7 @@ shutdown: LDLIBS += $(STATIC)
|
|||||||
shutdown: dowall.o shutdown.o utmp.o
|
shutdown: dowall.o shutdown.o utmp.o
|
||||||
|
|
||||||
bootlogd: LDLIBS += -lutil $(STATIC)
|
bootlogd: LDLIBS += -lutil $(STATIC)
|
||||||
bootlogd: bootlogd.o
|
bootlogd: bootlogd.o bootlogd.h
|
||||||
|
|
||||||
fstab-decode: LDLIBS += $(STATIC)
|
fstab-decode: LDLIBS += $(STATIC)
|
||||||
fstab-decode: fstab-decode.o
|
fstab-decode: fstab-decode.o
|
||||||
|
@ -53,10 +53,8 @@
|
|||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
#include <sys/mount.h>
|
#include <sys/mount.h>
|
||||||
#endif
|
#endif
|
||||||
|
#include "bootlogd.h"
|
||||||
|
|
||||||
char *Version = "@(#) bootlogd 2.86 03-Jun-2004 miquels@cistron.nl";
|
|
||||||
|
|
||||||
#define LOGFILE "/var/log/boot"
|
|
||||||
#define MAX_CONSOLES 16
|
#define MAX_CONSOLES 16
|
||||||
|
|
||||||
char ringbuf[32768];
|
char ringbuf[32768];
|
||||||
@ -508,7 +506,7 @@ int main(int argc, char **argv)
|
|||||||
rotate = 1;
|
rotate = 1;
|
||||||
break;
|
break;
|
||||||
case 'v':
|
case 'v':
|
||||||
printf("%s\n", Version);
|
printf("bootlogd - %s\n", VERSION);
|
||||||
exit(0);
|
exit(0);
|
||||||
break;
|
break;
|
||||||
case 'p':
|
case 'p':
|
||||||
|
12
src/bootlogd.h
Normal file
12
src/bootlogd.h
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
#ifndef LOGFILE
|
||||||
|
#define LOGFILE "/var/log/boot"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef TRUE
|
||||||
|
#define TRUE 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef FALSE
|
||||||
|
#define FALSE 0
|
||||||
|
#endif
|
||||||
|
|
101
src/readbootlog.c
Normal file
101
src/readbootlog.c
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include "bootlogd.h"
|
||||||
|
|
||||||
|
#ifndef MAX_LINE
|
||||||
|
#define MAX_LINE 256
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void print_usage()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
Clean up the unwanted characters from a line of input.
|
||||||
|
Cleaned line is passed back in output_line.
|
||||||
|
Returns TRUE on success or FALSE if we encounter an error.
|
||||||
|
*/
|
||||||
|
int Clean_Line(char *source_line, char *output_line)
|
||||||
|
{
|
||||||
|
int source_index = 0, target_index = 0;
|
||||||
|
int source_max_index;
|
||||||
|
char a_letter;
|
||||||
|
int done;
|
||||||
|
char *garbage;
|
||||||
|
|
||||||
|
if (! source_line) return FALSE;
|
||||||
|
if (! output_line) return FALSE;
|
||||||
|
|
||||||
|
source_max_index = strlen(source_line);
|
||||||
|
while (source_index < source_max_index)
|
||||||
|
{
|
||||||
|
a_letter = source_line[source_index];
|
||||||
|
if (a_letter == '^')
|
||||||
|
{
|
||||||
|
/* skip ahead until we find a valid place to stop */
|
||||||
|
done = FALSE;
|
||||||
|
while (! done)
|
||||||
|
{
|
||||||
|
source_index++;
|
||||||
|
if (source_index >= source_max_index)
|
||||||
|
done = TRUE;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
a_letter = source_line[source_index];
|
||||||
|
if ( (a_letter == '.') || (a_letter == ' ') ||
|
||||||
|
(a_letter == '(') || (a_letter == 'd') ||
|
||||||
|
(a_letter == '\n') )
|
||||||
|
done = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} /* done found character to scrub */
|
||||||
|
else
|
||||||
|
{
|
||||||
|
output_line[target_index] = a_letter;
|
||||||
|
target_index++;
|
||||||
|
source_index++;
|
||||||
|
} /* found valid character */
|
||||||
|
} /* done processing line */
|
||||||
|
|
||||||
|
garbage = strstr(output_line, " .\n");
|
||||||
|
if (garbage)
|
||||||
|
{
|
||||||
|
garbage[0] = '\n';
|
||||||
|
garbage[1] = '\0';
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
FILE *log_file = NULL;
|
||||||
|
char *log_filename = LOGFILE;
|
||||||
|
char line[MAX_LINE];
|
||||||
|
char output[MAX_LINE];
|
||||||
|
char *status;
|
||||||
|
|
||||||
|
log_file = fopen(log_filename, "r");
|
||||||
|
if (log_file)
|
||||||
|
{
|
||||||
|
status = fgets(line, MAX_LINE, log_file);
|
||||||
|
while (status)
|
||||||
|
{
|
||||||
|
memset(output, '\0', MAX_LINE);
|
||||||
|
if ( Clean_Line(line, output) )
|
||||||
|
{
|
||||||
|
printf("%s", output);
|
||||||
|
}
|
||||||
|
status = fgets(line, MAX_LINE, log_file);
|
||||||
|
} /* done reading file lines */
|
||||||
|
fclose(log_file);
|
||||||
|
} /* end of successfully opened log file */
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fprintf(stderr, "Unable to open file %s\n", log_filename);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user