gimli
A lazy, zero-copy parser for the DWARF debugging format.
-
Zero copy: everything is just a reference to the original input buffer. No copies of the input data get made.
-
Lazy: you can iterate compilation units without parsing their contents. Parse only as many debugging information entry (DIE) trees as you iterate over.
gimlialso usesDW_AT_siblingreferences to avoid parsing a DIE's children to find its next sibling, when possible. -
Cross-platform:
gimlimakes no assumptions about what kind of object file you're working with. The flipside to that is that it's up to you to provide an ELF loader on Linux or Mach-O loader on OSX.
Install
Either
$ cargo add gimli
or add this to your Cargo.toml:
[]
= "0.11.0"
Documentation
-
Example programs:
License
Licensed under either of
- Apache License, Version 2.0 (
LICENSE-APACHEor http://www.apache.org/licenses/LICENSE-2.0) - MIT license (
LICENSE-MITor http://opensource.org/licenses/MIT)
at your option.
Contribution
See CONTRIBUTING.md for hacking.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.