chainerror/booksrc/tutorial5.md

19 lines
594 B
Markdown
Raw Normal View History

2018-12-20 15:14:21 +01:00
## The source() of Errors
Sometimes you want to inspect the `source()` of an `Error`.
`chainerror` implements `std::error::Error::source()`, so you can get the cause of an error.
2018-12-20 14:52:06 +01:00
~~~rust
use crate::chainerror::*;
{{#include ../examples/tutorial5.rs:2:}}
# #[allow(dead_code)]
# mod chainerror {
{{#includecomment ../src/lib.rs}}
# }
2018-12-20 15:14:21 +01:00
~~~
Note, that we changed the output of the error in `main()` from `Debug` to `Display`, so we don't see
the error backtrace with filename and line number.
To enable the `Display` backtrace, you have to enable the feature `display-cause` for `chainerror`.