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
104
105
106
107
108
109
110
|
import "libc.hff";
import "option.hff";
/// Macros
defmacro assert {
(ex, s) [
(do
if not (ex) {
fprintf(stderr, "%s:%d: assertion failed: ", #FILE, #LINE);
fprintf(stderr, "`%s'", (s));
fprintf(stderr, "\n");
abort();
}
)
]
}
defmacro foreach(x, i, a, ...body) [
{
let $a = a;
for let i = 0; i < $a.#len; ++i {
let x = $a[i];
{ body }
}
}
]
defmacro ALIGNUP(x,a) [ (((x) + ((a) - 1)) & -(a)) ]
defmacro streq(a,b) [ (strcmp(a,b) == 0) ]
/// Types
struct Type;
struct Decl;
struct Expr;
struct Loc {
fileid i16,
col i16,
line int,
idx isize,
}
#[lax]
enum TokT {
// !sorted
kw_and, kw_as, kw_break, kw_case, kw_const,
kw_continue, kw_def, kw_defmacro, kw_do,
kw_else, kw_enum, kw_extern, kw_fn,
kw_for, kw_if, kw_import, kw_let, kw_not,
kw_or, kw_return, kw_sizeof, kw_static,
kw_struct, kw_switch, kw_typedef, kw_typeof,
kw_union, kw_while,
NUM_KEYWORDS,
int = -100,
flo,
bool,
str,
chr,
null,
ident,
macident,
gensym,
type,
label,
strify,
eof,
}
struct Tok {
t int,
loc Loc,
ty *const Type,
u union {
int i64,
uint u64,
flo f64,
bool bool,
str [#]const u8,
},
}
struct Decl {
}
struct Parser {
fp *FILE,
curfile *const u8,
tokloc Loc,
curloc Loc,
eof bool,
peekchr Option<int>,
peektok Option<Tok>,
}
// parse.cff
extern fn parser_init(*Parser, path *const u8) void;
extern fn parse(*Parser) [#]Decl;
// util.cff
extern fn xmalloc(n usize) *void;
extern fn xrealloc(p *void, n usize) *void;
def FNV1A_INI u32 = 0x811c9dc5;
extern fn fnv1a(h u32, [#]const u8) u32;
extern fn fnv1a_s(h u32, *const u8) u32;
extern fn addfilepath(*const u8) int;
|