Clone this repo:
  1. ca5202e Merge pull request #88 from rust-lang/release-plz-2026-01-15T15-09-27Z by León Orell Valerian Liehr · 5 days ago main
  2. f65a6d8 chore(rustc-demangle): release v0.1.27 by github-actions[bot] · 5 days ago rustc-demangle-v0.1.27
  3. bce5e74 Merge pull request #87 from fmease/v0-dyn-trait-assoc-const-bindings by León Orell Valerian Liehr · 5 days ago
  4. 2631bdf Support v0 demangling of trait object types with assoc const bindings by León Orell Valerian Liehr · 12 days ago
  5. c5688cf chore: release by github-actions[bot] · 6 months ago rustc-demangle-v0.1.26

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.