Как я могу исправить очевидный конфликт Qt4 / Qt5?

Я недавно установил Qt4 хотя у меня уже были некоторые Qt5 библиотеки установлены, потому что приложение, кажется, требует Qt4, К сожалению, это приложение также использовало mayavi, который теперь будет segfault, когда он попытался импортировать его mlab модуль. Мне удалось изолировать причину segfault для следующих импортов, оба из которых необходимы, чтобы вызвать сбой:

me@Bedrock:~$ python
Python 2.7.12 (default, Nov 19 2016, 06:48:10)
[GCC 5.4.0 20160609] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import vtk
>>> from pyface import api as pyface
QMetaType::registerType: Binary compatibility break -- Size mismatch for     type 'QUuid' [30]. Previously registered size 16, now registering size 0.
Aborted (core dumped)
me@Bedrock:~$ 

Поиск в Google привел к некоторым предложениям относительно того, как устанавливать переменные среды в .bashrc:

export QTCHOOSER_RUNTOOL=qtconfig
export QT_SELECT=4
export QT_API='pyside'
export ETS_TOOLKIT='qt4'

Я использовал это, несколько слепо, но безуспешно.

Правильно ли я считаю, что мои проблемы связаны с Qt4/Qt5 конфликт, и если так, что я должен делать с этим?

================================================== =========================== Я исследовал немного дальше. Теперь я могу получить этот сбой с помощью следующих двух импортов:

me@Bedrock:~/Downloads/temp3/mne-python$ python
Python 2.7.12 (default, Nov 19 2016, 06:48:10) 
[GCC 5.4.0 20160609] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> from vtk.vtkCommonCore import *
>>> from PySide.QtGui import *
QMetaType::registerType: Binary compatibility break -- Size mismatch for   type 'QUuid' [30]. Previously registered size 16, now registering size 0.
Aborted (core dumped)

vtk.vtkCommonCoreсодержит одну строку, которая импортирует vtkCommonCorePythonи это файл.so.

Так же, PySide.QtGui также файл.so.

Итак, мой следующий шаг должен был увидеть, какие файлы.so /usr/local/lib/python2.7/dist-packages/PySide/QtGui.so а также /usr/lib/python2.7/dist-packages/vtk/vtkCommonCorePython.x86_64-linux-gnu.so зависит от.

То, что я нашел, было это:

me@Bedrock:/usr/lib/python2.7/dist-packages/vtk$ ldd -v vtkCommonCorePython.x86_64-linux-gnu.so 
    linux-vdso.so.1 =>  (0x00007fff28fc0000)
    libvtkCommonCorePython27D-6.2.so.6.2 => /usr/lib/x86_64-linux-gnu/libvtkCommonCorePython27D-6.2.so.6.2 (0x00007f0488925000)
    libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007f04885a2000)
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f04881d9000)
    libvtkWrappingPython27Core-6.2.so.6.2 => /usr/lib/x86_64-linux-gnu/libvtkWrappingPython27Core-6.2.so.6.2 (0x00007f0487fac000)
    libvtkCommonCore-6.2.so.6.2 => /usr/lib/x86_64-linux-gnu/libvtkCommonCore-6.2.so.6.2 (0x00007f0487a7d000)
    libpython2.7.so.1.0 => /usr/lib/x86_64-linux-gnu/libpython2.7.so.1.0 (0x00007f04874ef000)
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f04871e6000)
    libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f0486fcf000)
    /lib64/ld-linux-x86-64.so.2 (0x000055b9eee1f000)
    libvtksys-6.2.so.6.2 => /usr/lib/x86_64-linux-gnu/libvtksys-6.2.so.6.2 (0x00007f0486d8a000)
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f0486b6c000)
    libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007f0486952000)
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f048674e000)
    libutil.so.1 => /lib/x86_64-linux-gnu/libutil.so.1 (0x00007f048654a000)

и это:

me@Bedrock:/usr/local/lib/python2.7/dist-packages/PySide$ ldd -v /usr/local/lib/python2.7/dist-packages/PySide/QtGui.so
    linux-vdso.so.1 =>  (0x00007fff37bfc000)
    libpyside-python2.7.so.1.2 (0x00007ff4672cf000)
    libpython2.7.so.1.0 => /usr/lib/x86_64-linux-gnu/libpython2.7.so.1.0 (0x00007ff466cfa000)
    libshiboken-python2.7.so.1.2 (0x00007ff466ac6000)
    libQtGui.so.4 => /usr/lib/x86_64-linux-gnu/libQtGui.so.4 (0x00007ff465dd2000)
    libQtCore.so.4 => /usr/lib/x86_64-linux-gnu/libQtCore.so.4 (0x00007ff4658de000)
    libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007ff46555c000)
    libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007ff465346000)
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007ff464f7c000)
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007ff464d5f000)
    libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007ff464b45000)
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007ff464940000)
    libutil.so.1 => /lib/x86_64-linux-gnu/libutil.so.1 (0x00007ff46473d000)
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007ff464434000)
    libfontconfig.so.1 => /usr/lib/x86_64-linux-gnu/libfontconfig.so.1 (0x00007ff4641f0000)
    libaudio.so.2 => /usr/lib/x86_64-linux-gnu/libaudio.so.2 (0x00007ff463fd7000)
    libglib-2.0.so.0 => /lib/x86_64-linux-gnu/libglib-2.0.so.0 (0x00007ff463cc6000)
    libpng12.so.0 => /lib/x86_64-linux-gnu/libpng12.so.0 (0x00007ff463aa0000)
    libfreetype.so.6 => /usr/lib/x86_64-linux-gnu/libfreetype.so.6 (0x00007ff4637f6000)
    libgobject-2.0.so.0 => /usr/lib/x86_64-linux-gnu/libgobject-2.0.so.0 (0x00007ff4635a3000)
    libSM.so.6 => /usr/lib/x86_64-linux-gnu/libSM.so.6 (0x00007ff46339a000)
    libICE.so.6 => /usr/lib/x86_64-linux-gnu/libICE.so.6 (0x00007ff463180000)
    libXi.so.6 => /usr/lib/x86_64-linux-gnu/libXi.so.6 (0x00007ff462f70000)
    libXrender.so.1 => /usr/lib/x86_64-linux-gnu/libXrender.so.1 (0x00007ff462d65000)
    libXext.so.6 => /usr/lib/x86_64-linux-gnu/libXext.so.6 (0x00007ff462b53000)
    libX11.so.6 => /usr/lib/x86_64-linux-gnu/libX11.so.6 (0x00007ff462819000)
    librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007ff462610000)
/lib64/ld-linux-x86-64.so.2 (0x000055bd99ece000)
    libexpat.so.1 => /lib/x86_64-linux-gnu/libexpat.so.1 (0x00007ff4623e7000)
    libXt.so.6 => /usr/lib/x86_64-linux-gnu/libXt.so.6 (0x00007ff46217d000)
    libXau.so.6 => /usr/lib/x86_64-linux-gnu/libXau.so.6 (0x00007ff461f79000)
    libpcre.so.3 => /lib/x86_64-linux-gnu/libpcre.so.3 (0x00007ff461d09000)
    libffi.so.6 => /usr/lib/x86_64-linux-gnu/libffi.so.6 (0x00007ff461b00000)
    libuuid.so.1 => /lib/x86_64-linux-gnu/libuuid.so.1 (0x00007ff4618fb000)
    libxcb.so.1 => /usr/lib/x86_64-linux-gnu/libxcb.so.1 (0x00007ff4616d8000)
    libXdmcp.so.6 => /usr/lib/x86_64-linux-gnu/libXdmcp.so.6 (0x00007ff4614d2000)

Только /usr/local/lib/python2.7/dist-packages/PySide/QtGui.so похоже, имеет какое-либо прямое соединение с библиотеками Qt, поэтому я не понимаю, как / почему vtk импорт мешает всему, что связано с Qt.

Наконец, мне стало любопытно, какая версия Qt /usr/lib/x86_64-linux-gnu/libQt...so файлы были использованы. Итак, я попробовал это:

me@Bedrock:~$ qmake --version
QMake version 2.01a
Using Qt version 4.8.7 in /usr/lib/x86_64-linux-gnu

Я также проверил свою версию vtk

>>> vtk.VTK_MAJOR_VERSION
6
>>> vtk.VTK_MINOR_VERSION
2
>>> 

и, отдельно, моя версия PySide:

>>> import PySide
>>> PySide.__version__
'1.2.4'

На данный момент, я только больше озадачен. Является ли моя проблема конфликтом Qt4/Qt5? (Я так думаю) Если нет, то почему я получаю Seg Faults с ошибкой:

QMetaType::registerType: Binary compatibility break -- Size mismatch for       type 'QUuid' [30]. Previously registered size 16, now registering size 0.
    Aborted (core dumped)

Если так, почему я, кажется, использую только одну версию Qt? Самое главное, как я могу это исправить?

1 ответ

Решение

В конфигурациях Qt по умолчанию данный процесс может использовать только одну версию Qt. Если вы загружаете модуль Python, который использует Qt 5, и другой, который использует Qt 4, возникнут проблемы, поскольку множество символов перекрываются.

Чтобы использовать Qt 4 параллельно с Qt 5 в приложении, вы должны скомпилировать одну из версий Qt в его собственном пространстве имен и пересобрать модули, которые используют эту версию Qt. Таким образом, символы не будут конфликтовать, и один и тот же процесс может использовать несколько версий Qt.

Другие вопросы по тегам