#debug-information #dwarf #file-format #mach-o #object-file #stack-trace

symbolic-debuginfo

A library to inspect and load DWARF debugging information from binaries, such as Mach-O or ELF

126 stable releases (11 major)

new 12.13.2 Jan 14, 2025
12.12.4 Dec 18, 2024
12.12.3 Nov 26, 2024
12.10.0 Jul 24, 2024
1.1.5 Dec 2, 2017

#280 in Debugging

Download history 5918/week @ 2024-09-26 8606/week @ 2024-10-03 8255/week @ 2024-10-10 8907/week @ 2024-10-17 10218/week @ 2024-10-24 8330/week @ 2024-10-31 10852/week @ 2024-11-07 9459/week @ 2024-11-14 9958/week @ 2024-11-21 10675/week @ 2024-11-28 11980/week @ 2024-12-05 10401/week @ 2024-12-12 5617/week @ 2024-12-19 1925/week @ 2024-12-26 4146/week @ 2025-01-02 6344/week @ 2025-01-09

20,133 downloads per month
Used in 27 crates (13 directly)

MIT license

740KB
13K SLoC

Abstractions for dealing with object files and debug information.

This module defines the Object type, which is an abstraction over various object file formats used in different platforms. Also, since executables on MacOS might contain multiple object files (called a "Fat MachO"), there is an Archive type, that provides a uniform interface with access to an objects iterator in all platforms.

Most processing of object files will happen on the Object type or its concrete implementation for one platform. To allow abstraction over this, there is the ObjectLike trait. It defines common attributes and gives access to a DebugSession, which can be used to perform more stateful handling of debug information.

See Object for the full API, or use one of the modules for direct access to the platform-dependent data.

Background

The functionality of symbolic::debuginfo is conceptionally similar to the object crate. However, there are key differences that warranted a separate implementation:

  • object has a stronger focus on executable formats, while symbolic focusses on debugging information. This is why symbolic also includes a variant for PDBs and Breakpad objects, where object instead has a WASM variant.
  • object contains far more generic access to the data within objects at the cost of performance. symbolic tries to optimize for debugging scenarios at the cost of generic usage.
  • symbolic contains an abstraction for multi-object files (Archive), which is not easily possible in object due to the use of lifetimes on the object::Object trait.

Dependencies

~0.8–9MB
~89K SLoC