From d3a57b96a9bff608f9488c5d0c3c19100997373d Mon Sep 17 00:00:00 2001 From: Veikka Tuominen Date: Tue, 15 Dec 2020 22:40:04 +0200 Subject: [PATCH] translate-c: detect parenthesized string literals --- src/translate_c.zig | 4 ++++ test/run_translated_c.zig | 7 +++++++ 2 files changed, 11 insertions(+) diff --git a/src/translate_c.zig b/src/translate_c.zig index 7469c6e996..e57a1952af 100644 --- a/src/translate_c.zig +++ b/src/translate_c.zig @@ -1797,6 +1797,10 @@ fn exprIsStringLiteral(expr: *const clang.Expr) bool { const op_expr = @ptrCast(*const clang.UnaryOperator, expr).getSubExpr(); return exprIsStringLiteral(op_expr); }, + .ParenExprClass => { + const op_expr = @ptrCast(*const clang.ParenExpr, expr).getSubExpr(); + return exprIsStringLiteral(op_expr); + }, else => return false, } } diff --git a/test/run_translated_c.zig b/test/run_translated_c.zig index eb0b7db50a..f51beb18bf 100644 --- a/test/run_translated_c.zig +++ b/test/run_translated_c.zig @@ -3,6 +3,13 @@ const tests = @import("tests.zig"); const nl = std.cstr.line_sep; pub fn addCases(cases: *tests.RunTranslatedCContext) void { + cases.add("parenthesized string literal", + \\void foo(const char *s) {} + \\int main(void) { + \\ foo(("bar")); + \\} + , ""); + cases.add("variable shadowing type type", \\#include \\int main() {