diff options
| author | Zuhaitz Méndez Fernández de Aránguiz <zuhaitz@debian> | 2026-01-17 18:09:31 +0000 |
|---|---|---|
| committer | Zuhaitz Méndez Fernández de Aránguiz <zuhaitz@debian> | 2026-01-17 18:09:31 +0000 |
| commit | 7ac5be7ba8f700f69009c5e980ee7b12b0653586 (patch) | |
| tree | 85c44ed59d768d0bae8849b4590655b82a2a8c57 /src/parser | |
| parent | 661a71defc66cfeea1681dddd944ba017087f78a (diff) | |
Fix for #60
Diffstat (limited to 'src/parser')
| -rw-r--r-- | src/parser/parser_utils.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/src/parser/parser_utils.c b/src/parser/parser_utils.c index 87cf24e..0dc7cbf 100644 --- a/src/parser/parser_utils.c +++ b/src/parser/parser_utils.c @@ -2248,6 +2248,14 @@ char *rewrite_expr_methods(ParserContext *ctx, char *raw) *pc = 0; } + // Resolve type alias if exists (for example: Vec2f -> Vec2_float) + const char *resolved_type = find_type_alias(ctx, base_t); + if (resolved_type) + { + free(base_t); + base_t = xstrdup(resolved_type); + } + ASTNode *def = find_struct_def(ctx, base_t); int is_field = 0; if (def && (def->type == NODE_STRUCT)) @@ -2299,7 +2307,7 @@ char *rewrite_expr_methods(ParserContext *ctx, char *raw) } // Mixin Lookup Logic - char target_func[128]; + char target_func[256]; sprintf(target_func, "%s__%s", ptr_check, method); char *final_cast = NULL; @@ -2405,7 +2413,7 @@ char *rewrite_expr_methods(ParserContext *ctx, char *raw) } } // Mixin Lookup Logic (No Parens) - char target_func[128]; + char target_func[256]; sprintf(target_func, "%s__%s", ptr_check, method); char *final_cast = NULL; |
