zig

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

commit eb4024036d3e8e0c4a8b0dcf09da107421f3fa01 (tree)
parent f2e249e92020462ac29f34fc3d45cef3dc90a3b2
Author: David Rubin <87927264+Rexicon226@users.noreply.github.com>
Date:   Sat,  3 Feb 2024 11:16:27 -0800

Add error hint when looping over `ErrorUnion`


Diffstat:
Msrc/Sema.zig | 5+++++
Atest/cases/compile_errors/for_loop_error_union.zig | 15+++++++++++++++
2 files changed, 20 insertions(+), 0 deletions(-)

diff --git a/src/Sema.zig b/src/Sema.zig @@ -4221,6 +4221,11 @@ fn zirForLen(sema: *Sema, block: *Block, inst: Zir.Inst.Index) CompileError!Air. const msg = try sema.errMsg(block, arg_src, "type '{}' is not indexable and not a range", .{object_ty.fmt(sema.mod)}); errdefer msg.destroy(sema.gpa); try sema.errNote(block, arg_src, msg, "for loop operand must be a range, array, slice, tuple, or vector", .{}); + + if (object_ty.zigTypeTag(mod) == .ErrorUnion) { + try sema.errNote(block, arg_src, msg, "consider using 'try', 'catch', or 'if'", .{}); + } + break :msg msg; }; return sema.failWithOwnedErrorMsg(block, msg); diff --git a/test/cases/compile_errors/for_loop_error_union.zig b/test/cases/compile_errors/for_loop_error_union.zig @@ -0,0 +1,15 @@ +fn b() !u32 { + return 2; +} + +export fn a() void { + for (b()) |_| {} +} + +// error +// backend=stage2 +// target=native +// +// :6:11: error: type '@typeInfo(@typeInfo(@TypeOf(tmp.b)).Fn.return_type.?).ErrorUnion.error_set!u32' is not indexable and not a range +// :6:11: note: for loop operand must be a range, array, slice, tuple, or vector +// :6:11: note: consider using 'try', 'catch', or 'if'