summaryrefslogtreecommitdiff
path: root/libre/pyqt5/pyqt-5.8-segfault.patch
diff options
context:
space:
mode:
authorAndré Fabian Silva Delgado <emulatorman@parabola.nu>2017-03-22 00:52:18 -0300
committerAndré Fabian Silva Delgado <emulatorman@parabola.nu>2017-03-22 01:03:41 -0300
commitd7df7c8c2da3a3258bc6bf1c6d44718050265dfb (patch)
treecbd55c40ee86ce8e92992a1f664ad51246a038a7 /libre/pyqt5/pyqt-5.8-segfault.patch
parent03e76038c8e800cc50fda38bcd37d4523681d64c (diff)
downloadabslibre-d7df7c8c2da3a3258bc6bf1c6d44718050265dfb.tar.gz
abslibre-d7df7c8c2da3a3258bc6bf1c6d44718050265dfb.tar.bz2
abslibre-d7df7c8c2da3a3258bc6bf1c6d44718050265dfb.zip
pyqt5-5.8-2.parabola1: fix segfault when starting cura - FS#53371 -> https://bugs.archlinux.org/task/53371
Diffstat (limited to 'libre/pyqt5/pyqt-5.8-segfault.patch')
-rw-r--r--libre/pyqt5/pyqt-5.8-segfault.patch62
1 files changed, 62 insertions, 0 deletions
diff --git a/libre/pyqt5/pyqt-5.8-segfault.patch b/libre/pyqt5/pyqt-5.8-segfault.patch
new file mode 100644
index 000000000..a8d1564af
--- /dev/null
+++ b/libre/pyqt5/pyqt-5.8-segfault.patch
@@ -0,0 +1,62 @@
+--- a/qpy/QtQml/qpyqml_register_type.cpp 2017-02-23 03:32:51.000000000 +0100
++++ b/qpy/QtQml/qpyqml_register_type.cpp 2017-02-25 03:32:58.000000000 +0100
+@@ -124,13 +124,13 @@
+
+ #define QPYQML_TYPE_INIT(n) \
+ case n##U: \
+- QPyQmlObject##n::staticMetaObject = *mo; \
++ QPyQmlObject##n::staticMetaObject = static_mo; \
+ QPyQmlObject##n::attachedPyType = attached; \
+ rt->typeId = qRegisterNormalizedMetaType<QPyQmlObject##n *>(ptr_name); \
+ rt->listId = qRegisterNormalizedMetaType<QQmlListProperty<QPyQmlObject##n> >(list_name); \
+ rt->objectSize = ctor ? sizeof(QPyQmlObject##n) : 0; \
+ if (ctor) rt->create = QQmlPrivate::createInto<QPyQmlObject##n>; else rt->create = 0; \
+- rt->metaObject = mo; \
++ rt->metaObject = &QPyQmlObject##n::staticMetaObject; \
+ rt->attachedPropertiesFunction = attached_mo ? QPyQmlObject##n::attachedProperties : 0; \
+ rt->attachedPropertiesMetaObject = attached_mo; \
+ rt->parserStatusCast = is_parser_status ? QQmlPrivate::StaticCastSelector<QPyQmlObject##n,QQmlParserStatus>::cast() : -1; \
+@@ -219,7 +219,33 @@
+ return 0;
+ }
+
+- const QMetaObject *mo = pyqt5_qtqml_get_qmetaobject(py_type);
++ const QMetaObject *orig_mo = pyqt5_qtqml_get_qmetaobject(py_type);
++ QMetaObject static_mo = *orig_mo;
++
++#if QT_VERSION >= 0x050800
++ // Qt v5.8.0 changed the way properties are handled by directly calling a
++ // class's static meta-call (if there was one) directly. This bypasses the
++ // proxy and calls the static meta-call with a pointer to the proxy rather
++ // than a pointer to the real object. To work round this we clone the
++ // QMetaObject chain and remove the references to the static meta-call
++ // forcing the earlier behaviour. This approach may also work with earlier
++ // versions of Qt - but if it ain't broke...
++ static_mo.d.static_metacall = 0;
++
++ QMetaObject *sub_mo = &static_mo;
++
++ // By retaining the QObject static meta-object we don't appear to be a
++ // gadget.
++ for (const QMetaObject *mo = sub_mo->d.superdata; mo != &QObject::staticMetaObject; mo = mo->d.superdata)
++ {
++ QMetaObject *new_mo = new QMetaObject;
++ *new_mo = *mo;
++ new_mo->d.static_metacall = 0;
++
++ sub_mo->d.superdata = new_mo;
++ sub_mo = new_mo;
++ }
++#endif
+
+ // See if the type is a parser status.
+ bool is_parser_status = PyType_IsSubtype(py_type,
+@@ -272,7 +298,7 @@
+
+ if (qquickitem_register)
+ {
+- sipErrorState estate = qquickitem_register(py_type, mo, ptr_name,
++ sipErrorState estate = qquickitem_register(py_type, orig_mo, ptr_name,
+ list_name, &rt);
+
+ if (estate == sipErrorFail)