Struct symbolic_demangle::DemangleOptions [−][src]
pub struct DemangleOptions { /* fields omitted */ }
Expand description
Options for Demangle::demangle
.
One can chose from complete, or name-only demangling, and toggle specific demangling features explicitly.
The resulting output depends very much on the language of the mangled Name
, and may change
over time as more fine grained demangling options and features are added. Not all options are
fully supported by each language, and not every feature is mutually exclusive on all languages.
Examples
use symbolic_common::{Name, NameMangling, Language}; use symbolic_demangle::{Demangle, DemangleOptions}; let symbol = Name::new("$s8mangling12GenericUnionO3FooyACyxGSicAEmlF", NameMangling::Mangled, Language::Swift); let simple = symbol.demangle(DemangleOptions::name_only()).unwrap(); assert_eq!(&simple, "GenericUnion.Foo<A>"); let full = symbol.demangle(DemangleOptions::complete()).unwrap(); assert_eq!(&full, "mangling.GenericUnion.Foo<A>(mangling.GenericUnion<A>.Type) -> (Swift.Int) -> mangling.GenericUnion<A>");
Implementations
DemangleOptions that output the most simple (likely name-only) demangling.
Determines whether a functions return type should be demangled.
Determines whether function argument types should be demangled.
Trait Implementations
Auto Trait Implementations
impl RefUnwindSafe for DemangleOptions
impl Send for DemangleOptions
impl Sync for DemangleOptions
impl Unpin for DemangleOptions
impl UnwindSafe for DemangleOptions
Blanket Implementations
Mutably borrows from an owned value. Read more