diff options
Diffstat (limited to 'aufgabe2/log.c')
| -rw-r--r-- | aufgabe2/log.c | 39 |
1 files changed, 37 insertions, 2 deletions
diff --git a/aufgabe2/log.c b/aufgabe2/log.c index 405cdbd..96b2a4f 100644 --- a/aufgabe2/log.c +++ b/aufgabe2/log.c @@ -1,18 +1,53 @@ /* * vim:ts=4:sw=4:expandtab - * + * */ #include <stdlib.h> #include <stdio.h> #include <unistd.h> +#include "queue.h" + +FILE *pipe_conv; +FILE *logfile; +char *message; + void log() { + int buffer; printf("log started\n"); - for (;;) { + + /* Die Pipe zum lesen öffnen */ + if ((pipe_conv = fdopen(queue[D_CONV_TO_LOG][READ], "r")) == NULL) { + perror("log.c fdopen()"); + exit(EXIT_FAILURE); + } + + /* Logdatei öffnen */ + if ((logfile = fopen("logfile.txt", "w")) == NULL) { + perror("log.c fopen()"); + exit(EXIT_FAILURE); + } + + /* Speicher für Nachricht reservieren */ + if ((message = calloc(1, sizeof(char)*SIZE_HEX+1)) == NULL) { + perror("log.c calloc()"); + exit(EXIT_FAILURE); + } + + /* Nachricht aus der Pipe lesen, als Endian abhängiger + * HEX-Wert in die Log Datei schreiben. Für portable + * Rückkonvertierung ins Dezimalsystem siehe Aufgabe 3. + */ + while (fgets(message, SIZE_HEX+1, pipe_conv)) { + fputs(message, logfile); } } void log_cleanup() { printf("log cleanup\n"); + fclose(logfile); + fclose(pipe_conv); + free(message); + close(queue[D_CONV_TO_LOG][READ]); _exit(EXIT_SUCCESS); } |
