llvm-project/lldb/source/Core/ValueObjectList.cpp
Pavel Labath 363f05b83d [lldb] Delete the SharingPtr class
Summary:
The only use of this class was to implement the SharedCluster of ValueObjects.
However, the same functionality can be implemented using a regular
std::shared_ptr, and its little-known "sub-object pointer" feature, where the
pointer can point to one thing, but actually delete something else when it goes
out of scope.

This patch reimplements SharedCluster using this feature --
SharedClusterPointer::GetObject now returns a std::shared_pointer which points
to the ValueObject, but actually owns the whole cluster. The only change I
needed to make here is that now the SharedCluster object needs to be created
before the root ValueObject. This means that all private ValueObject
constructors get a ClusterManager argument, and their static Create functions do
the create-a-manager-and-pass-it-to-value-object dance.

Reviewers: teemperor, JDevlieghere, jingham

Subscribers: mgorny, jfb, lldb-commits

Tags: #lldb

Differential Revision: https://reviews.llvm.org/D74153
2020-02-11 13:23:18 +01:00

110 lines
3.3 KiB
C++

//===-- ValueObjectList.cpp -----------------------------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#include "lldb/Core/ValueObjectList.h"
#include "lldb/Core/ValueObject.h"
#include "lldb/Utility/ConstString.h"
#include <utility>
using namespace lldb;
using namespace lldb_private;
const ValueObjectList &ValueObjectList::operator=(const ValueObjectList &rhs) {
if (this != &rhs)
m_value_objects = rhs.m_value_objects;
return *this;
}
void ValueObjectList::Append(const ValueObjectSP &val_obj_sp) {
m_value_objects.push_back(val_obj_sp);
}
void ValueObjectList::Append(const ValueObjectList &valobj_list) {
std::copy(valobj_list.m_value_objects.begin(), // source begin
valobj_list.m_value_objects.end(), // source end
back_inserter(m_value_objects)); // destination
}
size_t ValueObjectList::GetSize() const { return m_value_objects.size(); }
void ValueObjectList::Resize(size_t size) { m_value_objects.resize(size); }
lldb::ValueObjectSP ValueObjectList::GetValueObjectAtIndex(size_t idx) {
lldb::ValueObjectSP valobj_sp;
if (idx < m_value_objects.size())
valobj_sp = m_value_objects[idx];
return valobj_sp;
}
lldb::ValueObjectSP ValueObjectList::RemoveValueObjectAtIndex(size_t idx) {
lldb::ValueObjectSP valobj_sp;
if (idx < m_value_objects.size()) {
valobj_sp = m_value_objects[idx];
m_value_objects.erase(m_value_objects.begin() + idx);
}
return valobj_sp;
}
void ValueObjectList::SetValueObjectAtIndex(size_t idx,
const ValueObjectSP &valobj_sp) {
if (idx >= m_value_objects.size())
m_value_objects.resize(idx + 1);
m_value_objects[idx] = valobj_sp;
}
ValueObjectSP ValueObjectList::FindValueObjectByValueName(const char *name) {
ConstString name_const_str(name);
ValueObjectSP val_obj_sp;
collection::iterator pos, end = m_value_objects.end();
for (pos = m_value_objects.begin(); pos != end; ++pos) {
ValueObject *valobj = (*pos).get();
if (valobj && valobj->GetName() == name_const_str) {
val_obj_sp = *pos;
break;
}
}
return val_obj_sp;
}
ValueObjectSP ValueObjectList::FindValueObjectByUID(lldb::user_id_t uid) {
ValueObjectSP valobj_sp;
collection::iterator pos, end = m_value_objects.end();
for (pos = m_value_objects.begin(); pos != end; ++pos) {
// Watch out for NULL objects in our list as the list might get resized to
// a specific size and lazily filled in
ValueObject *valobj = (*pos).get();
if (valobj && valobj->GetID() == uid) {
valobj_sp = *pos;
break;
}
}
return valobj_sp;
}
ValueObjectSP
ValueObjectList::FindValueObjectByPointer(ValueObject *find_valobj) {
ValueObjectSP valobj_sp;
collection::iterator pos, end = m_value_objects.end();
for (pos = m_value_objects.begin(); pos != end; ++pos) {
ValueObject *valobj = (*pos).get();
if (valobj && valobj == find_valobj) {
valobj_sp = *pos;
break;
}
}
return valobj_sp;
}
void ValueObjectList::Swap(ValueObjectList &value_object_list) {
m_value_objects.swap(value_object_list.m_value_objects);
}