]> git.ozlabs.org Git - ccan/blob - ccan/opt/test/run-iter.c
opt: fix warnings with gcc and -O.
[ccan] / ccan / opt / test / run-iter.c
1 #define _GNU_SOURCE
2 #include <ccan/tap/tap.h>
3 #include <stdarg.h>
4 #include <setjmp.h>
5 #include <stdlib.h>
6 #include <stdarg.h>
7 #include "utils.h"
8 #include <ccan/opt/opt.c>
9 #include <ccan/opt/usage.c>
10
11 /* Test iterators. */
12 int main(int argc, char *argv[])
13 {
14         unsigned i, len;
15         const char *p;
16
17         plan_tests(37);
18         opt_register_table(subtables, NULL);
19
20         p = first_lopt(&i, &len);
21         ok1(i == 0);
22         ok1(len == 3);
23         ok1(strncmp(p, "jjj", len) == 0);
24         p = next_lopt(p, &i, &len);
25         ok1(i == 0);
26         ok1(len == 3);
27         ok1(strncmp(p, "lll", len) == 0);
28         p = next_lopt(p, &i, &len);
29         ok1(i == 1);
30         ok1(len == 3);
31         ok1(strncmp(p, "mmm", len) == 0);
32         p = next_lopt(p, &i, &len);
33         ok1(i == 5);
34         ok1(len == 3);
35         ok1(strncmp(p, "ddd", len) == 0);
36         p = next_lopt(p, &i, &len);
37         ok1(i == 6);
38         ok1(len == 3);
39         ok1(strncmp(p, "eee", len) == 0);
40         p = next_lopt(p, &i, &len);
41         ok1(i == 7);
42         ok1(len == 3);
43         ok1(strncmp(p, "ggg", len) == 0);
44         p = next_lopt(p, &i, &len);
45         ok1(i == 8);
46         ok1(len == 3);
47         ok1(strncmp(p, "hhh", len) == 0);
48         p = next_lopt(p, &i, &len);
49         ok1(!p);
50
51         p = first_sopt(&i);
52         ok1(i == 0);
53         ok1(*p == 'j');
54         p = next_sopt(p, &i);
55         ok1(i == 0);
56         ok1(*p == 'l');
57         p = next_sopt(p, &i);
58         ok1(i == 1);
59         ok1(*p == 'm');
60         p = next_sopt(p, &i);
61         ok1(i == 2);
62         ok1(*p == 'a');
63         p = next_sopt(p, &i);
64         ok1(i == 3);
65         ok1(*p == 'b');
66         p = next_sopt(p, &i);
67         ok1(i == 7);
68         ok1(*p == 'g');
69         p = next_sopt(p, &i);
70         ok1(i == 8);
71         ok1(*p == 'h');
72         p = next_sopt(p, &i);
73         ok1(!p);
74
75         return exit_status();
76 }