23 size_t GetIndexOfChildWithName(
ConstString name)
override {
27 bool MightHaveChildren()
override {
return true; }
28 bool Update()
override;
30 ValueObjectSP GetChildAtIndex(
size_t idx)
override;
38 std::vector<ValueObject*> m_elements;
43 bool TupleFrontEnd::Update() {
47 ValueObjectSP base_sp;
51 base_sp = m_backend.GetChildMemberWithName(
ConstString(
"base_"),
true);
55 m_base = base_sp.get();
56 m_elements.assign(base_sp->GetCompilerType().GetNumDirectBaseClasses(),
61 ValueObjectSP TupleFrontEnd::GetChildAtIndex(
size_t idx) {
62 if (idx >= m_elements.size())
63 return ValueObjectSP();
65 return ValueObjectSP();
67 return m_elements[idx]->GetSP();
72 return ValueObjectSP();
73 ValueObjectSP holder_sp = m_base->GetChildAtIndex(idx,
true);
75 return ValueObjectSP();
77 ValueObjectSP elem_sp = holder_sp->GetChildAtIndex(0,
true);
80 elem_sp->Clone(
ConstString(llvm::formatv(
"[{0}]", idx).str())).get();
83 return m_elements[idx]->GetSP();
84 return ValueObjectSP();
89 lldb::ValueObjectSP valobj_sp) {
91 return new TupleFrontEnd(*valobj_sp);