summaryrefslogtreecommitdiffstats
path: root/tests/opkg_active_list_test.c
blob: ec6bec1d7ebace960e9a44f72fc43d2e309d32f0 (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
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

/*
.--A---B----C----D-----E----F
    |             |__k---L
    |                    |_ N
    |__ G ---H ---I---J
             |_M      |_O

Then the sequence will be 
G M H I O J A B K N L C D E F
*/

#include <stdlib.h>
#include <libopkg/active_list.h>
#include <stdio.h>

struct active_test {
    char *str;
    struct active_list list;
} __attribute__((packed));

struct active_test *active_test_new(char *str) {
    struct active_test *ans = (struct active_test *)calloc(1, sizeof(struct active_test));
    ans->str = str;
    active_list_init(&ans->list); 
    return ans;
}
void active_test_add(struct active_list *head, struct active_test *node) {
    active_list_add(head, &node->list);
}

void active_test_add_depend(struct active_test *A, struct active_test *B) {
    active_list_add_depend(&A->list, &B->list);
}

void make_list(struct active_list *head) {
    struct active_test *A = active_test_new("A");
    struct active_test *B = active_test_new("B");
    struct active_test *C = active_test_new("C");
    struct active_test *D = active_test_new("D");
    struct active_test *E = active_test_new("E");
    struct active_test *F = active_test_new("F");
    struct active_test *G = active_test_new("G");
    struct active_test *H = active_test_new("H");
    struct active_test *I = active_test_new("I");
    struct active_test *J = active_test_new("J");
    struct active_test *K = active_test_new("K");
    struct active_test *L = active_test_new("L");
    struct active_test *M = active_test_new("M");
    struct active_test *N = active_test_new("N");
    struct active_test *O = active_test_new("O");

    active_test_add(head, A);
    active_test_add(head, B);
    active_test_add(head, C);
    active_test_add(head, D);
    active_test_add(head, E);
    active_test_add(head, F);
    active_test_add(head, G);
    active_test_add(head, H);
    active_test_add(head, I);
    active_test_add(head, J);
    active_test_add(head, K);
    active_test_add(head, L);
    active_test_add(head, M);
    active_test_add(head, N);
    active_test_add(head, O);
    active_test_add_depend(H, M);
    active_test_add_depend(A, G);
    active_test_add_depend(A, H);
    active_test_add_depend(A, I);
    active_test_add_depend(A, J);
    active_test_add_depend(J, O);
    active_test_add_depend(C, K);
    active_test_add_depend(C, L); 
    active_test_add_depend(L, N);
}

int main (void) {
    struct active_list head;
    struct active_list *ptr;
    struct active_test *test;
    active_list_init(&head);
    make_list(&head);

    for(ptr = active_list_next(&head, &head); ptr ;ptr = active_list_next(&head, ptr)) {
        test = list_entry(ptr, struct active_test, list);
        printf ("%s ",test->str);
    }
    printf("\n");
    for(ptr = active_list_next(&head, &head); ptr ;ptr = active_list_next(&head, ptr)) {
        test = list_entry(ptr, struct active_test, list);
        printf ("%s ",test->str);
    }
    printf("\n");
    for(ptr = active_list_next(&head, &head); ptr ;ptr = active_list_next(&head, ptr)) {
        test = list_entry(ptr, struct active_test, list);
        printf ("%s ",test->str);
    }
    printf("\n");


}