39
fn main() {
    foo().map_err(|err| println!("{:?}", err));
}

fn foo() -> Result<(), std::io::Error> {
    Ok(())
}

results:

warning: unused `std::result::Result` that must be used
 --> src/main.rs:2:5
  |
2 |     foo().map_err(|err| println!("{:?}", err));
  |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  |
  = note: #[warn(unused_must_use)] on by default
  = note: this `Result` may be an `Err` variant, which should be handled

    Finished dev [unoptimized + debuginfo] target(s) in 0.58s
     Running `target/debug/playground`

playground link

Shepmaster
  • 388,571
  • 95
  • 1,107
  • 1,366
marathon
  • 7,881
  • 17
  • 74
  • 137

1 Answers1

53

You're not handling the result, you're mapping the result from one type to another.

foo().map_err(|err| println!("{:?}", err));

What that line does is call foo(), which returns Result<(), std::io::Error>. Then map_err uses the type returned by your closure (in this case, ()), and modifies the error type and returns Result<(), ()>. This is the result that you are not handling. Since you seem to want to just ignore this result, the simplest thing to do would probably be to call ok().

foo().map_err(|err| println!("{:?}", err)).ok();

ok() converts Result<T,E> to Option<T>, converting errors to None, which you won't get a warning for ignoring.

Alternatively:

match foo() {
    Err(e) => println!("{:?}", e),
    _ => ()
}
Benjamin Lindley
  • 101,917
  • 9
  • 204
  • 274
  • 17
    Or [`foo().unwrap_or_else(|err| println!("{:?}", err))`](https://doc.rust-lang.org/stable/std/result/enum.Result.html#method.unwrap_or_else) – Jmb Nov 19 '18 at 07:49