/*! ~~~bash $ cargo run -q --example tutorial4 examples/tutorial4.rs:29: "func1 error" Caused by: examples/tutorial4.rs:24: "func2 error" Caused by: StringError("do_some_io error") ~~~ !*/ use chainerror::prelude::*; use std::error::Error; use std::result::Result; fn do_some_io() -> Result<(), Box> { Err("do_some_io error")?; Ok(()) } fn func2() -> Result<(), Box> { do_some_io().map_err(mstrerr!("func2 error"))?; Ok(()) } fn func1() -> Result<(), Box> { func2().map_err(mstrerr!("func1 error"))?; Ok(()) } fn main() -> Result<(), Box> { if let Err(e) = func1() { eprintln!("{:?}", e); } Ok(()) }