Clone this repo:
  1. 83f1bbd Merge pull request #83 from Kobzol/no-publish-native-c by Jakub Beránek · 4 days ago main
  2. f29ee05 Do not publish the `native-c` crate by Jakub Beránek · 4 days ago
  3. 6de8895 Merge pull request #71 from Kobzol/ci-release by Jakub Beránek · 4 days ago
  4. 7ea46eb Use release-plz for releases by Jakub Beránek · 4 days ago
  5. b0a5d89 Add a CI workflow to publish new releases after a tag is pushed by Jakub Beránek · 5 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.