about summary refs log tree commit diff
path: root/src/libstd
diff options
context:
space:
mode:
authorDirk Leifeld <leifeld@posteo.de>2019-03-09 19:16:54 +0100
committerDirk Leifeld <leifeld@posteo.de>2019-03-09 19:16:54 +0100
commitbd2e12609f190e7bf206dac2de2d68dbb4b1b5e6 (patch)
tree1ea51da28d589f5d354ad0830a55c1f651c18370 /src/libstd
parent097c04cf433048585dd9e3f63b30e03cc3509e4b (diff)
downloadrust-bd2e12609f190e7bf206dac2de2d68dbb4b1b5e6.tar.gz
rust-bd2e12609f190e7bf206dac2de2d68dbb4b1b5e6.zip
Revert "Revert "Add clamp functions""
Diffstat (limited to 'src/libstd')
-rw-r--r--src/libstd/f32.rs20
-rw-r--r--src/libstd/f64.rs20
2 files changed, 40 insertions, 0 deletions
diff --git a/src/libstd/f32.rs b/src/libstd/f32.rs
index cb1f9358177..df4dc2c7791 100644
--- a/src/libstd/f32.rs
+++ b/src/libstd/f32.rs
@@ -956,6 +956,26 @@ impl f32 {
     pub fn atanh(self) -> f32 {
         0.5 * ((2.0 * self) / (1.0 - self)).ln_1p()
     }
+    /// Returns max if self is greater than max, and min if self is less than min.
+    /// Otherwise this returns self.  Panics if min > max, min equals NaN, or max equals NaN.
+    ///
+    /// # Examples
+    ///
+    /// ```
+    /// assert!((-3.0f32).clamp(-2.0f32, 1.0f32) == -2.0f32);
+    /// assert!((0.0f32).clamp(-2.0f32, 1.0f32) == 0.0f32);
+    /// assert!((2.0f32).clamp(-2.0f32, 1.0f32) == 1.0f32);
+    /// ```
+    #[unstable(feature = "clamp", issue = "44095")]
+    #[inline]
+    pub fn clamp(self, min: f32, max: f32) -> f32 {
+        assert!(min <= max);
+        let mut x = self;
+        if x < min { x = min; }
+        if x > max { x = max; }
+        x
+    }
+
 }
 
 #[cfg(test)]
diff --git a/src/libstd/f64.rs b/src/libstd/f64.rs
index 7fa7b807519..00e7f279128 100644
--- a/src/libstd/f64.rs
+++ b/src/libstd/f64.rs
@@ -878,6 +878,26 @@ impl f64 {
         0.5 * ((2.0 * self) / (1.0 - self)).ln_1p()
     }
 
+    /// Returns max if self is greater than max, and min if self is less than min.
+    /// Otherwise this returns self.  Panics if min > max, min equals NaN, or max equals NaN.
+    ///
+    /// # Examples
+    ///
+    /// ```
+    /// assert!((-3.0f64).clamp(-2.0f64, 1.0f64) == -2.0f64);
+    /// assert!((0.0f64).clamp(-2.0f64, 1.0f64) == 0.0f64);
+    /// assert!((2.0f64).clamp(-2.0f64, 1.0f64) == 1.0f64);
+    /// ```
+    #[unstable(feature = "clamp", issue = "44095")]
+    #[inline]
+    pub fn clamp(self, min: f64, max: f64) -> f64 {
+        assert!(min <= max);
+        let mut x = self;
+        if x < min { x = min; }
+        if x > max { x = max; }
+        x
+    }
+
     // Solaris/Illumos requires a wrapper around log, log2, and log10 functions
     // because of their non-standard behavior (e.g., log(-n) returns -Inf instead
     // of expected NaN).