72 return llvm::createStringError(
73 "failed to determine start/end of vector data");
75 uint64_t start_val =
m_start->GetValueAsUnsigned(0);
76 uint64_t finish_val =
m_finish->GetValueAsUnsigned(0);
79 if (start_val == 0 && finish_val == 0)
83 return llvm::createStringError(
"invalid value for start of vector");
86 return llvm::createStringError(
"invalid value for end of vector");
88 if (start_val > finish_val)
89 return llvm::createStringError(
90 "start of vector data begins after end pointer");
92 size_t num_children = (finish_val - start_val);
94 return llvm::createStringError(
"size not multiple of element size");
106 offset = offset +
m_start->GetValueAsUnsigned(0);
108 name.
Printf(
"[%" PRIu64
"]", (uint64_t)idx);
122 m_start = data_sp->GetChildMemberWithName(
"_Myfirst").get();
123 m_finish = data_sp->GetChildMemberWithName(
"_Mylast").get();
128 llvm::Expected<uint64_t> size_or_err =
m_element_type.GetByteSize(
nullptr);
141 return llvm::createStringError(
"Type has no child named '%s'",
145 return llvm::createStringError(
"Type has no child named '%s'",
148 return *optional_idx;
194 size_t bytes_read = process_sp->ReadScalarIntegerFromMemory(
196 if (err.
Fail() || bytes_read == 0 || !scalar.
IsValid())
200 bool bit_set = scalar.
GetAPSInt()[bit_index];
201 std::optional<uint64_t> size =
202 llvm::expectedToOptional(
m_bool_type.GetByteSize(
nullptr));
206 if (bit_set && buffer_sp && buffer_sp->GetBytes()) {
208 *(buffer_sp->GetBytes()) = 1;
211 name.
Printf(
"[%" PRIu64
"]", (uint64_t)idx);
215 process_sp->GetAddressByteSize()),
233 auto exe_ctx_ref = valobj_sp->GetExecutionContextRef();
235 ValueObjectSP size_sp = valobj_sp->GetChildMemberWithName(
"_Mysize");
238 uint64_t count = size_sp->GetValueAsUnsigned(0);
243 {
"_Myvec",
"_Mypair",
"_Myval2",
"_Myfirst"}));
251 llvm::Expected<uint64_t> element_bit_size = begin_ty.
GetBitSize(
nullptr);
252 if (!element_bit_size)
255 uint64_t base_data_address = begin_sp->GetValueAsUnsigned(0);
256 if (!base_data_address)
266llvm::Expected<size_t>
270 return llvm::createStringError(
"Type has no child named '%s'",
274 return llvm::createStringError(
"Type has no child named '%s'",
277 uint32_t idx = *optional_idx;
279 return llvm::createStringError(
"Type has no child named '%s'",
290 valobj_sp = valobj_sp->GetNonSyntheticValue();
298 if (valobj_sp->GetChildMemberWithName(
"_Mypair") !=
nullptr)
301 if (valobj_sp->GetChildMemberWithName(
"_Myvec") !=
nullptr)
#define LLDB_LOG_ERRORV(log, error,...)
Generic representation of a type in a programming language.
CompilerType GetPointeeType() const
If this type is a pointer type, return the type that the pointer points to, else return an invalid ty...
llvm::Expected< uint64_t > GetBitSize(ExecutionContextScope *exe_scope) const
Return the size of the type in bits.
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.
llvm::APSInt GetAPSInt() const
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