btparse ======= A minimal deserializer for inspecting `std::backtrace::Backtrace`'s Debug format. ## Overview For the time being, the rust standard library is exporting the smallest API surface for `std::backtrace::Backtrace` that it possibly can, and only allows inspection via the `Debug` and `Display` traits. However, in order to provide custom formatting for backtraces, libraries like `color-backtrace` need to be able to iterate over the frames of a backtrace and access its various members like the filename and line number. This library provides a stop-gap solution. Until std eventually exports a stable iterator interface to backtrace frames this library will attempt to provide best effort parsing of backtrace's unstable Debug output. This will allow libraries like `color-backtrace` to provide unstable support for `std::backtrace::Backtrace` until it eventually stabilizes. Once std eventually stabilizes this library will update the internals to depend upon the provided iterator API instead of potentially fragile parsing.
# Usage ``` cargo add btparse ``` ```rust let bt = std::backtrace::Backtrace::capture(); let bt_parsed = btparse::deserialize(&bt); ```
#### License Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.