gimli 0.33.0

A library for reading and writing the DWARF debugging format.
Documentation
# `gimli`

[![](https://img.shields.io/crates/v/gimli.svg) ![](https://img.shields.io/crates/d/gimli.svg)](https://crates.io/crates/gimli)
[![](https://docs.rs/gimli/badge.svg)](https://docs.rs/gimli/)
[![Build Status](https://github.com/gimli-rs/gimli/workflows/Rust/badge.svg)](https://github.com/gimli-rs/gimli/actions)
[![Coverage Status](https://coveralls.io/repos/github/gimli-rs/gimli/badge.svg?branch=master)](https://coveralls.io/github/gimli-rs/gimli?branch=master)

`gimli` is a library for reading and writing the
[DWARF debugging format](https://dwarfstd.org/).

* **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. `gimli` also uses `DW_AT_sibling` references to avoid parsing a
  DIE's children to find its next sibling, when possible.

* **Cross-platform:** `gimli` makes 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 macOS.

  * Unsure which object file parser to use? Try the cross-platform
  [`object`]https://github.com/gimli-rs/object crate. See the
  [`gimli-examples`]./crates/examples/src/bin crate for usage with `gimli`.

## Install

To add a `gimli` dependency to your `Cargo.toml`, run:
```console
$ cargo add gimli
```

The minimum supported Rust version is 1.88.

## Documentation

* [Documentation on docs.rs]https://docs.rs/gimli/

* Example programs:

  * [A simple `.debug_info` parser]./crates/examples/src/bin/simple.rs

  * [A simple `.debug_line` parser]./crates/examples/src/bin/simple_line.rs

  * [A simple DWARF writer]./crates/examples/src/bin/simple_write.rs

  * [A simple DWARF converter]./crates/examples/src/bin/simple_convert.rs
    to read DWARF sections then write them back out again.

  * [A DWARF converter]./crates/examples/src/bin/convert.rs that modifies
    the DWARF by removing entries for dead code.

  * [A `dwarfdump` clone]./crates/examples/src/bin/dwarfdump.rs

  * [An `addr2line` clone]https://github.com/gimli-rs/addr2line

## License

Licensed under either of

  * Apache License, Version 2.0 ([`LICENSE-APACHE`]./LICENSE-APACHE or https://www.apache.org/licenses/LICENSE-2.0)
  * MIT license ([`LICENSE-MIT`]./LICENSE-MIT or https://opensource.org/licenses/MIT)

at your option.

## Contribution

See [CONTRIBUTING.md](./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.