-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathbymark.c
108 lines (87 loc) · 1.76 KB
/
bymark.c
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
struct mark_weight
{
int mark;
double w;
};
struct bymark
{
size_t module_number;
size_t nmarks;
struct mark_weight *mw;
};
void *
bymark_init(struct userdata *u, size_t n)
{
struct bymark *data;
data = malloc(sizeof(struct bymark));
if (!data) {
fprintf(stderr, "Module %s: malloc(%lu) failed\n",
modules[n].name, (long)sizeof(struct bymark));
goto fail_alloc;
}
data->nmarks = 0;
data->mw = NULL;
data->module_number = n;
return data;
fail_alloc:
return NULL;
}
void
bymark_conf(void *arg, char *param1, char *param2)
{
struct bymark *data = arg;
int mark;
double weight;
struct mark_weight *tmp_mw;
mark = strtol(param1, NULL, 10);
if (errno) {
fprintf(stderr, "Module %s: can't convert '%s' (mark) to integer \n",
modules[data->module_number].name,
param1);
mark = 0;
}
weight = strtod(param2, NULL);
if (errno) {
fprintf(stderr, "Module %s: can't convert '%s' (mark weight) to double \n",
modules[data->module_number].name,
param2);
}
data->nmarks++;
tmp_mw = realloc(data->mw, sizeof(struct mark_weight) * data->nmarks);
if (!tmp_mw) {
fprintf(stderr, "Module %s: realloc() failed\n", modules[data->module_number].name);
free(data->mw);
data->mw = NULL;
data->nmarks = 0;
return; /* FIXME: return error? */
}
data->mw = tmp_mw;
data->mw[data->nmarks - 1].mark = mark;
data->mw[data->nmarks - 1].w = weight;
}
int
bymark_postconf(void *arg)
{
return 1;
}
void
bymark_free(void *arg)
{
struct bymark *data = arg;
free(data->mw);
free(data);
}
double
bymark_weight(void *arg, char *packet, int packetlen, int mark)
{
unsigned int i;
struct bymark *data = arg;
double m = DBL_EPSILON;
for (i=0; i<data->nmarks; i++) {
if (mark == data->mw[i].mark) {
m = data->mw[i].w;
break;
}
}
return m;
}