23

My first thought is to map the Option, but I can't use try! from inside of the closure. The match statement looks unnecessary, but I can't figure out how to simplify it.

fn example<T, E>(val: Option<Result<T, E>>) -> Result<Option<T>, E> {
    Ok(match val {
        Some(v) => Some(v?),
        None => None
    })
}
GregoryComer
  • 740
  • 8
  • 18

2 Answers2

25

In Rust 1.33, transpose() is stable, so you can just call it:

fn main() {
    let x: Result<Option<i32>, ()> = Ok(Some(5));
    let y: Option<Result<i32, ()>> = Some(Ok(5));
    assert_eq!(x, y.transpose());
}
Stargateur
  • 24,473
  • 8
  • 65
  • 91
8

You can use Option::map_or():

val.map_or(Ok(None), |v| v.map(Some))
Lukas Kalbertodt
  • 79,749
  • 26
  • 255
  • 305
Ry-
  • 218,210
  • 55
  • 464
  • 476