blob: 8b200d8bb5b9f215c27fcf42b2417d4aefa0a04e (
plain)
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
|
static void allocr_test(void) {
Allocator a;
allocr_create(&a);
for (int x = 1000; x <= 8000; x += 1000) {
int nfoos = x;
int *foos = allocr_malloc(&a, (size_t)nfoos * sizeof(int));
for (int i = 0; i < nfoos; i++)
foos[i] = i;
for (int i = 0; i < nfoos; i++)
assert(foos[i] == i);
int nbars = x;
int *bars = allocr_calloc(&a, (size_t)nbars, sizeof(int));
for (int i = 0; i < nbars; i++)
assert(bars[i] == 0);
for (int i = 0; i < nbars; i++)
bars[i] = i;
for (int i = 0; i < nbars; i++)
assert(bars[i] == i);
}
int nfoos1 = 5;
int *foos = allocr_realloc(&a, NULL, (size_t)nfoos1 * sizeof(int));
for (int i = 0; i < nfoos1; i++)
foos[i] = i;
for (int i = 0; i < nfoos1; i++)
assert(foos[i] == i);
int nfoos2 = 10;
foos = allocr_realloc(&a, foos, (size_t)nfoos2 * sizeof(int));
for (int i = nfoos1; i < nfoos2; i++)
foos[i] = i;
for (int i = 0; i < nfoos2; i++)
assert(foos[i] == i);
int *arr = NULL;
int n = 1000;
for (int i = 0; i < n; i++) {
int *p = arr_adda(&arr, &a);
*p = i;
}
for (int i = 0; i < n; i++) {
assert(arr[i] == i);
}
allocr_free_all(&a);
}
static void test_all(void) {
allocr_test();
arr_test();
}
|