Преглед на файлове

Inline only actual trait implementations

Vinzent Steinberg преди 7 години
родител
ревизия
1db660ed56
променени са 1 файла, в които са добавени 22 реда и са изтрити 6 реда
  1. 22 6
      src/float.rs

+ 22 - 6
src/float.rs

@@ -15,15 +15,12 @@ use NumCast;
 /// This trait implements a subset of the `Float` trait.
 pub trait FloatCore: Num + Neg<Output = Self> + PartialOrd + Copy {
     /// Returns positive infinity.
-    #[inline]
     fn infinity() -> Self;
 
     /// Returns negative infinity.
-    #[inline]
     fn neg_infinity() -> Self;
 
     /// Returns NaN.
-    #[inline]
     fn nan() -> Self;
 
     /// Returns `true` if the number is NaN.
@@ -53,7 +50,6 @@ pub trait FloatCore: Num + Neg<Output = Self> + PartialOrd + Copy {
     /// Returns the floating point category of the number. If only one property
     /// is going to be tested, it is generally faster to use the specific
     /// predicate instead.
-    #[inline]
     fn classify(self) -> FpCategory;
 
     /// Computes the absolute value of `self`. Returns `FloatCore::nan()` if the
@@ -147,24 +143,29 @@ pub trait FloatCore: Num + Neg<Output = Self> + PartialOrd + Copy {
     }
 
     /// Converts to degrees, assuming the number is in radians.
-    #[inline]
     fn to_degrees(self) -> Self;
 
     /// Converts to radians, assuming the number is in degrees.
-    #[inline]
     fn to_radians(self) -> Self;
 }
 
 impl FloatCore for f32 {
+    #[inline]
     fn infinity() -> Self {
         ::core::f32::INFINITY
     }
+
+    #[inline]
     fn neg_infinity() -> Self {
         ::core::f32::NEG_INFINITY
     }
+
+    #[inline]
     fn nan() -> Self {
         ::core::f32::NAN
     }
+
+    #[inline]
     fn classify(self) -> FpCategory {
         const EXP_MASK: u32 = 0x7f800000;
         const MAN_MASK: u32 = 0x007fffff;
@@ -178,24 +179,35 @@ impl FloatCore for f32 {
             _ => FpCategory::Normal,
         }
     }
+
+    #[inline]
     fn to_degrees(self) -> Self {
         self * (180.0 / ::core::f32::consts::PI)
     }
+
+    #[inline]
     fn to_radians(self) -> Self {
         self * (::core::f32::consts::PI / 180.0)
     }
 }
 
 impl FloatCore for f64 {
+    #[inline]
     fn infinity() -> Self {
         ::core::f64::INFINITY
     }
+
+    #[inline]
     fn neg_infinity() -> Self {
         ::core::f64::NEG_INFINITY
     }
+
+    #[inline]
     fn nan() -> Self {
         ::core::f64::NAN
     }
+
+    #[inline]
     fn classify(self) -> FpCategory {
         const EXP_MASK: u64 = 0x7ff0000000000000;
         const MAN_MASK: u64 = 0x000fffffffffffff;
@@ -209,9 +221,13 @@ impl FloatCore for f64 {
             _ => FpCategory::Normal,
         }
     }
+
+    #[inline]
     fn to_degrees(self) -> Self {
         self * (180.0 / ::core::f64::consts::PI)
     }
+
+    #[inline]
     fn to_radians(self) -> Self {
         self * (::core::f64::consts::PI / 180.0)
     }