29 GenericBitsetFrontEnd(ValueObject &valobj, StdLib stdlib);
31 llvm::Expected<size_t> GetIndexOfChildWithName(ConstString name)
override {
34 return llvm::createStringError(
"Type has no child named '%s'",
42 return m_elements.size();
47 llvm::StringRef GetDataContainerMemberName();
56 std::vector<ValueObjectSP> m_elements;
57 ValueObject *m_first =
nullptr;
58 CompilerType m_bool_type;
60 uint8_t m_byte_size = 0;
65GenericBitsetFrontEnd::GenericBitsetFrontEnd(
ValueObject &valobj, StdLib stdlib)
68 if (
auto target_sp = m_backend.GetTargetSP()) {
69 m_byte_order = target_sp->GetArchitecture().GetByteOrder();
70 m_byte_size = target_sp->GetArchitecture().GetAddressByteSize();
75llvm::StringRef GenericBitsetFrontEnd::GetDataContainerMemberName() {
76 static constexpr llvm::StringLiteral s_libcxx_case(
"__first_");
77 static constexpr llvm::StringLiteral s_libstdcpp_case(
"_M_w");
81 case StdLib::LibStdcpp:
82 return s_libstdcpp_case;
84 llvm_unreachable(
"Unknown StdLib enum");
97 if (
auto arg = m_backend.GetCompilerType().GetIntegralTemplateArgument(0))
98 size = arg->value.GetAPSInt().getLimitedValue();
106ValueObjectSP GenericBitsetFrontEnd::GetChildAtIndex(uint32_t idx) {
107 if (idx >= m_elements.size() || !m_first)
111 return m_elements[idx];
113 ExecutionContext ctx = m_backend.GetExecutionContextRef().Lock(
false);
118 std::optional<uint64_t> bit_size = llvm::expectedToOptional(
120 if (!bit_size || *bit_size == 0)
125 chunk = m_first->
GetSP();
130 std::optional<uint64_t> bit_size = llvm::expectedToOptional(
132 if (!bit_size || *bit_size == 0)
134 size_t chunk_idx = idx % *bit_size;
135 uint8_t value = !!(chunk->GetValueAsUnsigned(0) & (uint64_t(1) << chunk_idx));
136 DataExtractor data(&value,
sizeof(value), m_byte_order, m_byte_size);
138 m_elements[idx] = CreateValueObjectFromData(llvm::formatv(
"[{0}]", idx).str(),
139 data, ctx, m_bool_type);
141 return m_elements[idx];
147 return new GenericBitsetFrontEnd(*valobj_sp,
148 GenericBitsetFrontEnd::StdLib::LibStdcpp);
155 return new GenericBitsetFrontEnd(*valobj_sp,
156 GenericBitsetFrontEnd::StdLib::LibCxx);
static std::optional< size_t > CalculateNumChildren(CompilerType container_elem_type, uint64_t num_elements, CompilerType element_type)
Calculates the number of elements stored in a container (with element type 'container_elem_type') as ...
bool IsArrayType(CompilerType *element_type=nullptr, uint64_t *size=nullptr, bool *is_incomplete=nullptr) const
llvm::Expected< uint64_t > GetBitSize(ExecutionContextScope *exe_scope) const
Return the size of the type in bits.
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.
ExecutionContextScope * GetBestExecutionContextScope() const
virtual lldb::ValueObjectSP GetChildAtIndex(uint32_t idx, bool can_create=true)
CompilerType GetCompilerType()
lldb::ValueObjectSP GetSP()
virtual lldb::ValueObjectSP GetChildMemberWithName(llvm::StringRef name, bool can_create=true)
lldb::TargetSP GetTargetSP() const
A class that represents a running process on the host machine.
ChildCacheState
Specifies if children need to be re-computed after a call to SyntheticChildrenFrontEnd::Update.
@ eRefetch
Children need to be recomputed dynamically.
std::shared_ptr< lldb_private::ValueObject > ValueObjectSP
ByteOrder
Byte ordering definitions.
std::shared_ptr< lldb_private::Target > TargetSP