[][src]Crate symbolic_demangle

Provides demangling support.

Currently supported languages:

  • C++ (without windows)
  • Rust
  • Swift
  • ObjC (only symbol detection)

As the demangling schemes for different languages are different, the feature set is also inconsistent. In particular Rust for instance has no overloading so argument types are generally not expected to be encoded into the function name whereas they are in Swift and C++.

Examples

use symbolic_common::{Language, Name};
use symbolic_demangle::Demangle;

let name = Name::new("__ZN3std2io4Read11read_to_end17hb85a0f6802e14499E");
assert_eq!(name.detect_language(), Language::Rust);
assert_eq!(name.try_demangle(Default::default()), "std::io::Read::read_to_end");

Structs

DemangleOptions

Options for the demangling.

Enums

DemangleFormat

Defines the output format of the demangler.

Traits

Demangle

Allows to demangle potentially mangled names.

Functions

demangle

Demangles an identifier and falls back to the original symbol.