blob: db296e6e65abe536feb24cd60208e7f2f08787a7 (
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
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
|
#include "include/test.h"
#include "../src/include/pp.h"
#include "../src/include/lexer.h"
#include "../src/include/tree.h"
#include "../src/include/parser.h"
TEST_INIT
void test_simple_empty() {
tree_t* tree;
pp_t* pp;
lexer_t* lexer;
parser_t* parser;
char src[] = " ";
/*
[block]
val:
NULL
nxt:
NULL
*/
tree = tree_init(TREE_TYPE_BLOCK);
tree->data.block.val = NULL;
tree->data.block.nxt = NULL;
pp = pp_init(src);
pp_run(pp);
lexer = lexer_init(pp->psrc);
lexer_run(lexer);
parser = parser_init(lexer->tokenl);
parser_run(parser);
ASSERT(tree_cmp(parser->tree, tree) == 1);
pp_destroy(pp);
parser_destroy(parser);
lexer_destroy(lexer);
}
void test_single_lint() {
tree_t* tree;
pp_t* pp;
lexer_t* lexer;
parser_t* parser;
char src[] = "1";
/*
[block]
val:
[lint]
val:
1
nxt:
NULL
*/
tree = tree_init(TREE_TYPE_BLOCK);
tree->data.block.val = tree_init(TREE_TYPE_LINT);
tree->data.block.val->data.lint.val = 1;
tree->data.block.nxt = NULL;
pp = pp_init(src);
pp_run(pp);
lexer = lexer_init(pp->psrc);
lexer_run(lexer);
parser = parser_init(lexer->tokenl);
parser_run(parser);
ASSERT(tree_cmp(parser->tree, tree) == 1);
token_destroy(lexer->tokenl);
lexer_destroy(lexer);
pp_destroy(pp);
tree_destroy(parser->tree);
parser_destroy(parser);
}
int main(int argc, char** argv) {
test_simple_empty();
test_single_lint();
TEST_REPORT;
return 0;
}
|