forked from OSchip/llvm-project
Recommit [DataFormatters] Add formatter for C++17 std::optional.
This should have all the correct files now. <rdar://problem/41471112> Patch by Shafik Yaghmour. Differential Revision: https://reviews.llvm.org/D49271 llvm-svn: 338156
This commit is contained in:
parent
b83b4e40fe
commit
1d44c46539
|
@ -388,6 +388,7 @@
|
||||||
945261C11B9A11FC00BF138D /* LibCxxInitializerList.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 945261B71B9A11E800BF138D /* LibCxxInitializerList.cpp */; };
|
945261C11B9A11FC00BF138D /* LibCxxInitializerList.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 945261B71B9A11E800BF138D /* LibCxxInitializerList.cpp */; };
|
||||||
945261C21B9A11FC00BF138D /* LibCxxList.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 945261B81B9A11E800BF138D /* LibCxxList.cpp */; };
|
945261C21B9A11FC00BF138D /* LibCxxList.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 945261B81B9A11E800BF138D /* LibCxxList.cpp */; };
|
||||||
945261C31B9A11FC00BF138D /* LibCxxMap.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 945261B91B9A11E800BF138D /* LibCxxMap.cpp */; };
|
945261C31B9A11FC00BF138D /* LibCxxMap.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 945261B91B9A11E800BF138D /* LibCxxMap.cpp */; };
|
||||||
|
E4A63A9120F55D28000D9548 /* LibCxxOptional.cpp in Sources */ = {isa = PBXBuildFile; fileRef = E4A63A9020F55D27000D9548 /* LibCxxOptional.cpp */; };
|
||||||
AF9FF1F71FAA79FE00474976 /* LibCxxQueue.cpp in Sources */ = {isa = PBXBuildFile; fileRef = AF9FF1F61FAA79FE00474976 /* LibCxxQueue.cpp */; };
|
AF9FF1F71FAA79FE00474976 /* LibCxxQueue.cpp in Sources */ = {isa = PBXBuildFile; fileRef = AF9FF1F61FAA79FE00474976 /* LibCxxQueue.cpp */; };
|
||||||
AF9FF1F51FAA79A400474976 /* LibCxxTuple.cpp in Sources */ = {isa = PBXBuildFile; fileRef = AF9FF1F41FAA79A400474976 /* LibCxxTuple.cpp */; };
|
AF9FF1F51FAA79A400474976 /* LibCxxTuple.cpp in Sources */ = {isa = PBXBuildFile; fileRef = AF9FF1F41FAA79A400474976 /* LibCxxTuple.cpp */; };
|
||||||
945261C41B9A11FC00BF138D /* LibCxxUnorderedMap.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 945261BA1B9A11E800BF138D /* LibCxxUnorderedMap.cpp */; };
|
945261C41B9A11FC00BF138D /* LibCxxUnorderedMap.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 945261BA1B9A11E800BF138D /* LibCxxUnorderedMap.cpp */; };
|
||||||
|
@ -2000,6 +2001,7 @@
|
||||||
945261B71B9A11E800BF138D /* LibCxxInitializerList.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxInitializerList.cpp; path = Language/CPlusPlus/LibCxxInitializerList.cpp; sourceTree = "<group>"; };
|
945261B71B9A11E800BF138D /* LibCxxInitializerList.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxInitializerList.cpp; path = Language/CPlusPlus/LibCxxInitializerList.cpp; sourceTree = "<group>"; };
|
||||||
945261B81B9A11E800BF138D /* LibCxxList.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxList.cpp; path = Language/CPlusPlus/LibCxxList.cpp; sourceTree = "<group>"; };
|
945261B81B9A11E800BF138D /* LibCxxList.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxList.cpp; path = Language/CPlusPlus/LibCxxList.cpp; sourceTree = "<group>"; };
|
||||||
945261B91B9A11E800BF138D /* LibCxxMap.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxMap.cpp; path = Language/CPlusPlus/LibCxxMap.cpp; sourceTree = "<group>"; };
|
945261B91B9A11E800BF138D /* LibCxxMap.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxMap.cpp; path = Language/CPlusPlus/LibCxxMap.cpp; sourceTree = "<group>"; };
|
||||||
|
E4A63A9020F55D27000D9548 /* LibCxxOptional.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxOptional.cpp; path = Language/CPlusPlus/LibCxxOptional.cpp; sourceTree = "<group>"; };
|
||||||
AF9FF1F61FAA79FE00474976 /* LibCxxQueue.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxQueue.cpp; path = Language/CPlusPlus/LibCxxQueue.cpp; sourceTree = "<group>"; };
|
AF9FF1F61FAA79FE00474976 /* LibCxxQueue.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxQueue.cpp; path = Language/CPlusPlus/LibCxxQueue.cpp; sourceTree = "<group>"; };
|
||||||
AF9FF1F41FAA79A400474976 /* LibCxxTuple.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxTuple.cpp; path = Language/CPlusPlus/LibCxxTuple.cpp; sourceTree = "<group>"; };
|
AF9FF1F41FAA79A400474976 /* LibCxxTuple.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxTuple.cpp; path = Language/CPlusPlus/LibCxxTuple.cpp; sourceTree = "<group>"; };
|
||||||
945261BA1B9A11E800BF138D /* LibCxxUnorderedMap.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxUnorderedMap.cpp; path = Language/CPlusPlus/LibCxxUnorderedMap.cpp; sourceTree = "<group>"; };
|
945261BA1B9A11E800BF138D /* LibCxxUnorderedMap.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = LibCxxUnorderedMap.cpp; path = Language/CPlusPlus/LibCxxUnorderedMap.cpp; sourceTree = "<group>"; };
|
||||||
|
@ -6351,6 +6353,7 @@
|
||||||
945261B71B9A11E800BF138D /* LibCxxInitializerList.cpp */,
|
945261B71B9A11E800BF138D /* LibCxxInitializerList.cpp */,
|
||||||
945261B81B9A11E800BF138D /* LibCxxList.cpp */,
|
945261B81B9A11E800BF138D /* LibCxxList.cpp */,
|
||||||
945261B91B9A11E800BF138D /* LibCxxMap.cpp */,
|
945261B91B9A11E800BF138D /* LibCxxMap.cpp */,
|
||||||
|
E4A63A9020F55D27000D9548 /* LibCxxOptional.cpp */,
|
||||||
AF9FF1F61FAA79FE00474976 /* LibCxxQueue.cpp */,
|
AF9FF1F61FAA79FE00474976 /* LibCxxQueue.cpp */,
|
||||||
AF9FF1F41FAA79A400474976 /* LibCxxTuple.cpp */,
|
AF9FF1F41FAA79A400474976 /* LibCxxTuple.cpp */,
|
||||||
945261BA1B9A11E800BF138D /* LibCxxUnorderedMap.cpp */,
|
945261BA1B9A11E800BF138D /* LibCxxUnorderedMap.cpp */,
|
||||||
|
@ -8045,6 +8048,7 @@
|
||||||
AF26703B1852D01E00B6CC36 /* QueueList.cpp in Sources */,
|
AF26703B1852D01E00B6CC36 /* QueueList.cpp in Sources */,
|
||||||
267C012B136880DF006E963E /* OptionGroupValueObjectDisplay.cpp in Sources */,
|
267C012B136880DF006E963E /* OptionGroupValueObjectDisplay.cpp in Sources */,
|
||||||
49CA96FE1E6AACC900C03FEE /* DataEncoder.cpp in Sources */,
|
49CA96FE1E6AACC900C03FEE /* DataEncoder.cpp in Sources */,
|
||||||
|
E4A63A9120F55D28000D9548 /* LibCxxOptional.cpp in Sources */,
|
||||||
26BCFC521368AE38006DC050 /* OptionGroupFormat.cpp in Sources */,
|
26BCFC521368AE38006DC050 /* OptionGroupFormat.cpp in Sources */,
|
||||||
2654A6901E552ED500DA1013 /* VASprintf.cpp in Sources */,
|
2654A6901E552ED500DA1013 /* VASprintf.cpp in Sources */,
|
||||||
AF81DEFA1828A23F0042CF19 /* SystemRuntime.cpp in Sources */,
|
AF81DEFA1828A23F0042CF19 /* SystemRuntime.cpp in Sources */,
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
LEVEL = ../../../../../make
|
||||||
|
|
||||||
|
CXX_SOURCES := main.cpp
|
||||||
|
|
||||||
|
USE_LIBCPP := 1
|
||||||
|
include $(LEVEL)/Makefile.rules
|
||||||
|
CXXFLAGS += -std=c++17
|
|
@ -0,0 +1,59 @@
|
||||||
|
"""
|
||||||
|
Test lldb data formatter subsystem.
|
||||||
|
"""
|
||||||
|
|
||||||
|
from __future__ import print_function
|
||||||
|
|
||||||
|
|
||||||
|
import os
|
||||||
|
import time
|
||||||
|
import lldb
|
||||||
|
from lldbsuite.test.decorators import *
|
||||||
|
from lldbsuite.test.lldbtest import *
|
||||||
|
from lldbsuite.test import lldbutil
|
||||||
|
|
||||||
|
|
||||||
|
class LibcxxOptionalDataFormatterTestCase(TestBase):
|
||||||
|
|
||||||
|
mydir = TestBase.compute_mydir(__file__)
|
||||||
|
|
||||||
|
@add_test_categories(["libc++"])
|
||||||
|
|
||||||
|
def test_with_run_command(self):
|
||||||
|
"""Test that that file and class static variables display correctly."""
|
||||||
|
self.build()
|
||||||
|
self.runCmd("file " + self.getBuildArtifact("a.out"), CURRENT_EXECUTABLE_SET)
|
||||||
|
|
||||||
|
bkpt = self.target().FindBreakpointByID(
|
||||||
|
lldbutil.run_break_set_by_source_regexp(
|
||||||
|
self, "break here"))
|
||||||
|
|
||||||
|
self.runCmd("run", RUN_SUCCEEDED)
|
||||||
|
|
||||||
|
# The stop reason of the thread should be breakpoint.
|
||||||
|
self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT,
|
||||||
|
substrs=['stopped',
|
||||||
|
'stop reason = breakpoint'])
|
||||||
|
|
||||||
|
self.expect("frame variable number_not_engaged",
|
||||||
|
substrs=['Has Value=false'])
|
||||||
|
|
||||||
|
self.expect("frame variable number_engaged",
|
||||||
|
substrs=['Has Value=true',
|
||||||
|
'Value = 42',
|
||||||
|
'}'])
|
||||||
|
|
||||||
|
self.expect("frame var numbers",
|
||||||
|
substrs=['(optional_int_vect) numbers = Has Value=true {',
|
||||||
|
'Value = size=4 {',
|
||||||
|
'[0] = 1',
|
||||||
|
'[1] = 2',
|
||||||
|
'[2] = 3',
|
||||||
|
'[3] = 4',
|
||||||
|
'}',
|
||||||
|
'}'])
|
||||||
|
|
||||||
|
self.expect("frame var ostring",
|
||||||
|
substrs=['(optional_string) ostring = Has Value=true {',
|
||||||
|
'Value = "hello"',
|
||||||
|
'}'])
|
|
@ -0,0 +1,27 @@
|
||||||
|
#include <cstdio>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
#include <optional>
|
||||||
|
|
||||||
|
using int_vect = std::vector<int> ;
|
||||||
|
using optional_int = std::optional<int> ;
|
||||||
|
using optional_int_vect = std::optional<int_vect> ;
|
||||||
|
using optional_string = std::optional<std::string> ;
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
optional_int number_not_engaged ;
|
||||||
|
optional_int number_engaged = 42 ;
|
||||||
|
|
||||||
|
printf( "%d\n", *number_engaged) ;
|
||||||
|
|
||||||
|
optional_int_vect numbers{{1,2,3,4}} ;
|
||||||
|
|
||||||
|
printf( "%d %d\n", numbers.value()[0], numbers.value()[1] ) ;
|
||||||
|
|
||||||
|
optional_string ostring = "hello" ;
|
||||||
|
|
||||||
|
printf( "%s\n", ostring->c_str() ) ;
|
||||||
|
|
||||||
|
return 0; // break here
|
||||||
|
}
|
|
@ -9,6 +9,7 @@ add_lldb_library(lldbPluginCPlusPlusLanguage PLUGIN
|
||||||
LibCxxInitializerList.cpp
|
LibCxxInitializerList.cpp
|
||||||
LibCxxList.cpp
|
LibCxxList.cpp
|
||||||
LibCxxMap.cpp
|
LibCxxMap.cpp
|
||||||
|
LibCxxOptional.cpp
|
||||||
LibCxxQueue.cpp
|
LibCxxQueue.cpp
|
||||||
LibCxxTuple.cpp
|
LibCxxTuple.cpp
|
||||||
LibCxxUnorderedMap.cpp
|
LibCxxUnorderedMap.cpp
|
||||||
|
|
|
@ -493,6 +493,10 @@ static void LoadLibCxxFormatters(lldb::TypeCategoryImplSP cpp_category_sp) {
|
||||||
"libc++ std::tuple synthetic children",
|
"libc++ std::tuple synthetic children",
|
||||||
ConstString("^std::__(ndk)?1::tuple<.*>(( )?&)?$"), stl_synth_flags,
|
ConstString("^std::__(ndk)?1::tuple<.*>(( )?&)?$"), stl_synth_flags,
|
||||||
true);
|
true);
|
||||||
|
AddCXXSynthetic(cpp_category_sp, LibcxxOptionalFrontEndCreator,
|
||||||
|
"libc++ std::optional synthetic children",
|
||||||
|
ConstString("^std::__(ndk)?1::optional<.+>(( )?&)?$"),
|
||||||
|
stl_synth_flags, true);
|
||||||
AddCXXSynthetic(
|
AddCXXSynthetic(
|
||||||
cpp_category_sp,
|
cpp_category_sp,
|
||||||
lldb_private::formatters::LibcxxAtomicSyntheticFrontEndCreator,
|
lldb_private::formatters::LibcxxAtomicSyntheticFrontEndCreator,
|
||||||
|
@ -584,6 +588,11 @@ static void LoadLibCxxFormatters(lldb::TypeCategoryImplSP cpp_category_sp) {
|
||||||
cpp_category_sp, lldb_private::formatters::LibCxxAtomicSummaryProvider,
|
cpp_category_sp, lldb_private::formatters::LibCxxAtomicSummaryProvider,
|
||||||
"libc++ std::atomic summary provider",
|
"libc++ std::atomic summary provider",
|
||||||
ConstString("^std::__(ndk)?1::atomic<.+>$"), stl_summary_flags, true);
|
ConstString("^std::__(ndk)?1::atomic<.+>$"), stl_summary_flags, true);
|
||||||
|
AddCXXSummary(cpp_category_sp,
|
||||||
|
lldb_private::formatters::LibcxxOptionalSummaryProvider,
|
||||||
|
"libc++ std::optional summary provider",
|
||||||
|
ConstString("^std::__(ndk)?1::optional<.+>(( )?&)?$"),
|
||||||
|
stl_summary_flags, true);
|
||||||
|
|
||||||
stl_summary_flags.SetSkipPointers(true);
|
stl_summary_flags.SetSkipPointers(true);
|
||||||
|
|
||||||
|
|
|
@ -33,6 +33,28 @@ using namespace lldb;
|
||||||
using namespace lldb_private;
|
using namespace lldb_private;
|
||||||
using namespace lldb_private::formatters;
|
using namespace lldb_private::formatters;
|
||||||
|
|
||||||
|
bool lldb_private::formatters::LibcxxOptionalSummaryProvider(
|
||||||
|
ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options) {
|
||||||
|
ValueObjectSP valobj_sp(valobj.GetNonSyntheticValue());
|
||||||
|
if (!valobj_sp)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// An optional either contains a value or not, the member __engaged_ is
|
||||||
|
// a bool flag, it is true if the optional has a value and false otherwise.
|
||||||
|
ValueObjectSP engaged_sp(
|
||||||
|
valobj_sp->GetChildMemberWithName(ConstString("__engaged_"), true));
|
||||||
|
|
||||||
|
if (!engaged_sp)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
llvm::StringRef engaged_as_cstring(
|
||||||
|
engaged_sp->GetValueAsUnsigned(0) == 1 ? "true" : "false");
|
||||||
|
|
||||||
|
stream.Printf(" Has Value=%s ", engaged_as_cstring.data());
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool lldb_private::formatters::LibcxxSmartPointerSummaryProvider(
|
bool lldb_private::formatters::LibcxxSmartPointerSummaryProvider(
|
||||||
ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options) {
|
ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options) {
|
||||||
ValueObjectSP valobj_sp(valobj.GetNonSyntheticValue());
|
ValueObjectSP valobj_sp(valobj.GetNonSyntheticValue());
|
||||||
|
|
|
@ -27,6 +27,10 @@ bool LibcxxWStringSummaryProvider(
|
||||||
ValueObject &valobj, Stream &stream,
|
ValueObject &valobj, Stream &stream,
|
||||||
const TypeSummaryOptions &options); // libc++ std::wstring
|
const TypeSummaryOptions &options); // libc++ std::wstring
|
||||||
|
|
||||||
|
bool LibcxxOptionalSummaryProvider(
|
||||||
|
ValueObject &valobj, Stream &stream,
|
||||||
|
const TypeSummaryOptions &options); // libc++ std::optional<>
|
||||||
|
|
||||||
bool LibcxxSmartPointerSummaryProvider(
|
bool LibcxxSmartPointerSummaryProvider(
|
||||||
ValueObject &valobj, Stream &stream,
|
ValueObject &valobj, Stream &stream,
|
||||||
const TypeSummaryOptions
|
const TypeSummaryOptions
|
||||||
|
@ -133,6 +137,10 @@ SyntheticChildrenFrontEnd *LibcxxQueueFrontEndCreator(CXXSyntheticChildren *,
|
||||||
SyntheticChildrenFrontEnd *LibcxxTupleFrontEndCreator(CXXSyntheticChildren *,
|
SyntheticChildrenFrontEnd *LibcxxTupleFrontEndCreator(CXXSyntheticChildren *,
|
||||||
lldb::ValueObjectSP);
|
lldb::ValueObjectSP);
|
||||||
|
|
||||||
|
SyntheticChildrenFrontEnd *
|
||||||
|
LibcxxOptionalFrontEndCreator(CXXSyntheticChildren *,
|
||||||
|
lldb::ValueObjectSP valobj_sp);
|
||||||
|
|
||||||
} // namespace formatters
|
} // namespace formatters
|
||||||
} // namespace lldb_private
|
} // namespace lldb_private
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,85 @@
|
||||||
|
//===-- LibCxxOptional.cpp --------------------------------------*- C++ -*-===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "LibCxx.h"
|
||||||
|
#include "lldb/DataFormatters/FormattersHelpers.h"
|
||||||
|
|
||||||
|
using namespace lldb;
|
||||||
|
using namespace lldb_private;
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
class OptionalFrontEnd : public SyntheticChildrenFrontEnd {
|
||||||
|
public:
|
||||||
|
OptionalFrontEnd(ValueObject &valobj) : SyntheticChildrenFrontEnd(valobj) {
|
||||||
|
Update();
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t GetIndexOfChildWithName(const ConstString &name) override {
|
||||||
|
return formatters::ExtractIndexFromString(name.GetCString());
|
||||||
|
}
|
||||||
|
|
||||||
|
bool MightHaveChildren() override { return true; }
|
||||||
|
bool Update() override;
|
||||||
|
size_t CalculateNumChildren() override { return m_size; }
|
||||||
|
ValueObjectSP GetChildAtIndex(size_t idx) override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
size_t m_size = 0;
|
||||||
|
ValueObjectSP m_base_sp;
|
||||||
|
};
|
||||||
|
} // namespace
|
||||||
|
|
||||||
|
bool OptionalFrontEnd::Update() {
|
||||||
|
ValueObjectSP engaged_sp(
|
||||||
|
m_backend.GetChildMemberWithName(ConstString("__engaged_"), true));
|
||||||
|
|
||||||
|
if (!engaged_sp)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// __engaged_ is a bool flag and is true if the optional contains a value.
|
||||||
|
// Converting it to unsigned gives us a size of 1 if it contains a value
|
||||||
|
// and 0 if not.
|
||||||
|
m_size = engaged_sp->GetValueAsUnsigned(0);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
ValueObjectSP OptionalFrontEnd::GetChildAtIndex(size_t idx) {
|
||||||
|
if (idx >= m_size)
|
||||||
|
return ValueObjectSP();
|
||||||
|
|
||||||
|
// __val_ contains the underlying value of an optional if it has one.
|
||||||
|
// Currently because it is part of an anonymous union GetChildMemberWithName()
|
||||||
|
// does not peer through and find it unless we are at the parent itself.
|
||||||
|
// We can obtain the parent through __engaged_.
|
||||||
|
ValueObjectSP val_sp(
|
||||||
|
m_backend.GetChildMemberWithName(ConstString("__engaged_"), true)
|
||||||
|
->GetParent()
|
||||||
|
->GetChildAtIndex(0, true)
|
||||||
|
->GetChildMemberWithName(ConstString("__val_"), true));
|
||||||
|
|
||||||
|
if (!val_sp)
|
||||||
|
return ValueObjectSP();
|
||||||
|
|
||||||
|
CompilerType holder_type = val_sp->GetCompilerType();
|
||||||
|
|
||||||
|
if (!holder_type)
|
||||||
|
return ValueObjectSP();
|
||||||
|
|
||||||
|
return val_sp->Clone(ConstString(llvm::formatv("Value").str()));
|
||||||
|
}
|
||||||
|
|
||||||
|
SyntheticChildrenFrontEnd *
|
||||||
|
formatters::LibcxxOptionalFrontEndCreator(CXXSyntheticChildren *,
|
||||||
|
lldb::ValueObjectSP valobj_sp) {
|
||||||
|
if (valobj_sp)
|
||||||
|
return new OptionalFrontEnd(*valobj_sp);
|
||||||
|
return nullptr;
|
||||||
|
}
|
Loading…
Reference in New Issue