diff --git a/src/translate_c.zig b/src/translate_c.zig index 16c2060163a1..2e9213a8c737 100644 --- a/src/translate_c.zig +++ b/src/translate_c.zig @@ -5793,6 +5793,10 @@ fn macroIntToBool(c: *Context, node: Node) !Node { if (isBoolRes(node)) { return node; } + if (node.tag() == .string_literal) { + const int_from_ptr = try Tag.int_from_ptr.create(c.arena, node); + return Tag.not_equal.create(c.arena, .{ .lhs = int_from_ptr, .rhs = Tag.zero_literal.init() }); + } return Tag.not_equal.create(c.arena, .{ .lhs = node, .rhs = Tag.zero_literal.init() }); } diff --git a/test/cases/translate_c/assert_with_strlit.c b/test/cases/translate_c/assert_with_strlit.c new file mode 100644 index 000000000000..445428bcf143 --- /dev/null +++ b/test/cases/translate_c/assert_with_strlit.c @@ -0,0 +1,8 @@ + +void assert(int x) {} +#define FOO assert(0 && "error message") + +// translate-c +// c_frontend=clang +// +// pub const FOO = assert((@as(c_int, 0) != 0) and (@intFromPtr("error message") != 0));