Skip to content

Commit a6efff5

Browse files
author
Jorge Aparicio
committed
---
yaml --- r: 276595 b: refs/heads/try c: 064ec35 h: refs/heads/master i: 276593: bbfb15f 276591: 3daf229
1 parent cce4e5d commit a6efff5

File tree

2 files changed

+58
-1
lines changed

2 files changed

+58
-1
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
---
22
refs/heads/master: 6dbb0e86aec11050480beb76eade6fb805010ba7
33
refs/heads/snap-stage3: 235d77457d80b549dad3ac36d94f235208a1eafb
4-
refs/heads/try: a440c4a10c9694465c679922f0dcec9d463f3d6b
4+
refs/heads/try: 064ec35c18f396c2c26c05517290fdc1a4379586
55
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
66
refs/tags/release-0.2: c870d2dffb391e14efb05aa27898f1f6333a9596
77
refs/tags/release-0.3: b5f0d0f648d9a6153664837026ba1be43d3e2503
Lines changed: 57 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,57 @@
1+
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
use std::num::{ParseFloatError, ParseIntError};
12+
13+
fn main() {
14+
assert_eq!(simple(), Ok(1));
15+
assert_eq!(nested(), Ok(2));
16+
assert_eq!(merge_ok(), Ok(3.0));
17+
assert_eq!(merge_int_err(), Err(Error::Int));
18+
assert_eq!(merge_float_err(), Err(Error::Float));
19+
}
20+
21+
fn simple() -> Result<i32, ParseIntError> {
22+
Ok(try!("1".parse()))
23+
}
24+
25+
fn nested() -> Result<i32, ParseIntError> {
26+
Ok(try!(try!("2".parse::<i32>()).to_string().parse::<i32>()))
27+
}
28+
29+
fn merge_ok() -> Result<f32, Error> {
30+
Ok(try!("1".parse::<i32>()) as f32 + try!("2.0".parse::<f32>()))
31+
}
32+
33+
fn merge_int_err() -> Result<f32, Error> {
34+
Ok(try!("a".parse::<i32>()) as f32 + try!("2.0".parse::<f32>()))
35+
}
36+
37+
fn merge_float_err() -> Result<f32, Error> {
38+
Ok(try!("1".parse::<i32>()) as f32 + try!("b".parse::<f32>()))
39+
}
40+
41+
#[derive(Debug, PartialEq)]
42+
enum Error {
43+
Int,
44+
Float,
45+
}
46+
47+
impl From<ParseIntError> for Error {
48+
fn from(_: ParseIntError) -> Error {
49+
Error::Int
50+
}
51+
}
52+
53+
impl From<ParseFloatError> for Error {
54+
fn from(_: ParseFloatError) -> Error {
55+
Error::Float
56+
}
57+
}

0 commit comments

Comments
 (0)