Clone this repo:
  1. 42b42cc Merge pull request #77 from arielb1/idiomatic-c-demangle by Mark Rousskov · 20 hours ago main
  2. 80e40f5 add comment about finding latest version of code by Ariel Ben-Yehuda · 23 hours ago
  3. 35e24fc change legacy_demangle to be more idiomatic C by Ariel Ben-Yehuda · 23 hours ago
  4. 2cdc89e add some missing statics (#76) by Ariel Ben-Yehuda · 3 days ago
  5. 735451f Add a native C demangler (#75) by Ariel Ben-Yehuda · 3 days ago

rustc-demangle

Demangling for Rust symbols, written in Rust.

Documentation

Usage

You can add this as a dependency via your Cargo.toml

[dependencies]
rustc-demangle = "0.1"

and then be sure to check out the crate documentation for usage.

Usage from non-Rust languages

You can also use this crate from other languages via the C API wrapper in the crates/capi directory. This can be build with:

$ cargo build -p rustc-demangle-capi --release

You'll then find target/release/librustc_demangle.a and target/release/librustc_demangle.so (or a different name depending on your platform). These objects implement the interface specified in crates/capi/include/rustc_demangle.h.

If your build system does not support Rust, there is also a mostly-identical C version in the crates/native-c which you can use via copy-paste or as a git submodule. Read crates/native-c/README.md for more details. It is likely to be less supported than the Rust version, so it is better to use the Rust version if your build system supports it.

Both the Rust and C versions don't require memory allocation or any other operating-system support.

License

This project is licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in rustc-demangle you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.