aboutsummaryrefslogtreecommitdiff
path: root/tests/test95.c
blob: 7e715b582dc43d8bdafdb5f9c70ec41dfa929121 (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
54
55
56
57
58
59
60
61
62
63
64
65
66
#include <assert.h>
#include <stddef.h>   /* size_t, NULL */
#include "utstack.h"

typedef struct el {
    int id, score;
    struct el *next;
    struct el *next2;
} el;

int main()
{
    el alpha = {1, 100, NULL, NULL};
    el beta = {2, 100, NULL, NULL};
    el gamma = {3, 100, NULL, NULL};
    el delta = {4, 100, NULL, NULL};

    el *stack1 = NULL;
    el *stack2 = NULL;
    el *dummy;
    int size1;
    size_t size2;

    STACK_COUNT(stack1, dummy, size1); assert(size1 == 0);
    STACK_COUNT(stack2, dummy, size2); assert(size2 == 0);
    assert(STACK_EMPTY(stack1));
    assert(STACK_EMPTY(stack2));

    STACK_PUSH(stack1, &alpha);
    STACK_COUNT(stack1, dummy, size1); assert(size1 == 1);
    STACK_PUSH(stack1, &beta);
    STACK_COUNT(stack1, dummy, size1); assert(size1 == 2);
    STACK_PUSH(stack1, &gamma);
    STACK_PUSH2(stack1, &delta, next);
    STACK_COUNT(stack1, dummy, size1); assert(size1 == 4);
    assert(stack1 == &delta);

    STACK_PUSH2(stack2, &alpha, next2);
    assert(stack2 == &alpha);
    assert(alpha.next2 == NULL);
    STACK_PUSH2(stack2, &delta, next2);
    assert(stack2 == &delta);
    assert(delta.next2 == &alpha);
    STACK_COUNT2(stack2, dummy, size2, next2); assert(size2 == 2);
    assert(!STACK_EMPTY(stack2));
    assert(stack2 == &delta);

    assert(!STACK_EMPTY(stack1));
    assert(!STACK_EMPTY(stack2));

    STACK_POP(stack1, dummy); assert(stack1 == &gamma); assert(dummy == &delta);
    STACK_POP(stack1, dummy); assert(stack1 == &beta); assert(dummy == &gamma);
    STACK_POP(stack1, dummy); assert(stack1 == &alpha); assert(dummy == &beta);
    STACK_COUNT(stack1, dummy, size1); assert(size1 == 1);
    STACK_POP(stack1, dummy); assert(stack1 == NULL); assert(dummy == &alpha);

    assert(STACK_TOP(stack2) == &delta);
    while (!STACK_EMPTY(stack2)) {
        STACK_POP2(stack2, dummy, next2);
    }

    assert(STACK_EMPTY(stack1));
    assert(STACK_EMPTY(stack2));

    return 0;
}