| // Copyright 2022 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef UI_GFX_GEOMETRY_CLAMP_FLOAT_GEOMETRY_H_ |
| #define UI_GFX_GEOMETRY_CLAMP_FLOAT_GEOMETRY_H_ |
| |
| #include <limits> |
| |
| #include "base/numerics/safe_conversions.h" |
| |
| namespace gfx { |
| |
| template <typename T> |
| struct FloatGeometrySaturationHandler { |
| static constexpr float NaN() { return 0; } |
| static constexpr float Overflow() { return max(); } |
| static constexpr float Underflow() { return lowest(); } |
| static constexpr float max() { |
| return std::numeric_limits<float>::max() / 1e6; |
| } |
| static constexpr float lowest() { |
| return std::numeric_limits<float>::lowest() / 1e6; |
| } |
| }; |
| |
| // Clamps |value| (float, double or long double) within the range of |
| // [numeric_limits<float>::lowest() / 1e6, numeric_limits<float::max() / 1e6f]. |
| // Returns 0 for NaN. This avoids NaN and infinity values immediately, and |
| // reduce the chance of producing NaN and infinity values for future unclamped |
| // operations like offsetting and scaling by devices / page scale factor. |
| template <typename T> |
| constexpr float ClampFloatGeometry(T value) { |
| return base::saturated_cast<float, FloatGeometrySaturationHandler, T>(value); |
| } |
| |
| } // namespace gfx |
| |
| #endif // UI_GFX_GEOMETRY_CLAMP_FLOAT_GEOMETRY_H_ |