blob: 6bd14263ec415b7db255026c1593febb33093e83 (
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
|
#include "match.h"
#include <stdlib.h>
#include <string.h>
struct leg *leg_init(int points, char *name)
{
struct leg *l = calloc(1, sizeof(*l));
l->name = name;
l->start = l->rem = points;
l->size_visits = 16;
l->visits = calloc(l->size_visits, sizeof(*(l->visits)));
return l;
}
void leg_free(struct leg *l)
{
for (int i = 0; i < l->n_visits; ++i) {
if (l->visits[i].darts)
free(l->visits[i].darts);
if (l->visits[i].ccoords)
free(l->visits[i].ccoords);
}
free(l->visits);
free(l);
}
void leg_grow_visits(struct leg *l)
{
size_t bytes = l->size_visits * sizeof(*(l->visits));
l->size_visits *= 2;
l->visits = realloc(l->visits, 2 * bytes);
memset((char *)l->visits + bytes, 0, bytes);
}
|