13#include "llvm/Support/ErrorExtras.h"
73 return llvm::createStringError(
74 "failed to determine start/end of vector data");
76 uint64_t start_val =
m_start->GetValueAsUnsigned(0);
77 uint64_t finish_val =
m_finish->GetValueAsUnsigned(0);
80 if (start_val == 0 && finish_val == 0)
84 return llvm::createStringError(
"invalid value for start of vector");
87 return llvm::createStringError(
"invalid value for end of vector");
89 if (start_val > finish_val)
90 return llvm::createStringError(
91 "start of vector data begins after end pointer");
93 size_t num_children = (finish_val - start_val);
95 return llvm::createStringError(
"size not multiple of element size");
107 offset = offset +
m_start->GetValueAsUnsigned(0);
109 name.
Printf(
"[%" PRIu64
"]", (uint64_t)idx);
123 m_start = data_sp->GetChildMemberWithName(
"_Myfirst").get();
124 m_finish = data_sp->GetChildMemberWithName(
"_Mylast").get();
129 llvm::Expected<uint64_t> size_or_err =
m_element_type.GetByteSize(
nullptr);
142 return llvm::createStringErrorV(
"type has no child named '{0}'", name);
145 return llvm::createStringErrorV(
"type has no child named '{0}'", name);
147 return *optional_idx;
193 size_t bytes_read = process_sp->ReadScalarIntegerFromMemory(
195 if (err.
Fail() || bytes_read == 0 || !scalar.
IsValid())
199 bool bit_set = scalar.
GetAPSInt()[bit_index];
200 std::optional<uint64_t> size =
201 llvm::expectedToOptional(
m_bool_type.GetByteSize(
nullptr));
205 if (bit_set && buffer_sp && buffer_sp->GetBytes()) {
207 *(buffer_sp->GetBytes()) = 1;
210 name.
Printf(
"[%" PRIu64
"]", (uint64_t)idx);
214 process_sp->GetAddressByteSize()),
232 auto exe_ctx_ref = valobj_sp->GetExecutionContextRef();
234 ValueObjectSP size_sp = valobj_sp->GetChildMemberWithName(
"_Mysize");
237 uint64_t count = size_sp->GetValueAsUnsigned(0);
242 {
"_Myvec",
"_Mypair",
"_Myval2",
"_Myfirst"}));
247 CompilerType begin_ty = begin_sp->GetCompilerType().GetPointeeType();
250 llvm::Expected<uint64_t> element_bit_size = begin_ty.
GetBitSize(
nullptr);
251 if (!element_bit_size)
254 uint64_t base_data_address = begin_sp->GetValueAsUnsigned(0);
255 if (!base_data_address)
265llvm::Expected<size_t>
269 return llvm::createStringErrorV(
"type has no child named '{0}'", name);
272 return llvm::createStringErrorV(
"type has no child named '{0}'", name);
274 uint32_t idx = *optional_idx;
276 return llvm::createStringErrorV(
"type has no child named '{0}'", name);
286 valobj_sp = valobj_sp->GetNonSyntheticValue();
294 if (valobj_sp->GetChildMemberWithName(
"_Mypair") !=
nullptr)
297 if (valobj_sp->GetChildMemberWithName(
"_Myvec") !=
nullptr)
#define LLDB_LOG_ERRORV(log, error,...)
Generic representation of a type in a programming language.
llvm::Expected< uint64_t > GetBitSize(ExecutionContextScope *exe_scope) const
Return the size of the type in bits.
A uniqued constant string class.
const char * GetCString() const
Get the string value as a C string.
const char * AsCString(const char *value_if_empty) 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