LLDB mainline
CPlusPlusLanguage.cpp
Go to the documentation of this file.
1//===-- CPlusPlusLanguage.cpp ---------------------------------------------===//
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#include "CPlusPlusLanguage.h"
10
11#include <cctype>
12#include <cstring>
13
14#include <functional>
15#include <memory>
16#include <mutex>
17#include <set>
18
19#include "llvm/ADT/StringRef.h"
20#include "llvm/Demangle/ItaniumDemangle.h"
21
23#include "lldb/Core/Mangled.h"
24#include "lldb/Core/Module.h"
36#include "lldb/Utility/Log.h"
39
40#include "BlockPointer.h"
41#include "CPlusPlusNameParser.h"
42#include "Coroutines.h"
43#include "CxxStringTypes.h"
44#include "Generic.h"
45#include "LibCxx.h"
46#include "LibCxxAtomic.h"
47#include "LibCxxVariant.h"
48#include "LibStdcpp.h"
50#include "MsvcStl.h"
52
53using namespace lldb;
54using namespace lldb_private;
55using namespace lldb_private::formatters;
56
58
63
67
68std::unique_ptr<Language::MethodName>
70 std::unique_ptr<CxxMethodName> cpp_method =
71 std::make_unique<CxxMethodName>(full_name);
72 cpp_method->IsValid();
73 return cpp_method;
74}
75
76std::pair<FunctionNameType, std::optional<ConstString>>
79 return {eFunctionNameTypeFull, std::nullopt};
80
81 FunctionNameType func_name_type = eFunctionNameTypeNone;
82 CxxMethodName method(name);
83 llvm::StringRef basename = method.GetBasename();
84 if (basename.empty()) {
85 llvm::StringRef context;
86 func_name_type |=
87 (ExtractContextAndIdentifier(name.GetStringRef(), context, basename)
88 ? (eFunctionNameTypeMethod | eFunctionNameTypeBase)
89 : eFunctionNameTypeFull);
90 } else {
91 func_name_type |= (eFunctionNameTypeMethod | eFunctionNameTypeBase);
92 }
93
94 if (!method.GetQualifiers().empty()) {
95 // There is a 'const' or other qualifier following the end of the function
96 // parens, this can't be a eFunctionNameTypeBase.
97 func_name_type &= ~(eFunctionNameTypeBase);
98 }
99
100 if (basename.empty())
101 return {func_name_type, std::nullopt};
102 else
103 return {func_name_type, ConstString(basename)};
104}
105
107 auto mangling_scheme =
109 return mangling_scheme == Mangled::eManglingSchemeItanium ||
110 mangling_scheme == Mangled::eManglingSchemeMSVC;
111}
112
114 Mangled mangled) const {
115 const char *mangled_name_cstr = mangled.GetMangledName().GetCString();
116 ConstString demangled_name = mangled.GetDemangledName();
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' && // avoid virtual table, VTT structure,
120 // typeinfo structure, and typeinfo
121 // mangled_name
122 mangled_name_cstr[2] != 'G' && // avoid guard variables
123 mangled_name_cstr[2] != 'Z')) // named local entities (if we
124 // eventually handle eSymbolTypeData,
125 // we will want this back)
126 {
127 CxxMethodName cxx_method(demangled_name);
128 if (!cxx_method.GetBasename().empty()) {
129 std::string shortname;
130 if (!cxx_method.GetContext().empty())
131 shortname = cxx_method.GetContext().str() + "::";
132 shortname += cxx_method.GetBasename().str();
133 return ConstString(shortname);
134 }
135 }
136 }
137 if (demangled_name)
138 return demangled_name;
139 return mangled.GetMangledName();
140}
141
142// Static Functions
143
145 // Use plugin for C++ but not for Objective-C++ (which has its own plugin).
146 if (Language::LanguageIsCPlusPlus(language) &&
147 language != eLanguageTypeObjC_plus_plus)
148 return new CPlusPlusLanguage();
149 return nullptr;
150}
151
152static bool ReverseFindMatchingChars(const llvm::StringRef &s,
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)
162 return false;
163 right_pos = pos;
164 uint32_t depth = 1;
165 while (pos > 0 && depth > 0) {
166 pos = s.find_last_of(left_right_chars, pos);
167 if (pos == llvm::StringRef::npos)
168 return false;
169 if (s[pos] == left_char) {
170 if (--depth == 0) {
171 left_pos = pos;
172 return left_pos < right_pos;
173 }
174 } else if (s[pos] == right_char) {
175 ++depth;
176 }
177 }
178 return false;
179}
180
181static bool IsTrivialBasename(const llvm::StringRef &basename) {
182 // Check that the basename matches with the following regular expression
183 // "^~?([A-Za-z_][A-Za-z_0-9]*)$" We are using a hand written implementation
184 // because it is significantly more efficient then using the general purpose
185 // regular expression library.
186 size_t idx = 0;
187 if (basename.starts_with('~'))
188 idx = 1;
189
190 if (basename.size() <= idx)
191 return false; // Empty string or "~"
192
193 if (!std::isalpha(static_cast<unsigned char>(basename[idx])) &&
194 basename[idx] != '_')
195 return false; // First character (after removing the possible '~'') isn't in
196 // [A-Za-z_]
197
198 // Read all characters matching [A-Za-z_0-9]
199 ++idx;
200 while (idx < basename.size()) {
201 if (!std::isalnum(static_cast<unsigned char>(basename[idx])) &&
202 basename[idx] != '_')
203 break;
204 ++idx;
205 }
206
207 // We processed all characters. It is a vaild basename.
208 return idx == basename.size();
209}
210
211/// A context is trivial if an only if it matches this pattern.
212/// "^\s*([A-Za-z_:]*)\s*$". for example function `foo::bar::func()`
213/// has a trivial context but. but `foo<int>::bar::func()` doesn't.
214static bool IsTrivialContext(llvm::StringRef context) {
215 // remove trailing or leading whitespace.
216 context = context.trim();
217
218 const auto iter = context.find_if_not([](char current) {
219 return std::isalnum(static_cast<unsigned char>(current)) ||
220 current == '_' || current == ':';
221 });
222 return iter == llvm::StringRef::npos;
223}
224
225/// Writes out the function name in 'full_name' to 'out_stream'
226/// but replaces each argument type with the variable name
227/// and the corresponding pretty-printed value
229 char const *full_name,
230 ExecutionContextScope *exe_scope,
231 VariableList const &args) {
232 CPlusPlusLanguage::CxxMethodName cpp_method{ConstString(full_name)};
233
234 if (!cpp_method.IsValid())
235 return false;
236
237 llvm::StringRef return_type = cpp_method.GetReturnType();
238 if (!return_type.empty()) {
239 out_stream.PutCString(return_type);
240 out_stream.PutChar(' ');
241 }
242
243 out_stream.PutCString(cpp_method.GetScopeQualifiedName());
244 out_stream.PutChar('(');
245
246 FormatEntity::PrettyPrintFunctionArguments(out_stream, args, exe_scope);
247
248 out_stream.PutChar(')');
249
250 llvm::StringRef qualifiers = cpp_method.GetQualifiers();
251 if (!qualifiers.empty()) {
252 out_stream.PutChar(' ');
253 out_stream.PutCString(qualifiers);
254 }
255
256 return true;
257}
258
259static llvm::Expected<std::pair<llvm::StringRef, DemangledNameInfo>>
262 if (!mangled)
263 return llvm::createStringError("Function does not have a mangled name.");
264
265 auto demangled_name = mangled.GetDemangledName().GetStringRef();
266 if (demangled_name.empty())
267 return llvm::createStringError(
268 "Function '%s' does not have a demangled name.",
269 mangled.GetMangledName().AsCString(""));
270
271 const std::optional<DemangledNameInfo> &info = mangled.GetDemangledInfo();
272 if (!info)
273 return llvm::createStringError(
274 "Function '%s' does not have demangled info.", demangled_name.data());
275
276 // Function without a basename is nonsense.
277 if (!info->hasBasename())
278 return llvm::createStringError(
279 "DemangledInfo for '%s does not have basename range.",
280 demangled_name.data());
281
282 return std::make_pair(demangled_name, *info);
283}
284
285static llvm::Expected<llvm::StringRef>
287 auto info_or_err = GetAndValidateInfo(sc);
288 if (!info_or_err)
289 return info_or_err.takeError();
290
291 auto [demangled_name, info] = *info_or_err;
292
293 return CPlusPlusLanguage::GetDemangledBasename(demangled_name, info);
294}
295
296llvm::StringRef
298 const DemangledNameInfo &info) {
299 assert(info.hasBasename());
300 return demangled.slice(info.BasenameRange.first, info.BasenameRange.second);
301}
302
303llvm::Expected<llvm::StringRef>
305 llvm::StringRef demangled, const DemangledNameInfo &info) {
306 if (!info.hasTemplateArguments())
307 return llvm::createStringError(
308 "Template arguments range for '%s' is invalid.", demangled.data());
309
310 return demangled.slice(info.TemplateArgumentsRange.first,
311 info.TemplateArgumentsRange.second);
312}
313
314static llvm::Expected<llvm::StringRef>
316 auto info_or_err = GetAndValidateInfo(sc);
317 if (!info_or_err)
318 return info_or_err.takeError();
319
320 auto [demangled_name, info] = *info_or_err;
321
322 return CPlusPlusLanguage::GetDemangledTemplateArguments(demangled_name, info);
323}
324
325llvm::Expected<llvm::StringRef>
327 const DemangledNameInfo &info) {
328 if (info.ScopeRange.first >= demangled.size())
329 return llvm::createStringError(
330 "Scope range for '%s' LHS return type is invalid.", demangled.data());
331
332 return demangled.substr(0, info.ScopeRange.first);
333}
334
335static llvm::Expected<llvm::StringRef>
337 auto info_or_err = GetAndValidateInfo(sc);
338 if (!info_or_err)
339 return info_or_err.takeError();
340
341 auto [demangled_name, info] = *info_or_err;
342
343 return CPlusPlusLanguage::GetDemangledReturnTypeLHS(demangled_name, info);
344}
345
346llvm::Expected<llvm::StringRef>
348 llvm::StringRef demangled, const DemangledNameInfo &info) {
349 if (!info.hasQualifiers())
350 return llvm::createStringError("Qualifiers range for '%s' is invalid.",
351 demangled.data());
352
353 return demangled.slice(info.QualifiersRange.first,
354 info.QualifiersRange.second);
355}
356
357static llvm::Expected<llvm::StringRef>
359 auto info_or_err = GetAndValidateInfo(sc);
360 if (!info_or_err)
361 return info_or_err.takeError();
362
363 auto [demangled_name, info] = *info_or_err;
364
366 info);
367}
368
369llvm::Expected<llvm::StringRef>
371 const DemangledNameInfo &info) {
372 if (info.QualifiersRange.first < info.ArgumentsRange.second)
373 return llvm::createStringError(
374 "Qualifiers range for '%s' RHS return type is invalid.",
375 demangled.data());
376
377 return demangled.slice(info.ArgumentsRange.second,
378 info.QualifiersRange.first);
379}
380
381static llvm::Expected<llvm::StringRef>
383 auto info_or_err = GetAndValidateInfo(sc);
384 if (!info_or_err)
385 return info_or_err.takeError();
386
387 auto [demangled_name, info] = *info_or_err;
388
389 return CPlusPlusLanguage::GetDemangledReturnTypeRHS(demangled_name, info);
390}
391
392llvm::Expected<llvm::StringRef>
393CPlusPlusLanguage::GetDemangledScope(llvm::StringRef demangled,
394 const DemangledNameInfo &info) {
395 if (!info.hasScope())
396 return llvm::createStringError("Scope range for '%s' is invalid.",
397 demangled.data());
398
399 return demangled.slice(info.ScopeRange.first, info.ScopeRange.second);
400}
401
402static llvm::Expected<llvm::StringRef>
404 auto info_or_err = GetAndValidateInfo(sc);
405 if (!info_or_err)
406 return info_or_err.takeError();
407
408 auto [demangled_name, info] = *info_or_err;
409
410 return CPlusPlusLanguage::GetDemangledScope(demangled_name, info);
411}
412
413llvm::Expected<llvm::StringRef>
415 const DemangledNameInfo &info) {
416 if (!info.hasSuffix())
417 return llvm::createStringError("Suffix range for '%s' is invalid.",
418 demangled.data());
419
420 return demangled.slice(info.SuffixRange.first, info.SuffixRange.second);
421}
422
423static llvm::Expected<llvm::StringRef>
425 auto info_or_err = GetAndValidateInfo(sc);
426 if (!info_or_err)
427 return info_or_err.takeError();
428
429 auto [demangled_name, info] = *info_or_err;
430
431 return CPlusPlusLanguage::GetDemangledFunctionSuffix(demangled_name, info);
432}
433
434llvm::Expected<llvm::StringRef>
436 llvm::StringRef demangled, const DemangledNameInfo &info) {
437 if (!info.hasArguments())
438 return llvm::createStringError(
439 "Function arguments range for '%s' is invalid.", demangled.data());
440
441 return demangled.slice(info.ArgumentsRange.first, info.ArgumentsRange.second);
442}
443
445 assert(sc.symbol);
446
447 auto info_or_err = GetAndValidateInfo(sc);
448 if (!info_or_err) {
449 LLDB_LOG_ERROR(GetLog(LLDBLog::Language), info_or_err.takeError(),
450 "Failed to handle ${{function.formatted-arguments}} "
451 "frame-format variable: {0}");
452 return false;
453 }
454
455 auto [demangled_name, info] = *info_or_err;
456
457 auto args_or_err =
459 if (!args_or_err) {
460 LLDB_LOG_ERROR(GetLog(LLDBLog::Language), args_or_err.takeError(),
461 "Failed to handle ${{function.formatted-arguments}} "
462 "frame-format variable: {0}");
463 return false;
464 }
465
466 s << *args_or_err;
467
468 return true;
469}
470
472 // This method tries to parse simple method definitions which are presumably
473 // most comman in user programs. Definitions that can be parsed by this
474 // function don't have return types and templates in the name.
475 // A::B::C::fun(std::vector<T> &) const
476 size_t arg_start, arg_end;
477 llvm::StringRef full(m_full.GetCString());
478 llvm::StringRef parens("()", 2);
479 if (ReverseFindMatchingChars(full, parens, arg_start, arg_end)) {
480 m_arguments = full.substr(arg_start, arg_end - arg_start + 1);
481 if (arg_end + 1 < full.size())
482 m_qualifiers = full.substr(arg_end + 1).ltrim();
483
484 if (arg_start == 0)
485 return false;
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)
490 m_basename = full.substr(0, basename_end);
491 else {
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);
496 }
497
499 return true;
500 }
501 // The C++ basename doesn't match our regular expressions so this can't
502 // be a valid C++ method, clear everything out and indicate an error
503 m_context = llvm::StringRef();
504 m_basename = llvm::StringRef();
505 m_arguments = llvm::StringRef();
506 m_qualifiers = llvm::StringRef();
507 m_return_type = llvm::StringRef();
508 return false;
509 }
510 return false;
511}
512
514 if (!m_parsed && m_full) {
515 if (TrySimplifiedParse()) {
516 m_parse_error = false;
517 } else {
518 CPlusPlusNameParser parser(m_full.GetStringRef());
519 if (auto function = parser.ParseAsFunctionDefinition()) {
520 m_basename = function->name.basename;
521 m_context = function->name.context;
522 m_arguments = function->arguments;
523 m_qualifiers = function->qualifiers;
524 m_return_type = function->return_type;
525 m_parse_error = false;
526 } else {
527 m_parse_error = true;
528 }
529 }
530 if (m_context.empty()) {
531 m_scope_qualified = std::string(m_basename);
532 } else {
534 m_scope_qualified += "::";
536 }
537 m_parsed = true;
538 }
539}
540
541llvm::StringRef
543 llvm::StringRef basename = GetBasename();
544 size_t arg_start, arg_end;
545 llvm::StringRef parens("<>", 2);
546 if (ReverseFindMatchingChars(basename, parens, arg_start, arg_end))
547 return basename.substr(0, arg_start);
548
549 return basename;
550}
551
553 if (!m_parsed)
554 Parse();
555
556 // If we can't parse the incoming name, then just check that it contains path.
557 if (m_parse_error)
558 return m_full.GetStringRef().contains(path);
559
560 llvm::StringRef identifier;
561 llvm::StringRef context;
562 const bool success =
563 CPlusPlusLanguage::ExtractContextAndIdentifier(path, context, identifier);
564 if (!success)
565 return m_full.GetStringRef().contains(path);
566
567 // Basename may include template arguments.
568 // E.g.,
569 // GetBaseName(): func<int>
570 // identifier : func
571 //
572 // ...but we still want to account for identifiers with template parameter
573 // lists, e.g., when users set breakpoints on template specializations.
574 //
575 // E.g.,
576 // GetBaseName(): func<uint32_t>
577 // identifier : func<int32_t*>
578 //
579 // Try to match the basename with or without template parameters.
580 if (GetBasename() != identifier &&
581 GetBasenameNoTemplateParameters() != identifier)
582 return false;
583
584 // Incoming path only had an identifier, so we match.
585 if (context.empty())
586 return true;
587 // Incoming path has context but this method does not, no match.
588 if (m_context.empty())
589 return false;
590
591 llvm::StringRef haystack = m_context;
592 if (!haystack.consume_back(context))
593 return false;
594 if (haystack.empty() || !isalnum(haystack.back()))
595 return true;
596
597 return false;
598}
599
601 ConstString demangled) const {
602 CxxMethodName demangled_name(demangled);
603 return demangled_name.ContainsPath(path);
604}
605
607 llvm::StringRef name, llvm::StringRef &context,
608 llvm::StringRef &identifier) {
611 identifier);
612
613 CPlusPlusNameParser parser(name);
614 if (auto full_name = parser.ParseAsFullName()) {
615 identifier = full_name->basename;
616 context = full_name->context;
617 return true;
618 }
619 return false;
620}
621
623 const ConstString mangled_name) const {
624 std::vector<ConstString> alternates;
625
626 /// Get a basic set of alternative manglings for the given symbol `name`, by
627 /// making a few basic possible substitutions on basic types, storage duration
628 /// and `const`ness for the given symbol. The output parameter `alternates`
629 /// is filled with a best-guess, non-exhaustive set of different manglings
630 /// for the given name.
631
632 // Maybe we're looking for a const symbol but the debug info told us it was
633 // non-const...
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);
638 alternates.push_back(ConstString(fixed_scratch));
639 }
640
641 // Maybe we're looking for a static symbol but we thought it was global...
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);
646 alternates.push_back(ConstString(fixed_scratch));
647 }
648
649 auto *log = GetLog(LLDBLog::Language);
650
651 // `char` is implementation defined as either `signed` or `unsigned`. As a
652 // result a char parameter has 3 possible manglings: 'c'-char, 'a'-signed
653 // char, 'h'-unsigned char. If we're looking for symbols with a signed char
654 // parameter, try finding matches which have the general case 'c'.
655 if (auto char_fixup_or_err =
656 SubstituteType_ItaniumMangle(mangled_name.GetStringRef(), "a", "c")) {
657 // LLDB_LOG(log, "Substituted mangling {0} -> {1}", Mangled, Result);
658 if (*char_fixup_or_err)
659 alternates.push_back(*char_fixup_or_err);
660 } else
661 LLDB_LOG_ERROR(log, char_fixup_or_err.takeError(),
662 "Failed to substitute 'char' type mangling: {0}");
663
664 // long long parameter mangling 'x', may actually just be a long 'l' argument
665 if (auto long_fixup_or_err =
666 SubstituteType_ItaniumMangle(mangled_name.GetStringRef(), "x", "l")) {
667 if (*long_fixup_or_err)
668 alternates.push_back(*long_fixup_or_err);
669 } else
670 LLDB_LOG_ERROR(log, long_fixup_or_err.takeError(),
671 "Failed to substitute 'long long' type mangling: {0}");
672
673 // unsigned long long parameter mangling 'y', may actually just be unsigned
674 // long 'm' argument
675 if (auto ulong_fixup_or_err =
676 SubstituteType_ItaniumMangle(mangled_name.GetStringRef(), "y", "m")) {
677 if (*ulong_fixup_or_err)
678 alternates.push_back(*ulong_fixup_or_err);
679 } else
681 log, ulong_fixup_or_err.takeError(),
682 "Failed to substitute 'unsigned long long' type mangling: {0}");
683
684 if (auto ctor_fixup_or_err = SubstituteStructorAliases_ItaniumMangle(
685 mangled_name.GetStringRef())) {
686 if (*ctor_fixup_or_err) {
687 alternates.push_back(*ctor_fixup_or_err);
688 }
689 } else
690 LLDB_LOG_ERROR(log, ctor_fixup_or_err.takeError(),
691 "Failed to substitute structor alias manglings: {0}");
692
693 return alternates;
694}
695
697 const Mangled mangled, const SymbolContext &sym_ctx) const {
698 ConstString demangled = mangled.GetDemangledName();
699 if (!demangled)
700 return ConstString();
701
702 CxxMethodName cpp_name(demangled);
703 std::string scope_qualified_name = cpp_name.GetScopeQualifiedName();
704
705 if (!scope_qualified_name.size())
706 return ConstString();
707
708 if (!sym_ctx.module_sp)
709 return ConstString();
710
711 lldb_private::SymbolFile *sym_file = sym_ctx.module_sp->GetSymbolFile();
712 if (!sym_file)
713 return ConstString();
714
715 std::vector<ConstString> alternates;
716 sym_file->GetMangledNamesForFunction(scope_qualified_name, alternates);
717
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);
723 ConstString demangled = mangled.GetDemangledName();
724
725 CxxMethodName alternate_cpp_name(demangled);
726 if (!cpp_name.IsValid())
727 continue;
728
729 if (alternate_cpp_name.GetArguments() == cpp_name.GetArguments()) {
730 if (alternate_cpp_name.GetQualifiers() == cpp_name.GetQualifiers())
731 param_and_qual_matches.push_back(alternate_mangled_name);
732 else
733 param_matches.push_back(alternate_mangled_name);
734 }
735 }
736
737 if (param_and_qual_matches.size())
738 return param_and_qual_matches[0]; // It is assumed that there will be only
739 // one!
740 else if (param_matches.size())
741 return param_matches[0]; // Return one of them as a best match
742 else
743 return ConstString();
744}
745
746static void LoadLibCxxFormatters(lldb::TypeCategoryImplSP cpp_category_sp) {
747 if (!cpp_category_sp)
748 return;
749
750 TypeSummaryImpl::Flags stl_summary_flags;
751 stl_summary_flags.SetCascades(true)
752 .SetSkipPointers(false)
753 .SetSkipReferences(false)
755 .SetDontShowValue(false)
757 .SetHideItemNames(false);
758
759 AddCXXSummary(cpp_category_sp,
761 "std::string summary provider", "^std::__[[:alnum:]]+::string$",
762 stl_summary_flags, true);
763 AddCXXSummary(cpp_category_sp,
765 "std::string summary provider",
766 "^std::__[[:alnum:]]+::basic_string<char, "
767 "std::__[[:alnum:]]+::char_traits<char>,.*>$",
768 stl_summary_flags, true);
769 AddCXXSummary(cpp_category_sp,
771 "std::string summary provider",
772 "^std::__[[:alnum:]]+::basic_string<unsigned char, "
773 "std::__[[:alnum:]]+::char_traits<unsigned char>,.*>$",
774 stl_summary_flags, true);
775
776 AddCXXSummary(cpp_category_sp,
778 "std::u16string summary provider",
779 "^std::__[[:alnum:]]+::basic_string<char16_t, "
780 "std::__[[:alnum:]]+::char_traits<char16_t>,.*>$",
781 stl_summary_flags, true);
782
783 AddCXXSummary(cpp_category_sp,
785 "std::u32string summary provider",
786 "^std::__[[:alnum:]]+::basic_string<char32_t, "
787 "std::__[[:alnum:]]+::char_traits<char32_t>,.*>$",
788 stl_summary_flags, true);
789
790 AddCXXSummary(cpp_category_sp,
792 "std::wstring summary provider",
793 "^std::__[[:alnum:]]+::wstring$", stl_summary_flags, true);
794 AddCXXSummary(cpp_category_sp,
796 "std::wstring summary provider",
797 "^std::__[[:alnum:]]+::basic_string<wchar_t, "
798 "std::__[[:alnum:]]+::char_traits<wchar_t>,.*>$",
799 stl_summary_flags, true);
800
801 AddCXXSummary(cpp_category_sp,
803 "std::string_view summary provider",
804 "^std::__[[:alnum:]]+::string_view$", stl_summary_flags, true);
805 AddCXXSummary(cpp_category_sp,
807 "std::string_view summary provider",
808 "^std::__[[:alnum:]]+::basic_string_view<char, "
809 "std::__[[:alnum:]]+::char_traits<char> >$",
810 stl_summary_flags, true);
811 AddCXXSummary(cpp_category_sp,
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);
817
818 AddCXXSummary(cpp_category_sp,
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);
824
825 AddCXXSummary(cpp_category_sp,
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);
831
832 AddCXXSummary(cpp_category_sp,
834 "std::wstring_view summary provider",
835 "^std::__[[:alnum:]]+::wstring_view$", stl_summary_flags, true);
836 AddCXXSummary(cpp_category_sp,
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);
842
843 SyntheticChildren::Flags stl_synth_flags;
844 stl_synth_flags.SetCascades(true).SetSkipPointers(false).SetSkipReferences(
845 false);
846 SyntheticChildren::Flags stl_deref_flags = stl_synth_flags;
847 stl_deref_flags.SetFrontEndWantsDereference();
848
850 cpp_category_sp,
852 "libc++ std::bitset synthetic children",
853 "^std::__[[:alnum:]]+::bitset<.+>$", stl_deref_flags, true);
855 cpp_category_sp,
857 "libc++ std::vector synthetic children",
858 "^std::__[[:alnum:]]+::vector<.+>$", stl_deref_flags, true);
860 cpp_category_sp,
862 "libc++ std::valarray synthetic children",
863 "^std::__[[:alnum:]]+::valarray<.+>$", stl_deref_flags, true);
865 cpp_category_sp,
867 "libc++ std::slice_array synthetic children",
868 "^std::__[[:alnum:]]+::slice_array<.+>$", stl_deref_flags, true);
870 cpp_category_sp,
872 "libc++ synthetic children for the valarray proxy arrays",
873 "^std::__[[:alnum:]]+::(gslice|mask|indirect)_array<.+>$",
874 stl_deref_flags, true);
876 cpp_category_sp,
878 "libc++ std::forward_list synthetic children",
879 "^std::__[[:alnum:]]+::forward_list<.+>$", stl_synth_flags, true);
881 cpp_category_sp,
883 "libc++ std::list synthetic children", "^std::__[[:alnum:]]+::list<.+>$",
884 stl_deref_flags, true);
886 cpp_category_sp,
888 "libc++ std::map synthetic children", "^std::__[[:alnum:]]+::map<.+> >$",
889 stl_synth_flags, true);
891 cpp_category_sp,
893 "libc++ std::set synthetic children", "^std::__[[:alnum:]]+::set<.+> >$",
894 stl_deref_flags, true);
896 cpp_category_sp,
898 "libc++ std::multiset synthetic children",
899 "^std::__[[:alnum:]]+::multiset<.+> >$", stl_deref_flags, true);
901 cpp_category_sp,
903 "libc++ std::multimap synthetic children",
904 "^std::__[[:alnum:]]+::multimap<.+> >$", stl_synth_flags, true);
906 cpp_category_sp,
908 "libc++ std::unordered containers synthetic children",
909 "^std::__[[:alnum:]]+::unordered_(multi)?(map|set)<.+> >$",
910 stl_synth_flags, true);
912 "libc++ std::queue synthetic children",
913 "^std::__[[:alnum:]]+::queue<.+>$", stl_synth_flags, true);
915 "libc++ std::tuple synthetic children",
916 "^std::__[[:alnum:]]+::tuple<.*>$", stl_synth_flags, true);
918 "libc++ std::optional synthetic children",
919 "^std::__[[:alnum:]]+::optional<.+>$", stl_synth_flags, true);
921 "libc++ std::variant synthetic children",
922 "^std::__[[:alnum:]]+::variant<.+>$", stl_synth_flags, true);
924 cpp_category_sp,
926 "libc++ std::atomic synthetic children",
927 "^std::__[[:alnum:]]+::atomic<.+>$", stl_synth_flags, true);
929 cpp_category_sp,
931 "libc++ std::span synthetic children", "^std::__[[:alnum:]]+::span<.+>$",
932 stl_deref_flags, true);
934 cpp_category_sp,
936 "libc++ std::ranges::ref_view synthetic children",
937 "^std::__[[:alnum:]]+::ranges::ref_view<.+>$", stl_deref_flags, true);
938
939 cpp_category_sp->AddTypeSynthetic(
940 "^std::__[[:alnum:]]+::deque<.+>$", eFormatterMatchRegex,
942 stl_synth_flags,
943 "lldb.formatters.cpp.libcxx.stddeque_SynthProvider")));
944
946 cpp_category_sp,
948 "shared_ptr synthetic children", "^std::__[[:alnum:]]+::shared_ptr<.+>$",
949 stl_synth_flags, true);
950
951 static constexpr const char *const libcxx_std_unique_ptr_regex =
952 "^std::__[[:alnum:]]+::unique_ptr<.+>$";
954 cpp_category_sp,
956 "unique_ptr synthetic children", libcxx_std_unique_ptr_regex,
957 stl_synth_flags, true);
958
960 cpp_category_sp,
962 "weak_ptr synthetic children", "^std::__[[:alnum:]]+::weak_ptr<.+>$",
963 stl_synth_flags, true);
964 AddCXXSummary(cpp_category_sp,
966 "libc++ std::function summary provider",
967 "^std::__[[:alnum:]]+::function<.+>$", stl_summary_flags, true);
968
969 static constexpr const char *const libcxx_std_coroutine_handle_regex =
970 "^std::__[[:alnum:]]+::coroutine_handle<.+>$";
972 cpp_category_sp,
974 "coroutine_handle synthetic children", libcxx_std_coroutine_handle_regex,
975 stl_deref_flags, true);
976
977 stl_summary_flags.SetDontShowChildren(false);
978 stl_summary_flags.SetSkipPointers(false);
979 AddCXXSummary(cpp_category_sp,
981 "libc++ std::bitset summary provider",
982 "^std::__[[:alnum:]]+::bitset<.+>$", stl_summary_flags, true);
983 AddCXXSummary(cpp_category_sp,
985 "libc++ std::vector summary provider",
986 "^std::__[[:alnum:]]+::vector<.+>$", stl_summary_flags, true);
987 AddCXXSummary(cpp_category_sp,
989 "libc++ std::valarray summary provider",
990 "^std::__[[:alnum:]]+::valarray<.+>$", stl_summary_flags, true);
991 AddCXXSummary(cpp_category_sp,
993 "libc++ std::slice_array summary provider",
994 "^std::__[[:alnum:]]+::slice_array<.+>$", stl_summary_flags,
995 true);
996 AddCXXSummary(cpp_category_sp,
998 "libc++ summary provider for the valarray proxy arrays",
999 "^std::__[[:alnum:]]+::(gslice|mask|indirect)_array<.+>$",
1000 stl_summary_flags, true);
1003 "libc++ std::list summary provider",
1004 "^std::__[[:alnum:]]+::forward_list<.+>$", stl_summary_flags, true);
1005 AddCXXSummary(cpp_category_sp,
1007 "libc++ std::list summary provider",
1008 "^std::__[[:alnum:]]+::list<.+>$", stl_summary_flags, true);
1009 AddCXXSummary(cpp_category_sp,
1011 "libc++ std::map summary provider",
1012 "^std::__[[:alnum:]]+::map<.+>$", stl_summary_flags, true);
1013 AddCXXSummary(cpp_category_sp,
1015 "libc++ std::deque summary provider",
1016 "^std::__[[:alnum:]]+::deque<.+>$", stl_summary_flags, true);
1017 AddCXXSummary(cpp_category_sp,
1019 "libc++ std::queue summary provider",
1020 "^std::__[[:alnum:]]+::queue<.+>$", stl_summary_flags, true);
1021 AddCXXSummary(cpp_category_sp,
1023 "libc++ std::set summary provider",
1024 "^std::__[[:alnum:]]+::set<.+>$", stl_summary_flags, true);
1025 AddCXXSummary(cpp_category_sp,
1027 "libc++ std::multiset summary provider",
1028 "^std::__[[:alnum:]]+::multiset<.+>$", stl_summary_flags, true);
1029 AddCXXSummary(cpp_category_sp,
1031 "libc++ std::multimap summary provider",
1032 "^std::__[[:alnum:]]+::multimap<.+>$", stl_summary_flags, true);
1033 AddCXXSummary(cpp_category_sp,
1035 "libc++ std::unordered containers summary provider",
1036 "^std::__[[:alnum:]]+::unordered_(multi)?(map|set)<.+> >$",
1037 stl_summary_flags, true);
1039 "libc++ std::tuple summary provider",
1040 "^std::__[[:alnum:]]+::tuple<.*>$", stl_summary_flags, true);
1041 AddCXXSummary(cpp_category_sp,
1043 "libc++ std::atomic summary provider",
1044 "^std::__[[:alnum:]]+::atomic<.+>$", stl_summary_flags, true);
1045 AddCXXSummary(cpp_category_sp,
1047 "libc++ std::optional summary provider",
1048 "^std::__[[:alnum:]]+::optional<.+>$", stl_summary_flags, true);
1049 AddCXXSummary(cpp_category_sp,
1051 "libc++ std::variant summary provider",
1052 "^std::__[[:alnum:]]+::variant<.+>$", stl_summary_flags, true);
1053 AddCXXSummary(cpp_category_sp,
1055 "libc++ std::span summary provider",
1056 "^std::__[[:alnum:]]+::span<.+>$", stl_summary_flags, true);
1057
1058 stl_summary_flags.SetSkipPointers(true);
1059
1060 AddCXXSummary(cpp_category_sp,
1062 "libc++ std::shared_ptr summary provider",
1063 "^std::__[[:alnum:]]+::shared_ptr<.+>$", stl_summary_flags,
1064 true);
1065 AddCXXSummary(cpp_category_sp,
1067 "libc++ std::weak_ptr summary provider",
1068 "^std::__[[:alnum:]]+::weak_ptr<.+>$", stl_summary_flags, true);
1069 AddCXXSummary(cpp_category_sp,
1071 "libc++ std::unique_ptr summary provider",
1072 libcxx_std_unique_ptr_regex, stl_summary_flags, true);
1073
1074 AddCXXSummary(cpp_category_sp,
1076 "libc++ std::coroutine_handle summary provider",
1077 libcxx_std_coroutine_handle_regex, stl_summary_flags, true);
1078
1080 cpp_category_sp,
1082 "std::vector iterator synthetic children",
1083 "^std::__[[:alnum:]]+::__wrap_iter<.+>$", stl_synth_flags, true);
1084
1086 cpp_category_sp,
1088 "std::map iterator synthetic children",
1089 "^std::__[[:alnum:]]+::__map_(const_)?iterator<.+>$", stl_synth_flags,
1090 true);
1091
1092 AddCXXSynthetic(cpp_category_sp,
1095 "std::unordered_map iterator synthetic children",
1096 "^std::__[[:alnum:]]+::__hash_map_(const_)?iterator<.+>$",
1097 stl_synth_flags, true);
1098 // Chrono duration typedefs
1099 cpp_category_sp->AddTypeSummary(
1100 "^std::__[[:alnum:]]+::chrono::nanoseconds", eFormatterMatchRegex,
1102 eTypeOptionHideChildren | eTypeOptionHideValue, "${var.__rep_} ns")));
1103 cpp_category_sp->AddTypeSummary(
1104 "^std::__[[:alnum:]]+::chrono::microseconds", eFormatterMatchRegex,
1106 eTypeOptionHideChildren | eTypeOptionHideValue, "${var.__rep_} µs")));
1107 cpp_category_sp->AddTypeSummary(
1108 "^std::__[[:alnum:]]+::chrono::milliseconds", eFormatterMatchRegex,
1110 eTypeOptionHideChildren | eTypeOptionHideValue, "${var.__rep_} ms")));
1111 cpp_category_sp->AddTypeSummary(
1112 "^std::__[[:alnum:]]+::chrono::seconds", eFormatterMatchRegex,
1114 eTypeOptionHideChildren | eTypeOptionHideValue, "${var.__rep_} s")));
1115 cpp_category_sp->AddTypeSummary(
1116 "^std::__[[:alnum:]]+::chrono::minutes", eFormatterMatchRegex,
1117 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1118 eTypeOptionHideValue,
1119 "${var.__rep_} min")));
1120 cpp_category_sp->AddTypeSummary(
1121 "^std::__[[:alnum:]]+::chrono::hours", eFormatterMatchRegex,
1123 eTypeOptionHideChildren | eTypeOptionHideValue, "${var.__rep_} h")));
1124
1125 cpp_category_sp->AddTypeSummary(
1126 "^std::__[[:alnum:]]+::chrono::days", eFormatterMatchRegex,
1127 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1128 eTypeOptionHideValue,
1129 "${var.__rep_} days")));
1130 cpp_category_sp->AddTypeSummary(
1131 "^std::__[[:alnum:]]+::chrono::weeks", eFormatterMatchRegex,
1132 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1133 eTypeOptionHideValue,
1134 "${var.__rep_} weeks")));
1135 cpp_category_sp->AddTypeSummary(
1136 "^std::__[[:alnum:]]+::chrono::months", eFormatterMatchRegex,
1137 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1138 eTypeOptionHideValue,
1139 "${var.__rep_} months")));
1140 cpp_category_sp->AddTypeSummary(
1141 "^std::__[[:alnum:]]+::chrono::years", eFormatterMatchRegex,
1142 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1143 eTypeOptionHideValue,
1144 "${var.__rep_} years")));
1145 cpp_category_sp->AddTypeSummary(
1146 "^std::__[[:alnum:]]+::chrono::seconds", eFormatterMatchRegex,
1148 eTypeOptionHideChildren | eTypeOptionHideValue, "${var.__rep_} s")));
1149
1150 // Chrono time point types
1151
1152 AddCXXSummary(cpp_category_sp,
1154 "libc++ std::chrono::sys_seconds summary provider",
1155 "^std::__[[:alnum:]]+::chrono::time_point<"
1156 "std::__[[:alnum:]]+::chrono::system_clock, "
1157 "std::__[[:alnum:]]+::chrono::duration<.*, "
1158 "std::__[[:alnum:]]+::ratio<1, 1> "
1159 "> >$",
1160 eTypeOptionHideChildren | eTypeOptionHideValue |
1161 eTypeOptionCascade,
1162 true);
1163 AddCXXSummary(cpp_category_sp,
1165 "libc++ std::chrono::sys_seconds summary provider",
1166 "^std::__[[:alnum:]]+::chrono::time_point<"
1167 "std::__[[:alnum:]]+::chrono::system_clock, "
1168 "std::__[[:alnum:]]+::chrono::duration<int, "
1169 "std::__[[:alnum:]]+::ratio<86400, 1> "
1170 "> >$",
1171 eTypeOptionHideChildren | eTypeOptionHideValue |
1172 eTypeOptionCascade,
1173 true);
1174
1176 cpp_category_sp,
1178 "libc++ std::chrono::local_seconds summary provider",
1179 "^std::__[[:alnum:]]+::chrono::time_point<"
1180 "std::__[[:alnum:]]+::chrono::local_t, "
1181 "std::__[[:alnum:]]+::chrono::duration<.*, "
1182 "std::__[[:alnum:]]+::ratio<1, 1> "
1183 "> >$",
1184 eTypeOptionHideChildren | eTypeOptionHideValue | eTypeOptionCascade,
1185 true);
1186 AddCXXSummary(cpp_category_sp,
1188 "libc++ std::chrono::local_seconds summary provider",
1189 "^std::__[[:alnum:]]+::chrono::time_point<"
1190 "std::__[[:alnum:]]+::chrono::local_t, "
1191 "std::__[[:alnum:]]+::chrono::duration<int, "
1192 "std::__[[:alnum:]]+::ratio<86400, 1> "
1193 "> >$",
1194 eTypeOptionHideChildren | eTypeOptionHideValue |
1195 eTypeOptionCascade,
1196 true);
1197
1198 // Chrono calendar types
1199
1200 cpp_category_sp->AddTypeSummary(
1201 "^std::__[[:alnum:]]+::chrono::day$", eFormatterMatchRegex,
1202 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1203 eTypeOptionHideValue,
1204 "day=${var.__d_%u}")));
1205
1206 AddCXXSummary(cpp_category_sp,
1208 "libc++ std::chrono::month summary provider",
1209 "^std::__[[:alnum:]]+::chrono::month$",
1210 eTypeOptionHideChildren | eTypeOptionHideValue, true);
1211
1212 cpp_category_sp->AddTypeSummary(
1213 "^std::__[[:alnum:]]+::chrono::year$", eFormatterMatchRegex,
1215 eTypeOptionHideChildren | eTypeOptionHideValue, "year=${var.__y_}")));
1216
1217 AddCXXSummary(cpp_category_sp,
1219 "libc++ std::chrono::weekday summary provider",
1220 "^std::__[[:alnum:]]+::chrono::weekday$",
1221 eTypeOptionHideChildren | eTypeOptionHideValue, true);
1222
1223 cpp_category_sp->AddTypeSummary(
1224 "^std::__[[:alnum:]]+::chrono::weekday_indexed$", eFormatterMatchRegex,
1226 eTypeOptionHideChildren | eTypeOptionHideValue,
1227 "${var.__wd_} index=${var.__idx_%u}")));
1228
1229 cpp_category_sp->AddTypeSummary(
1230 "^std::__[[:alnum:]]+::chrono::weekday_last$", eFormatterMatchRegex,
1231 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1232 eTypeOptionHideValue,
1233 "${var.__wd_} index=last")));
1234 cpp_category_sp->AddTypeSummary(
1235 "^std::__[[:alnum:]]+::chrono::month_day$", eFormatterMatchRegex,
1236 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1237 eTypeOptionHideValue,
1238 "${var.__m_} ${var.__d_}")));
1239 cpp_category_sp->AddTypeSummary(
1240 "^std::__[[:alnum:]]+::chrono::month_day_last$", eFormatterMatchRegex,
1241 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1242 eTypeOptionHideValue,
1243 "${var.__m_} day=last")));
1244
1245 cpp_category_sp->AddTypeSummary(
1246 "^std::__[[:alnum:]]+::chrono::month_weekday$", eFormatterMatchRegex,
1247 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1248 eTypeOptionHideValue,
1249 "${var.__m_} ${var.__wdi_}")));
1250
1251 cpp_category_sp->AddTypeSummary(
1252 "^std::__[[:alnum:]]+::chrono::month_weekday_last$", eFormatterMatchRegex,
1253 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1254 eTypeOptionHideValue,
1255 "${var.__m_} ${var.__wdl_}")));
1256
1257 cpp_category_sp->AddTypeSummary(
1258 "^std::__[[:alnum:]]+::chrono::year_month$", eFormatterMatchRegex,
1259 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1260 eTypeOptionHideValue,
1261 "${var.__y_} ${var.__m_}")));
1262
1264 cpp_category_sp,
1266 "libc++ std::chrono::year_month_day summary provider",
1267 "^std::__[[:alnum:]]+::chrono::year_month_day$",
1268 eTypeOptionHideChildren | eTypeOptionHideValue, true);
1269
1270 cpp_category_sp->AddTypeSummary(
1271 "^std::__[[:alnum:]]+::chrono::year_month_day_last$",
1273 TypeSummaryImplSP(new StringSummaryFormat(eTypeOptionHideChildren |
1274 eTypeOptionHideValue,
1275 "${var.__y_} ${var.__mdl_}")));
1276
1277 cpp_category_sp->AddTypeSummary(
1278 "^std::__[[:alnum:]]+::chrono::year_month_weekday$", eFormatterMatchRegex,
1280 eTypeOptionHideChildren | eTypeOptionHideValue,
1281 "${var.__y_} ${var.__m_} ${var.__wdi_}")));
1282
1283 cpp_category_sp->AddTypeSummary(
1284 "^std::__[[:alnum:]]+::chrono::year_month_weekday_last$",
1287 eTypeOptionHideChildren | eTypeOptionHideValue,
1288 "${var.__y_} ${var.__m_} ${var.__wdl_}")));
1289
1290 AddCXXSummary(cpp_category_sp,
1292 "libc++ std::partial_ordering summary provider",
1293 "^std::__[[:alnum:]]+::partial_ordering$",
1294 eTypeOptionHideChildren | eTypeOptionHideValue, true);
1295 AddCXXSummary(cpp_category_sp,
1297 "libc++ std::weak_ordering summary provider",
1298 "^std::__[[:alnum:]]+::weak_ordering$",
1299 eTypeOptionHideChildren | eTypeOptionHideValue, true);
1300 AddCXXSummary(cpp_category_sp,
1302 "libc++ std::strong_ordering summary provider",
1303 "^std::__[[:alnum:]]+::strong_ordering$",
1304 eTypeOptionHideChildren | eTypeOptionHideValue, true);
1305}
1306
1308 const lldb::TypeCategoryImplSP &category_sp, llvm::StringRef string_ty,
1309 llvm::StringRef char_ty, lldb::TypeSummaryImplSP summary_sp) {
1310 auto makeSpecifier = [](llvm::StringRef name) {
1311 return std::make_shared<lldb_private::TypeNameSpecifierImpl>(
1312 name, eFormatterMatchExact);
1313 };
1314
1315 category_sp->AddTypeSummary(makeSpecifier(string_ty), summary_sp);
1316
1317 category_sp->AddTypeSummary(
1318 makeSpecifier(llvm::formatv("std::basic_string<{}>", char_ty).str()),
1319 summary_sp);
1320
1321 category_sp->AddTypeSummary(
1322 std::make_shared<lldb_private::TypeNameSpecifierImpl>(
1323 llvm::formatv("^std::basic_string<{0}, ?std::char_traits<{0}>,.*>$",
1324 char_ty)
1325 .str(),
1327 summary_sp);
1328}
1329
1331 const lldb::TypeCategoryImplSP &category_sp, llvm::StringRef string_ty,
1332 llvm::StringRef char_ty, lldb::TypeSummaryImplSP summary_sp) {
1333 // std::string_view
1334 category_sp->AddTypeSummary(
1335 std::make_shared<lldb_private::TypeNameSpecifierImpl>(
1336 string_ty, eFormatterMatchExact),
1337 summary_sp);
1338
1339 // std::basic_string_view<char, std::char_traits<char>>
1340 // NativePDB has spaces at different positions compared to PDB and DWARF, so
1341 // use a regex and make them optional.
1342 category_sp->AddTypeSummary(
1343 std::make_shared<lldb_private::TypeNameSpecifierImpl>(
1344 llvm::formatv(
1345 "^std::basic_string_view<{0}, ?std::char_traits<{0}> ?>$",
1346 char_ty)
1347 .str(),
1349 summary_sp);
1350}
1351
1353 if (!cpp_category_sp)
1354 return;
1355
1356 TypeSummaryImpl::Flags stl_summary_flags;
1357 stl_summary_flags.SetCascades(true)
1358 .SetSkipPointers(false)
1359 .SetSkipReferences(false)
1360 .SetDontShowChildren(true)
1361 .SetDontShowValue(false)
1363 .SetHideItemNames(false);
1364
1366 stl_summary_flags, LibStdcppStringSummaryProvider,
1367 "libstdc++ std::(w)string summary provider"));
1368 cpp_category_sp->AddTypeSummary("std::__cxx11::string", eFormatterMatchExact,
1369 string_summary_sp);
1370 cpp_category_sp->AddTypeSummary(
1371 "^std::__cxx11::basic_string<char, std::char_traits<char>,.*>$",
1372 eFormatterMatchRegex, string_summary_sp);
1373 cpp_category_sp->AddTypeSummary("^std::__cxx11::basic_string<unsigned char, "
1374 "std::char_traits<unsigned char>,.*>$",
1375 eFormatterMatchRegex, string_summary_sp);
1376
1377 cpp_category_sp->AddTypeSummary("std::__cxx11::wstring", eFormatterMatchExact,
1378 string_summary_sp);
1379 cpp_category_sp->AddTypeSummary(
1380 "^std::__cxx11::basic_string<wchar_t, std::char_traits<wchar_t>,.*>$",
1381 eFormatterMatchRegex, string_summary_sp);
1382
1383 SyntheticChildren::Flags stl_synth_flags;
1384 stl_synth_flags.SetCascades(true).SetSkipPointers(false).SetSkipReferences(
1385 false);
1386 SyntheticChildren::Flags stl_deref_flags = stl_synth_flags;
1387 stl_deref_flags.SetFrontEndWantsDereference();
1388
1389 cpp_category_sp->AddTypeSynthetic(
1390 "^std::__debug::vector<.+>(( )?&)?$", eFormatterMatchRegex,
1392 stl_synth_flags,
1393 "lldb.formatters.cpp.gnu_libstdcpp.StdVectorSynthProvider")));
1394 cpp_category_sp->AddTypeSynthetic(
1395 "^std::__debug::map<.+> >(( )?&)?$", eFormatterMatchRegex,
1397 stl_synth_flags,
1398 "lldb.formatters.cpp.gnu_libstdcpp.StdMapLikeSynthProvider")));
1399 cpp_category_sp->AddTypeSynthetic(
1400 "^std::__debug::deque<.+>(( )?&)?$", eFormatterMatchRegex,
1402 stl_deref_flags,
1403 "lldb.formatters.cpp.gnu_libstdcpp.StdDequeSynthProvider")));
1404 cpp_category_sp->AddTypeSynthetic(
1405 "^std::__debug::set<.+> >(( )?&)?$", eFormatterMatchRegex,
1407 stl_deref_flags,
1408 "lldb.formatters.cpp.gnu_libstdcpp.StdMapLikeSynthProvider")));
1409 cpp_category_sp->AddTypeSynthetic(
1410 "^std::__debug::multimap<.+> >(( )?&)?$", eFormatterMatchRegex,
1412 stl_deref_flags,
1413 "lldb.formatters.cpp.gnu_libstdcpp.StdMapLikeSynthProvider")));
1414 cpp_category_sp->AddTypeSynthetic(
1415 "^std::__debug::multiset<.+> >(( )?&)?$", eFormatterMatchRegex,
1417 stl_deref_flags,
1418 "lldb.formatters.cpp.gnu_libstdcpp.StdMapLikeSynthProvider")));
1419 cpp_category_sp->AddTypeSynthetic(
1420 "^std::__debug::unordered_(multi)?(map|set)<.+> >$", eFormatterMatchRegex,
1422 stl_deref_flags,
1423 "lldb.formatters.cpp.gnu_libstdcpp.StdUnorderedMapSynthProvider")));
1424 cpp_category_sp->AddTypeSynthetic(
1425 "^std::__(debug|cxx11)::list<.+>(( )?&)?$", eFormatterMatchRegex,
1427 stl_deref_flags,
1428 "lldb.formatters.cpp.gnu_libstdcpp.StdListSynthProvider")));
1429 cpp_category_sp->AddTypeSynthetic(
1430 "^std::__(debug|cxx11)::forward_list<.+>(( )?&)?$", eFormatterMatchRegex,
1432 stl_synth_flags,
1433 "lldb.formatters.cpp.gnu_libstdcpp.StdForwardListSynthProvider")));
1434
1435 stl_summary_flags.SetDontShowChildren(false);
1436 stl_summary_flags.SetSkipPointers(false);
1437
1440 "libstdc++ std::bitset summary provider",
1441 "^std::(__debug::)?bitset<.+>(( )?&)?$", stl_summary_flags, true);
1442
1443 AddCXXSummary(cpp_category_sp,
1445 "libstdc++ std::__debug::vector summary provider",
1446 "^std::__debug::vector<.+>(( )?&)?$", stl_summary_flags, true);
1447
1448 AddCXXSummary(cpp_category_sp,
1450 "libstdc++ debug std::map summary provider",
1451 "^std::__debug::map<.+> >(( )?&)?$", stl_summary_flags, true);
1452
1453 AddCXXSummary(cpp_category_sp,
1455 "libstdc++ debug std::set summary provider",
1456 "^std::__debug::set<.+> >(( )?&)?$", stl_summary_flags, true);
1457
1459 "libstdc++ debug std::deque summary provider",
1460 "^std::__debug::deque<.+>(( )?&)?$", stl_summary_flags, true);
1461
1464 "libstdc++ debug std::multimap summary provider",
1465 "^std::__debug::multimap<.+> >(( )?&)?$", stl_summary_flags, true);
1466
1469 "libstdc++ debug std::multiset summary provider",
1470 "^std::__debug::multiset<.+> >(( )?&)?$", stl_summary_flags, true);
1471
1472 AddCXXSummary(cpp_category_sp,
1474 "libstdc++ debug std unordered container summary provider",
1475 "^std::__debug::unordered_(multi)?(map|set)<.+> >$",
1476 stl_summary_flags, true);
1477
1480 "libstdc++ debug std::list summary provider",
1481 "^std::__(debug|cxx11)::list<.+>(( )?&)?$", stl_summary_flags, true);
1482
1483 cpp_category_sp->AddTypeSummary(
1484 "^std::__(debug|cxx11)::forward_list<.+>(( )?&)?$", eFormatterMatchRegex,
1486 stl_summary_flags,
1487 "lldb.formatters.cpp.gnu_libstdcpp.ForwardListSummaryProvider")));
1488
1490 cpp_category_sp,
1492 "std::vector iterator synthetic children",
1493 "^__gnu_cxx::__normal_iterator<.+>$", stl_synth_flags, true);
1494
1496 cpp_category_sp,
1498 "std::map iterator synthetic children",
1499 "^std::_Rb_tree_(const_)?iterator<.+>$", stl_synth_flags, true);
1500
1502 cpp_category_sp,
1504 "std::unique_ptr synthetic children", "^std::unique_ptr<.+>(( )?&)?$",
1505 stl_synth_flags, true);
1506
1507 static constexpr const char *const libstdcpp_std_coroutine_handle_regex =
1508 "^std::coroutine_handle<.+>(( )?&)?$";
1510 cpp_category_sp,
1512 "std::coroutine_handle synthetic children",
1513 libstdcpp_std_coroutine_handle_regex, stl_deref_flags, true);
1514
1516 cpp_category_sp,
1518 "std::bitset synthetic child", "^std::(__debug::)?bitset<.+>(( )?&)?$",
1519 stl_deref_flags, true);
1520
1521 AddCXXSummary(cpp_category_sp,
1523 "libstdc++ std::coroutine_handle summary provider",
1524 libstdcpp_std_coroutine_handle_regex, stl_summary_flags, true);
1525}
1526
1527static lldb_private::SyntheticChildrenFrontEnd *
1529 lldb::ValueObjectSP valobj_sp) {
1530 if (!valobj_sp)
1531 return nullptr;
1532
1533 if (IsMsvcStlSmartPointer(*valobj_sp))
1535 return LibStdcppSharedPtrSyntheticFrontEndCreator(children, valobj_sp);
1536}
1537
1538static bool
1540 const TypeSummaryOptions &options) {
1541 if (IsMsvcStlSmartPointer(valobj))
1542 return MsvcStlSmartPointerSummaryProvider(valobj, stream, options);
1543 return LibStdcppSmartPointerSummaryProvider(valobj, stream, options);
1544}
1545
1546static lldb_private::SyntheticChildrenFrontEnd *
1548 lldb::ValueObjectSP valobj_sp) {
1549 if (!valobj_sp)
1550 return nullptr;
1551
1552 if (IsMsvcStlUniquePtr(*valobj_sp))
1554 return LibStdcppUniquePtrSyntheticFrontEndCreator(children, valobj_sp);
1555}
1556
1558 const TypeSummaryOptions &options) {
1559 if (IsMsvcStlUniquePtr(valobj))
1560 return MsvcStlUniquePtrSummaryProvider(valobj, stream, options);
1561 return LibStdcppUniquePointerSummaryProvider(valobj, stream, options);
1562}
1563
1564static SyntheticChildrenFrontEnd *
1566 lldb::ValueObjectSP valobj_sp) {
1567 if (!valobj_sp)
1568 return nullptr;
1569
1570 if (IsMsvcStlTuple(*valobj_sp))
1571 return MsvcStlTupleSyntheticFrontEndCreator(children, valobj_sp);
1572 return LibStdcppTupleSyntheticFrontEndCreator(children, valobj_sp);
1573}
1574
1575static SyntheticChildrenFrontEnd *
1577 lldb::ValueObjectSP valobj_sp) {
1578 if (!valobj_sp)
1579 return nullptr;
1580
1581 // checks for vector<T> and vector<bool>
1582 if (auto *msvc = MsvcStlVectorSyntheticFrontEndCreator(valobj_sp))
1583 return msvc;
1584
1586 "lldb.formatters.cpp.gnu_libstdcpp.StdVectorSynthProvider", *valobj_sp);
1587}
1588
1589static SyntheticChildrenFrontEnd *
1591 lldb::ValueObjectSP valobj_sp) {
1592 if (!valobj_sp)
1593 return nullptr;
1594
1595 if (IsMsvcStlList(*valobj_sp))
1596 return MsvcStlListSyntheticFrontEndCreator(children, valobj_sp);
1598 "lldb.formatters.cpp.gnu_libstdcpp.StdListSynthProvider", *valobj_sp);
1599}
1600
1601static SyntheticChildrenFrontEnd *
1603 lldb::ValueObjectSP valobj_sp) {
1604 if (!valobj_sp)
1605 return nullptr;
1606
1607 if (IsMsvcStlList(*valobj_sp))
1608 return MsvcStlForwardListSyntheticFrontEndCreator(children, valobj_sp);
1610 "lldb.formatters.cpp.gnu_libstdcpp.StdForwardListSynthProvider",
1611 *valobj_sp);
1612}
1613
1614static SyntheticChildrenFrontEnd *
1616 lldb::ValueObjectSP valobj_sp) {
1617 if (!valobj_sp)
1618 return nullptr;
1619
1620 if (IsMsvcStlOptional(*valobj_sp))
1621 return MsvcStlOptionalSyntheticFrontEndCreator(children, valobj_sp);
1622 return LibStdcppOptionalSyntheticFrontEndCreator(children, valobj_sp);
1623}
1624
1625static SyntheticChildrenFrontEnd *
1627 lldb::ValueObjectSP valobj_sp) {
1628 if (!valobj_sp)
1629 return nullptr;
1630
1631 if (IsMsvcStlVariant(*valobj_sp))
1632 return MsvcStlVariantSyntheticFrontEndCreator(children, valobj_sp);
1634 "lldb.formatters.cpp.gnu_libstdcpp.VariantSynthProvider", *valobj_sp);
1635}
1636
1638 const TypeSummaryOptions &options) {
1639 if (IsMsvcStlVariant(valobj))
1640 return MsvcStlVariantSummaryProvider(valobj, stream, options);
1641 return LibStdcppVariantSummaryProvider(valobj, stream, options);
1642}
1643
1644static SyntheticChildrenFrontEnd *
1646 ValueObjectSP valobj_sp) {
1647 if (!valobj_sp)
1648 return nullptr;
1649
1650 if (IsMsvcStlUnordered(*valobj_sp))
1651 return MsvcStlUnorderedSyntheticFrontEndCreator(children, valobj_sp);
1653 "lldb.formatters.cpp.gnu_libstdcpp.StdUnorderedMapSynthProvider",
1654 *valobj_sp);
1655}
1656
1657static SyntheticChildrenFrontEnd *
1659 ValueObjectSP valobj_sp) {
1660 if (!valobj_sp)
1661 return nullptr;
1662
1663 if (IsMsvcStlMapLike(*valobj_sp))
1666 "lldb.formatters.cpp.gnu_libstdcpp.StdMapLikeSynthProvider", *valobj_sp);
1667}
1668
1669static SyntheticChildrenFrontEnd *
1671 ValueObjectSP valobj_sp) {
1672 if (!valobj_sp)
1673 return nullptr;
1674
1675 if (IsMsvcStlDeque(*valobj_sp))
1676 return MsvcStlDequeSyntheticFrontEndCreator(children, valobj_sp);
1678 "lldb.formatters.cpp.gnu_libstdcpp.StdDequeSynthProvider", *valobj_sp);
1679}
1680
1681static SyntheticChildrenFrontEnd *
1683 ValueObjectSP valobj_sp) {
1684 if (!valobj_sp)
1685 return nullptr;
1686
1687 if (IsMsvcStlSpan(*valobj_sp))
1688 return MsvcStlSpanSyntheticFrontEndCreator(children, valobj_sp);
1689 return LibStdcppSpanSyntheticFrontEndCreator(children, valobj_sp);
1690}
1691
1692static bool
1694 const TypeSummaryOptions &options) {
1695 if (IsMsvcStlOrdering(valobj))
1696 return MsvcStlPartialOrderingSummaryProvider(valobj, stream, options);
1697 return LibStdcppPartialOrderingSummaryProvider(valobj, stream, options);
1698}
1699
1700static bool
1702 const TypeSummaryOptions &options) {
1703 if (IsMsvcStlOrdering(valobj))
1704 return MsvcStlWeakOrderingSummaryProvider(valobj, stream, options);
1705 return LibStdcppWeakOrderingSummaryProvider(valobj, stream, options);
1706}
1707
1708static bool
1710 const TypeSummaryOptions &options) {
1711 if (IsMsvcStlOrdering(valobj))
1712 return MsvcStlStrongOrderingSummaryProvider(valobj, stream, options);
1713 return LibStdcppStrongOrderingSummaryProvider(valobj, stream, options);
1714}
1715
1716/// Load formatters that are formatting types from more than one STL
1718 if (!cpp_category_sp)
1719 return;
1720
1721 TypeSummaryImpl::Flags stl_summary_flags;
1722 stl_summary_flags.SetCascades(true)
1723 .SetSkipPointers(false)
1724 .SetSkipReferences(false)
1725 .SetDontShowChildren(true)
1726 .SetDontShowValue(false)
1728 .SetHideItemNames(false);
1729 SyntheticChildren::Flags stl_synth_flags;
1730 stl_synth_flags.SetCascades(true).SetSkipPointers(false).SetSkipReferences(
1731 false);
1732
1734
1736 cpp_category_sp, "std::string", "char",
1737 std::make_shared<CXXFunctionSummaryFormat>(
1738 stl_summary_flags,
1739 [](ValueObject &valobj, Stream &stream,
1740 const TypeSummaryOptions &options) {
1741 if (IsMsvcStlStringType(valobj))
1743 valobj, stream, options);
1744 return LibStdcppStringSummaryProvider(valobj, stream, options);
1745 },
1746 "MSVC STL/libstdc++ std::string summary provider"));
1748 cpp_category_sp, "std::wstring", "wchar_t",
1749 std::make_shared<CXXFunctionSummaryFormat>(
1750 stl_summary_flags,
1751 [](ValueObject &valobj, Stream &stream,
1752 const TypeSummaryOptions &options) {
1753 if (IsMsvcStlStringType(valobj))
1754 return MsvcStlWStringSummaryProvider(valobj, stream, options);
1755 return LibStdcppStringSummaryProvider(valobj, stream, options);
1756 },
1757 "MSVC STL/libstdc++ std::wstring summary provider"));
1758
1760 cpp_category_sp, "std::string_view", "char",
1761 std::make_shared<CXXFunctionSummaryFormat>(
1762 stl_summary_flags,
1763 [](ValueObject &valobj, Stream &stream,
1764 const TypeSummaryOptions &options) {
1765 if (IsMsvcStlStringViewType(valobj))
1767 valobj, stream, options);
1769 valobj, stream, options);
1770 },
1771 "MSVC STL/libstdc++ std::string_view summary provider"));
1773 cpp_category_sp, "std::u8string_view", "char8_t",
1774 std::make_shared<CXXFunctionSummaryFormat>(
1775 stl_summary_flags,
1776 [](ValueObject &valobj, Stream &stream,
1777 const TypeSummaryOptions &options) {
1778 if (IsMsvcStlStringViewType(valobj))
1780 valobj, stream, options);
1782 valobj, stream, options);
1783 },
1784 "MSVC STL/libstdc++ std::u8string_view summary provider"));
1786 cpp_category_sp, "std::u16string_view", "char16_t",
1787 std::make_shared<CXXFunctionSummaryFormat>(
1788 stl_summary_flags,
1789 [](ValueObject &valobj, Stream &stream,
1790 const TypeSummaryOptions &options) {
1791 if (IsMsvcStlStringViewType(valobj))
1793 valobj, stream, options);
1795 valobj, stream, options);
1796 },
1797 "MSVC STL/libstdc++ std::u16string_view summary provider"));
1799 cpp_category_sp, "std::u32string_view", "char32_t",
1800 std::make_shared<CXXFunctionSummaryFormat>(
1801 stl_summary_flags,
1802 [](ValueObject &valobj, Stream &stream,
1803 const TypeSummaryOptions &options) {
1804 if (IsMsvcStlStringViewType(valobj))
1806 valobj, stream, options);
1808 valobj, stream, options);
1809 },
1810 "MSVC STL/libstdc++ std::u32string_view summary provider"));
1812 cpp_category_sp, "std::wstring_view", "wchar_t",
1813 std::make_shared<CXXFunctionSummaryFormat>(
1814 stl_summary_flags,
1815 [](ValueObject &valobj, Stream &stream,
1816 const TypeSummaryOptions &options) {
1817 if (IsMsvcStlStringViewType(valobj))
1818 return MsvcStlWStringViewSummaryProvider(valobj, stream, options);
1819 return LibStdcppWStringViewSummaryProvider(valobj, stream, options);
1820 },
1821 "MSVC STL/libstdc++ std::wstring_view summary provider"));
1822
1823 // NOTE: it is loaded as a common formatter because the libc++ version is not
1824 // in the `__1` namespace, hence we need to dispatch based on the class
1825 // layout.
1826 AddCXXSynthetic(cpp_category_sp,
1828 "std::initializer_list synthetic children",
1829 "^std::initializer_list<.+>$", stl_synth_flags, true);
1830
1831 stl_summary_flags.SetDontShowChildren(false);
1832 stl_summary_flags.SetSkipPointers(false);
1833
1835 "std::shared_ptr synthetic children",
1836 "^std::shared_ptr<.+>(( )?&)?$", stl_synth_flags, true);
1838 "std::weak_ptr synthetic children",
1839 "^std::weak_ptr<.+>(( )?&)?$", stl_synth_flags, true);
1841 "std::unique_ptr synthetic children",
1842 "^std::unique_ptr<.+>(( )?&)?$", stl_synth_flags, true);
1844 "std::tuple synthetic children", "^std::tuple<.*>(( )?&)?$",
1845 stl_synth_flags, true);
1847 "std::list synthetic children", "^std::list<.+>(( )?&)?$",
1848 stl_synth_flags, true);
1850 "std::forward_list synthetic children",
1851 "^std::forward_list<.+>(( )?&)?$", stl_synth_flags, true);
1853 "std::variant synthetic children", "^std::variant<.*>$",
1854 stl_synth_flags, true);
1856 "std::unordered container synthetic children",
1857 "^std::unordered_(multi)?(map|set)<.+> ?>$", stl_synth_flags,
1858 true);
1859
1860 SyntheticChildren::Flags stl_deref_flags = stl_synth_flags;
1861 stl_deref_flags.SetFrontEndWantsDereference();
1863 "std::optional synthetic children",
1864 "^std::optional<.+>(( )?&)?$", stl_deref_flags, true);
1866 "std::deque container synthetic children",
1867 "^std::deque<.+>(( )?&)?$", stl_deref_flags, true);
1869 "std::span container synthetic children", "^std::span<.+>$",
1870 stl_deref_flags, true);
1871
1873 "std::(multi)?map/set synthetic children",
1874 "^std::(multi)?(map|set)<.+>(( )?&)?$", stl_synth_flags,
1875 true);
1876
1878 "std::initializer_list summary provider",
1879 "^std::initializer_list<.+>$", stl_summary_flags, true);
1881 "MSVC STL/libstdc++ std::shared_ptr summary provider",
1882 "^std::shared_ptr<.+>(( )?&)?$", stl_summary_flags, true);
1884 "MSVC STL/libstdc++ std::weak_ptr summary provider",
1885 "^std::weak_ptr<.+>(( )?&)?$", stl_summary_flags, true);
1887 "MSVC STL/libstdc++ std::unique_ptr summary provider",
1888 "^std::unique_ptr<.+>(( )?&)?$", stl_summary_flags, true);
1890 "MSVC STL/libstdc++ std::tuple summary provider",
1891 "^std::tuple<.*>(( )?&)?$", stl_summary_flags, true);
1893 "MSVC/libstdc++ std::vector summary provider",
1894 "^std::vector<.+>(( )?&)?$", stl_summary_flags, true);
1896 "MSVC/libstdc++ std::vector synthetic provider",
1897 "^std::vector<.+>(( )?&)?$", stl_synth_flags, true);
1899 "MSVC STL/libstdc++ std::list summary provider",
1900 "^std::list<.+>(( )?&)?$", stl_summary_flags, true);
1901 cpp_category_sp->AddTypeSummary(
1902 "^std::forward_list<.+>(( )?&)?$", eFormatterMatchRegex,
1904 stl_summary_flags,
1905 "lldb.formatters.cpp.gnu_libstdcpp.ForwardListSummaryProvider")));
1907 "MSVC STL/libstd++ std::optional summary provider",
1908 "^std::optional<.+>(( )?&)?$", stl_summary_flags, true);
1910 "MSVC STL/libstdc++ std::variant summary provider",
1911 "^std::variant<.*>$", stl_summary_flags, true);
1913 "MSVC STL/libstdc++ std unordered container summary provider",
1914 "^std::unordered_(multi)?(map|set)<.+> ?>$", stl_summary_flags,
1915 true);
1917 "MSVC STL/libstdc++ std::(multi)?map/set summary provider",
1918 "^std::(multi)?(map|set)<.+>(( )?&)?$", stl_summary_flags,
1919 true);
1921 "MSVC STL/libstd++ std::deque summary provider",
1922 "^std::deque<.+>(( )?&)?$", stl_summary_flags, true);
1924 "MSVC STL/libstd++ std::span summary provider",
1925 "^std::span<.+>$", stl_summary_flags, true);
1927 "MSVC STL/libstdc++ std::partial_ordering summary provider",
1928 "std::partial_ordering",
1929 eTypeOptionHideChildren | eTypeOptionHideValue, false);
1931 "MSVC STL/libstdc++ std::weak_ordering summary provider",
1932 "std::weak_ordering",
1933 eTypeOptionHideChildren | eTypeOptionHideValue, false);
1935 "MSVC STL/libstdc++ std::strong_ordering summary provider",
1936 "std::strong_ordering",
1937 eTypeOptionHideChildren | eTypeOptionHideValue, false);
1938}
1939
1941 if (!cpp_category_sp)
1942 return;
1943
1944 TypeSummaryImpl::Flags stl_summary_flags;
1945 stl_summary_flags.SetCascades(true)
1946 .SetSkipPointers(false)
1947 .SetSkipReferences(false)
1948 .SetDontShowChildren(true)
1949 .SetDontShowValue(false)
1951 .SetHideItemNames(false);
1952 SyntheticChildren::Flags stl_synth_flags;
1953 stl_synth_flags.SetCascades(true).SetSkipPointers(false).SetSkipReferences(
1954 false);
1955
1957
1959 cpp_category_sp, "std::u8string", "char8_t",
1960 std::make_shared<CXXFunctionSummaryFormat>(
1961 stl_summary_flags,
1963 "MSVC STL std::u8string summary provider"));
1965 cpp_category_sp, "std::u16string", "char16_t",
1966 std::make_shared<CXXFunctionSummaryFormat>(
1967 stl_summary_flags,
1969 "MSVC STL std::u16string summary provider"));
1971 cpp_category_sp, "std::u32string", "char32_t",
1972 std::make_shared<CXXFunctionSummaryFormat>(
1973 stl_summary_flags,
1975 "MSVC STL std::u32string summary provider"));
1976
1977 stl_summary_flags.SetDontShowChildren(false);
1978
1980 "MSVC STL std::atomic synthetic children",
1981 "^std::atomic<.+>$", stl_synth_flags, true);
1982
1984 "MSVC STL std::atomic summary provider", "^std::atomic<.+>$",
1985 stl_summary_flags, true);
1987 "MSVC STL tree iterator synthetic children",
1988 "^std::_Tree(_const)?_iterator<.+>(( )?&)?$", stl_synth_flags,
1989 true);
1991 "MSVC STL tree iterator summary",
1992 "^std::_Tree(_const)?_iterator<.+>(( )?&)?$", stl_summary_flags,
1993 true);
1994}
1995
1997 if (!cpp_category_sp)
1998 return;
1999
2000 TypeSummaryImpl::Flags string_flags;
2001 string_flags.SetCascades(true)
2002 .SetSkipPointers(true)
2003 .SetSkipReferences(false)
2004 .SetDontShowChildren(true)
2005 .SetDontShowValue(false)
2007 .SetHideItemNames(false);
2008
2009 TypeSummaryImpl::Flags string_array_flags;
2010 string_array_flags.SetCascades(true)
2011 .SetSkipPointers(true)
2012 .SetSkipReferences(false)
2013 .SetDontShowChildren(true)
2014 .SetDontShowValue(true)
2016 .SetHideItemNames(false);
2017
2018 AddCXXSummary(cpp_category_sp,
2020 "char8_t * summary provider", "char8_t *", string_flags);
2021 AddCXXSummary(cpp_category_sp,
2023 "char8_t [] summary provider", "char8_t ?\\[[0-9]+\\]",
2024 string_array_flags, true);
2025
2026 AddCXXSummary(cpp_category_sp,
2028 "char16_t * summary provider", "char16_t *", string_flags);
2029 AddCXXSummary(cpp_category_sp,
2031 "char16_t [] summary provider", "char16_t ?\\[[0-9]+\\]",
2032 string_array_flags, true);
2033
2034 AddCXXSummary(cpp_category_sp,
2036 "char32_t * summary provider", "char32_t *", string_flags);
2037 AddCXXSummary(cpp_category_sp,
2039 "char32_t [] summary provider", "char32_t ?\\[[0-9]+\\]",
2040 string_array_flags, true);
2041
2042 AddCXXSummary(cpp_category_sp,
2044 "wchar_t * summary provider", "wchar_t *", string_flags);
2045 AddCXXSummary(cpp_category_sp,
2047 "wchar_t * summary provider", "wchar_t ?\\[[0-9]+\\]",
2048 string_array_flags, true);
2049
2050 AddCXXSummary(cpp_category_sp,
2052 "unichar * summary provider", "unichar *", string_flags);
2053
2054 TypeSummaryImpl::Flags widechar_flags;
2055 widechar_flags.SetDontShowValue(true)
2056 .SetSkipPointers(true)
2057 .SetSkipReferences(false)
2058 .SetCascades(true)
2059 .SetDontShowChildren(true)
2060 .SetHideItemNames(true)
2061 .SetShowMembersOneLiner(false);
2062
2064 "char8_t summary provider", "char8_t", widechar_flags);
2065 AddCXXSummary(cpp_category_sp,
2067 "char16_t summary provider", "char16_t", widechar_flags);
2068 AddCXXSummary(cpp_category_sp,
2070 "char32_t summary provider", "char32_t", widechar_flags);
2072 "wchar_t summary provider", "wchar_t", widechar_flags);
2073
2074 AddCXXSummary(cpp_category_sp,
2076 "unichar summary provider", "unichar", widechar_flags);
2077}
2078
2079std::unique_ptr<Language::TypeScavenger> CPlusPlusLanguage::GetTypeScavenger() {
2080 class CPlusPlusTypeScavenger : public Language::ImageListTypeScavenger {
2081 public:
2082 CompilerType AdjustForInclusion(CompilerType &candidate) override {
2083 LanguageType lang_type(candidate.GetMinimumLanguage());
2084 if (!Language::LanguageIsC(lang_type) &&
2086 return CompilerType();
2087 if (candidate.IsTypedefType())
2088 return candidate.GetTypedefedType();
2089 return candidate;
2090 }
2091 };
2092
2093 return std::unique_ptr<TypeScavenger>(new CPlusPlusTypeScavenger());
2094}
2095
2097 static llvm::once_flag g_initialize;
2098 static TypeCategoryImplSP g_category;
2099
2100 llvm::call_once(g_initialize, [this]() -> void {
2102 g_category);
2103 if (g_category) {
2104 // NOTE: the libstdcpp formatters are loaded after libcxx formatters
2105 // because we don't want to the libcxx formatters to match the potential
2106 // `__debug` inline namespace that libstdcpp may use.
2107 // LLDB prioritizes the last loaded matching formatter.
2108 LoadLibCxxFormatters(g_category);
2109 LoadLibStdcppFormatters(g_category);
2110 LoadMsvcStlFormatters(g_category);
2111 LoadCommonStlFormatters(g_category);
2112 LoadSystemFormatters(g_category);
2113 }
2114 });
2115 return g_category;
2116}
2117
2120 static llvm::once_flag g_initialize;
2121 static ConstString g_vectortypes("VectorTypes");
2123
2124 llvm::call_once(g_initialize, []() -> void {
2125 g_formatters.push_back(
2128 static CXXFunctionSummaryFormat::SharedPointer formatter_sp(
2132 "Function pointer summary provider"));
2133 if (CompilerType CT = valobj.GetCompilerType();
2134 CT.IsFunctionPointerType() || CT.IsMemberFunctionPointerType() ||
2136 return formatter_sp;
2137 }
2138 return nullptr;
2139 });
2140 g_formatters.push_back(
2143 static CXXFunctionSummaryFormat::SharedPointer formatter_sp(
2146 .SetCascades(true)
2147 .SetDontShowChildren(true)
2148 .SetHideItemNames(true)
2149 .SetShowMembersOneLiner(true)
2150 .SetSkipPointers(true)
2151 .SetSkipReferences(false),
2153 "vector_type pointer summary provider"));
2154 if (valobj.GetCompilerType().IsVectorType()) {
2155 if (fmt_mgr.GetCategory(g_vectortypes)->IsEnabled())
2156 return formatter_sp;
2157 }
2158 return nullptr;
2159 });
2160 g_formatters.push_back(
2163 static CXXFunctionSummaryFormat::SharedPointer formatter_sp(
2166 .SetCascades(true)
2167 .SetDontShowChildren(true)
2168 .SetHideItemNames(true)
2169 .SetShowMembersOneLiner(true)
2170 .SetSkipPointers(true)
2171 .SetSkipReferences(false),
2173 "block pointer summary provider"));
2174 if (valobj.GetCompilerType().IsBlockPointerType()) {
2175 return formatter_sp;
2176 }
2177 return nullptr;
2178 });
2179 });
2180
2181 return g_formatters;
2182}
2183
2186 static llvm::once_flag g_initialize;
2187 static ConstString g_vectortypes("VectorTypes");
2189
2190 llvm::call_once(g_initialize, []() -> void {
2191 g_formatters.push_back([](lldb_private::ValueObject &valobj,
2194 static CXXSyntheticChildren::SharedPointer formatter_sp(
2197 .SetCascades(true)
2198 .SetSkipPointers(true)
2199 .SetSkipReferences(true)
2200 .SetNonCacheable(true),
2201 "vector_type synthetic children",
2203 if (valobj.GetCompilerType().IsVectorType()) {
2204 if (fmt_mgr.GetCategory(g_vectortypes)->IsEnabled())
2205 return formatter_sp;
2206 }
2207 return nullptr;
2208 });
2209 g_formatters.push_back([](lldb_private::ValueObject &valobj,
2212 static CXXSyntheticChildren::SharedPointer formatter_sp(
2215 .SetCascades(true)
2216 .SetSkipPointers(true)
2217 .SetSkipReferences(true)
2218 .SetNonCacheable(true),
2219 "block pointer synthetic children",
2221 if (valobj.GetCompilerType().IsBlockPointerType()) {
2222 return formatter_sp;
2223 }
2224 return nullptr;
2225 });
2226 });
2227
2228 return g_formatters;
2229}
2230
2233 !valobj.IsPointerType())
2234 return false;
2235 bool canReadValue = true;
2236 bool isZero = valobj.GetValueAsUnsigned(0, &canReadValue) == 0;
2237 return canReadValue && isZero;
2238}
2239
2240bool CPlusPlusLanguage::IsSourceFile(llvm::StringRef file_path) const {
2241 const auto suffixes = {".cpp", ".cxx", ".c++", ".cc", ".c",
2242 ".h", ".hh", ".hpp", ".hxx", ".h++"};
2243 for (auto suffix : suffixes) {
2244 if (file_path.ends_with_insensitive(suffix))
2245 return true;
2246 }
2247
2248 // Check if we're in a STL path (where the files usually have no extension
2249 // that we could check for.
2250 return file_path.contains("/usr/include/c++/");
2251}
2252
2254 assert(sc.function);
2255
2256 if (sc.block)
2257 if (Block *inline_block = sc.block->GetContainingInlinedBlock())
2258 return inline_block->GetBlockVariableList(true);
2259
2260 return sc.function->GetBlock(true).GetBlockVariableList(true);
2261}
2262
2264 const ExecutionContext *exe_ctx,
2265 const SymbolContext &sc) {
2266 assert(sc.function);
2267
2268 ExecutionContextScope *exe_scope =
2269 exe_ctx ? exe_ctx->GetBestExecutionContextScope() : nullptr;
2270
2271 const char *cstr = sc.GetPossiblyInlinedFunctionName()
2273 .AsCString();
2274 if (!cstr)
2275 return false;
2276
2277 VariableList args;
2278 if (auto variable_list_sp = GetFunctionVariableList(sc))
2280 args);
2281
2282 if (args.GetSize() > 0)
2283 return PrettyPrintFunctionNameWithArgs(s, cstr, exe_scope, args);
2284
2285 // FIXME: can we just unconditionally call PrettyPrintFunctionNameWithArgs?
2286 // It should be able to handle the "no arguments" case.
2287 s.PutCString(cstr);
2288
2289 return true;
2290}
2291
2293 const SymbolContext &sc, const ExecutionContext *exe_ctx,
2294 FunctionNameRepresentation representation, Stream &s) {
2295 switch (representation) {
2297 // Print the function name with arguments in it
2298 if (sc.function)
2299 return PrintFunctionNameWithArgs(s, exe_ctx, sc);
2300
2301 if (!sc.symbol)
2302 return false;
2303
2304 const char *cstr = sc.symbol->GetName().AsCString(nullptr);
2305 if (!cstr)
2306 return false;
2307
2308 s.PutCString(cstr);
2309
2310 return true;
2311 }
2314 return false;
2315 }
2316 llvm_unreachable("Fully covered switch above");
2317}
2318
2320 const SymbolContext &sc, const ExecutionContext *exe_ctx,
2322 switch (type) {
2324 auto scope_or_err = ::GetDemangledScope(sc);
2325 if (!scope_or_err) {
2327 GetLog(LLDBLog::Language), scope_or_err.takeError(),
2328 "Failed to handle ${{function.scope}} frame-format variable: {0}");
2329 return false;
2330 }
2331
2332 s << *scope_or_err;
2333
2334 return true;
2335 }
2336
2338 auto name_or_err = ::GetDemangledBasename(sc);
2339 if (!name_or_err) {
2341 GetLog(LLDBLog::Language), name_or_err.takeError(),
2342 "Failed to handle ${{function.basename}} frame-format variable: {0}");
2343 return false;
2344 }
2345
2346 s << *name_or_err;
2347
2348 return true;
2349 }
2350
2352 auto template_args_or_err = ::GetDemangledTemplateArguments(sc);
2353 if (!template_args_or_err) {
2355 template_args_or_err.takeError(),
2356 "Failed to handle ${{function.template-arguments}} "
2357 "frame-format variable: {0}");
2358 return false;
2359 }
2360
2361 s << *template_args_or_err;
2362
2363 return true;
2364 }
2365
2367 // This ensures we print the arguments even when no debug-info is available.
2368 //
2369 // FIXME: we should have a Entry::Type::FunctionArguments and
2370 // use it in the plugin.cplusplus.display.function-name-format
2371 // once we have a "fallback operator" in the frame-format language.
2372 if (!sc.function && sc.symbol)
2373 return PrintDemangledArgumentList(s, sc);
2374
2375 VariableList args;
2376 if (auto variable_list_sp = GetFunctionVariableList(sc))
2378 args);
2379
2380 ExecutionContextScope *exe_scope =
2381 exe_ctx ? exe_ctx->GetBestExecutionContextScope() : nullptr;
2382
2383 s << '(';
2385 s << ')';
2386
2387 return true;
2388 }
2390 auto return_rhs_or_err = ::GetDemangledReturnTypeRHS(sc);
2391 if (!return_rhs_or_err) {
2392 LLDB_LOG_ERROR(GetLog(LLDBLog::Language), return_rhs_or_err.takeError(),
2393 "Failed to handle ${{function.return-right}} frame-format "
2394 "variable: {0}");
2395 return false;
2396 }
2397
2398 s << *return_rhs_or_err;
2399
2400 return true;
2401 }
2403 auto return_lhs_or_err = ::GetDemangledReturnTypeLHS(sc);
2404 if (!return_lhs_or_err) {
2405 LLDB_LOG_ERROR(GetLog(LLDBLog::Language), return_lhs_or_err.takeError(),
2406 "Failed to handle ${{function.return-left}} frame-format "
2407 "variable: {0}");
2408 return false;
2409 }
2410
2411 s << *return_lhs_or_err;
2412
2413 return true;
2414 }
2416 auto quals_or_err = ::GetDemangledFunctionQualifiers(sc);
2417 if (!quals_or_err) {
2418 LLDB_LOG_ERROR(GetLog(LLDBLog::Language), quals_or_err.takeError(),
2419 "Failed to handle ${{function.qualifiers}} frame-format "
2420 "variable: {0}");
2421 return false;
2422 }
2423
2424 s << *quals_or_err;
2425
2426 return true;
2427 }
2429 auto suffix_or_err = ::GetDemangledFunctionSuffix(sc);
2430 if (!suffix_or_err) {
2432 GetLog(LLDBLog::Language), suffix_or_err.takeError(),
2433 "Failed to handle ${{function.suffix}} frame-format variable: {0}");
2434 return false;
2435 }
2436
2437 s << *suffix_or_err;
2438
2439 return true;
2440 }
2441 default:
2442 return false;
2443 }
2444}
2445
2446namespace {
2447class NodeAllocator {
2448 llvm::BumpPtrAllocator Alloc;
2449
2450public:
2451 void reset() { Alloc.Reset(); }
2452
2453 template <typename T, typename... Args> T *makeNode(Args &&...args) {
2454 return new (Alloc.Allocate(sizeof(T), alignof(T)))
2455 T(std::forward<Args>(args)...);
2456 }
2457
2458 void *allocateNodeArray(size_t sz) {
2459 return Alloc.Allocate(sizeof(llvm::itanium_demangle::Node *) * sz,
2460 alignof(llvm::itanium_demangle::Node *));
2461 }
2462};
2463
2464template <typename Derived>
2465class ManglingSubstitutor
2466 : public llvm::itanium_demangle::AbstractManglingParser<Derived,
2467 NodeAllocator> {
2468 using Base =
2469 llvm::itanium_demangle::AbstractManglingParser<Derived, NodeAllocator>;
2470
2471public:
2472 ManglingSubstitutor() : Base(nullptr, nullptr) {}
2473
2474 template <typename... Ts>
2475 llvm::Expected<ConstString> substitute(llvm::StringRef Mangled,
2476 Ts &&...Vals) {
2477 this->getDerived().reset(Mangled, std::forward<Ts>(Vals)...);
2478 return substituteImpl(Mangled);
2479 }
2480
2481protected:
2482 void reset(llvm::StringRef Mangled) {
2483 Base::reset(Mangled.begin(), Mangled.end());
2484 Written = Mangled.begin();
2485 Result.clear();
2486 Substituted = false;
2487 }
2488
2489 llvm::Expected<ConstString> substituteImpl(llvm::StringRef Mangled) {
2490 if (this->parse() == nullptr)
2491 return llvm::createStringError(
2492 llvm::formatv("Failed to substitute mangling in '{0}'", Mangled));
2493
2494 if (!Substituted)
2495 return ConstString();
2496
2497 // Append any trailing unmodified input.
2498 appendUnchangedInput();
2499 return ConstString(Result);
2500 }
2501
2502 void trySubstitute(llvm::StringRef From, llvm::StringRef To) {
2503 if (!llvm::StringRef(currentParserPos(), this->numLeft()).starts_with(From))
2504 return;
2505
2506 // We found a match. Append unmodified input up to this point.
2507 appendUnchangedInput();
2508
2509 // And then perform the replacement.
2510 Result += To;
2511 Written += From.size();
2512 Substituted = true;
2513 }
2514
2515private:
2516 /// Input character until which we have constructed the respective output
2517 /// already.
2518 const char *Written = "";
2519
2520 llvm::SmallString<128> Result;
2521
2522 /// Whether we have performed any substitutions.
2523 bool Substituted = false;
2524
2525 const char *currentParserPos() const { return this->First; }
2526
2527 void appendUnchangedInput() {
2528 Result +=
2529 llvm::StringRef(Written, std::distance(Written, currentParserPos()));
2530 Written = currentParserPos();
2531 }
2532};
2533
2534/// Given a mangled function `Mangled`, replace all the primitive function type
2535/// arguments of `Search` with type `Replace`.
2536class TypeSubstitutor : public ManglingSubstitutor<TypeSubstitutor> {
2537 llvm::StringRef Search;
2538 llvm::StringRef Replace;
2539
2540public:
2541 void reset(llvm::StringRef Mangled, llvm::StringRef Search,
2542 llvm::StringRef Replace) {
2543 ManglingSubstitutor::reset(Mangled);
2544 this->Search = Search;
2545 this->Replace = Replace;
2546 }
2547
2548 llvm::itanium_demangle::Node *parseType() {
2549 trySubstitute(Search, Replace);
2550 return ManglingSubstitutor::parseType();
2551 }
2552};
2553
2554class CtorDtorSubstitutor : public ManglingSubstitutor<CtorDtorSubstitutor> {
2555 llvm::StringRef Search;
2556 llvm::StringRef Replace;
2557
2558public:
2559 void reset(llvm::StringRef Mangled, llvm::StringRef Search,
2560 llvm::StringRef Replace) {
2561 ManglingSubstitutor::reset(Mangled);
2562 this->Search = Search;
2563 this->Replace = Replace;
2564 }
2565
2566 void reset(llvm::StringRef Mangled) { ManglingSubstitutor::reset(Mangled); }
2567
2568 llvm::itanium_demangle::Node *
2569 parseCtorDtorName(llvm::itanium_demangle::Node *&SoFar, NameState *State) {
2570 if (!Search.empty() && !Replace.empty()) {
2571 trySubstitute(Search, Replace);
2572 } else {
2573 trySubstitute("D1", "D2");
2574 trySubstitute("C1", "C2");
2575 }
2576 return ManglingSubstitutor::parseCtorDtorName(SoFar, State);
2577 }
2578};
2579} // namespace
2580
2581llvm::Expected<ConstString>
2583 llvm::StringRef subst_from,
2584 llvm::StringRef subst_to) {
2585 return TypeSubstitutor().substitute(mangled_name, subst_from, subst_to);
2586}
2587
2589 llvm::StringRef mangled_name, llvm::StringRef subst_from,
2590 llvm::StringRef subst_to) {
2591 return CtorDtorSubstitutor().substitute(mangled_name, subst_from, subst_to);
2592}
2593
2594llvm::Expected<ConstString>
2596 llvm::StringRef mangled_name) {
2597 return CtorDtorSubstitutor().substitute(mangled_name);
2598}
2599
2600#define LLDB_PROPERTIES_language_cplusplus
2601#include "LanguageCPlusPlusProperties.inc"
2602
2603enum {
2604#define LLDB_PROPERTIES_language_cplusplus
2605#include "LanguageCPlusPlusPropertiesEnum.inc"
2606};
2607
2608namespace {
2609class PluginProperties : public Properties {
2610public:
2611 static llvm::StringRef GetSettingName() { return "display"; }
2612
2613 PluginProperties() {
2614 m_collection_sp = std::make_shared<OptionValueProperties>(GetSettingName());
2615 m_collection_sp->Initialize(g_language_cplusplus_properties);
2616 }
2617
2618 FormatEntity::Entry GetFunctionNameFormat() const {
2619 return GetPropertyAtIndexAs<FormatEntity::Entry>(
2620 ePropertyFunctionNameFormat, {});
2621 }
2622};
2623} // namespace
2624
2625static PluginProperties &GetGlobalPluginProperties() {
2626 static PluginProperties g_settings;
2627 return g_settings;
2628}
2629
2633
2636 debugger, PluginProperties::GetSettingName())) {
2638 debugger, GetGlobalPluginProperties().GetValueProperties(),
2639 "Properties for the CPlusPlus language plug-in.",
2640 /*is_global_property=*/true);
2641 }
2642}
static void LoadLibStdcppFormatters(lldb::TypeCategoryImplSP cpp_category_sp)
static llvm::Expected< llvm::StringRef > GetDemangledReturnTypeLHS(const SymbolContext &sc)
static bool GenericStrongOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
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 SyntheticChildrenFrontEnd * GenericSpanSyntheticFrontEndCreator(CXXSyntheticChildren *children, ValueObjectSP valobj_sp)
static llvm::Expected< llvm::StringRef > GetDemangledScope(const SymbolContext &sc)
static bool GenericPartialOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
static bool GenericWeakOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
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 bool PrintFunctionNameWithArgs(Stream &s, const ExecutionContext *exe_ctx, const SymbolContext &sc)
static void PrettyPrintFunctionNameWithArgs(Stream &out_stream, char const *full_name, ExecutionContextScope *exe_scope, VariableList const &args)
Writes out the function name in 'full_name' to 'out_stream' but replaces each argument type with the ...
static VariableListSP GetFunctionVariableList(const SymbolContext &sc)
static PluginProperties & GetGlobalPluginProperties()
template bool lldb_private::formatters::LibStdcppStringViewSummaryProvider< StringElementType::ASCII >(ValueObject &, Stream &, const TypeSummaryOptions &)
template bool lldb_private::formatters::LibStdcppStringViewSummaryProvider< StringElementType::UTF32 >(ValueObject &, Stream &, const TypeSummaryOptions &)
template bool lldb_private::formatters::LibStdcppStringViewSummaryProvider< StringElementType::UTF16 >(ValueObject &, Stream &, const TypeSummaryOptions &)
template bool lldb_private::formatters::LibStdcppStringViewSummaryProvider< StringElementType::UTF8 >(ValueObject &, Stream &, const TypeSummaryOptions &)
#define LLDB_LOG_ERROR(log, error,...)
Definition Log.h:392
bool lldb_private::formatters::MsvcStlStringViewSummaryProvider< StringElementType::UTF32 >(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
Definition MsvcStl.cpp:220
bool lldb_private::formatters::MsvcStlStringViewSummaryProvider< StringElementType::UTF8 >(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
Definition MsvcStl.cpp:206
bool lldb_private::formatters::MsvcStlStringSummaryProvider< StringElementType::ASCII >(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
Definition MsvcStl.cpp:163
bool lldb_private::formatters::MsvcStlStringViewSummaryProvider< StringElementType::ASCII >(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
Definition MsvcStl.cpp:199
bool lldb_private::formatters::MsvcStlStringViewSummaryProvider< StringElementType::UTF16 >(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
Definition MsvcStl.cpp:213
#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.
Definition Args.h:33
A class that describes a single lexical block.
Definition Block.h:41
lldb::VariableListSP GetBlockVariableList(bool can_create)
Get the variable list for this block only.
Definition Block.cpp:392
Block * GetContainingInlinedBlock()
Get the inlined block that contains this block.
Definition Block.cpp:206
llvm::StringRef GetBasenameNoTemplateParameters()
Returns the Basename of this method without a template parameter list, if any.
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 &)
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 IsVectorType(CompilerType *element_type=nullptr, uint64_t *size=nullptr) const
A uniqued constant string class.
Definition ConstString.h:40
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.
Definition Debugger.h:87
"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
lldb::TypeCategoryImplSP GetCategory(const char *category_name=nullptr, bool can_create=true)
Block & GetBlock(bool can_create)
Get accessor for the block list.
Definition Function.cpp:383
HardcodedFormatterFinders< SyntheticChildren > HardcodedSyntheticFinder
HardcodedFormatterFinders< TypeSummaryImpl > HardcodedSummaryFinder
llvm::StringRef GetQualifiers()
Definition Language.h:271
llvm::StringRef GetReturnType()
Definition Language.h:277
static bool LanguageIsC(lldb::LanguageType language)
Definition Language.cpp:371
static bool LanguageIsCPlusPlus(lldb::LanguageType language)
Definition Language.cpp:346
A class that handles mangled names.
Definition Mangled.h:34
static bool IsMangledName(llvm::StringRef name)
Definition Mangled.cpp:39
ConstString GetMangledName() const
Mangled name get accessor.
Definition Mangled.h:152
ConstString GetDemangledName() const
Demangled name get accessor.
Definition Mangled.cpp:284
const std::optional< DemangledNameInfo > & GetDemangledInfo() const
Retrieve DemangledNameInfo of the demangled name held by this object.
Definition Mangled.cpp:288
ConstString GetName(NamePreference preference=ePreferDemangled) const
Best name get accessor.
Definition Mangled.cpp:369
static Mangled::ManglingScheme GetManglingScheme(llvm::StringRef name)
Try to identify the mangling scheme used.
Definition Mangled.cpp:43
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.
Definition Stream.h:28
size_t PutCString(llvm::StringRef cstr)
Output a C string to the stream.
Definition Stream.cpp:65
size_t PutChar(char ch)
Definition Stream.cpp:131
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.
Definition SymbolFile.h:51
virtual void GetMangledNamesForFunction(const std::string &scope_qualified_name, std::vector< ConstString > &mangled_names)
ConstString GetName() const
Definition Symbol.cpp:511
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)
Definition TypeSummary.h:86
Flags & SetSkipPointers(bool value=true)
Definition TypeSummary.h:99
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)
void PrettyPrintFunctionArguments(Stream &out_stream, VariableList const &args, ExecutionContextScope *exe_scope)
For each variable in 'args' this function writes the variable name and it's pretty-printed value repr...
SyntheticChildrenFrontEnd * LibCxxUnorderedMapIteratorSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
SyntheticChildrenFrontEnd * LibStdcppOptionalSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
SyntheticChildrenFrontEnd * LibcxxStdSpanSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool IsMsvcStlDeque(ValueObject &valobj)
bool Char32StringSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool LibcxxChronoSysSecondsSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:845
bool LibcxxChronoMonthSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:911
SyntheticChildrenFrontEnd * VectorTypeSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
SyntheticChildrenFrontEnd * LibcxxUniquePtrSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool IsMsvcStlUnordered(ValueObject &valobj)
bool LibcxxUniquePointerSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:228
SyntheticChildrenFrontEnd * LibStdcppUniquePtrSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool IsMsvcStlOptional(ValueObject &valobj)
bool WCharSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool IsMsvcStlStringType(ValueObject &valobj)
Definition MsvcStl.cpp:142
bool LibcxxPartialOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:261
bool LibStdcppStrongOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool IsMsvcStlTuple(ValueObject &valobj)
bool LibcxxSmartPointerSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:182
bool LibcxxStringViewSummaryProviderASCII(ValueObject &valueObj, Stream &stream, const TypeSummaryOptions &summary_options)
Definition LibCxx.cpp:748
bool LibcxxStringViewSummaryProviderUTF16(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
Definition LibCxx.cpp:755
lldb_private::SyntheticChildrenFrontEnd * MsvcStlVectorSyntheticFrontEndCreator(lldb::ValueObjectSP valobj_sp)
SyntheticChildrenFrontEnd * LibCxxVectorIteratorSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool VectorTypeSummaryProvider(ValueObject &, Stream &, const TypeSummaryOptions &)
SyntheticChildrenFrontEnd * LibStdcppTupleSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
SyntheticChildrenFrontEnd * LibcxxStdVectorSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool LibcxxStringViewSummaryProviderUTF32(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
Definition LibCxx.cpp:762
SyntheticChildrenFrontEnd * LibStdcppSpanSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool LibStdcppSmartPointerSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool MsvcStlUniquePtrSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
SyntheticChildrenFrontEnd * LibcxxQueueFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool LibStdcppStringSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool LibcxxWeakOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:285
SyntheticChildrenFrontEnd * LibcxxBitsetSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
void AddCXXSummary(TypeCategoryImpl::SharedPointer category_sp, CXXFunctionSummaryFormat::Callback funct, const char *description, llvm::StringRef type_name, TypeSummaryImpl::Flags flags, bool regex=false)
Add a summary that is implemented by a C++ callback.
SyntheticChildrenFrontEnd * MsvcStlListSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
bool MsvcStlPartialOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition MsvcStl.cpp:243
bool MsvcStlWeakOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition MsvcStl.cpp:267
bool LibcxxChronoYearMonthDaySummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:953
bool LibStdcppUniquePointerSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool LibcxxWStringSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:631
SyntheticChildrenFrontEnd * LibcxxTupleFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool LibcxxStringSummaryProviderASCII(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
Definition LibCxx.cpp:688
SyntheticChildrenFrontEnd * MsvcStlForwardListSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
bool LibcxxChronoLocalSecondsSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:851
SyntheticChildrenFrontEnd * StdlibCoroutineHandleSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
SyntheticChildrenFrontEnd * LibcxxStdRangesRefViewSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
SyntheticChildrenFrontEnd * MsvcStlTupleSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
bool LibcxxWStringViewSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:769
bool Char8SummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool LibcxxChronoWeekdaySummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:932
bool MsvcStlVariantSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool IsMsvcStlMapLike(ValueObject &valobj)
SyntheticChildrenFrontEnd * LibcxxOptionalSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
SyntheticChildrenFrontEnd * LibStdcppVectorIteratorSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool MsvcStlStrongOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition MsvcStl.cpp:288
SyntheticChildrenFrontEnd * LibcxxStdProxyArraySyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool LibcxxStringSummaryProviderUTF16(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
Definition LibCxx.cpp:695
bool Char16SummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool LibcxxStdSliceArraySummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool LibcxxFunctionSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:134
bool MsvcStlSmartPointerSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool LibcxxStringSummaryProviderUTF32(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
Definition LibCxx.cpp:702
bool IsMsvcStlUniquePtr(ValueObject &valobj)
SyntheticChildrenFrontEnd * LibcxxStdListSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool LibcxxStrongOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:306
void AddCXXSynthetic(TypeCategoryImpl::SharedPointer category_sp, CXXSyntheticChildren::CreateFrontEndCallback generator, const char *description, llvm::StringRef type_name, ScriptedSyntheticChildren::Flags flags, bool regex=false)
Add a synthetic that is implemented by a C++ callback.
SyntheticChildrenFrontEnd * GenericInitializerListSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
bool MsvcStlStringSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &summary_options)
bool LibcxxChronoLocalDaysSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:905
SyntheticChildrenFrontEnd * LibstdcppMapIteratorSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
SyntheticChildrenFrontEnd * MsvcStlOptionalSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
SyntheticChildrenFrontEnd * MsvcStlVariantSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
lldb_private::SyntheticChildrenFrontEnd * MsvcStlMapLikeSyntheticFrontEndCreator(lldb::ValueObjectSP valobj_sp)
bool MsvcStlTreeIterSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool IsMsvcStlOrdering(ValueObject &valobj)
Definition MsvcStl.cpp:226
bool Char8StringSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
SyntheticChildrenFrontEnd * LibcxxStdMapSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool IsMsvcStlStringViewType(ValueObject &valobj)
Definition MsvcStl.cpp:148
SyntheticChildrenFrontEnd * LibStdcppBitsetSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool LibStdcppPartialOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
SyntheticChildrenFrontEnd * LibcxxVariantFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
SyntheticChildrenFrontEnd * LibStdcppSharedPtrSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool StdlibCoroutineHandleSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Summary provider for std::coroutine_handle<T> from libc++, libstdc++ and MSVC STL.
bool MsvcStlWStringViewSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition MsvcStl.cpp:190
bool LibcxxVariantSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool LibCxxAtomicSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool ContainerSizeSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool Char16StringSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
SyntheticChildrenFrontEnd * MsvcStlUnorderedSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
bool WCharStringSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool IsMsvcStlList(ValueObject &valobj)
SyntheticChildrenFrontEnd * LibcxxAtomicSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool GenericOptionalSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
SyntheticChildrenFrontEnd * LibcxxStdUnorderedMapSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
SyntheticChildrenFrontEnd * BlockPointerSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool IsMsvcStlSpan(ValueObject &valobj)
SyntheticChildrenFrontEnd * MsvcStlSpanSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
SyntheticChildrenFrontEnd * MsvcStlDequeSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
bool BlockPointerSummaryProvider(ValueObject &, Stream &, const TypeSummaryOptions &)
lldb_private::SyntheticChildrenFrontEnd * MsvcStlTreeIterSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
SyntheticChildrenFrontEnd * LibcxxStdForwardListSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
SyntheticChildrenFrontEnd * LibcxxSharedPtrSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
SyntheticChildrenFrontEnd * LibCxxMapIteratorSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
lldb_private::SyntheticChildrenFrontEnd * MsvcStlSmartPointerSyntheticFrontEndCreator(lldb::ValueObjectSP valobj_sp)
bool LibcxxChronoSysDaysSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition LibCxx.cpp:899
bool LibStdcppVariantSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool MsvcStlWStringSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
Definition MsvcStl.cpp:154
SyntheticChildrenFrontEnd * LibcxxStdSliceArraySyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool Char32SummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
lldb_private::SyntheticChildrenFrontEnd * MsvcStlUniquePtrSyntheticFrontEndCreator(lldb::ValueObjectSP valobj_sp)
bool IsMsvcStlVariant(ValueObject &valobj)
bool CXXFunctionPointerSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool LibStdcppWStringViewSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
SyntheticChildrenFrontEnd * MsvcStlAtomicSyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP valobj_sp)
SyntheticChildrenFrontEnd * LibcxxStdValarraySyntheticFrontEndCreator(CXXSyntheticChildren *, lldb::ValueObjectSP)
bool LibStdcppWeakOrderingSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
bool IsMsvcStlSmartPointer(ValueObject &valobj)
bool MsvcStlAtomicSummaryProvider(ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options)
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.
Definition Log.h:332
std::shared_ptr< lldb_private::TypeSummaryImpl > TypeSummaryImplSP
std::shared_ptr< lldb_private::ValueObject > ValueObjectSP
LanguageType
Programming language type.
@ eLanguageTypeObjC_plus_plus
Objective-C++.
@ eFormatterMatchExact
@ eFormatterMatchRegex
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
std::shared_ptr< CXXFunctionSummaryFormat > SharedPointer
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,...