86 return llvm::createStringError(
87 "failed to determine start/end of vector data");
89 uint64_t start_val =
m_start->GetValueAsUnsigned(0);
90 uint64_t finish_val =
m_finish->GetValueAsUnsigned(0);
93 if (start_val == 0 && finish_val == 0)
97 return llvm::createStringError(
"invalid value for start of vector");
100 return llvm::createStringError(
"invalid value for end of vector");
102 if (start_val > finish_val)
103 return llvm::createStringError(
104 "start of vector data begins after end pointer");
106 size_t num_children = (finish_val - start_val);
108 return llvm::createStringError(
"size not multiple of element size");
120 offset = offset +
m_start->GetValueAsUnsigned(0);
122 name.
Printf(
"[%" PRIu64
"]", (uint64_t)idx);
130 root, 2,
"__cap_",
"__end_cap_");
134 if (is_compressed_pair)
149 llvm::Expected<uint64_t> size_or_err =
m_element_type.GetByteSize(
nullptr);
165llvm::Expected<size_t>
169 return llvm::createStringError(
"Type has no child named '%s'",
173 return llvm::createStringError(
"Type has no child named '%s'",
176 return *optional_idx;
207 size_t byte_idx = (idx >> 3);
208 size_t bit_index = (idx & 7);
216 size_t bytes_read = process_sp->ReadMemory(byte_location, &
byte, 1, err);
217 if (err.
Fail() || bytes_read == 0)
219 mask = 1 << bit_index;
220 bool bit_set = ((
byte & mask) != 0);
221 std::optional<uint64_t> size =
222 llvm::expectedToOptional(
m_bool_type.GetByteSize(
nullptr));
226 if (bit_set && buffer_sp && buffer_sp->GetBytes()) {
228 *(buffer_sp->GetBytes()) = 1;
231 name.
Printf(
"[%" PRIu64
"]", (uint64_t)idx);
235 process_sp->GetAddressByteSize()),
249 ValueObjectSP size_sp(valobj_sp->GetChildMemberWithName(
"__size_"));
252 m_count = size_sp->GetValueAsUnsigned(0);
255 ValueObjectSP begin_sp(valobj_sp->GetChildMemberWithName(
"__begin_"));
268llvm::Expected<size_t>
272 return llvm::createStringError(
"Type has no child named '%s'",
276 return llvm::createStringError(
"Type has no child named '%s'",
279 uint32_t idx = *optional_idx;
281 return llvm::createStringError(
"Type has no child named '%s'",
static ValueObjectSP GetDataPointer(ValueObject &root)
#define LLDB_LOG_ERRORV(log, error,...)
Generic representation of a type in a programming language.
CompilerType GetTypeTemplateArgument(size_t idx, bool expand_pack=false) const
size_t GetNumTemplateArguments(bool expand_pack=false) const
Return the number of template arguments the type has.
ConstString GetTypeName(bool BaseOnly=false) const
A uniqued constant string class.
const char * AsCString(const char *value_if_empty=nullptr) const
Get the string value as a C string.
const char * GetCString() const
Get the string value as a C string.
A subclass of DataBuffer that stores a data buffer on the heap.
Execution context objects refer to objects in the execution of the program that is being debugged.
bool Fail() const
Test for error condition.
llvm::StringRef GetString() const
size_t Printf(const char *format,...) __attribute__((format(printf
Output printf formatted output to the stream.
uint32_t CalculateNumChildrenIgnoringErrors(uint32_t max=UINT32_MAX)
lldb::ValueObjectSP CreateValueObjectFromData(llvm::StringRef name, const DataExtractor &data, const ExecutionContext &exe_ctx, CompilerType type)
SyntheticChildrenFrontEnd(ValueObject &backend)
lldb::ValueObjectSP CreateValueObjectFromAddress(llvm::StringRef name, uint64_t address, const ExecutionContext &exe_ctx, CompilerType type, bool do_deref=true)
A class that represents a running process on the host machine.
Log * GetLog(Cat mask)
Retrieve the Log object for the channel associated with the given log enum.
ChildCacheState
Specifies if children need to be re-computed after a call to SyntheticChildrenFrontEnd::Update.
@ eRefetch
Children need to be recomputed dynamically.
@ eReuse
Children did not change and don't need to be recomputed; re-use what we computed the last time we cal...
std::shared_ptr< lldb_private::ValueObject > ValueObjectSP
std::shared_ptr< lldb_private::Process > ProcessSP
std::shared_ptr< lldb_private::WritableDataBuffer > WritableDataBufferSP