添加了对CAST、COMPOUND、LVALUE、BUILTIN等表达式类型的支持, 以及SWITCH、CASE、DEFAULT等语句类型的框架实现。 fix(hir_dump): 修复整数值格式化显示问题 修改了整数值的获取方式,从原来的const_int.int32改为integer.data.digit, 并添加了hack注释说明。 fix(lir_module): 修复数据符号添加中的比较操作符错误 将赋值操作符'='改为相等比较操作符'==',修正了条件判断逻辑。 refactor(mir_x86): 改进寄存器分配和指令选择逻辑 添加了函数元数据字段用于虚拟寄存器计数,改进了移动指令的处理逻辑, 将条件分支相关代码替换为setcc指令序列。 fix(parser): 修正类型指针返回类型一致性 统一了类型获取函数的返回类型,从const指针改为非const指针, 确保类型系统的一致性。 fix(parser): 修复结构体类型解析中的类型分配问题 修改了匿名结构体类型的处理逻辑,确保类型声明能够正确挂载到AST中。 fix(config): 修正emit-target参数类型配置 将emit-target选项的参数类型从字符串改为布尔型,修正了配置解析。 test: 增加全局超时控制和测试优化 添加了全局超时机制防止测试无限等待,改进了测试运行器的统计信息输出。
127 lines
3.9 KiB
C
127 lines
3.9 KiB
C
#ifndef __SCC_PARSER_H__
|
|
#define __SCC_PARSER_H__
|
|
|
|
#include "scc_sema.h"
|
|
#include <scc_ast.h>
|
|
#include <scc_core_ring.h>
|
|
#include <scc_hashtable.h>
|
|
#include <scc_lexer_token.h>
|
|
|
|
/**
|
|
* @brief 解析器状态
|
|
*/
|
|
typedef struct scc_parser {
|
|
scc_lexer_tok_ring_t *ring;
|
|
usize checkpoint;
|
|
|
|
scc_ast_ctx_t *ast_ctx;
|
|
scc_sema_ctx_t *sema_ctx;
|
|
int owned_sema;
|
|
scc_ast_translation_unit_t *translation_unit;
|
|
int errcode;
|
|
} scc_parser_t;
|
|
|
|
/**
|
|
* @brief 初始化解析器
|
|
* @param parser 解析器实例
|
|
* @param lexer 词法分析器实例
|
|
* @param callbacks 语义分析回调(可为 nullptr)
|
|
*/
|
|
void scc_parser_init(scc_parser_t *parser, scc_lexer_tok_ring_t *tok_ring,
|
|
scc_ast_ctx_t *ast_ctx, scc_sema_ctx_t *callbacks);
|
|
|
|
/**
|
|
* @brief 销毁解析器
|
|
* @param parser 解析器实例
|
|
*/
|
|
void scc_parser_drop(scc_parser_t *parser);
|
|
|
|
/**
|
|
* @brief 解析整个翻译单元
|
|
* @param parser 解析器实例
|
|
* @return 翻译单元 AST 节点
|
|
*/
|
|
scc_ast_translation_unit_t *scc_parse_translation_unit(scc_parser_t *parser);
|
|
|
|
/**
|
|
* @brief 解析声明
|
|
* @param parser 解析器实例
|
|
* @return 声明 AST 节点
|
|
*/
|
|
scc_ast_decl_t *scc_parse_declaration(scc_parser_t *parser);
|
|
scc_ast_expr_t *scc_parse_initializer(scc_parser_t *parser,
|
|
scc_ast_expr_t *base);
|
|
|
|
/**
|
|
* @brief 解析语句
|
|
* @param parser 解析器实例
|
|
* @return 语句 AST 节点
|
|
*/
|
|
scc_ast_stmt_t *scc_parse_statement(scc_parser_t *parser);
|
|
scc_ast_expr_t *scc_parse_assignment_expression(scc_parser_t *parser);
|
|
scc_ast_expr_t *scc_parser_constant_expression(scc_parser_t *parser);
|
|
|
|
/**
|
|
* @brief 解析表达式
|
|
* @param parser 解析器实例
|
|
* @return 表达式 AST 节点
|
|
*/
|
|
scc_ast_expr_t *scc_parse_expression(scc_parser_t *parser);
|
|
|
|
/**
|
|
* @brief 解析类型
|
|
* @param parser 解析器实例
|
|
* @return 类型 AST 节点
|
|
*/
|
|
scc_ast_decl_t *scc_parse_declarator(scc_parser_t *parser,
|
|
scc_ast_qual_type_t *type);
|
|
scc_ast_qual_type_t *scc_parse_declaration_specifiers(scc_parser_t *parser);
|
|
scc_ast_qual_type_t *scc_parse_type_name(scc_parser_t *parser);
|
|
|
|
static inline void scc_sema_decl(scc_parser_t *parser, scc_ast_node_kind_t kind,
|
|
scc_ast_decl_t *decl) {
|
|
parser->sema_ctx->on_decl(parser->sema_ctx, kind, decl);
|
|
}
|
|
|
|
static inline void scc_sema_expr(scc_parser_t *parser, scc_ast_node_kind_t kind,
|
|
scc_ast_expr_t *expr) {
|
|
parser->sema_ctx->on_expr(parser->sema_ctx, kind, expr);
|
|
}
|
|
|
|
static inline void scc_sema_stmt(scc_parser_t *parser, scc_ast_node_kind_t kind,
|
|
scc_ast_stmt_t *stmt) {
|
|
parser->sema_ctx->on_stmt(parser->sema_ctx, kind, stmt);
|
|
}
|
|
|
|
static inline void scc_sema_type(scc_parser_t *parser, scc_ast_node_kind_t kind,
|
|
scc_ast_qual_type_t *type) {
|
|
parser->sema_ctx->on_type(parser->sema_ctx, kind, type);
|
|
}
|
|
|
|
static inline void scc_parse_decl_sema(scc_parser_t *parser,
|
|
scc_ast_decl_t *decl) {
|
|
scc_sema_decl(parser, decl ? decl->base.type : SCC_AST_UNKNOWN, decl);
|
|
}
|
|
|
|
static inline void scc_parse_expr_sema(scc_parser_t *parser,
|
|
scc_ast_expr_t *expr) {
|
|
scc_sema_expr(parser, expr ? expr->base.type : SCC_AST_UNKNOWN, expr);
|
|
}
|
|
|
|
static inline void scc_parse_stmt_sema(scc_parser_t *parser,
|
|
scc_ast_stmt_t *stmt) {
|
|
scc_sema_stmt(parser, stmt ? stmt->base.type : SCC_AST_UNKNOWN, stmt);
|
|
}
|
|
|
|
static inline void scc_parse_type_sema(scc_parser_t *parser,
|
|
scc_ast_qual_type_t *type) {
|
|
scc_sema_type(parser, type ? type->base.type : SCC_AST_UNKNOWN, type);
|
|
}
|
|
|
|
static inline scc_ast_qual_type_t *scc_parse_got_type(scc_parser_t *parser,
|
|
const char *name) {
|
|
return parser->sema_ctx->got_type(parser->sema_ctx, name);
|
|
}
|
|
|
|
#endif /* __SCC_PARSER_H__ */
|