chainerror/examples/tutorial4.rs

27 lines
525 B
Rust
Raw Normal View History

2018-12-20 14:52:06 +01:00
use chainerror::*;
2018-12-20 10:08:54 +01:00
use std::error::Error;
use std::result::Result;
fn do_some_io() -> Result<(), Box<Error>> {
Err("do_some_io error")?;
Ok(())
}
fn func2() -> Result<(), Box<Error>> {
2018-12-20 15:14:21 +01:00
let filename = "foo.txt";
do_some_io().map_err(mstrerr!("Error reading '{}'", filename))?;
2018-12-20 10:08:54 +01:00
Ok(())
}
fn func1() -> Result<(), Box<Error>> {
func2().map_err(mstrerr!("func1 error"))?;
Ok(())
}
fn main() -> Result<(), Box<Error>> {
if let Err(e) = func1() {
eprintln!("{:?}", e);
}
Ok(())
}