mod.rs 4.0 KB
Newer Older
1 2 3 4 5 6 7 8 9 10
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.

11 12 13 14
use core::cmp::PartialEq;
use core::fmt::Show;
use core::num::{NumCast, cast};
use core::ops::{Add, Sub, Mul, Div, Rem};
N
Nick Cameron 已提交
15
use core::marker::Copy;
16

A
Alex Crichton 已提交
17
#[macro_use]
18
mod int_macros;
19

20 21 22 23 24
mod i8;
mod i16;
mod i32;
mod i64;
mod int;
25

A
Alex Crichton 已提交
26
#[macro_use]
27
mod uint_macros;
28

29 30 31 32 33 34 35
mod u8;
mod u16;
mod u32;
mod u64;
mod uint;

/// Helper function for testing numeric operations
36 37
pub fn test_num<T>(ten: T, two: T) where
    T: PartialEq + NumCast
J
Jorge Aparicio 已提交
38 39 40
     + Add<Output=T> + Sub<Output=T>
     + Mul<Output=T> + Div<Output=T>
     + Rem<Output=T> + Show
J
Jorge Aparicio 已提交
41
     + Copy
42
{
J
Jorge Aparicio 已提交
43 44 45 46 47
    assert_eq!(ten.add(two),  cast(12i).unwrap());
    assert_eq!(ten.sub(two),  cast(8i).unwrap());
    assert_eq!(ten.mul(two),  cast(20i).unwrap());
    assert_eq!(ten.div(two),  cast(5i).unwrap());
    assert_eq!(ten.rem(two),  cast(0i).unwrap());
48

J
Jorge Aparicio 已提交
49 50 51 52 53
    assert_eq!(ten.add(two),  ten + two);
    assert_eq!(ten.sub(two),  ten - two);
    assert_eq!(ten.mul(two),  ten * two);
    assert_eq!(ten.div(two),  ten / two);
    assert_eq!(ten.rem(two),  ten % two);
54
}
B
Brendan Zabarauskas 已提交
55 56 57

#[cfg(test)]
mod test {
C
Corey Farwell 已提交
58 59
    use core::option::Option;
    use core::option::Option::{Some, None};
B
Brendan Zabarauskas 已提交
60 61 62 63 64 65 66 67 68 69
    use core::num::Float;
    use core::num::from_str_radix;

    #[test]
    fn from_str_issue7588() {
        let u : Option<u8> = from_str_radix("1000", 10);
        assert_eq!(u, None);
        let s : Option<i16> = from_str_radix("80000", 10);
        assert_eq!(s, None);
        let f : Option<f32> = from_str_radix("10000000000000000000000000000000000000000", 10);
70
        assert_eq!(f, Some(Float::infinity()));
B
Brendan Zabarauskas 已提交
71
        let fe : Option<f32> = from_str_radix("1e40", 10);
72
        assert_eq!(fe, Some(Float::infinity()));
B
Brendan Zabarauskas 已提交
73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
    }

    #[test]
    fn test_from_str_radix_float() {
        let x1 : Option<f64> = from_str_radix("-123.456", 10);
        assert_eq!(x1, Some(-123.456));
        let x2 : Option<f32> = from_str_radix("123.456", 10);
        assert_eq!(x2, Some(123.456));
        let x3 : Option<f32> = from_str_radix("-0.0", 10);
        assert_eq!(x3, Some(-0.0));
        let x4 : Option<f32> = from_str_radix("0.0", 10);
        assert_eq!(x4, Some(0.0));
        let x4 : Option<f32> = from_str_radix("1.0", 10);
        assert_eq!(x4, Some(1.0));
        let x5 : Option<f32> = from_str_radix("-1.0", 10);
        assert_eq!(x5, Some(-1.0));
    }

    #[test]
    fn test_int_from_str_overflow() {
        let mut i8_val: i8 = 127_i8;
A
Alex Crichton 已提交
94 95
        assert_eq!("127".parse::<i8>(), Some(i8_val));
        assert_eq!("128".parse::<i8>(), None);
B
Brendan Zabarauskas 已提交
96 97

        i8_val += 1 as i8;
A
Alex Crichton 已提交
98 99
        assert_eq!("-128".parse::<i8>(), Some(i8_val));
        assert_eq!("-129".parse::<i8>(), None);
B
Brendan Zabarauskas 已提交
100 101

        let mut i16_val: i16 = 32_767_i16;
A
Alex Crichton 已提交
102 103
        assert_eq!("32767".parse::<i16>(), Some(i16_val));
        assert_eq!("32768".parse::<i16>(), None);
B
Brendan Zabarauskas 已提交
104 105

        i16_val += 1 as i16;
A
Alex Crichton 已提交
106 107
        assert_eq!("-32768".parse::<i16>(), Some(i16_val));
        assert_eq!("-32769".parse::<i16>(), None);
B
Brendan Zabarauskas 已提交
108 109

        let mut i32_val: i32 = 2_147_483_647_i32;
A
Alex Crichton 已提交
110 111
        assert_eq!("2147483647".parse::<i32>(), Some(i32_val));
        assert_eq!("2147483648".parse::<i32>(), None);
B
Brendan Zabarauskas 已提交
112 113

        i32_val += 1 as i32;
A
Alex Crichton 已提交
114 115
        assert_eq!("-2147483648".parse::<i32>(), Some(i32_val));
        assert_eq!("-2147483649".parse::<i32>(), None);
B
Brendan Zabarauskas 已提交
116 117

        let mut i64_val: i64 = 9_223_372_036_854_775_807_i64;
A
Alex Crichton 已提交
118 119
        assert_eq!("9223372036854775807".parse::<i64>(), Some(i64_val));
        assert_eq!("9223372036854775808".parse::<i64>(), None);
B
Brendan Zabarauskas 已提交
120 121

        i64_val += 1 as i64;
A
Alex Crichton 已提交
122 123
        assert_eq!("-9223372036854775808".parse::<i64>(), Some(i64_val));
        assert_eq!("-9223372036854775809".parse::<i64>(), None);
B
Brendan Zabarauskas 已提交
124 125
    }
}