aboutsummaryrefslogtreecommitdiff
path: root/aufgabe3/log.c
blob: 88a394d5792eae71333319de90ea184b3b03e7a5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/*
 * vim:ts=4:sw=4:expandtab
 *
 */
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>

#include "queue.h"

FILE *logfile;
char *message;

void logmsg() {
    int random_number = 0;
    mqd_t log;

    /* Message Queue zur Kommunikation mit dem conv Prozess öffnen.
     */
    if ((log = mq_open(MQ_TO_LOG, O_RDONLY)) == -1) {
        perror("logmsg() mq_open");
        exit(EXIT_FAILURE);
    }

    /* Logdatei öffnen */
    if ((logfile = fopen("logfile.txt", "w")) == NULL) {
        perror("logmsg() fopen");
        exit(EXIT_FAILURE);
    }

    /*
     * Speicher für Nachricht allokieren.
     */
    if ((message = calloc(1, MQ_MSG_SIZE_RCV)) == NULL) {
        perror("logmsg()");
        exit(EXIT_FAILURE);
    }

    for (;;) {

        /* Nachricht über log Queue empfangen */
        if (mq_receive(log, message, MQ_MSG_SIZE_RCV, NULL) == -1) {
            perror("logmsg() mq_receive");
            exit(EXIT_FAILURE);
        }

        /* Zufallszahl aus dem String zurück zur Dezimalzahl konvertieren */
        sscanf(message, "%x", &random_number);

        /* Die konvertierte Zahl in die Log datei schreiben */
        fprintf(logfile, "%d\n", random_number);

    }
}

void logmsg_cleanup() {
    printf("log cleanup\n");
    free(message);
    mq_unlink(MQ_TO_LOG);
    fclose(logfile);
    _exit(EXIT_SUCCESS);
}