-
Notifications
You must be signed in to change notification settings - Fork 37
/
Copy pathtoken.c
106 lines (87 loc) · 2.69 KB
/
token.c
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
#include "compiler.h"
#include "helpers/vector.h"
#include "helpers/buffer.h"
#define PRIMTIIVE_TYPES_TOTAL 7
const char* primitive_types[PRIMTIIVE_TYPES_TOTAL] = {
"void", "char", "short", "int", "long", "float", "double"
};
bool token_is_identifier(struct token* token)
{
return token && token->type == TOKEN_TYPE_IDENTIFIER;
}
bool token_is_keyword(struct token *token, const char *value)
{
return token && token->type == TOKEN_TYPE_KEYWORD && S_EQ(token->sval, value);
}
bool token_is_symbol(struct token* token, char c)
{
return token && token->type == TOKEN_TYPE_SYMBOL && token->cval == c;
}
bool token_is_operator(struct token* token, const char* val)
{
return token && token->type == TOKEN_TYPE_OPERATOR && S_EQ(token->sval, val);
}
bool is_operator_token(struct token* token)
{
return token && token->type == TOKEN_TYPE_OPERATOR;
}
bool token_is_nl_or_comment_or_newline_seperator(struct token *token)
{
if (!token)
return false;
return token->type == TOKEN_TYPE_NEWLINE ||
token->type == TOKEN_TYPE_COMMENT ||
token_is_symbol(token, '\\');
}
bool token_is_primitive_keyword(struct token* token)
{
if (!token)
return false;
if (token->type != TOKEN_TYPE_KEYWORD)
return false;
for (int i = 0; i < PRIMTIIVE_TYPES_TOTAL; i++)
{
if (S_EQ(primitive_types[i], token->sval))
return true;
}
return false;
}
void tokens_join_buffer_write_token(struct buffer* fmt_buf, struct token* token)
{
switch(token->type)
{
case TOKEN_TYPE_IDENTIFIER:
case TOKEN_TYPE_OPERATOR:
case TOKEN_TYPE_KEYWORD:
buffer_printf(fmt_buf, "%s", token->sval);
break;
case TOKEN_TYPE_STRING:
buffer_printf(fmt_buf, "\"%s\"", token->sval);
break;
case TOKEN_TYPE_NUMBER:
buffer_printf(fmt_buf, "%lld", token->llnum);
break;
case TOKEN_TYPE_NEWLINE:
buffer_printf(fmt_buf, "\n");
break;
case TOKEN_TYPE_SYMBOL:
buffer_printf(fmt_buf, "%c", token->cval);
break;
default:
FAIL_ERR("BUG: Incompatible token");
}
}
struct vector* tokens_join_vector(struct compile_process* compiler, struct vector* token_vec)
{
struct buffer* buf = buffer_create();
vector_set_peek_pointer(token_vec, 0);
struct token* token = vector_peek(token_vec);
while(token)
{
tokens_join_buffer_write_token(buf, token);
token = vector_peek(token_vec);
}
struct lex_process* lex_process = tokens_build_for_string(compiler, buffer_ptr(buf));
assert(lex_process);
return lex_process->token_vec;
}