From da3cfd5bbc56cfa3227dbc975da491be4dcd391b Mon Sep 17 00:00:00 2001 From: timmot Date: Sat, 18 Nov 2023 20:00:14 +1100 Subject: [PATCH] AK+LibWeb: Make clamp_to_int generic over all integrals --- AK/Math.h | 14 +++++++------- Userland/Libraries/LibWeb/PixelUnits.h | 10 +++++----- 2 files changed, 12 insertions(+), 12 deletions(-) diff --git a/AK/Math.h b/AK/Math.h index 474848e3d69..d063d5bc5c6 100644 --- a/AK/Math.h +++ b/AK/Math.h @@ -1026,17 +1026,17 @@ constexpr T pow(T x, T y) return exp2(y * log2(x)); } -template -constexpr int clamp_to_int(T value) +template +constexpr I clamp_to(T value) { - if (value >= static_cast(NumericLimits::max())) - return NumericLimits::max(); + if (value >= static_cast(NumericLimits::max())) + return NumericLimits::max(); - if (value <= static_cast(NumericLimits::min())) - return NumericLimits::min(); + if (value <= static_cast(NumericLimits::min())) + return NumericLimits::min(); if constexpr (IsFloatingPoint) - return round_to(value); + return round_to(value); return value; } diff --git a/Userland/Libraries/LibWeb/PixelUnits.h b/Userland/Libraries/LibWeb/PixelUnits.h index e39172415cc..873cc372a96 100644 --- a/Userland/Libraries/LibWeb/PixelUnits.h +++ b/Userland/Libraries/LibWeb/PixelUnits.h @@ -88,7 +88,7 @@ public: { i32 raw_value = 0; if (!isnan(value)) - raw_value = AK::clamp_to_int(value * fixed_point_denominator); + raw_value = AK::clamp_to(value * fixed_point_denominator); // Note: The resolution of CSSPixels is 0.015625, so care must be taken when converting // floats/doubles to CSSPixels as small values (such as scale factors) can underflow to zero, // or otherwise produce inaccurate results (when scaled back up). @@ -181,7 +181,7 @@ public: i64 value = raw_value(); value *= other.raw_value(); - int int_value = AK::clamp_to_int(value >> fractional_bits); + int int_value = AK::clamp_to(value >> fractional_bits); // Rounding: // If last bit cut off was 1: @@ -321,7 +321,7 @@ public: i64 wide_value = m_numerator.raw_value(); wide_value <<= CSSPixels::fractional_bits; wide_value = rounding_divide(wide_value, m_denominator.raw_value()); - return CSSPixels::from_raw(AK::clamp_to_int(wide_value)); + return CSSPixels::from_raw(AK::clamp_to(wide_value)); } constexpr CSSPixels operator-(CSSPixels const& other) const @@ -373,7 +373,7 @@ constexpr CSSPixels CSSPixels::operator*(CSSPixelFraction const& other) const i64 wide_value = raw_value(); wide_value *= other.numerator().raw_value(); wide_value = rounding_divide(wide_value, other.denominator().raw_value()); - return CSSPixels::from_raw(AK::clamp_to_int(wide_value)); + return CSSPixels::from_raw(AK::clamp_to(wide_value)); } constexpr CSSPixelFraction CSSPixels::operator/(CSSPixels const& other) const @@ -385,7 +385,7 @@ constexpr CSSPixels CSSPixels::operator/(CSSPixelFraction const& other) const i64 wide_value = raw_value(); wide_value *= other.denominator().raw_value(); wide_value = rounding_divide(wide_value, other.numerator().raw_value()); - return CSSPixels::from_raw(AK::clamp_to_int(wide_value)); + return CSSPixels::from_raw(AK::clamp_to(wide_value)); } template