summaryrefslogtreecommitdiff
path: root/src/parser
diff options
context:
space:
mode:
authorZuhaitz Méndez Fernández de Aránguiz <zuhaitz@debian>2026-01-17 10:53:58 +0000
committerZuhaitz Méndez Fernández de Aránguiz <zuhaitz@debian>2026-01-17 10:53:58 +0000
commit3704ce90083862680f7768916e1a40ddb85e833d (patch)
treec3ba73a759f4357ec0a722114f5a0aa0bc06a14b /src/parser
parent42d955d21eb9a809bcdac6d7e8d27566b2b49da7 (diff)
Fix for #59
Diffstat (limited to 'src/parser')
-rw-r--r--src/parser/parser_type.c17
1 files changed, 14 insertions, 3 deletions
diff --git a/src/parser/parser_type.c b/src/parser/parser_type.c
index b966a4d..1b5e8b6 100644
--- a/src/parser/parser_type.c
+++ b/src/parser/parser_type.c
@@ -141,9 +141,20 @@ Type *parse_type_base(ParserContext *ctx, Lexer *l)
char *merged;
if (mod)
{
- // Module-qualified type: Use module base name
- merged = xmalloc(strlen(mod->base_name) + strlen(resolved_suffix) + 2);
- sprintf(merged, "%s_%s", mod->base_name, resolved_suffix);
+ // Module-qualified type
+ if (mod->is_c_header)
+ {
+ // C header: Use type name directly without prefix
+ // To prevent name mangling, we might consider changing
+ // this to also use the prefix.
+ merged = xstrdup(resolved_suffix);
+ }
+ else
+ {
+ // Zen module: Use module base name as prefix
+ merged = xmalloc(strlen(mod->base_name) + strlen(resolved_suffix) + 2);
+ sprintf(merged, "%s_%s", mod->base_name, resolved_suffix);
+ }
}
else
{