aboutsummaryrefslogtreecommitdiff
path: root/src/check_builtin.cpp
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2025-02-08 07:49:22 +0000
committerGitHub <noreply@github.com>2025-02-08 07:49:22 +0000
commitfbee045023e638feb612d51aee1795009ff654cc (patch)
tree59ab5a06257e81da861e2239e4b98fe218321696 /src/check_builtin.cpp
parentcf326df54bc9abcd40920d5dbbcf25a985fdb23b (diff)
parent5defddffd074b221cbb393bfdd9c3d50ffd7b499 (diff)
Merge pull request #4797 from laytan/improve-abs-of-float
improve abs() on floats for more correct and faster results
Diffstat (limited to 'src/check_builtin.cpp')
-rw-r--r--src/check_builtin.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/check_builtin.cpp b/src/check_builtin.cpp
index 7d0ce3aef..5aa4cf027 100644
--- a/src/check_builtin.cpp
+++ b/src/check_builtin.cpp
@@ -3488,9 +3488,12 @@ gb_internal bool check_builtin_procedure(CheckerContext *c, Operand *operand, As
case ExactValue_Integer:
mp_abs(&operand->value.value_integer, &operand->value.value_integer);
break;
- case ExactValue_Float:
- operand->value.value_float = gb_abs(operand->value.value_float);
+ case ExactValue_Float: {
+ u64 abs = bit_cast<u64>(operand->value.value_float);
+ abs &= 0x7FFFFFFFFFFFFFFF;
+ operand->value.value_float = bit_cast<f64>(abs);
break;
+ }
case ExactValue_Complex: {
f64 r = operand->value.value_complex->real;
f64 i = operand->value.value_complex->imag;