From 7d28c089b45d465b18df1c5cda72abed3748118f Mon Sep 17 00:00:00 2001 From: Thorsten Töpper Date: Mon, 10 Jan 2011 20:02:33 +0100 Subject: Aufgabe 2: main.c, log.c und conv.c ausgebaut. MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * main.c: Öffnen der Pipes * conv.c: Pseudozufallszahlen, schreiben in die Pipes zum log und statistic Prozess * log.c: log() implementiert --- aufgabe2/log.c | 39 +++++++++++++++++++++++++++++++++++++-- 1 file changed, 37 insertions(+), 2 deletions(-) (limited to 'aufgabe2/log.c') 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 #include #include +#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); } -- cgit v1.2.3-70-g09d2