diff options
| author | Davide Italiano <davide@freebsd.org> | 2018-07-27 19:57:30 +0000 |
|---|---|---|
| committer | Davide Italiano <davide@freebsd.org> | 2018-07-27 19:57:30 +0000 |
| commit | 1d44c46539fa1a40c74b4354022f5aeaeb9c3b6a (patch) | |
| tree | 77b377918ce6632f8aab37e1e5c07121b1d78c5d /lldb/source/Plugins/Language/CPlusPlus/LibCxx.cpp | |
| parent | b83b4e40fe430524aa215005de3cd751e32864b7 (diff) | |
| download | bcm5719-llvm-1d44c46539fa1a40c74b4354022f5aeaeb9c3b6a.tar.gz bcm5719-llvm-1d44c46539fa1a40c74b4354022f5aeaeb9c3b6a.zip | |
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
Diffstat (limited to 'lldb/source/Plugins/Language/CPlusPlus/LibCxx.cpp')
| -rw-r--r-- | lldb/source/Plugins/Language/CPlusPlus/LibCxx.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/lldb/source/Plugins/Language/CPlusPlus/LibCxx.cpp b/lldb/source/Plugins/Language/CPlusPlus/LibCxx.cpp index 95e02a473cd..6c5a4f6095c 100644 --- a/lldb/source/Plugins/Language/CPlusPlus/LibCxx.cpp +++ b/lldb/source/Plugins/Language/CPlusPlus/LibCxx.cpp @@ -33,6 +33,28 @@ using namespace lldb; using namespace lldb_private; 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( ValueObject &valobj, Stream &stream, const TypeSummaryOptions &options) { ValueObjectSP valobj_sp(valobj.GetNonSyntheticValue()); |

