zig

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

commit cffa98eef54568bf43cbbe14a3cbbf972a2c7a7a (tree)
parent 201c0f54a597a53d04c782687c903cd5ea177066
Author: Marc Tiehuis <marc@tiehu.is>
Date:   Sun,  8 Jun 2025 14:32:16 +1200

std.fmt.parseFloat: fix hex-float negative inf

Closes #24111.

Diffstat:
Mlib/std/fmt/parse_float.zig | 3+++
Mlib/std/fmt/parse_float/convert_hex.zig | 2+-
2 files changed, 4 insertions(+), 1 deletion(-)

diff --git a/lib/std/fmt/parse_float.zig b/lib/std/fmt/parse_float.zig @@ -159,6 +159,9 @@ test "hex.special" { try testing.expect(math.isPositiveInf(try parseFloat(f32, "iNf"))); try testing.expect(math.isPositiveInf(try parseFloat(f32, "+Inf"))); try testing.expect(math.isNegativeInf(try parseFloat(f32, "-iNf"))); + + try testing.expect(math.isPositiveInf(try parseFloat(f32, "0x9999p9999"))); + try testing.expect(math.isNegativeInf(try parseFloat(f32, "-0x9999p9999"))); } test "hex.zero" { diff --git a/lib/std/fmt/parse_float/convert_hex.zig b/lib/std/fmt/parse_float/convert_hex.zig @@ -78,7 +78,7 @@ pub fn convertHex(comptime T: type, n_: Number(T)) T { // Infinity and range error if (n.exponent > max_exp) { - return math.inf(T); + return if (n.negative) -math.inf(T) else math.inf(T); } var bits = n.mantissa & ((1 << mantissa_bits) - 1);