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);
}
|