#backtrace #std #parse #debugging #parser

btparse-stable

A minimal deserializer for inspecting std::backtrace::Backtrace’s Debug format

1 unstable release

0.1.2 Dec 17, 2023

#1236 in Parser implementations

Download history 2764/week @ 2023-12-23 2721/week @ 2023-12-30 2566/week @ 2024-01-06 2928/week @ 2024-01-13 3403/week @ 2024-01-20 3466/week @ 2024-01-27 3510/week @ 2024-02-03 3023/week @ 2024-02-10 2761/week @ 2024-02-17 2699/week @ 2024-02-24 3085/week @ 2024-03-02 1791/week @ 2024-03-09 1651/week @ 2024-03-16 1798/week @ 2024-03-23 1759/week @ 2024-03-30 1587/week @ 2024-04-06

6,914 downloads per month
Used in 6 crates (via backtrace_printer)

MIT/Apache

17KB
356 lines

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
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.

No runtime deps