diff options
Diffstat (limited to 'src/parser')
| -rw-r--r-- | src/parser/parser.h | 4 | ||||
| -rw-r--r-- | src/parser/parser_expr.c | 15 | ||||
| -rw-r--r-- | src/parser/parser_utils.c | 12 |
3 files changed, 26 insertions, 5 deletions
diff --git a/src/parser/parser.h b/src/parser/parser.h index f566979..6f62435 100644 --- a/src/parser/parser.h +++ b/src/parser/parser.h @@ -370,6 +370,10 @@ void register_selective_import(ParserContext *ctx, const char *symbol, const cha const char *source_module); SelectiveImport *find_selective_import(ParserContext *ctx, const char *name); +// Type Aliases +void register_type_alias(ParserContext *ctx, const char *alias, const char *original); +const char *find_type_alias(ParserContext *ctx, const char *alias); + // External symbol tracking (C interop) void register_extern_symbol(ParserContext *ctx, const char *name); int is_extern_symbol(ParserContext *ctx, const char *name); diff --git a/src/parser/parser_expr.c b/src/parser/parser_expr.c index 092b86b..2d0e10b 100644 --- a/src/parser/parser_expr.c +++ b/src/parser/parser_expr.c @@ -1384,6 +1384,21 @@ ASTNode *parse_primary(ParserContext *ctx, Lexer *l) char *tmp = xmalloc(strlen(acc) + suffix.len + 3); ASTNode *def = find_struct_def(ctx, acc); + + // If not found as a struct, check if it's an alias + if (!def) + { + const char *aliased = find_type_alias(ctx, acc); + if (aliased) + { + // Found an alias: replace acc with the aliased name + free(acc); + acc = xstrdup(aliased); + // Try finding the struct definition again with the resolved name + def = find_struct_def(ctx, acc); + } + } + if (def) { int is_variant = 0; diff --git a/src/parser/parser_utils.c b/src/parser/parser_utils.c index 4973111..afd6f33 100644 --- a/src/parser/parser_utils.c +++ b/src/parser/parser_utils.c @@ -2666,8 +2666,10 @@ char *rewrite_expr_methods(ParserContext *ctx, char *raw) char mangled[256]; - // Resolve alias - Module *mod = find_module(ctx, func_name); + const char *aliased = find_type_alias(ctx, func_name); + const char *use_name = aliased ? aliased : func_name; + + Module *mod = find_module(ctx, use_name); if (mod) { if (mod->is_c_header) @@ -2681,14 +2683,14 @@ char *rewrite_expr_methods(ParserContext *ctx, char *raw) } else { - ASTNode *sdef = find_struct_def(ctx, func_name); + ASTNode *sdef = find_struct_def(ctx, use_name); if (sdef) { - snprintf(mangled, sizeof(mangled), "%s__%s", func_name, method); + snprintf(mangled, sizeof(mangled), "%s__%s", use_name, method); } else { - snprintf(mangled, sizeof(mangled), "%s_%s", func_name, method); + snprintf(mangled, sizeof(mangled), "%s_%s", use_name, method); } } |
