diff options
| author | Jacob Young <jacobly0@users.noreply.github.com> | 2022-12-26 04:16:32 -0500 |
|---|---|---|
| committer | Jacob Young <jacobly0@users.noreply.github.com> | 2022-12-26 04:39:32 -0500 |
| commit | 64865679cf173c024a01d158686fc1cc9965a012 (patch) | |
| tree | ad2e6d293b0c1187f3a6bcd20283e0d3def5afb7 | |
| parent | 8dd844d96fdc1975365e4cc8f12f0d55d5e0cef4 (diff) | |
| download | zig-64865679cf173c024a01d158686fc1cc9965a012.tar.gz zig-64865679cf173c024a01d158686fc1cc9965a012.zip | |
Sema: add missing `resolveLazyValue` cases
Closes #14032
| -rw-r--r-- | src/Sema.zig | 6 | ||||
| -rw-r--r-- | test/behavior/struct.zig | 31 |
2 files changed, 31 insertions, 6 deletions
diff --git a/src/Sema.zig b/src/Sema.zig index 418f74b6f1..de9018be6e 100644 --- a/src/Sema.zig +++ b/src/Sema.zig @@ -29708,6 +29708,12 @@ fn resolveLazyValue(sema: *Sema, val: Value) CompileError!void { const field_ptr = val.castTag(.comptime_field_ptr).?.data; return sema.resolveLazyValue(field_ptr.field_val); }, + .eu_payload, + .opt_payload, + => { + const sub_val = val.cast(Value.Payload.SubValue).?.data; + return sema.resolveLazyValue(sub_val); + }, .@"union" => { const union_val = val.castTag(.@"union").?.data; return sema.resolveLazyValue(union_val.val); diff --git a/test/behavior/struct.zig b/test/behavior/struct.zig index a23294a102..2a9ea945e0 100644 --- a/test/behavior/struct.zig +++ b/test/behavior/struct.zig @@ -1420,15 +1420,34 @@ test "struct field has a pointer to an aligned version of itself" { try expect(&e == e.next); } -test "struct only referenced from optional parameter/return" { +test "struct has only one reference" { const S = struct { - fn f(_: ?struct { x: u8 }) void {} - fn g() ?struct { x: u8 } { + fn optionalStructParam(_: ?struct { x: u8 }) void {} + fn errorUnionStructParam(_: error{}!struct { x: u8 }) void {} + fn optionalStructReturn() ?struct { x: u8 } { return null; } + fn errorUnionStructReturn() error{Foo}!struct { x: u8 } { + return error.Foo; + } + fn optionalComptimeIntParam(comptime x: ?comptime_int) comptime_int { + return x.?; + } + fn errorUnionComptimeIntParam(comptime x: error{}!comptime_int) comptime_int { + return x catch unreachable; + } }; - const fp: *const anyopaque = &S.f; - const gp: *const anyopaque = &S.g; - try expect(fp != gp); + const optional_struct_param: *const anyopaque = &S.optionalStructParam; + const error_union_struct_param: *const anyopaque = &S.errorUnionStructParam; + try expect(optional_struct_param != error_union_struct_param); + + const optional_struct_return: *const anyopaque = &S.optionalStructReturn; + const error_union_struct_return: *const anyopaque = &S.errorUnionStructReturn; + try expect(optional_struct_return != error_union_struct_return); + + try expectEqual(@alignOf(struct {}), S.optionalComptimeIntParam(@alignOf(struct {}))); + try expectEqual(@alignOf(struct { x: u8 }), S.errorUnionComptimeIntParam(@alignOf(struct { x: u8 }))); + try expectEqual(@sizeOf(struct { x: u16 }), S.optionalComptimeIntParam(@sizeOf(struct { x: u16 }))); + try expectEqual(@sizeOf(struct { x: u32 }), S.errorUnionComptimeIntParam(@sizeOf(struct { x: u32 }))); } |
