19#include "llvm/ADT/StringRef.h"
20#include "llvm/Demangle/ItaniumDemangle.h"
68std::unique_ptr<Language::MethodName>
70 std::unique_ptr<CxxMethodName> cpp_method =
71 std::make_unique<CxxMethodName>(full_name);
72 cpp_method->IsValid();
76std::pair<FunctionNameType, std::optional<ConstString>>
79 return {eFunctionNameTypeFull, std::nullopt};
81 FunctionNameType func_name_type = eFunctionNameTypeNone;
84 if (basename.empty()) {
85 llvm::StringRef context;
88 ? (eFunctionNameTypeMethod | eFunctionNameTypeBase)
89 : eFunctionNameTypeFull);
91 func_name_type |= (eFunctionNameTypeMethod | eFunctionNameTypeBase);
97 func_name_type &= ~(eFunctionNameTypeBase);
100 if (basename.empty())
101 return {func_name_type, std::nullopt};
107 auto mangling_scheme =
117 if (demangled_name && mangled_name_cstr && mangled_name_cstr[0]) {
118 if (mangled_name_cstr[0] ==
'_' && mangled_name_cstr[1] ==
'Z' &&
119 (mangled_name_cstr[2] !=
'T' &&
122 mangled_name_cstr[2] !=
'G' &&
123 mangled_name_cstr[2] !=
'Z'))
129 std::string shortname;
131 shortname = cxx_method.
GetContext().str() +
"::";
138 return demangled_name;
153 const llvm::StringRef &left_right_chars,
154 size_t &left_pos,
size_t &right_pos,
155 size_t pos = llvm::StringRef::npos) {
156 assert(left_right_chars.size() == 2);
157 left_pos = llvm::StringRef::npos;
158 const char left_char = left_right_chars[0];
159 const char right_char = left_right_chars[1];
160 pos = s.find_last_of(left_right_chars, pos);
161 if (pos == llvm::StringRef::npos || s[pos] == left_char)
165 while (pos > 0 && depth > 0) {
166 pos = s.find_last_of(left_right_chars, pos);
167 if (pos == llvm::StringRef::npos)
169 if (s[pos] == left_char) {
172 return left_pos < right_pos;
174 }
else if (s[pos] == right_char) {
187 if (basename.starts_with(
'~'))
190 if (basename.size() <= idx)
193 if (!std::isalpha(
static_cast<unsigned char>(basename[idx])) &&
194 basename[idx] !=
'_')
200 while (idx < basename.size()) {
201 if (!std::isalnum(
static_cast<unsigned char>(basename[idx])) &&
202 basename[idx] !=
'_')
208 return idx == basename.size();
216 context = context.trim();
218 const auto iter = context.find_if_not([](
char current) {
219 return std::isalnum(
static_cast<unsigned char>(current)) ||
220 current ==
'_' || current ==
':';
222 return iter == llvm::StringRef::npos;
229 char const *full_name,
238 if (!return_type.empty()) {
251 if (!qualifiers.empty()) {
259static llvm::Expected<std::pair<llvm::StringRef, DemangledNameInfo>>
263 return llvm::createStringError(
"Function does not have a mangled name.");
266 if (demangled_name.empty())
267 return llvm::createStringError(
268 "Function '%s' does not have a demangled name.",
273 return llvm::createStringError(
274 "Function '%s' does not have demangled info.", demangled_name.data());
277 if (!info->hasBasename())
278 return llvm::createStringError(
279 "DemangledInfo for '%s does not have basename range.",
280 demangled_name.data());
282 return std::make_pair(demangled_name, *info);
285static llvm::Expected<llvm::StringRef>
289 return info_or_err.takeError();
291 auto [demangled_name, info] = *info_or_err;
303llvm::Expected<llvm::StringRef>
307 return llvm::createStringError(
308 "Template arguments range for '%s' is invalid.", demangled.data());
314static llvm::Expected<llvm::StringRef>
318 return info_or_err.takeError();
320 auto [demangled_name, info] = *info_or_err;
325llvm::Expected<llvm::StringRef>
328 if (info.
ScopeRange.first >= demangled.size())
329 return llvm::createStringError(
330 "Scope range for '%s' LHS return type is invalid.", demangled.data());
332 return demangled.substr(0, info.
ScopeRange.first);
335static llvm::Expected<llvm::StringRef>
339 return info_or_err.takeError();
341 auto [demangled_name, info] = *info_or_err;
346llvm::Expected<llvm::StringRef>
350 return llvm::createStringError(
"Qualifiers range for '%s' is invalid.",
357static llvm::Expected<llvm::StringRef>
361 return info_or_err.takeError();
363 auto [demangled_name, info] = *info_or_err;
369llvm::Expected<llvm::StringRef>
373 return llvm::createStringError(
374 "Qualifiers range for '%s' RHS return type is invalid.",
381static llvm::Expected<llvm::StringRef>
385 return info_or_err.takeError();
387 auto [demangled_name, info] = *info_or_err;
392llvm::Expected<llvm::StringRef>
396 return llvm::createStringError(
"Scope range for '%s' is invalid.",
402static llvm::Expected<llvm::StringRef>
406 return info_or_err.takeError();
408 auto [demangled_name, info] = *info_or_err;
413llvm::Expected<llvm::StringRef>
417 return llvm::createStringError(
"Suffix range for '%s' is invalid.",
423static llvm::Expected<llvm::StringRef>
427 return info_or_err.takeError();
429 auto [demangled_name, info] = *info_or_err;
434llvm::Expected<llvm::StringRef>
438 return llvm::createStringError(
439 "Function arguments range for '%s' is invalid.", demangled.data());
450 "Failed to handle ${{function.formatted-arguments}} "
451 "frame-format variable: {0}");
455 auto [demangled_name, info] = *info_or_err;
461 "Failed to handle ${{function.formatted-arguments}} "
462 "frame-format variable: {0}");
476 size_t arg_start, arg_end;
477 llvm::StringRef full(
m_full.GetCString());
478 llvm::StringRef parens(
"()", 2);
480 m_arguments = full.substr(arg_start, arg_end - arg_start + 1);
481 if (arg_end + 1 < full.size())
486 size_t basename_end = arg_start;
487 size_t context_start = 0;
488 size_t context_end = full.rfind(
':', basename_end);
489 if (context_end == llvm::StringRef::npos)
492 if (context_start < context_end)
493 m_context = full.substr(context_start, context_end - 1 - context_start);
494 const size_t basename_begin = context_end + 1;
495 m_basename = full.substr(basename_begin, basename_end - basename_begin);
544 size_t arg_start, arg_end;
545 llvm::StringRef parens(
"<>", 2);
547 return basename.substr(0, arg_start);
558 return m_full.GetStringRef().contains(path);
560 llvm::StringRef identifier;
561 llvm::StringRef context;
565 return m_full.GetStringRef().contains(path);
592 if (!haystack.consume_back(context))
594 if (haystack.empty() || !isalnum(haystack.back()))
607 llvm::StringRef name, llvm::StringRef &context,
608 llvm::StringRef &identifier) {
615 identifier = full_name->basename;
616 context = full_name->context;
624 std::vector<ConstString> alternates;
634 if (!strncmp(mangled_name.
GetCString(),
"_ZN", 3) &&
635 strncmp(mangled_name.
GetCString(),
"_ZNK", 4)) {
636 std::string fixed_scratch(
"_ZNK");
637 fixed_scratch.append(mangled_name.
GetCString() + 3);
642 if (!strncmp(mangled_name.
GetCString(),
"_Z", 2) &&
643 strncmp(mangled_name.
GetCString(),
"_ZL", 3)) {
644 std::string fixed_scratch(
"_ZL");
645 fixed_scratch.append(mangled_name.
GetCString() + 2);
655 if (
auto char_fixup_or_err =
658 if (*char_fixup_or_err)
659 alternates.push_back(*char_fixup_or_err);
662 "Failed to substitute 'char' type mangling: {0}");
665 if (
auto long_fixup_or_err =
667 if (*long_fixup_or_err)
668 alternates.push_back(*long_fixup_or_err);
671 "Failed to substitute 'long long' type mangling: {0}");
675 if (
auto ulong_fixup_or_err =
677 if (*ulong_fixup_or_err)
678 alternates.push_back(*ulong_fixup_or_err);
681 log, ulong_fixup_or_err.takeError(),
682 "Failed to substitute 'unsigned long long' type mangling: {0}");
686 if (*ctor_fixup_or_err) {
687 alternates.push_back(*ctor_fixup_or_err);
691 "Failed to substitute structor alias manglings: {0}");
705 if (!scope_qualified_name.size())
715 std::vector<ConstString> alternates;
718 std::vector<ConstString> param_and_qual_matches;
719 std::vector<ConstString> param_matches;
720 for (
size_t i = 0; i < alternates.size(); i++) {
721 ConstString alternate_mangled_name = alternates[i];
722 Mangled mangled(alternate_mangled_name);
731 param_and_qual_matches.push_back(alternate_mangled_name);
733 param_matches.push_back(alternate_mangled_name);
737 if (param_and_qual_matches.size())
738 return param_and_qual_matches[0];
740 else if (param_matches.size())
741 return param_matches[0];
747 if (!cpp_category_sp)
761 "std::string summary provider",
"^std::__[[:alnum:]]+::string$",
762 stl_summary_flags,
true);
765 "std::string summary provider",
766 "^std::__[[:alnum:]]+::basic_string<char, "
767 "std::__[[:alnum:]]+::char_traits<char>,.*>$",
768 stl_summary_flags,
true);
771 "std::string summary provider",
772 "^std::__[[:alnum:]]+::basic_string<unsigned char, "
773 "std::__[[:alnum:]]+::char_traits<unsigned char>,.*>$",
774 stl_summary_flags,
true);
778 "std::u16string summary provider",
779 "^std::__[[:alnum:]]+::basic_string<char16_t, "
780 "std::__[[:alnum:]]+::char_traits<char16_t>,.*>$",
781 stl_summary_flags,
true);
785 "std::u32string summary provider",
786 "^std::__[[:alnum:]]+::basic_string<char32_t, "
787 "std::__[[:alnum:]]+::char_traits<char32_t>,.*>$",
788 stl_summary_flags,
true);
792 "std::wstring summary provider",
793 "^std::__[[:alnum:]]+::wstring$", stl_summary_flags,
true);
796 "std::wstring summary provider",
797 "^std::__[[:alnum:]]+::basic_string<wchar_t, "
798 "std::__[[:alnum:]]+::char_traits<wchar_t>,.*>$",
799 stl_summary_flags,
true);
803 "std::string_view summary provider",
804 "^std::__[[:alnum:]]+::string_view$", stl_summary_flags,
true);
807 "std::string_view summary provider",
808 "^std::__[[:alnum:]]+::basic_string_view<char, "
809 "std::__[[:alnum:]]+::char_traits<char> >$",
810 stl_summary_flags,
true);
813 "std::string_view summary provider",
814 "^std::__[[:alnum:]]+::basic_string_view<unsigned char, "
815 "std::__[[:alnum:]]+::char_traits<unsigned char> >$",
816 stl_summary_flags,
true);
820 "std::u16string_view summary provider",
821 "^std::__[[:alnum:]]+::basic_string_view<char16_t, "
822 "std::__[[:alnum:]]+::char_traits<char16_t> >$",
823 stl_summary_flags,
true);
827 "std::u32string_view summary provider",
828 "^std::__[[:alnum:]]+::basic_string_view<char32_t, "
829 "std::__[[:alnum:]]+::char_traits<char32_t> >$",
830 stl_summary_flags,
true);
834 "std::wstring_view summary provider",
835 "^std::__[[:alnum:]]+::wstring_view$", stl_summary_flags,
true);
838 "std::wstring_view summary provider",
839 "^std::__[[:alnum:]]+::basic_string_view<wchar_t, "
840 "std::__[[:alnum:]]+::char_traits<wchar_t> >$",
841 stl_summary_flags,
true);
852 "libc++ std::bitset synthetic children",
853 "^std::__[[:alnum:]]+::bitset<.+>$", stl_deref_flags,
true);
857 "libc++ std::vector synthetic children",
858 "^std::__[[:alnum:]]+::vector<.+>$", stl_deref_flags,
true);
862 "libc++ std::valarray synthetic children",
863 "^std::__[[:alnum:]]+::valarray<.+>$", stl_deref_flags,
true);
867 "libc++ std::slice_array synthetic children",
868 "^std::__[[:alnum:]]+::slice_array<.+>$", stl_deref_flags,
true);
872 "libc++ synthetic children for the valarray proxy arrays",
873 "^std::__[[:alnum:]]+::(gslice|mask|indirect)_array<.+>$",
874 stl_deref_flags,
true);
878 "libc++ std::forward_list synthetic children",
879 "^std::__[[:alnum:]]+::forward_list<.+>$", stl_synth_flags,
true);
883 "libc++ std::list synthetic children",
886 "^std::__([A-Zabd-z0-9]|cx?[A-Za-wyz0-9]|cxx1?[A-Za-z02-9]|"
887 "cxx11[[:alnum:]])[[:alnum:]]*::list<.+>$",
888 stl_deref_flags,
true);
892 "libc++ std::map synthetic children",
"^std::__[[:alnum:]]+::map<.+> >$",
893 stl_synth_flags,
true);
897 "libc++ std::set synthetic children",
"^std::__[[:alnum:]]+::set<.+> >$",
898 stl_deref_flags,
true);
902 "libc++ std::multiset synthetic children",
903 "^std::__[[:alnum:]]+::multiset<.+> >$", stl_deref_flags,
true);
907 "libc++ std::multimap synthetic children",
908 "^std::__[[:alnum:]]+::multimap<.+> >$", stl_synth_flags,
true);
912 "libc++ std::unordered containers synthetic children",
913 "^std::__[[:alnum:]]+::unordered_(multi)?(map|set)<.+> >$",
914 stl_synth_flags,
true);
916 "libc++ std::queue synthetic children",
917 "^std::__[[:alnum:]]+::queue<.+>$", stl_synth_flags,
true);
919 "libc++ std::tuple synthetic children",
920 "^std::__[[:alnum:]]+::tuple<.*>$", stl_synth_flags,
true);
922 "libc++ std::optional synthetic children",
923 "^std::__[[:alnum:]]+::optional<.+>$", stl_synth_flags,
true);
925 "libc++ std::variant synthetic children",
926 "^std::__[[:alnum:]]+::variant<.+>$", stl_synth_flags,
true);
930 "libc++ std::atomic synthetic children",
931 "^std::__[[:alnum:]]+::atomic<.+>$", stl_synth_flags,
true);
935 "libc++ std::span synthetic children",
"^std::__[[:alnum:]]+::span<.+>$",
936 stl_deref_flags,
true);
940 "libc++ std::ranges::ref_view synthetic children",
941 "^std::__[[:alnum:]]+::ranges::ref_view<.+>$", stl_deref_flags,
true);
943 cpp_category_sp->AddTypeSynthetic(
947 "lldb.formatters.cpp.libcxx.stddeque_SynthProvider")));
952 "shared_ptr synthetic children",
"^std::__[[:alnum:]]+::shared_ptr<.+>$",
953 stl_synth_flags,
true);
955 static constexpr const char *
const libcxx_std_unique_ptr_regex =
956 "^std::__[[:alnum:]]+::unique_ptr<.+>$";
960 "unique_ptr synthetic children", libcxx_std_unique_ptr_regex,
961 stl_synth_flags,
true);
966 "weak_ptr synthetic children",
"^std::__[[:alnum:]]+::weak_ptr<.+>$",
967 stl_synth_flags,
true);
970 "libc++ std::function summary provider",
971 "^std::__[[:alnum:]]+::function<.+>$", stl_summary_flags,
true);
973 static constexpr const char *
const libcxx_std_coroutine_handle_regex =
974 "^std::__[[:alnum:]]+::coroutine_handle<.+>$";
978 "coroutine_handle synthetic children", libcxx_std_coroutine_handle_regex,
979 stl_deref_flags,
true);
985 "libc++ std::bitset summary provider",
986 "^std::__[[:alnum:]]+::bitset<.+>$", stl_summary_flags,
true);
989 "libc++ std::vector summary provider",
990 "^std::__[[:alnum:]]+::vector<.+>$", stl_summary_flags,
true);
993 "libc++ std::valarray summary provider",
994 "^std::__[[:alnum:]]+::valarray<.+>$", stl_summary_flags,
true);
997 "libc++ std::slice_array summary provider",
998 "^std::__[[:alnum:]]+::slice_array<.+>$", stl_summary_flags,
1002 "libc++ summary provider for the valarray proxy arrays",
1003 "^std::__[[:alnum:]]+::(gslice|mask|indirect)_array<.+>$",
1004 stl_summary_flags,
true);
1007 "libc++ std::list summary provider",
1008 "^std::__[[:alnum:]]+::forward_list<.+>$", stl_summary_flags,
true);
1011 "libc++ std::list summary provider",
1014 "^std::__([A-Zabd-z0-9]|cx?[A-Za-wyz0-9]|cxx1?[A-Za-z02-9]|"
1015 "cxx11[[:alnum:]])[[:alnum:]]*::list<.+>$",
1016 stl_summary_flags,
true);
1019 "libc++ std::map summary provider",
1020 "^std::__[[:alnum:]]+::map<.+>$", stl_summary_flags,
true);
1023 "libc++ std::deque summary provider",
1024 "^std::__[[:alnum:]]+::deque<.+>$", stl_summary_flags,
true);
1027 "libc++ std::queue summary provider",
1028 "^std::__[[:alnum:]]+::queue<.+>$", stl_summary_flags,
true);
1031 "libc++ std::set summary provider",
1032 "^std::__[[:alnum:]]+::set<.+>$", stl_summary_flags,
true);
1035 "libc++ std::multiset summary provider",
1036 "^std::__[[:alnum:]]+::multiset<.+>$", stl_summary_flags,
true);
1039 "libc++ std::multimap summary provider",
1040 "^std::__[[:alnum:]]+::multimap<.+>$", stl_summary_flags,
true);
1043 "libc++ std::unordered containers summary provider",
1044 "^std::__[[:alnum:]]+::unordered_(multi)?(map|set)<.+> >$",
1045 stl_summary_flags,
true);
1047 "libc++ std::tuple summary provider",
1048 "^std::__[[:alnum:]]+::tuple<.*>$", stl_summary_flags,
true);
1051 "libc++ std::atomic summary provider",
1052 "^std::__[[:alnum:]]+::atomic<.+>$", stl_summary_flags,
true);
1055 "libc++ std::optional summary provider",
1056 "^std::__[[:alnum:]]+::optional<.+>$", stl_summary_flags,
true);
1059 "libc++ std::variant summary provider",
1060 "^std::__[[:alnum:]]+::variant<.+>$", stl_summary_flags,
true);
1063 "libc++ std::span summary provider",
1064 "^std::__[[:alnum:]]+::span<.+>$", stl_summary_flags,
true);
1070 "libc++ std::shared_ptr summary provider",
1071 "^std::__[[:alnum:]]+::shared_ptr<.+>$", stl_summary_flags,
1075 "libc++ std::weak_ptr summary provider",
1076 "^std::__[[:alnum:]]+::weak_ptr<.+>$", stl_summary_flags,
true);
1079 "libc++ std::unique_ptr summary provider",
1080 libcxx_std_unique_ptr_regex, stl_summary_flags,
true);
1084 "libc++ std::coroutine_handle summary provider",
1085 libcxx_std_coroutine_handle_regex, stl_summary_flags,
true);
1090 "std::vector iterator synthetic children",
1091 "^std::__[[:alnum:]]+::__wrap_iter<.+>$", stl_synth_flags,
true);
1096 "std::map iterator synthetic children",
1097 "^std::__[[:alnum:]]+::__map_(const_)?iterator<.+>$", stl_synth_flags,
1103 "std::unordered_map iterator synthetic children",
1104 "^std::__[[:alnum:]]+::__hash_map_(const_)?iterator<.+>$",
1105 stl_synth_flags,
true);
1107 cpp_category_sp->AddTypeSummary(
1110 eTypeOptionHideChildren | eTypeOptionHideValue,
"${var.__rep_} ns")));
1111 cpp_category_sp->AddTypeSummary(
1114 eTypeOptionHideChildren | eTypeOptionHideValue,
"${var.__rep_} µs")));
1115 cpp_category_sp->AddTypeSummary(
1118 eTypeOptionHideChildren | eTypeOptionHideValue,
"${var.__rep_} ms")));
1119 cpp_category_sp->AddTypeSummary(
1122 eTypeOptionHideChildren | eTypeOptionHideValue,
"${var.__rep_} s")));
1123 cpp_category_sp->AddTypeSummary(
1126 eTypeOptionHideValue,
1127 "${var.__rep_} min")));
1128 cpp_category_sp->AddTypeSummary(
1131 eTypeOptionHideChildren | eTypeOptionHideValue,
"${var.__rep_} h")));
1133 cpp_category_sp->AddTypeSummary(
1136 eTypeOptionHideValue,
1137 "${var.__rep_} days")));
1138 cpp_category_sp->AddTypeSummary(
1141 eTypeOptionHideValue,
1142 "${var.__rep_} weeks")));
1143 cpp_category_sp->AddTypeSummary(
1146 eTypeOptionHideValue,
1147 "${var.__rep_} months")));
1148 cpp_category_sp->AddTypeSummary(
1151 eTypeOptionHideValue,
1152 "${var.__rep_} years")));
1153 cpp_category_sp->AddTypeSummary(
1156 eTypeOptionHideChildren | eTypeOptionHideValue,
"${var.__rep_} s")));
1162 "libc++ std::chrono::sys_seconds summary provider",
1163 "^std::__[[:alnum:]]+::chrono::time_point<"
1164 "std::__[[:alnum:]]+::chrono::system_clock, "
1165 "std::__[[:alnum:]]+::chrono::duration<.*, "
1166 "std::__[[:alnum:]]+::ratio<1, 1> "
1168 eTypeOptionHideChildren | eTypeOptionHideValue |
1173 "libc++ std::chrono::sys_seconds summary provider",
1174 "^std::__[[:alnum:]]+::chrono::time_point<"
1175 "std::__[[:alnum:]]+::chrono::system_clock, "
1176 "std::__[[:alnum:]]+::chrono::duration<int, "
1177 "std::__[[:alnum:]]+::ratio<86400, 1> "
1179 eTypeOptionHideChildren | eTypeOptionHideValue |
1186 "libc++ std::chrono::local_seconds summary provider",
1187 "^std::__[[:alnum:]]+::chrono::time_point<"
1188 "std::__[[:alnum:]]+::chrono::local_t, "
1189 "std::__[[:alnum:]]+::chrono::duration<.*, "
1190 "std::__[[:alnum:]]+::ratio<1, 1> "
1192 eTypeOptionHideChildren | eTypeOptionHideValue | eTypeOptionCascade,
1196 "libc++ std::chrono::local_seconds summary provider",
1197 "^std::__[[:alnum:]]+::chrono::time_point<"
1198 "std::__[[:alnum:]]+::chrono::local_t, "
1199 "std::__[[:alnum:]]+::chrono::duration<int, "
1200 "std::__[[:alnum:]]+::ratio<86400, 1> "
1202 eTypeOptionHideChildren | eTypeOptionHideValue |
1208 cpp_category_sp->AddTypeSummary(
1211 eTypeOptionHideValue,
1212 "day=${var.__d_%u}")));
1216 "libc++ std::chrono::month summary provider",
1217 "^std::__[[:alnum:]]+::chrono::month$",
1218 eTypeOptionHideChildren | eTypeOptionHideValue,
true);
1220 cpp_category_sp->AddTypeSummary(
1223 eTypeOptionHideChildren | eTypeOptionHideValue,
"year=${var.__y_}")));
1227 "libc++ std::chrono::weekday summary provider",
1228 "^std::__[[:alnum:]]+::chrono::weekday$",
1229 eTypeOptionHideChildren | eTypeOptionHideValue,
true);
1231 cpp_category_sp->AddTypeSummary(
1234 eTypeOptionHideChildren | eTypeOptionHideValue,
1235 "${var.__wd_} index=${var.__idx_%u}")));
1237 cpp_category_sp->AddTypeSummary(
1240 eTypeOptionHideValue,
1241 "${var.__wd_} index=last")));
1242 cpp_category_sp->AddTypeSummary(
1245 eTypeOptionHideValue,
1246 "${var.__m_} ${var.__d_}")));
1247 cpp_category_sp->AddTypeSummary(
1250 eTypeOptionHideValue,
1251 "${var.__m_} day=last")));
1253 cpp_category_sp->AddTypeSummary(
1256 eTypeOptionHideValue,
1257 "${var.__m_} ${var.__wdi_}")));
1259 cpp_category_sp->AddTypeSummary(
1262 eTypeOptionHideValue,
1263 "${var.__m_} ${var.__wdl_}")));
1265 cpp_category_sp->AddTypeSummary(
1268 eTypeOptionHideValue,
1269 "${var.__y_} ${var.__m_}")));
1274 "libc++ std::chrono::year_month_day summary provider",
1275 "^std::__[[:alnum:]]+::chrono::year_month_day$",
1276 eTypeOptionHideChildren | eTypeOptionHideValue,
true);
1278 cpp_category_sp->AddTypeSummary(
1279 "^std::__[[:alnum:]]+::chrono::year_month_day_last$",
1282 eTypeOptionHideValue,
1283 "${var.__y_} ${var.__mdl_}")));
1285 cpp_category_sp->AddTypeSummary(
1288 eTypeOptionHideChildren | eTypeOptionHideValue,
1289 "${var.__y_} ${var.__m_} ${var.__wdi_}")));
1291 cpp_category_sp->AddTypeSummary(
1292 "^std::__[[:alnum:]]+::chrono::year_month_weekday_last$",
1295 eTypeOptionHideChildren | eTypeOptionHideValue,
1296 "${var.__y_} ${var.__m_} ${var.__wdl_}")));
1302 auto makeSpecifier = [](llvm::StringRef name) {
1303 return std::make_shared<lldb_private::TypeNameSpecifierImpl>(
1307 category_sp->AddTypeSummary(makeSpecifier(string_ty), summary_sp);
1309 category_sp->AddTypeSummary(
1310 makeSpecifier(llvm::formatv(
"std::basic_string<{}>", char_ty).str()),
1313 category_sp->AddTypeSummary(
1314 std::make_shared<lldb_private::TypeNameSpecifierImpl>(
1315 llvm::formatv(
"^std::basic_string<{0}, ?std::char_traits<{0}>,.*>$",
1326 category_sp->AddTypeSummary(
1327 std::make_shared<lldb_private::TypeNameSpecifierImpl>(
1334 category_sp->AddTypeSummary(
1335 std::make_shared<lldb_private::TypeNameSpecifierImpl>(
1337 "^std::basic_string_view<{0}, ?std::char_traits<{0}> ?>$",
1345 if (!cpp_category_sp)
1359 "libstdc++ std::(w)string summary provider"));
1362 cpp_category_sp->AddTypeSummary(
1363 "^std::__cxx11::basic_string<char, std::char_traits<char>,.*>$",
1365 cpp_category_sp->AddTypeSummary(
"^std::__cxx11::basic_string<unsigned char, "
1366 "std::char_traits<unsigned char>,.*>$",
1371 cpp_category_sp->AddTypeSummary(
1372 "^std::__cxx11::basic_string<wchar_t, std::char_traits<wchar_t>,.*>$",
1381 cpp_category_sp->AddTypeSynthetic(
1385 "lldb.formatters.cpp.gnu_libstdcpp.StdVectorSynthProvider")));
1386 cpp_category_sp->AddTypeSynthetic(
1390 "lldb.formatters.cpp.gnu_libstdcpp.StdMapLikeSynthProvider")));
1391 cpp_category_sp->AddTypeSynthetic(
1395 "lldb.formatters.cpp.gnu_libstdcpp.StdDequeSynthProvider")));
1396 cpp_category_sp->AddTypeSynthetic(
1400 "lldb.formatters.cpp.gnu_libstdcpp.StdMapLikeSynthProvider")));
1401 cpp_category_sp->AddTypeSynthetic(
1405 "lldb.formatters.cpp.gnu_libstdcpp.StdMapLikeSynthProvider")));
1406 cpp_category_sp->AddTypeSynthetic(
1410 "lldb.formatters.cpp.gnu_libstdcpp.StdMapLikeSynthProvider")));
1411 cpp_category_sp->AddTypeSynthetic(
1415 "lldb.formatters.cpp.gnu_libstdcpp.StdUnorderedMapSynthProvider")));
1416 cpp_category_sp->AddTypeSynthetic(
1420 "lldb.formatters.cpp.gnu_libstdcpp.StdListSynthProvider")));
1421 cpp_category_sp->AddTypeSynthetic(
1425 "lldb.formatters.cpp.gnu_libstdcpp.StdForwardListSynthProvider")));
1428 "libstdc++ std::span synthetic children",
"^std::span<.+>$",
1429 stl_deref_flags,
true);
1436 "libstdc++ std::bitset summary provider",
1437 "^std::(__debug::)?bitset<.+>(( )?&)?$", stl_summary_flags,
true);
1441 "libstdc++ std::__debug::vector summary provider",
1442 "^std::__debug::vector<.+>(( )?&)?$", stl_summary_flags,
true);
1446 "libstdc++ debug std::map summary provider",
1447 "^std::__debug::map<.+> >(( )?&)?$", stl_summary_flags,
true);
1451 "libstdc++ debug std::set summary provider",
1452 "^std::__debug::set<.+> >(( )?&)?$", stl_summary_flags,
true);
1455 "libstdc++ debug std::deque summary provider",
1456 "^std::__debug::deque<.+>(( )?&)?$", stl_summary_flags,
true);
1460 "libstdc++ debug std::multimap summary provider",
1461 "^std::__debug::multimap<.+> >(( )?&)?$", stl_summary_flags,
true);
1465 "libstdc++ debug std::multiset summary provider",
1466 "^std::__debug::multiset<.+> >(( )?&)?$", stl_summary_flags,
true);
1470 "libstdc++ debug std unordered container summary provider",
1471 "^std::__debug::unordered_(multi)?(map|set)<.+> >$",
1472 stl_summary_flags,
true);
1476 "libstdc++ debug std::list summary provider",
1477 "^std::__(debug|cxx11)::list<.+>(( )?&)?$", stl_summary_flags,
true);
1479 cpp_category_sp->AddTypeSummary(
1483 "lldb.formatters.cpp.gnu_libstdcpp.ForwardListSummaryProvider")));
1488 "std::vector iterator synthetic children",
1489 "^__gnu_cxx::__normal_iterator<.+>$", stl_synth_flags,
true);
1494 "std::map iterator synthetic children",
1495 "^std::_Rb_tree_(const_)?iterator<.+>$", stl_synth_flags,
true);
1500 "std::unique_ptr synthetic children",
"^std::unique_ptr<.+>(( )?&)?$",
1501 stl_synth_flags,
true);
1503 static constexpr const char *
const libstdcpp_std_coroutine_handle_regex =
1504 "^std::coroutine_handle<.+>(( )?&)?$";
1508 "std::coroutine_handle synthetic children",
1509 libstdcpp_std_coroutine_handle_regex, stl_deref_flags,
true);
1514 "std::bitset synthetic child",
"^std::(__debug::)?bitset<.+>(( )?&)?$",
1515 stl_deref_flags,
true);
1519 "libstdc++ std::coroutine_handle summary provider",
1520 libstdcpp_std_coroutine_handle_regex, stl_summary_flags,
true);
1524 "libstdc++ std::span summary provider",
"^std::span<.+>$",
1525 stl_summary_flags,
true);
1528static lldb_private::SyntheticChildrenFrontEnd *
1547static lldb_private::SyntheticChildrenFrontEnd *
1565static SyntheticChildrenFrontEnd *
1576static SyntheticChildrenFrontEnd *
1587 "lldb.formatters.cpp.gnu_libstdcpp.StdVectorSynthProvider", *valobj_sp);
1590static SyntheticChildrenFrontEnd *
1599 "lldb.formatters.cpp.gnu_libstdcpp.StdListSynthProvider", *valobj_sp);
1602static SyntheticChildrenFrontEnd *
1611 "lldb.formatters.cpp.gnu_libstdcpp.StdForwardListSynthProvider",
1615static SyntheticChildrenFrontEnd *
1626static SyntheticChildrenFrontEnd *
1635 "lldb.formatters.cpp.gnu_libstdcpp.VariantSynthProvider", *valobj_sp);
1645static SyntheticChildrenFrontEnd *
1654 "lldb.formatters.cpp.gnu_libstdcpp.StdUnorderedMapSynthProvider",
1658static SyntheticChildrenFrontEnd *
1667 "lldb.formatters.cpp.gnu_libstdcpp.StdMapLikeSynthProvider", *valobj_sp);
1670static SyntheticChildrenFrontEnd *
1679 "lldb.formatters.cpp.gnu_libstdcpp.StdDequeSynthProvider", *valobj_sp);
1684 if (!cpp_category_sp)
1702 cpp_category_sp,
"std::string",
"char",
1703 std::make_shared<CXXFunctionSummaryFormat>(
1709 valobj, stream, options);
1712 "MSVC STL/libstdc++ std::string summary provider"));
1714 cpp_category_sp,
"std::wstring",
"wchar_t",
1715 std::make_shared<CXXFunctionSummaryFormat>(
1723 "MSVC STL/libstdc++ std::wstring summary provider"));
1730 "std::initializer_list synthetic children",
1731 "^std::initializer_list<.+>$", stl_synth_flags,
true);
1737 "std::shared_ptr synthetic children",
1738 "^std::shared_ptr<.+>(( )?&)?$", stl_synth_flags,
true);
1740 "std::weak_ptr synthetic children",
1741 "^std::weak_ptr<.+>(( )?&)?$", stl_synth_flags,
true);
1743 "std::unique_ptr synthetic children",
1744 "^std::unique_ptr<.+>(( )?&)?$", stl_synth_flags,
true);
1746 "std::tuple synthetic children",
"^std::tuple<.*>(( )?&)?$",
1747 stl_synth_flags,
true);
1749 "std::list synthetic children",
"^std::list<.+>(( )?&)?$",
1750 stl_synth_flags,
true);
1752 "std::forward_list synthetic children",
1753 "^std::forward_list<.+>(( )?&)?$", stl_synth_flags,
true);
1755 "std::variant synthetic children",
"^std::variant<.*>$",
1756 stl_synth_flags,
true);
1758 "std::unordered container synthetic children",
1759 "^std::unordered_(multi)?(map|set)<.+> ?>$", stl_synth_flags,
1765 "std::optional synthetic children",
1766 "^std::optional<.+>(( )?&)?$", stl_deref_flags,
true);
1768 "std::deque container synthetic children",
1769 "^std::deque<.+>(( )?&)?$", stl_deref_flags,
true);
1772 "std::(multi)?map/set synthetic children",
1773 "^std::(multi)?(map|set)<.+>(( )?&)?$", stl_synth_flags,
1777 "std::initializer_list summary provider",
1778 "^std::initializer_list<.+>$", stl_summary_flags,
true);
1780 "MSVC STL/libstdc++ std::shared_ptr summary provider",
1781 "^std::shared_ptr<.+>(( )?&)?$", stl_summary_flags,
true);
1783 "MSVC STL/libstdc++ std::weak_ptr summary provider",
1784 "^std::weak_ptr<.+>(( )?&)?$", stl_summary_flags,
true);
1786 "MSVC STL/libstdc++ std::unique_ptr summary provider",
1787 "^std::unique_ptr<.+>(( )?&)?$", stl_summary_flags,
true);
1789 "MSVC STL/libstdc++ std::tuple summary provider",
1790 "^std::tuple<.*>(( )?&)?$", stl_summary_flags,
true);
1792 "MSVC/libstdc++ std::vector summary provider",
1793 "^std::vector<.+>(( )?&)?$", stl_summary_flags,
true);
1795 "MSVC/libstdc++ std::vector synthetic provider",
1796 "^std::vector<.+>(( )?&)?$", stl_synth_flags,
true);
1798 "MSVC STL/libstdc++ std::list summary provider",
1799 "^std::list<.+>(( )?&)?$", stl_summary_flags,
true);
1800 cpp_category_sp->AddTypeSummary(
1804 "lldb.formatters.cpp.gnu_libstdcpp.ForwardListSummaryProvider")));
1806 "MSVC STL/libstd++ std::optional summary provider",
1807 "^std::optional<.+>(( )?&)?$", stl_summary_flags,
true);
1809 "MSVC STL/libstdc++ std::variant summary provider",
1810 "^std::variant<.*>$", stl_summary_flags,
true);
1812 "MSVC STL/libstdc++ std unordered container summary provider",
1813 "^std::unordered_(multi)?(map|set)<.+> ?>$", stl_summary_flags,
1816 "MSVC STL/libstdc++ std::(multi)?map/set summary provider",
1817 "^std::(multi)?(map|set)<.+>(( )?&)?$", stl_summary_flags,
1820 "MSVC STL/libstd++ std::deque summary provider",
1821 "^std::deque<.+>(( )?&)?$", stl_summary_flags,
true);
1825 if (!cpp_category_sp)
1843 cpp_category_sp,
"std::u8string",
"char8_t",
1844 std::make_shared<CXXFunctionSummaryFormat>(
1847 "MSVC STL std::u8string summary provider"));
1849 cpp_category_sp,
"std::u16string",
"char16_t",
1850 std::make_shared<CXXFunctionSummaryFormat>(
1853 "MSVC STL std::u16string summary provider"));
1855 cpp_category_sp,
"std::u32string",
"char32_t",
1856 std::make_shared<CXXFunctionSummaryFormat>(
1859 "MSVC STL std::u32string summary provider"));
1862 cpp_category_sp,
"std::string_view",
"char",
1863 std::make_shared<CXXFunctionSummaryFormat>(
1866 "MSVC STL std::string_view summary provider"));
1868 cpp_category_sp,
"std::u8string_view",
"char8_t",
1869 std::make_shared<CXXFunctionSummaryFormat>(
1872 "MSVC STL std::u8string_view summary provider"));
1874 cpp_category_sp,
"std::u16string_view",
"char16_t",
1875 std::make_shared<CXXFunctionSummaryFormat>(
1878 "MSVC STL std::u16string_view summary provider"));
1880 cpp_category_sp,
"std::u32string_view",
"char32_t",
1881 std::make_shared<CXXFunctionSummaryFormat>(
1884 "MSVC STL std::u32string_view summary provider"));
1886 cpp_category_sp,
"std::wstring_view",
"wchar_t",
1887 std::make_shared<CXXFunctionSummaryFormat>(
1889 "MSVC STL std::wstring_view summary provider"));
1894 "MSVC STL std::atomic synthetic children",
1895 "^std::atomic<.+>$", stl_synth_flags,
true);
1898 "MSVC STL std::atomic summary provider",
"^std::atomic<.+>$",
1899 stl_summary_flags,
true);
1901 "MSVC STL tree iterator synthetic children",
1902 "^std::_Tree(_const)?_iterator<.+>(( )?&)?$", stl_synth_flags,
1905 "MSVC STL tree iterator summary",
1906 "^std::_Tree(_const)?_iterator<.+>(( )?&)?$", stl_summary_flags,
1911 if (!cpp_category_sp)
1934 "char8_t * summary provider",
"char8_t *", string_flags);
1937 "char8_t [] summary provider",
"char8_t ?\\[[0-9]+\\]",
1938 string_array_flags,
true);
1942 "char16_t * summary provider",
"char16_t *", string_flags);
1945 "char16_t [] summary provider",
"char16_t ?\\[[0-9]+\\]",
1946 string_array_flags,
true);
1950 "char32_t * summary provider",
"char32_t *", string_flags);
1953 "char32_t [] summary provider",
"char32_t ?\\[[0-9]+\\]",
1954 string_array_flags,
true);
1958 "wchar_t * summary provider",
"wchar_t *", string_flags);
1961 "wchar_t * summary provider",
"wchar_t ?\\[[0-9]+\\]",
1962 string_array_flags,
true);
1966 "unichar * summary provider",
"unichar *", string_flags);
1978 "char8_t summary provider",
"char8_t", widechar_flags);
1981 "char16_t summary provider",
"char16_t", widechar_flags);
1984 "char32_t summary provider",
"char32_t", widechar_flags);
1986 "wchar_t summary provider",
"wchar_t", widechar_flags);
1990 "unichar summary provider",
"unichar", widechar_flags);
2007 return std::unique_ptr<TypeScavenger>(
new CPlusPlusTypeScavenger());
2011 static llvm::once_flag g_initialize;
2014 llvm::call_once(g_initialize, [
this]() ->
void {
2034 static llvm::once_flag g_initialize;
2038 llvm::call_once(g_initialize, []() ->
void {
2039 g_formatters.push_back(
2046 "Function pointer summary provider"));
2050 return formatter_sp;
2054 g_formatters.push_back(
2061 .SetDontShowChildren(
true)
2062 .SetHideItemNames(
true)
2063 .SetShowMembersOneLiner(
true)
2064 .SetSkipPointers(
true)
2065 .SetSkipReferences(
false),
2067 "vector_type pointer summary provider"));
2069 if (fmt_mgr.
GetCategory(g_vectortypes)->IsEnabled())
2070 return formatter_sp;
2074 g_formatters.push_back(
2081 .SetDontShowChildren(
true)
2082 .SetHideItemNames(
true)
2083 .SetShowMembersOneLiner(
true)
2084 .SetSkipPointers(
true)
2085 .SetSkipReferences(
false),
2087 "block pointer summary provider"));
2089 return formatter_sp;
2095 return g_formatters;
2100 static llvm::once_flag g_initialize;
2104 llvm::call_once(g_initialize, []() ->
void {
2112 .SetSkipPointers(
true)
2113 .SetSkipReferences(
true)
2114 .SetNonCacheable(
true),
2115 "vector_type synthetic children",
2118 if (fmt_mgr.
GetCategory(g_vectortypes)->IsEnabled())
2119 return formatter_sp;
2130 .SetSkipPointers(
true)
2131 .SetSkipReferences(
true)
2132 .SetNonCacheable(
true),
2133 "block pointer synthetic children",
2136 return formatter_sp;
2142 return g_formatters;
2149 bool canReadValue =
true;
2151 return canReadValue && isZero;
2155 const auto suffixes = {
".cpp",
".cxx",
".c++",
".cc",
".c",
2156 ".h",
".hh",
".hpp",
".hxx",
".h++"};
2157 for (
auto suffix : suffixes) {
2158 if (file_path.ends_with_insensitive(suffix))
2164 return file_path.contains(
"/usr/include/c++/");
2172 return inline_block->GetBlockVariableList(
true);
2209 switch (representation) {
2230 llvm_unreachable(
"Fully covered switch above");
2239 if (!scope_or_err) {
2242 "Failed to handle ${{function.scope}} frame-format variable: {0}");
2256 "Failed to handle ${{function.basename}} frame-format variable: {0}");
2267 if (!template_args_or_err) {
2269 template_args_or_err.takeError(),
2270 "Failed to handle ${{function.template-arguments}} "
2271 "frame-format variable: {0}");
2275 s << *template_args_or_err;
2305 if (!return_rhs_or_err) {
2307 "Failed to handle ${{function.return-right}} frame-format "
2312 s << *return_rhs_or_err;
2318 if (!return_lhs_or_err) {
2320 "Failed to handle ${{function.return-left}} frame-format "
2325 s << *return_lhs_or_err;
2331 if (!quals_or_err) {
2333 "Failed to handle ${{function.qualifiers}} frame-format "
2344 if (!suffix_or_err) {
2347 "Failed to handle ${{function.suffix}} frame-format variable: {0}");
2351 s << *suffix_or_err;
2361class NodeAllocator {
2362 llvm::BumpPtrAllocator Alloc;
2365 void reset() { Alloc.Reset(); }
2367 template <
typename T,
typename...
Args> T *makeNode(
Args &&...args) {
2368 return new (Alloc.Allocate(
sizeof(T),
alignof(T)))
2369 T(std::forward<Args>(args)...);
2372 void *allocateNodeArray(
size_t sz) {
2373 return Alloc.Allocate(
sizeof(llvm::itanium_demangle::Node *) * sz,
2374 alignof(llvm::itanium_demangle::Node *));
2378template <
typename Derived>
2379class ManglingSubstitutor
2380 :
public llvm::itanium_demangle::AbstractManglingParser<Derived,
2383 llvm::itanium_demangle::AbstractManglingParser<Derived, NodeAllocator>;
2386 ManglingSubstitutor() : Base(nullptr, nullptr) {}
2388 template <
typename... Ts>
2389 llvm::Expected<ConstString> substitute(llvm::StringRef Mangled,
2391 this->getDerived().reset(Mangled, std::forward<Ts>(Vals)...);
2392 return substituteImpl(Mangled);
2396 void reset(llvm::StringRef Mangled) {
2397 Base::reset(Mangled.begin(), Mangled.end());
2398 Written = Mangled.begin();
2400 Substituted =
false;
2403 llvm::Expected<ConstString> substituteImpl(llvm::StringRef Mangled) {
2404 if (this->parse() ==
nullptr)
2405 return llvm::createStringError(
2406 llvm::formatv(
"Failed to substitute mangling in '{0}'", Mangled));
2409 return ConstString();
2412 appendUnchangedInput();
2413 return ConstString(Result);
2416 void trySubstitute(llvm::StringRef From, llvm::StringRef To) {
2417 if (!llvm::StringRef(currentParserPos(), this->numLeft()).starts_with(From))
2421 appendUnchangedInput();
2425 Written += From.size();
2432 const char *Written =
"";
2434 llvm::SmallString<128> Result;
2437 bool Substituted =
false;
2439 const char *currentParserPos()
const {
return this->First; }
2441 void appendUnchangedInput() {
2443 llvm::StringRef(Written, std::distance(Written, currentParserPos()));
2444 Written = currentParserPos();
2450class TypeSubstitutor :
public ManglingSubstitutor<TypeSubstitutor> {
2451 llvm::StringRef Search;
2452 llvm::StringRef Replace;
2455 void reset(llvm::StringRef Mangled, llvm::StringRef Search,
2456 llvm::StringRef Replace) {
2457 ManglingSubstitutor::reset(Mangled);
2458 this->Search = Search;
2459 this->Replace = Replace;
2462 llvm::itanium_demangle::Node *parseType() {
2463 trySubstitute(Search, Replace);
2464 return ManglingSubstitutor::parseType();
2468class CtorDtorSubstitutor :
public ManglingSubstitutor<CtorDtorSubstitutor> {
2469 llvm::StringRef Search;
2470 llvm::StringRef Replace;
2473 void reset(llvm::StringRef Mangled, llvm::StringRef Search,
2474 llvm::StringRef Replace) {
2475 ManglingSubstitutor::reset(Mangled);
2476 this->Search = Search;
2477 this->Replace = Replace;
2480 void reset(llvm::StringRef Mangled) { ManglingSubstitutor::reset(Mangled); }
2482 llvm::itanium_demangle::Node *
2483 parseCtorDtorName(llvm::itanium_demangle::Node *&SoFar, NameState *
State) {
2484 if (!Search.empty() && !Replace.empty()) {
2485 trySubstitute(Search, Replace);
2487 trySubstitute(
"D1",
"D2");
2488 trySubstitute(
"C1",
"C2");
2490 return ManglingSubstitutor::parseCtorDtorName(SoFar,
State);
2495llvm::Expected<ConstString>
2497 llvm::StringRef subst_from,
2498 llvm::StringRef subst_to) {
2499 return TypeSubstitutor().substitute(mangled_name, subst_from, subst_to);
2503 llvm::StringRef mangled_name, llvm::StringRef subst_from,
2504 llvm::StringRef subst_to) {
2505 return CtorDtorSubstitutor().substitute(mangled_name, subst_from, subst_to);
2508llvm::Expected<ConstString>
2510 llvm::StringRef mangled_name) {
2511 return CtorDtorSubstitutor().substitute(mangled_name);
2514#define LLDB_PROPERTIES_language_cplusplus
2515#include "LanguageCPlusPlusProperties.inc"
2518#define LLDB_PROPERTIES_language_cplusplus
2519#include "LanguageCPlusPlusPropertiesEnum.inc"
2523class PluginProperties :
public Properties {
2525 static llvm::StringRef GetSettingName() {
return "display"; }
2527 PluginProperties() {
2528 m_collection_sp = std::make_shared<OptionValueProperties>(GetSettingName());
2529 m_collection_sp->Initialize(g_language_cplusplus_properties);
2532 FormatEntity::Entry GetFunctionNameFormat()
const {
2533 return GetPropertyAtIndexAs<FormatEntity::Entry>(
2534 ePropertyFunctionNameFormat, {});
2540 static PluginProperties g_settings;
2550 debugger, PluginProperties::GetSettingName())) {
2553 "Properties for the CPlusPlus language plug-in.",
static void LoadLibStdcppFormatters(lldb::TypeCategoryImplSP cpp_category_sp)
static llvm::Expected< llvm::StringRef > GetDemangledReturnTypeLHS(const SymbolContext &sc)
static llvm::Expected< llvm::StringRef > GetDemangledFunctionSuffix(const SymbolContext &sc)
static SyntheticChildrenFrontEnd * GenericUnorderedSyntheticFrontEndCreator(CXXSyntheticChildren *children, ValueObjectSP valobj_sp)
static SyntheticChildrenFrontEnd * GenericDequeSyntheticFrontEndCreator(CXXSyntheticChildren *children, ValueObjectSP valobj_sp)
static bool IsTrivialBasename(const llvm::StringRef &basename)
static bool PrintDemangledArgumentList(Stream &s, const SymbolContext &sc)
static SyntheticChildrenFrontEnd * GenericTupleSyntheticFrontEndCreator(CXXSyntheticChildren *children, lldb::ValueObjectSP valobj_sp)
static void RegisterStdStringSummaryProvider(const lldb::TypeCategoryImplSP &category_sp, llvm::StringRef string_ty, llvm::StringRef char_ty, lldb::TypeSummaryImplSP summary_sp)
static llvm::Expected< llvm::StringRef > GetDemangledBasename(const SymbolContext &sc)
static void LoadLibCxxFormatters(lldb::TypeCategoryImplSP cpp_category_sp)
static llvm::Expected< llvm::StringRef > GetDemangledScope(const SymbolContext &sc)
static bool GenericSmartPointerSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
static bool IsTrivialContext(llvm::StringRef context)
A context is trivial if an only if it matches this pattern.
static llvm::Expected< std::pair< llvm::StringRef, DemangledNameInfo > > GetAndValidateInfo(const SymbolContext &sc)
static llvm::Expected< llvm::StringRef > GetDemangledFunctionQualifiers(const SymbolContext &sc)
static SyntheticChildrenFrontEnd * GenericListSyntheticFrontEndCreator(CXXSyntheticChildren *children, lldb::ValueObjectSP valobj_sp)
static SyntheticChildrenFrontEnd * GenericOptionalSyntheticFrontEndCreator(CXXSyntheticChildren *children, lldb::ValueObjectSP valobj_sp)
static SyntheticChildrenFrontEnd * GenericVariantSyntheticFrontEndCreator(CXXSyntheticChildren *children, lldb::ValueObjectSP valobj_sp)
static void LoadMsvcStlFormatters(lldb::TypeCategoryImplSP cpp_category_sp)
static SyntheticChildrenFrontEnd * GenericMapLikeSyntheticFrontEndCreator(CXXSyntheticChildren *children, ValueObjectSP valobj_sp)
static llvm::Expected< llvm::StringRef > GetDemangledTemplateArguments(const SymbolContext &sc)
static SyntheticChildrenFrontEnd * GenericForwardListSyntheticFrontEndCreator(CXXSyntheticChildren *children, lldb::ValueObjectSP valobj_sp)
static lldb_private::SyntheticChildrenFrontEnd * GenericSmartPointerSyntheticFrontEndCreator(CXXSyntheticChildren *children, lldb::ValueObjectSP valobj_sp)
static void RegisterStdStringViewSummaryProvider(const lldb::TypeCategoryImplSP &category_sp, llvm::StringRef string_ty, llvm::StringRef char_ty, lldb::TypeSummaryImplSP summary_sp)
static llvm::Expected< llvm::StringRef > GetDemangledReturnTypeRHS(const SymbolContext &sc)
static bool ReverseFindMatchingChars(const llvm::StringRef &s, const llvm::StringRef &left_right_chars, size_t &left_pos, size_t &right_pos, size_t pos=llvm::StringRef::npos)
static void LoadCommonStlFormatters(lldb::TypeCategoryImplSP cpp_category_sp)
Load formatters that are formatting types from more than one STL.
static SyntheticChildrenFrontEnd * GenericVectorSyntheticFrontEndCreator(CXXSyntheticChildren *children, lldb::ValueObjectSP valobj_sp)
static void LoadSystemFormatters(lldb::TypeCategoryImplSP cpp_category_sp)
static lldb_private::SyntheticChildrenFrontEnd * GenericUniquePtrSyntheticFrontEndCreator(CXXSyntheticChildren *children, lldb::ValueObjectSP valobj_sp)
static bool GenericVariantSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
static bool GenericUniquePtrSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
static PluginProperties & GetGlobalPluginProperties()
#define LLDB_LOG_ERROR(log, error,...)
bool lldb_private::formatters::MsvcStlStringSummaryProvider< StringElementType::ASCII >(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
#define LLDB_PLUGIN_DEFINE(PluginName)
StringPrinter::StringElementType StringElementType
static bool IsMSVCUndecoratedName(llvm::StringRef name)
static bool ExtractContextAndIdentifier(llvm::StringRef name, llvm::StringRef &context, llvm::StringRef &identifier)
A command line argument class.
A class that describes a single lexical block.
lldb::VariableListSP GetBlockVariableList(bool can_create)
Get the variable list for this block only.
Block * GetContainingInlinedBlock()
Get the inlined block that contains this block.
bool ContainsPath(llvm::StringRef path)
llvm::StringRef GetBasenameNoTemplateParameters()
Returns the Basename of this method without a template parameter list, if any.
bool TrySimplifiedParse()
bool IsNilReference(ValueObject &valobj) override
static llvm::Expected< llvm::StringRef > GetDemangledFunctionQualifiers(llvm::StringRef demangled, const DemangledNameInfo &info)
static llvm::Expected< llvm::StringRef > GetDemangledReturnTypeLHS(llvm::StringRef demangled, const DemangledNameInfo &info)
static llvm::Expected< llvm::StringRef > GetDemangledTemplateArguments(llvm::StringRef demangled, const DemangledNameInfo &info)
bool IsSourceFile(llvm::StringRef file_path) const override
ConstString GetDemangledFunctionNameWithoutArguments(Mangled mangled) const override
static bool ExtractContextAndIdentifier(llvm::StringRef name, llvm::StringRef &context, llvm::StringRef &identifier)
lldb::TypeCategoryImplSP GetFormatters() override
static llvm::StringRef GetPluginNameStatic()
FormatEntity::Entry GetFunctionNameFormat() const override
HardcodedFormatters::HardcodedSyntheticFinder GetHardcodedSynthetics() override
static llvm::StringRef GetDemangledBasename(llvm::StringRef demangled, const DemangledNameInfo &info)
llvm::StringRef GetPluginName() override
std::vector< ConstString > GenerateAlternateFunctionManglings(const ConstString mangled) const override
static llvm::Expected< ConstString > SubstituteType_ItaniumMangle(llvm::StringRef mangled_name, llvm::StringRef subst_from, llvm::StringRef subst_to)
Substitutes Itanium type encoding substrings given by subst_from in mangled_name with subst_to.
bool GetFunctionDisplayName(const SymbolContext &sc, const ExecutionContext *exe_ctx, FunctionNameRepresentation representation, Stream &s) override
static llvm::Expected< llvm::StringRef > GetDemangledReturnTypeRHS(llvm::StringRef demangled, const DemangledNameInfo &info)
std::pair< lldb::FunctionNameType, std::optional< ConstString > > GetFunctionNameInfo(ConstString name) const override
bool DemangledNameContainsPath(llvm::StringRef path, ConstString demangled) const override
static llvm::Expected< llvm::StringRef > GetDemangledFunctionSuffix(llvm::StringRef demangled, const DemangledNameInfo &info)
ConstString FindBestAlternateFunctionMangledName(const Mangled mangled, const SymbolContext &sym_ctx) const override
bool SymbolNameFitsToLanguage(const Mangled &mangled) const override
Returns true iff the given symbol name is compatible with the mangling scheme of this language.
static llvm::Expected< llvm::StringRef > GetDemangledFunctionArguments(llvm::StringRef demangled, const DemangledNameInfo &info)
static llvm::Expected< llvm::StringRef > GetDemangledScope(llvm::StringRef demangled, const DemangledNameInfo &info)
std::unique_ptr< TypeScavenger > GetTypeScavenger() override
static llvm::Expected< ConstString > SubstituteStructor_ItaniumMangle(llvm::StringRef mangled_name, llvm::StringRef subst_from, llvm::StringRef subst_to)
Substitutes Itanium structor encoding substrings given by subst_from in mangled_name with subst_to.
HardcodedFormatters::HardcodedSummaryFinder GetHardcodedSummaries() override
static lldb_private::Language * CreateInstance(lldb::LanguageType language)
static llvm::Expected< ConstString > SubstituteStructorAliases_ItaniumMangle(llvm::StringRef mangled_name)
Tries replacing Itanium structor encoding substrings in mangled_name with potential aliases....
virtual std::unique_ptr< Language::MethodName > GetMethodName(ConstString name) const override
bool HandleFrameFormatVariable(const SymbolContext &sc, const ExecutionContext *exe_ctx, FormatEntity::Entry::Type type, Stream &s) override
static void DebuggerInitialize(Debugger &)
CPlusPlusLanguage()=default
std::optional< ParsedFunction > ParseAsFunctionDefinition()
std::optional< ParsedName > ParseAsFullName()
Generic representation of a type in a programming language.
lldb::LanguageType GetMinimumLanguage()
bool IsBlockPointerType(CompilerType *function_pointer_type_ptr=nullptr) const
CompilerType GetTypedefedType() const
If the current object represents a typedef type, get the underlying type.
bool IsFunctionPointerType() const
bool IsTypedefType() const
bool IsVectorType(CompilerType *element_type=nullptr, uint64_t *size=nullptr) const
A uniqued constant string class.
const char * AsCString(const char *value_if_empty=nullptr) const
Get the string value as a C string.
llvm::StringRef GetStringRef() const
Get the string value as a llvm::StringRef.
const char * GetCString() const
Get the string value as a C string.
static bool GetCategory(ConstString category, lldb::TypeCategoryImplSP &entry, bool allow_create=true)
A class to manage flag bits.
"lldb/Target/ExecutionContextScope.h" Inherit from this if your object can reconstruct its execution ...
"lldb/Target/ExecutionContext.h" A class that contains an execution context.
ExecutionContextScope * GetBestExecutionContextScope() const
Block & GetBlock(bool can_create)
Get accessor for the block list.
llvm::StringRef m_return_type
llvm::StringRef GetArguments()
llvm::StringRef m_basename
llvm::StringRef GetQualifiers()
llvm::StringRef m_qualifiers
std::string m_scope_qualified
llvm::StringRef m_arguments
llvm::StringRef GetReturnType()
llvm::StringRef GetBasename()
llvm::StringRef m_context
std::string GetScopeQualifiedName()
llvm::StringRef GetContext()
FunctionNameRepresentation
static bool LanguageIsC(lldb::LanguageType language)
static bool LanguageIsCPlusPlus(lldb::LanguageType language)
A class that handles mangled names.
static bool IsMangledName(llvm::StringRef name)
ConstString GetMangledName() const
Mangled name get accessor.
ConstString GetDemangledName() const
Demangled name get accessor.
const std::optional< DemangledNameInfo > & GetDemangledInfo() const
Retrieve DemangledNameInfo of the demangled name held by this object.
ConstString GetName(NamePreference preference=ePreferDemangled) const
Best name get accessor.
static Mangled::ManglingScheme GetManglingScheme(llvm::StringRef name)
Try to identify the mangling scheme used.
static bool RegisterPlugin(llvm::StringRef name, llvm::StringRef description, ABICreateInstance create_callback)
static lldb::OptionValuePropertiesSP GetSettingForCPlusPlusLanguagePlugin(Debugger &debugger, llvm::StringRef setting_name)
static bool CreateSettingForCPlusPlusLanguagePlugin(Debugger &debugger, const lldb::OptionValuePropertiesSP &properties_sp, llvm::StringRef description, bool is_global_property)
static bool UnregisterPlugin(ABICreateInstance create_callback)
A stream class that can stream formatted output to a file.
size_t PutCString(llvm::StringRef cstr)
Output a C string to the stream.
Defines a symbol context baton that can be handed other debug core functions.
Function * function
The Function for a given query.
Block * block
The Block for a given query.
lldb::ModuleSP module_sp
The Module for a given query.
Symbol * symbol
The Symbol for a given query.
Mangled GetPossiblyInlinedFunctionName() const
If available, will return the function name according to the specified mangling preference.
Provides public interface for all SymbolFiles.
virtual void GetMangledNamesForFunction(const std::string &scope_qualified_name, std::vector< ConstString > &mangled_names)
ConstString GetName() const
Flags & SetSkipReferences(bool value=true)
Flags & SetFrontEndWantsDereference(bool value=true)
Flags & SetSkipPointers(bool value=true)
Flags & SetCascades(bool value=true)
std::shared_ptr< SyntheticChildren > SharedPointer
Flags & SetCascades(bool value=true)
Flags & SetSkipPointers(bool value=true)
Flags & SetHideItemNames(bool value=true)
Flags & SetDontShowChildren(bool value=true)
Flags & SetSkipReferences(bool value=true)
Flags & SetShowMembersOneLiner(bool value=true)
Flags & SetDontShowValue(bool value=true)
std::shared_ptr< TypeSummaryImpl > SharedPointer
CompilerType GetCompilerType()
virtual uint64_t GetValueAsUnsigned(uint64_t fail_value, bool *success=nullptr)
virtual lldb::ValueType GetValueType() const =0
lldb::LanguageType GetObjectRuntimeLanguage()
size_t AppendVariablesWithScope(lldb::ValueType type, VariableList &var_list, bool if_unique=true)
A class that represents a running process on the host machine.
Log * GetLog(Cat mask)
Retrieve the Log object for the channel associated with the given log enum.
std::shared_ptr< lldb_private::TypeSummaryImpl > TypeSummaryImplSP
std::shared_ptr< lldb_private::ValueObject > ValueObjectSP
LanguageType
Programming language type.
@ eLanguageTypeObjC_plus_plus
Objective-C++.
std::shared_ptr< lldb_private::VariableList > VariableListSP
std::shared_ptr< lldb_private::SyntheticChildren > SyntheticChildrenSP
std::shared_ptr< lldb_private::TypeCategoryImpl > TypeCategoryImplSP
@ eValueTypeVTableEntry
function pointer in virtual function table
@ eValueTypeVariableArgument
function argument variables
Stores information about where certain portions of a demangled function name begin and end.
bool hasSuffix() const
Returns true if this object holds a valid suffix range.
bool hasBasename() const
Returns true if this object holds a valid basename range.
std::pair< size_t, size_t > TemplateArgumentsRange
A [start, end) pair for the function template arguments.
std::pair< size_t, size_t > ArgumentsRange
Indicates the [start, end) of the function argument list.
std::pair< size_t, size_t > SuffixRange
Indicates the [start, end) of the function's suffix.
std::pair< size_t, size_t > BasenameRange
A [start, end) pair for the function basename.
bool hasTemplateArguments() const
Returns true if this object holds a valid template arguments range.
bool hasScope() const
Returns true if this object holds a valid scope range.
bool hasQualifiers() const
Returns true if this object holds a valid qualifiers range.
bool hasArguments() const
Returns true if this object holds a valid arguments range.
std::pair< size_t, size_t > ScopeRange
A [start, end) pair for the function scope qualifiers.
std::pair< size_t, size_t > QualifiersRange
Indicates the [start, end) of the function qualifiers (e.g., CV-qualifiers, reference qualifiers,...
@ FunctionTemplateArguments
@ FunctionFormattedArguments