commit 4b9fd57aa86a480f2afd6ba117fcc7ef6eace572 (tree)
parent d805adddd6744e0d55263c02d2a03e27ad0c7d68
Author: Evan Haas <evan@lagerdata.com>
Date: Tue, 8 Mar 2022 10:38:51 -0800
translate-c: use nested scope for comma operator in macros
Fixes #11040
Diffstat:
4 files changed, 19 insertions(+), 1 deletion(-)
diff --git a/src/translate_c.zig b/src/translate_c.zig
@@ -5563,7 +5563,7 @@ fn parseCExpr(c: *Context, m: *MacroCtx, scope: *Scope) ParseError!Node {
const ignore = try Tag.discard.create(c.arena, .{ .should_skip = false, .value = last });
try block_scope.statements.append(ignore);
- last = try parseCCondExpr(c, m, scope);
+ last = try parseCCondExpr(c, m, &block_scope.base);
if (m.next().? != .Comma) {
m.i -= 1;
break;
diff --git a/test/behavior/translate_c_macros.h b/test/behavior/translate_c_macros.h
@@ -37,3 +37,5 @@ union U {
#define IGNORE_ME_10(x) (volatile const void)(x)
#define UNION_CAST(X) (union U)(X)
+
+#define NESTED_COMMA_OPERATOR (1, (2, 3))
diff --git a/test/behavior/translate_c_macros.zig b/test/behavior/translate_c_macros.zig
@@ -56,3 +56,9 @@ test "casting to union with a macro" {
casted = h.UNION_CAST(d);
try expectEqual(d, casted.d);
}
+
+test "nested comma operator" {
+ if (builtin.zig_backend == .stage2_c) return error.SkipZigTest; // TODO
+
+ try expectEqual(@as(c_int, 3), h.NESTED_COMMA_OPERATOR);
+}
diff --git a/test/run_translated_c.zig b/test/run_translated_c.zig
@@ -1851,4 +1851,14 @@ pub fn addCases(cases: *tests.RunTranslatedCContext) void {
\\ return 0;
\\}
, "");
+
+ cases.add("Nested comma operator in macro. Issue #11040",
+ \\#include <stdlib.h>
+ \\#define FOO (1, (2, 3))
+ \\int main(void) {
+ \\ int x = FOO;
+ \\ if (x != 3) abort();
+ \\ return 0;
+ \\}
+ , "");
}