aboutsummaryrefslogtreecommitdiffstats
path: root/libpyside
diff options
context:
space:
mode:
authorHugo Parente Lima <hugo.pl@gmail.com>2011-08-12 16:56:39 -0300
committerHugo Parente Lima <hugo.pl@gmail.com>2012-03-08 16:54:43 -0300
commitbbf66078ea911cbacca69550da15fa21a000e3ab (patch)
tree9407994126f0226f76d5f4abedb0520673e19f3f /libpyside
parentb633bd4c2e575ff6101f2ae9ae39e192bad7fcb4 (diff)
Fix bug 953 - "Segfault when QObject is garbage collected after QTimer.singeShot"
Reviewer: Renato Araújo <renato.filho@openbossa.org> Luciano Wolf <luciano.wolf@openbossa.org>
Diffstat (limited to 'libpyside')
-rw-r--r--libpyside/signalmanager.cpp13
1 files changed, 9 insertions, 4 deletions
diff --git a/libpyside/signalmanager.cpp b/libpyside/signalmanager.cpp
index b24d0b97e..b7b9b3d93 100644
--- a/libpyside/signalmanager.cpp
+++ b/libpyside/signalmanager.cpp
@@ -323,11 +323,13 @@ int SignalManager::qt_metacall(QObject* object, QMetaObject::Call call, int id,
PyObject* pp_name = 0;
QMetaProperty mp;
PyObject* pySelf = 0;
+ int methodCount = metaObject->methodCount();
+ int propertyCount = metaObject->propertyCount();
if (call != QMetaObject::InvokeMetaMethod) {
mp = metaObject->property(id);
if (!mp.isValid())
- return id - metaObject->methodCount();
+ return id - methodCount;
Shiboken::GilState gil;
pySelf = (PyObject*)Shiboken::BindingManager::instance().retrieveWrapper(object);
@@ -337,7 +339,7 @@ int SignalManager::qt_metacall(QObject* object, QMetaObject::Call call, int id,
if (!pp) {
qWarning("Invalid property: %s.", mp.name());
Py_XDECREF(pp_name);
- return id - metaObject->methodCount();
+ return id - methodCount;
}
}
@@ -362,10 +364,13 @@ int SignalManager::qt_metacall(QObject* object, QMetaObject::Call call, int id,
qWarning("Unsupported meta invocation type.");
}
+ // WARNING Isn't safe to call any metaObject and/or object methods beyond this point
+ // because the object can be deleted inside the called slot.
+
if (call == QMetaObject::InvokeMetaMethod)
- id = id - metaObject->methodCount();
+ id = id - methodCount;
else
- id = id - metaObject->propertyCount();
+ id = id - propertyCount;
if (pp || pp_name) {
Shiboken::GilState gil;