summaryrefslogtreecommitdiff
path: root/src/core
diff options
context:
space:
mode:
authorrubidium <rubidium@openttd.org>2009-12-09 00:41:18 +0000
committerrubidium <rubidium@openttd.org>2009-12-09 00:41:18 +0000
commitb0eacbf35013982a63b663b84d85e06f8a9f63fa (patch)
tree8958f30e74fba24f02e7098d3036639e592618a2 /src/core
parent784d6d836d5d879faa95ce3cbe7bdc2f1d4c072b (diff)
downloadopenttd-b0eacbf35013982a63b663b84d85e06f8a9f63fa.tar.xz
(svn r18438) -Codechange [FS#3337]: introduce a template for Clamp (fonsinchen) and reuse template functions in their non-template counterparts.
Diffstat (limited to 'src/core')
-rw-r--r--src/core/math_func.hpp41
1 files changed, 30 insertions, 11 deletions
diff --git a/src/core/math_func.hpp b/src/core/math_func.hpp
index b5e921a7c..576db697d 100644
--- a/src/core/math_func.hpp
+++ b/src/core/math_func.hpp
@@ -67,7 +67,7 @@ static FORCEINLINE T min(const T a, const T b)
*/
static FORCEINLINE int min(const int a, const int b)
{
- return (a < b) ? a : b;
+ return min<int>(a, b);
}
/**
@@ -81,7 +81,7 @@ static FORCEINLINE int min(const int a, const int b)
*/
static FORCEINLINE uint minu(const uint a, const uint b)
{
- return (a < b) ? a : b;
+ return min<uint>(a, b);
}
/**
@@ -131,7 +131,7 @@ static FORCEINLINE T *AlignPtr(T *x, uint n)
}
/**
- * Clamp an integer between an interval.
+ * Clamp a value between an interval.
*
* This function returns a value which is between the given interval of
* min and max. If the given value is in this interval the value itself
@@ -145,8 +145,10 @@ static FORCEINLINE T *AlignPtr(T *x, uint n)
* @param max the maximum of the interval.
* @returns A value between min and max which is closest to a.
* @see ClampU(uint, uint, uint)
+ * @see Clamp(int, int, int)
*/
-static FORCEINLINE int Clamp(const int a, const int min, const int max)
+template <typename T>
+static FORCEINLINE T Clamp(const T a, const T min, const T max)
{
if (a <= min) return min;
if (a >= max) return max;
@@ -154,6 +156,27 @@ static FORCEINLINE int Clamp(const int a, const int min, const int max)
}
/**
+ * Clamp an integer between an interval.
+ *
+ * This function returns a value which is between the given interval of
+ * min and max. If the given value is in this interval the value itself
+ * is returned otherwise the border of the interval is returned, according
+ * which side of the interval was 'left'.
+ *
+ * @note The min value must be less or equal of max or you get some
+ * unexpected results.
+ * @param a The value to clamp/truncate.
+ * @param min The minimum of the interval.
+ * @param max the maximum of the interval.
+ * @returns A value between min and max which is closest to a.
+ * @see ClampU(uint, uint, uint)
+ */
+static FORCEINLINE int Clamp(const int a, const int min, const int max)
+{
+ return Clamp<int>(a, min, max);
+}
+
+/**
* Clamp an unsigned integer between an interval.
*
* This function returns a value which is between the given interval of
@@ -171,9 +194,7 @@ static FORCEINLINE int Clamp(const int a, const int min, const int max)
*/
static FORCEINLINE uint ClampU(const uint a, const uint min, const uint max)
{
- if (a <= min) return min;
- if (a >= max) return max;
- return a;
+ return Clamp<uint>(a, min, max);
}
/**
@@ -192,9 +213,7 @@ static FORCEINLINE uint ClampU(const uint a, const uint min, const uint max)
*/
static FORCEINLINE int32 ClampToI32(const int64 a)
{
- if (a <= INT32_MIN) return INT32_MIN;
- if (a >= INT32_MAX) return INT32_MAX;
- return (int32)a;
+ return (int32)Clamp<int64>(a, INT32_MIN, INT32_MAX);
}
/**
@@ -206,7 +225,7 @@ static FORCEINLINE int32 ClampToI32(const int64 a)
*/
static FORCEINLINE uint16 ClampToU16(const uint64 a)
{
- return (uint16)(a <= UINT16_MAX ? a : UINT16_MAX);
+ return (uint16)min<uint64>(a, UINT16_MAX);
}
/**