zig

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

commit 9343c31c3879514c890c9bfa2a1cd1a1f222ed6d (tree)
parent 6bd54793060191ffce2c7492a90a40a30f9e2a1d
Author: Jacob Young <jacobly0@users.noreply.github.com>
Date:   Mon, 26 Jun 2023 17:47:32 -0400

Sema: fix `@min`/`@max` type resolution with all runtime args

Closes #16229

Diffstat:
Msrc/Sema.zig | 4++++
Mtest/behavior/maximum_minimum.zig | 14++++++++++++++
2 files changed, 18 insertions(+), 0 deletions(-)

diff --git a/src/Sema.zig b/src/Sema.zig @@ -23301,6 +23301,7 @@ fn analyzeMinMax( if (cur_minmax == null) { // No comptime operands - use the first operand as the starting value + assert(bounds_status == .unknown); assert(runtime_idx == 0); cur_minmax = operands[0]; cur_minmax_src = runtime_src; @@ -23309,6 +23310,9 @@ fn analyzeMinMax( if (scalar_ty.isInt(mod)) { cur_min_scalar = try scalar_ty.minInt(mod, scalar_ty); cur_max_scalar = try scalar_ty.maxInt(mod, scalar_ty); + bounds_status = .defined; + } else { + bounds_status = .non_integral; } } diff --git a/test/behavior/maximum_minimum.zig b/test/behavior/maximum_minimum.zig @@ -295,3 +295,17 @@ test "@min/@max notices bounds from vector types when element of comptime-known try expectEqual(@as(u32, 1_000_000), max[0]); // Cannot assert values at index 1 as one was undefined } + +test "@min/@max of signed and unsigned runtime integers" { + var x: i32 = -1; + var y: u31 = 1; + + const min = @min(x, y); + const max = @max(x, y); + + comptime assert(@TypeOf(min) == i32); + comptime assert(@TypeOf(max) == u31); + + try expectEqual(x, @min(x, y)); + try expectEqual(y, @max(x, y)); +}