numfmt/numeric.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
/// An object is representable as a 64-bit floating point number.
pub trait Numeric {
/// Perform the conversion.
fn to_f64(&self) -> f64;
/// Return if the number is NaN.
///
/// The default implementation converts to `f64` and performs the test.
#[inline(always)]
fn is_nan(&self) -> bool {
self.to_f64().is_nan()
}
/// Return if the number is negative.
///
/// The default implementation converts to `f64` and performs the test.
#[inline(always)]
fn is_negative(&self) -> bool {
self.to_f64().is_sign_negative()
}
/// Return if the number is infinite.
///
/// The default implementation converts to `f64` and performs the test.
#[inline(always)]
fn is_infinite(&self) -> bool {
self.to_f64().is_infinite()
}
/// Return if the number is zero.
///
/// The default implementation converts to `f64` and performs the test.
#[inline(always)]
fn is_zero(&self) -> bool {
self.to_f64() == 0.0
}
}
macro_rules! prim_impls {
(float => $($t:ty)*) => {
$(impl Numeric for $t {
#[inline(always)]
fn to_f64(&self) -> f64 {
(*self).into()
}
#[inline(always)]
fn is_nan(&self) -> bool {
Self::is_nan(*self)
}
#[inline(always)]
fn is_negative(&self) -> bool {
Self::is_sign_negative(*self)
}
#[inline(always)]
fn is_infinite(&self) -> bool {
Self::is_infinite(*self)
}
#[inline(always)]
fn is_zero(&self) -> bool {
*self == 0.0
}
})*
};
(uint => $($t:ty)*) => {
$(impl Numeric for $t {
#[inline(always)]
fn to_f64(&self) -> f64 {
*self as f64
}
#[inline(always)]
fn is_nan(&self) -> bool {
false
}
#[inline(always)]
fn is_negative(&self) -> bool {
false
}
#[inline(always)]
fn is_infinite(&self) -> bool {
false
}
#[inline(always)]
fn is_zero(&self) -> bool {
*self == 0
}
})*
};
(int => $($t:ty)*) => {
$(impl Numeric for $t {
#[inline(always)]
fn to_f64(&self) -> f64 {
*self as f64
}
#[inline(always)]
fn is_nan(&self) -> bool {
false
}
#[inline(always)]
fn is_negative(&self) -> bool {
*self < 0
}
#[inline(always)]
fn is_infinite(&self) -> bool {
false
}
#[inline(always)]
fn is_zero(&self) -> bool {
*self == 0
}
})*
};
}
prim_impls!(float => f32 f64);
prim_impls!(uint => u8 u16 u32 u64 u128 usize);
prim_impls!(int => i8 i16 i32 i64 i128 isize);