1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
|
/*
SPDX-FileCopyrightText: 2014 Kevin Funk <kfunk@kde.org>
SPDX-License-Identifier: GPL-2.0-only OR GPL-3.0-only OR LicenseRef-KDE-Accepted-GPL
*/
#include "objectlist.h"
using namespace KDevelop;
class KDevelop::ObjectListTrackerPrivate
{
public:
/// List of tracked objects (contains unique items only)
QList<QObject*> m_list;
ObjectListTracker::CleanupBehavior m_cleanupBehavior;
};
ObjectListTracker::ObjectListTracker(CleanupBehavior behavior, QObject* parent)
: QObject(parent)
, d_ptr(new ObjectListTrackerPrivate {{}, behavior})
{
}
ObjectListTracker::~ObjectListTracker()
{
Q_D(ObjectListTracker);
if (d->m_cleanupBehavior == CleanupWhenDone) {
deleteAll();
}
}
const QList<QObject*>& ObjectListTracker::data() const
{
Q_D(const ObjectListTracker);
return d->m_list;
}
void ObjectListTracker::objectDestroyed(QObject* object)
{
Q_D(ObjectListTracker);
bool success = d->m_list.removeOne(object);
Q_ASSERT(success);
Q_UNUSED(success);
}
void ObjectListTracker::append(QObject* object)
{
Q_D(ObjectListTracker);
if (!object || d->m_list.contains(object)) {
return;
}
d->m_list.append(object);
connect(object, &QObject::destroyed, this, &ObjectListTracker::objectDestroyed);
}
bool ObjectListTracker::remove(QObject* object)
{
Q_D(ObjectListTracker);
if (!object) {
return false;
}
disconnect(object, &QObject::destroyed, this, &ObjectListTracker::objectDestroyed);
return d->m_list.removeOne(object);
}
void ObjectListTracker::deleteAll()
{
Q_D(ObjectListTracker);
qDeleteAll(d->m_list);
d->m_list.clear();
}
#include "moc_objectlist.cpp"
|