================ @@ -287,8 +292,49 @@ bool lldb_private::formatters::LibStdcppStringSummaryProvider( } else return true; } break; - case eAddressTypeHost: - break; + case eAddressTypeHost: { + + DataExtractor data; + Status error; + valobj.GetData(data, error); + if (error.Fail()) + return false; + + lldb::offset_t offset = 0; + AddressType child_addressType = valobj.GetAddressTypeOfChildren(); + if (child_addressType == eAddressTypeLoad) { + // We have the host address of our std::string + // But we need to read the pointee data from the debugged process. + ProcessSP process_sp(valobj.GetProcessSP()); + // We want to read the address from std::string, which is the first 8 bytes. + lldb::addr_t addr = data.GetAddress(&offset); + if (!addr) { + stream.Printf("nullptr"); + return true; + } + std::string contents; + process_sp->ReadCStringFromMemory(addr, contents, error); + if (error.Fail()) + return false; + + stream.Printf("%s", contents.c_str()); + return true; + } + + if (child_addressType == eAddressTypeHost) { ---------------- clayborg wrote:
This code is never being run because no one will set the child address type to host memory. https://github.com/llvm/llvm-project/pull/89110 _______________________________________________ lldb-commits mailing list lldb-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits