wayland support in wheels on Pypi

Sergio Callegari sergio.callegari at gmail.com
Fri Feb 21 08:42:45 GMT 2025


I have digged a little further.

On 19/02/2025 23:33, Sergio Callegari wrote:
> Debugging as suggesting reveals that, as suspected, |pyqt5-qt5| does not 
> contain the wayland plugin, that is not in the wheel for this package.

It is my understanding that the wheels for pyqt5-qt5 on pypi are built 
using the PyQt-bundle tool, part of PyQt-builder. Can this be confirmed?

I also understand that PyQt-builder is available from Pypi, so one can 
install it and so get the pyqt-bundle command line tool. Is this correct?

Once one has this, it should be possible to run pyqt-bundle against your 
system QT library directory, and the pyqt-bundle should be able to pick 
the relevant part and make a wheel of it. If I get it right, this should 
be the way in which the PyQt5-Qt5 wheels present on Pypi are built by 
Phil Thompson, who is also the maintainer of the pyqt-builder framework. 
Right?

Now, assuming that the above points are right (my apology if they are 
not), there are still a few missing points for me.

1) Why does the "official" pyqt5-qt5 wheel from pypi miss the qt wayland 
plugin? is the bundle tool explicitly excluding it or is the wheel built 
from a QT distribution without it? In the latter case, would it be 
possible to update the wheel to also include the wayland plugin?

2) Alternatively, do python packages have something like the 'provides' 
concept that most linux distro packaging systems have? In other words, 
would it be possible to have on pypi a pyqt5-qt-wayland package that 
provides pyqt5-qt also including the wayland plugin?

3) Alternatively, can I use the pyqt-bundle cli tool to build my own 
pyqt5-qt5 wheel based on my system's qt5 that includes the wayland 
plugin and use that to satisfy the dependencies of other packages?

4) And finally: would it be possible to create a 'fake' pyqt5-qt5 
package to be used only locally merely pointing at the system qt5 
installation, without duplicating it?

Thanks,
Sergio


> Trying to point to my system QT5 plugins does not work either. They are 
> recognized but they are not binary compatible, there must be some 
> difference in the toolchain.
> 
> The pyqt5-qt5 package is said to contain the subset of a Qt installation 
> that is required by PyQt5. As of today that should probably include also 
> the wayland plugin, or there should be another package on pypi providing it.
> 
> Any clue?
> 
> Sergio
> 
> On 17/02/2025 09:32, Charles wrote:
> 
>> Just set QT_DEBUG_PLUGINS [1], check where it tries to load the 
>> plugins, and if it is a wrong path, fix it using the methods in [2].
>>
>> As a python application it isn't always clear where the application 
>> path is which is used to load the plugins.
>>
>> [1] https://doc.qt.io/qt-6/debug.html#environment-variables- 
>> recognized-by-qt
>> [2] https://doc.qt.io/qt-6/deployment-plugins.html
>>
>> On Mon, Feb 17, 2025 at 3:07 PM Sergio Callegari 
>> <sergio.callegari at gmail.com> wrote:
>>
>>     Hi,
>>
>>     I have noticed a strange behavior from applications using PyQt5
>>     and PyQt5-Qt5 (seen using the python IDE spyder).
>>
>>     When I run spyder after having installed it from the packages
>>     provided by my distribution (manjaro), spyder runs as a wayland
>>     application on my system.
>>
>>     However, if I install spyder using pip, uv, or pipx (namely
>>     installation methods that rely on pre-built wheels from pypi),
>>     then spyder cannot run anymore as a wayland application. From its
>>     logs, I see that it cannot find the appropriate Qt plugin:
>>
>>     Could not find the Qt platform plugin “wayland” in “”
>>
>>     Now I wonder if there might be something missing in the pre-built
>>     wheels of PyQt5 distributed on Pypi.
>>
>>     Being able to have Qt applications working as wayland applications
>>     could be beneficial on systems with two displays with different
>>     resolutions, which is a setup not well supported by some
>>     compositors with Xwayland.
>>
>>     Thanks for the attention and your help,
>>
>>     Sergio
>>
>>>>
>


More information about the PyQt mailing list