MathUtil: Fix Rectangle::GetWidth/Height for unsigned types

`std::abs(x - y)` where x and y are unsigned integers fails to compile
with an "call of overloaded 'abs(unsigned int)' is ambiguous" error
on GCC, and even if it did compile, that expression still wouldn't
give the correct result since `x - y` is unsigned.
This commit is contained in:
Léo Lam 2020-04-29 00:48:13 +02:00
parent 0ab9475f8e
commit 07ab79db64
1 changed files with 12 additions and 2 deletions

View File

@ -6,6 +6,7 @@
#include <algorithm> #include <algorithm>
#include <cmath> #include <cmath>
#include <type_traits>
#include <vector> #include <vector>
#include "Common/CommonTypes.h" #include "Common/CommonTypes.h"
@ -71,8 +72,8 @@ struct Rectangle
return left == r.left && top == r.top && right == r.right && bottom == r.bottom; return left == r.left && top == r.top && right == r.right && bottom == r.bottom;
} }
T GetWidth() const { return std::abs(right - left); } constexpr T GetWidth() const { return GetDistance(left, right); }
T GetHeight() const { return std::abs(bottom - top); } constexpr T GetHeight() const { return GetDistance(top, bottom); }
// If the rectangle is in a coordinate system with a lower-left origin, use // If the rectangle is in a coordinate system with a lower-left origin, use
// this Clamp. // this Clamp.
void ClampLL(T x1, T y1, T x2, T y2) void ClampLL(T x1, T y1, T x2, T y2)
@ -92,6 +93,15 @@ struct Rectangle
top = std::clamp(top, y1, y2); top = std::clamp(top, y1, y2);
bottom = std::clamp(bottom, y1, y2); bottom = std::clamp(bottom, y1, y2);
} }
private:
constexpr T GetDistance(T a, T b) const
{
if constexpr (std::is_unsigned<T>())
return b > a ? b - a : a - b;
else
return std::abs(b - a);
}
}; };
template <typename T> template <typename T>