LLVM 19.0.0git
Demangle.cpp
Go to the documentation of this file.
1//===-- Demangle.cpp - Common demangling functions ------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8///
9/// \file This file contains definitions of common demangling functions.
10///
11//===----------------------------------------------------------------------===//
12
15#include <cstdlib>
16#include <string_view>
17
18using llvm::itanium_demangle::starts_with;
19
20std::string llvm::demangle(std::string_view MangledName) {
21 std::string Result;
22
23 if (nonMicrosoftDemangle(MangledName, Result))
24 return Result;
25
26 if (starts_with(MangledName, '_') &&
27 nonMicrosoftDemangle(MangledName.substr(1), Result,
28 /*CanHaveLeadingDot=*/false))
29 return Result;
30
31 if (char *Demangled = microsoftDemangle(MangledName, nullptr, nullptr)) {
32 Result = Demangled;
33 std::free(Demangled);
34 } else {
35 Result = MangledName;
36 }
37 return Result;
38}
39
40static bool isItaniumEncoding(std::string_view S) {
41 // Itanium encoding requires 1 or 3 leading underscores, followed by 'Z'.
42 return starts_with(S, "_Z") || starts_with(S, "___Z");
43}
44
45static bool isRustEncoding(std::string_view S) { return starts_with(S, "_R"); }
46
47static bool isDLangEncoding(std::string_view S) { return starts_with(S, "_D"); }
48
49bool llvm::nonMicrosoftDemangle(std::string_view MangledName,
50 std::string &Result, bool CanHaveLeadingDot,
51 bool ParseParams) {
52 char *Demangled = nullptr;
53
54 // Do not consider the dot prefix as part of the demangled symbol name.
55 if (CanHaveLeadingDot && MangledName.size() > 0 && MangledName[0] == '.') {
56 MangledName.remove_prefix(1);
57 Result = ".";
58 }
59
60 if (isItaniumEncoding(MangledName))
61 Demangled = itaniumDemangle(MangledName, ParseParams);
62 else if (isRustEncoding(MangledName))
63 Demangled = rustDemangle(MangledName);
64 else if (isDLangEncoding(MangledName))
65 Demangled = dlangDemangle(MangledName);
66
67 if (!Demangled)
68 return false;
69
70 Result += Demangled;
71 std::free(Demangled);
72 return true;
73}
static bool isRustEncoding(std::string_view S)
Definition: Demangle.cpp:45
static bool isDLangEncoding(std::string_view S)
Definition: Demangle.cpp:47
static bool isItaniumEncoding(std::string_view S)
Definition: Demangle.cpp:40
DEMANGLE_NAMESPACE_BEGIN bool starts_with(std::string_view self, char C) noexcept
bool nonMicrosoftDemangle(std::string_view MangledName, std::string &Result, bool CanHaveLeadingDot=true, bool ParseParams=true)
Definition: Demangle.cpp:49
char * itaniumDemangle(std::string_view mangled_name, bool ParseParams=true)
Returns a non-NULL pointer to a NUL-terminated C style string that should be explicitly freed,...
char * dlangDemangle(std::string_view MangledName)
char * rustDemangle(std::string_view MangledName)
char * microsoftDemangle(std::string_view mangled_name, size_t *n_read, int *status, MSDemangleFlags Flags=MSDF_None)
Demangles the Microsoft symbol pointed at by mangled_name and returns it.
std::string demangle(std::string_view MangledName)
Attempt to demangle a string using different demangling schemes.
Definition: Demangle.cpp:20