stage1: fix exporting enums

After extern enums were removed, stage1 was left in an incorrect state
of checking for `extern enum` for exported enums. This commit fixes it
to look for an explicit integer tag type instead, and adds test coverage
for the compile error case as well as the success case.

closes #9498
This commit is contained in:
Andrew Kelley
2021-11-25 18:20:39 -07:00
parent 7b78b4fff0
commit 67b201982b
3 changed files with 36 additions and 4 deletions

View File

@@ -23,6 +23,20 @@ pub fn addCases(ctx: *TestContext) !void {
});
}
ctx.objErrStage1("exported enum without explicit integer tag type",
\\const E = enum { one, two };
\\comptime {
\\ @export(E, .{ .name = "E" });
\\}
\\const e: E = .two;
\\comptime {
\\ @export(e, .{ .name = "e" });
\\}
, &.{
"tmp.zig:3:13: error: exported enum without explicit integer tag type",
"tmp.zig:7:13: error: exported enum value without explicit integer tag type",
});
ctx.objErrStage1("issue #9346: return outside of function scope",
\\pub const empty = return 1;
, &.{"tmp.zig:1:19: error: 'return' outside function scope"});