[go: up one dir, main page]

lexical-core 0.6.5

Lexical, to- and from-string conversion routines.
Documentation
//! Utilities for Rust primitives.

use lib::fmt;
use super::cast::{AsCast, TryCast};

/// Type that can be converted to primitive with `as`.
pub trait AsPrimitive: Copy + PartialEq + PartialOrd + Send + Sync {
    fn as_u8(self) -> u8;
    fn as_u16(self) -> u16;
    fn as_u32(self) -> u32;
    fn as_u64(self) -> u64;
    fn as_usize(self) -> usize;
    fn as_i8(self) -> i8;
    fn as_i16(self) -> i16;
    fn as_i32(self) -> i32;
    fn as_i64(self) -> i64;
    fn as_isize(self) -> isize;
    fn as_f32(self) -> f32;
    fn as_f64(self) -> f64;

    #[cfg(has_i128)]
    fn as_u128(self) -> u128;

    #[cfg(has_i128)]
    fn as_i128(self) -> i128;
}

macro_rules! as_primitive {
    ($($t:ty)*) => ($(
        impl AsPrimitive for $t {
            #[inline]
            fn as_u8(self) -> u8 {
                self as u8
            }

            #[inline]
            fn as_u16(self) -> u16 {
                self as u16
            }

            #[inline]
            fn as_u32(self) -> u32 {
                self as u32
            }

            #[inline]
            fn as_u64(self) -> u64 {
                self as u64
            }

            #[cfg(has_i128)]
            #[inline]
            fn as_u128(self) -> u128 {
                self as u128
            }

            #[inline]
            fn as_usize(self) -> usize {
                self as usize
            }

            #[inline]
            fn as_i8(self) -> i8 {
                self as i8
            }

            #[inline]
            fn as_i16(self) -> i16 {
                self as i16
            }

            #[inline]
            fn as_i32(self) -> i32 {
                self as i32
            }

            #[inline]
            fn as_i64(self) -> i64 {
                self as i64
            }

            #[cfg(has_i128)]
            #[inline]
            fn as_i128(self) -> i128 {
                self as i128
            }

            #[inline]
            fn as_isize(self) -> isize {
                self as isize
            }

            #[inline]
            fn as_f32(self) -> f32 {
                self as f32
            }

            #[inline]
            fn as_f64(self) -> f64 {
                self as f64
            }
        }
    )*)
}

as_primitive! { u8 u16 u32 u64 usize i8 i16 i32 i64 isize f32 f64 }
#[cfg(has_i128)] as_primitive! { u128 i128 }

macro_rules! def_try_primitive {
    ($($t:ty)*) => (
        /// Type that can be converted to primitive with `as`.
        pub trait TryPrimitive:
            AsCast +
            $(TryCast<$t> +)*
        {
            #[inline]
            fn try_u8(self) -> Option<u8> {
                self.try_cast()
            }

            #[inline]
            fn try_u16(self) -> Option<u16> {
                self.try_cast()
            }

            #[inline]
            fn try_u32(self) -> Option<u32> {
                self.try_cast()
            }

            #[inline]
            fn try_u64(self) -> Option<u64> {
                self.try_cast()
            }

            #[cfg(has_i128)]
            #[inline]
            fn try_u128(self) -> Option<u128> {
                self.try_cast()
            }

            #[inline]
            fn try_usize(self) -> Option<usize> {
                self.try_cast()
            }

            #[inline]
            fn try_i8(self) -> Option<i8> {
                self.try_cast()
            }

            #[inline]
            fn try_i16(self) -> Option<i16> {
                self.try_cast()
            }

            #[inline]
            fn try_i32(self) -> Option<i32> {
                self.try_cast()
            }

            #[inline]
            fn try_i64(self) -> Option<i64> {
                self.try_cast()
            }

            #[cfg(has_i128)]
            #[inline]
            fn try_i128(self) -> Option<i128> {
                self.try_cast()
            }

            #[inline]
            fn try_isize(self) -> Option<isize> {
                self.try_cast()
            }

            #[inline]
            fn try_f32(self) -> Option<f32> {
                self.try_cast()
            }

            #[inline]
            fn try_f64(self) -> Option<f64> {
                self.try_cast()
            }
        }
    );
}

#[cfg(has_i128)]
def_try_primitive!(u8 u16 u32 u64 u128 usize i8 i16 i32 i64 i128 isize f32 f64);

#[cfg(not(has_i128))]
def_try_primitive!(u8 u16 u32 u64 usize i8 i16 i32 i64 isize f32 f64);

macro_rules! try_primitive {
    ($($t:ty)*) => ($(
        impl TryPrimitive for $t {}
    )*)
}

try_primitive! { u8 u16 u32 u64 usize i8 i16 i32 i64 isize f32 f64 }
#[cfg(has_i128)] try_primitive! { u128 i128 }

// PRIMITIVE

/// Primitive type trait (which all have static lifetimes).
pub trait Primitive: 'static + fmt::Debug + fmt::Display + TryPrimitive
{}

macro_rules! primitive {
    ($($t:ty)*) => ($(
        impl Primitive for $t {}
    )*)
}

primitive! { u8 u16 u32 u64 usize i8 i16 i32 i64 isize f32 f64 }
#[cfg(has_i128)] primitive! { u128 i128 }

// TEST
// ----

#[cfg(test)]
mod tests {
    use super::*;

    fn check_as_primitive<T: AsPrimitive>(t: T) {
        let _: u8 = t.as_u8();
        let _: u16 = t.as_u16();
        let _: u32 = t.as_u32();
        let _: u64 = t.as_u64();
        let _: u128 = t.as_u128();
        let _: usize = t.as_usize();
        let _: i8 = t.as_i8();
        let _: i16 = t.as_i16();
        let _: i32 = t.as_i32();
        let _: i64 = t.as_i64();
        let _: i128 = t.as_i128();
        let _: isize = t.as_isize();
        let _: f32 = t.as_f32();
        let _: f64 = t.as_f64();
    }

    #[test]
    fn as_primitive_test() {
        check_as_primitive(1u8);
        check_as_primitive(1u16);
        check_as_primitive(1u32);
        check_as_primitive(1u64);
        check_as_primitive(1u128);
        check_as_primitive(1usize);
        check_as_primitive(1i8);
        check_as_primitive(1i16);
        check_as_primitive(1i32);
        check_as_primitive(1i64);
        check_as_primitive(1i128);
        check_as_primitive(1isize);
        check_as_primitive(1f32);
        check_as_primitive(1f64);
    }
}