zig

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

commit 37cd21eb5f23d2bb26e36ca3de76f0a71e16230c (tree)
parent ffd071f55821f70fbfc59bab172ae07eaf7cde23
Author: WillLillis <wlillis@umass.edu>
Date:   Mon,  9 Sep 2024 20:58:06 -0400

fix: disallow discard as errdefer capture

Diffstat:
Mlib/std/zig/AstGen.zig | 3+++
Atest/cases/errdefer_discard.zig | 7+++++++
2 files changed, 10 insertions(+), 0 deletions(-)

diff --git a/lib/std/zig/AstGen.zig b/lib/std/zig/AstGen.zig @@ -3156,6 +3156,9 @@ fn deferStmt( const have_err_code = scope_tag == .defer_error and payload_token != 0; const sub_scope = if (!have_err_code) &defer_gen.base else blk: { const ident_name = try gz.astgen.identAsString(payload_token); + if (std.mem.eql(u8, tree.tokenSlice(payload_token), "_")) { + return gz.astgen.failTok(payload_token, "discard of error capture; omit it instead", .{}); + } const remapped_err_code: Zir.Inst.Index = @enumFromInt(gz.astgen.instructions.len); opt_remapped_err_code = remapped_err_code.toOptional(); try gz.astgen.instructions.append(gz.astgen.gpa, .{ diff --git a/test/cases/errdefer_discard.zig b/test/cases/errdefer_discard.zig @@ -0,0 +1,7 @@ +pub fn main() !void { + errdefer |_| _ = @"_"; +} + +// error +// +// :2:15: error: discard of error capture; omit it instead