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
pub trait ParseNum {
fn parse_num<T: num::Num>(&self) -> Result<T, T::FromStrRadixErr>;
}
impl ParseNum for str {
fn parse_num<T: num::Num>(&self) -> Result<T, T::FromStrRadixErr> {
let (radix, trimmed_str) =
if self.starts_with("0x") || self.starts_with("0X") {
(16, &self[2..])
} else if self.starts_with("0b") || self.starts_with("0B") {
(2, &self[2..])
} else if self.starts_with("0o") || self.starts_with("0O") {
(8, &self[2..])
} else {
(10, self)
};
T::from_str_radix(trimmed_str, radix)
}
}
#[cfg(test)]
mod test {
use super::ParseNum;
#[test]
fn conversion() {
assert_eq!("0".parse_num::<i32>().unwrap(), 0i32);
assert_eq!("10".parse_num::<f32>().unwrap(), 10f32);
assert_eq!("0x01".parse_num::<u16>().unwrap(), 1u16);
assert_eq!("0xFF".parse_num::<f64>().unwrap(), 255f64);
assert_eq!("0b1111".parse_num::<u8>().unwrap(), 0b1111u8);
assert_eq!("0o1463".parse_num::<u16>().unwrap(), 0o1463u16);
assert_eq!("0XfF".parse_num::<f64>().unwrap(), 255f64);
assert_eq!("0B1111".parse_num::<u8>().unwrap(), 0b1111u8);
assert_eq!("0O1463".parse_num::<u16>().unwrap(), 0o1463u16);
}
#[test]
fn fails() {
assert!("".parse_num::<i8>().is_err());
assert!("0b".parse_num::<u8>().is_err());
assert!("0o".parse_num::<i16>().is_err());
assert!("0x".parse_num::<u16>().is_err());
assert!("a".parse_num::<i8>().is_err());
assert!("0b2".parse_num::<u8>().is_err());
assert!("0o8".parse_num::<i16>().is_err());
assert!("0xg".parse_num::<u16>().is_err());
}
}