keep track of the context parents

keep internally a pointer (important that is *not* a smart pointer)
to the item the context has been created for.
on context deletion, remove the copy from the static bookeeping hash
this solves two related crashes: an infinite recursion
and a connection to a deleted object
This commit is contained in:
Marco Martin 2016-01-08 13:38:06 +01:00
parent dc1bfc3de1
commit 5911ad2920
2 changed files with 13 additions and 9 deletions

View File

@ -29,7 +29,8 @@ QHash<QObject *, ColorScope *> ColorScope::s_attachedScopes = QHash<QObject *, C
ColorScope::ColorScope(QQuickItem *parent)
: QQuickItem(parent),
m_inherit(false),
m_group(Plasma::Theme::NormalColorGroup)
m_group(Plasma::Theme::NormalColorGroup),
m_parent(parent)
{
connect(&m_theme, &Plasma::Theme::themeChanged, this, &ColorScope::colorsChanged);
@ -41,7 +42,7 @@ ColorScope::ColorScope(QQuickItem *parent)
ColorScope::~ColorScope()
{
s_attachedScopes.remove(parentItem());
s_attachedScopes.remove(m_parent);
}
ColorScope *ColorScope::qmlAttachedProperties(QObject *object)
@ -65,11 +66,11 @@ ColorScope *ColorScope::qmlAttachedProperties(QObject *object)
ColorScope *ColorScope::findParentScope() const
{
QQuickItem *p = 0;
if (parentItem()) {
p = parentItem()->parentItem();
if (m_parent) {
p = m_parent->parentItem();
}
if (!p || !parentItem()) {
if (!p || !m_parent) {
if (m_parentScope) {
disconnect(m_parentScope.data(), &ColorScope::colorGroupChanged,
this, &ColorScope::colorGroupChanged);
@ -91,10 +92,12 @@ ColorScope *ColorScope::findParentScope() const
disconnect(m_parentScope.data(), &ColorScope::colorsChanged,
this, &ColorScope::colorsChanged);
}
connect(c, &ColorScope::colorGroupChanged,
this, &ColorScope::colorGroupChanged);
connect(c, &ColorScope::colorsChanged,
this, &ColorScope::colorsChanged);
if (c) {
connect(c, &ColorScope::colorGroupChanged,
this, &ColorScope::colorGroupChanged);
connect(c, &ColorScope::colorsChanged,
this, &ColorScope::colorsChanged);
}
//HACK
const_cast<ColorScope *>(this)->m_parentScope = c;
}

View File

@ -91,6 +91,7 @@ private:
Plasma::Theme m_theme;
Plasma::Theme::ColorGroup m_group;
QPointer<ColorScope> m_parentScope;
QQuickItem *m_parent;
static QHash<QObject *, ColorScope *> s_attachedScopes;
};