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
})
}
You can use
Option::map_or()
:In Rust 1.33,
transpose()
is stable, so you can just call it: