zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 583e698256a2a26f26738c983e319d76926ef048 (tree)
parent d404d8a3637bc30dffc736e5fa1a68b8af0e19cb
Author: fmaggi <61335294+fmaggi@users.noreply.github.com>
Date:   Mon, 15 Jul 2024 04:58:33 -0300

Sema: disallow casting to opaque


Diffstat:
Msrc/Sema.zig | 6++++++
Mtest/cases/compile_errors/directly_embedding_opaque_type_in_struct_and_union.zig | 15+++++++--------
2 files changed, 13 insertions(+), 8 deletions(-)

diff --git a/src/Sema.zig b/src/Sema.zig @@ -10188,9 +10188,15 @@ fn analyzeAs( const dest_ty_tag = dest_ty.zigTypeTagOrPoison(mod) catch |err| switch (err) { error.GenericPoison => return operand, }; + + if (dest_ty_tag == .Opaque) { + return sema.fail(block, src, "cannot cast to opaque type '{}'", .{dest_ty.fmt(pt)}); + } + if (dest_ty_tag == .NoReturn) { return sema.fail(block, src, "cannot cast to noreturn", .{}); } + const is_ret = if (zir_dest_type.toIndex()) |ptr_index| sema.code.instructions.items(.tag)[@intFromEnum(ptr_index)] == .ret_type else diff --git a/test/cases/compile_errors/directly_embedding_opaque_type_in_struct_and_union.zig b/test/cases/compile_errors/directly_embedding_opaque_type_in_struct_and_union.zig @@ -15,14 +15,13 @@ export fn b() void { _ = &bar; } export fn c() void { - const baz = &@as(O, undefined); - const qux = .{baz.*}; - _ = qux; + const baz = @as(O, undefined); + _ = baz; } export fn d() void { - const baz = &@as(O, undefined); - const qux = .{ .a = baz.* }; - _ = qux; + const ptr: *O = @ptrFromInt(0x1000); + const x = .{ptr.*}; + _ = x; } // error @@ -33,7 +32,7 @@ export fn d() void { // :1:11: note: opaque declared here // :7:10: error: opaque types have unknown size and therefore cannot be directly embedded in unions // :1:11: note: opaque declared here -// :19:22: error: cannot load opaque type 'tmp.O' +// :18:24: error: cannot cast to opaque type 'tmp.O' // :1:11: note: opaque declared here -// :24:28: error: cannot load opaque type 'tmp.O' +// :23:20: error: cannot load opaque type 'tmp.O' // :1:11: note: opaque declared here