- 添加 .gitignore 文件,忽略编译器生成的二进制文件 - 重构 lexer.c 文件,改进了关键字处理和字符串处理 - 更新前端的前端、解析器和 AST 相关文件,以适应新的词法分析器 - 优化了 token 相关的定义和函数,引入了新的 token 类型
52 lines
1.5 KiB
C
52 lines
1.5 KiB
C
#include "../ast.h"
|
|
#include "../parser.h"
|
|
#include "../type.h"
|
|
|
|
ast_node_t* new_ast_ident_node(tok_t* tok) {
|
|
if (tok->sub_type != TOKEN_IDENT) {
|
|
LOG_ERROR("syntax error: want identifier but got %d", tok->sub_type);
|
|
}
|
|
ast_node_t* node = new_ast_node();
|
|
node->type = NT_TERM_IDENT;
|
|
node->syms.tok = *tok;
|
|
node->syms.decl_node = NULL;
|
|
return node;
|
|
}
|
|
|
|
ast_node_t* expect_pop_ident(tok_stream_t* tokbuf) {
|
|
flush_peek_tok(tokbuf);
|
|
tok_t* tok = peek_tok(tokbuf);
|
|
ast_node_t* node = new_ast_ident_node(tok);
|
|
pop_tok(tokbuf);
|
|
return node;
|
|
}
|
|
|
|
ast_node_t* parse_type(parser_t* parser) {
|
|
tok_stream_t* tokbuf = &parser->tokbuf;
|
|
flush_peek_tok(tokbuf);
|
|
cc_tktype_t ttype = peek_tok_type(tokbuf);
|
|
data_type_t dtype;
|
|
switch(ttype) {
|
|
case TOKEN_VOID: dtype = TYPE_VOID; break;
|
|
case TOKEN_CHAR: dtype = TYPE_CHAR; break;
|
|
case TOKEN_SHORT: dtype = TYPE_SHORT; break;
|
|
case TOKEN_INT: dtype = TYPE_INT; break;
|
|
case TOKEN_LONG: dtype = TYPE_LONG; break;
|
|
case TOKEN_FLOAT: dtype = TYPE_FLOAT; break;
|
|
case TOKEN_DOUBLE: dtype = TYPE_DOUBLE; break;
|
|
default:
|
|
LOG_ERROR("无效的类型说明符");
|
|
}
|
|
|
|
ast_node_t* node = new_ast_node();
|
|
node->type = NT_TERM_TYPE;
|
|
// TODO added by disable warning, will add typing system
|
|
dtype += 1;
|
|
pop_tok(tokbuf);
|
|
|
|
if (peek_tok_type(tokbuf) == TOKEN_MUL) {
|
|
pop_tok(tokbuf);
|
|
}
|
|
return node;
|
|
}
|