summaryrefslogtreecommitdiff
path: root/src/parser
diff options
context:
space:
mode:
Diffstat (limited to 'src/parser')
-rw-r--r--src/parser/parser.h4
-rw-r--r--src/parser/parser_expr.c15
-rw-r--r--src/parser/parser_utils.c12
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);
}
}