fixed wallpaper engine
This commit is contained in:
@@ -104,6 +104,32 @@ pkgs.kdePackages.mkKdeDerivation rec {
|
||||
|
||||
# Fix Qt6 deprecation warning in qthelper.hpp
|
||||
sed -i 's|v.type()|v.metaType().id()|g' src/backend_mpv/qthelper.hpp
|
||||
|
||||
# Fix Qt6 qplatformnativeinterface.h removal in MpvBackend.cpp
|
||||
# Wrap the Qt5-only header in version check
|
||||
sed -i '/# include <qpa\/qplatformnativeinterface.h>/{
|
||||
i\#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0))
|
||||
a\#endif
|
||||
}' src/backend_mpv/MpvBackend.cpp
|
||||
|
||||
# Remove TODO comments
|
||||
sed -i '/TODO.*QX11Application/d' src/backend_mpv/MpvBackend.cpp
|
||||
sed -i '/same for wayland/d' src/backend_mpv/MpvBackend.cpp
|
||||
|
||||
# Fix X11 display access for Qt6
|
||||
sed -i '/params\[2\].type = MPV_RENDER_PARAM_X11_DISPLAY;/,/params\[2\].data = QX11Info::display();/{
|
||||
s|auto\* native = QGuiApplication::platformNativeInterface();|auto* x11App = qApp->nativeInterface<QNativeInterface::QX11Application>();|
|
||||
s|params\[2\].data = native->nativeResourceForWindow("display", nullptr);|params[2].data = x11App ? x11App->display() : nullptr;|
|
||||
}' src/backend_mpv/MpvBackend.cpp
|
||||
|
||||
# Fix Wayland display access for Qt6
|
||||
sed -i '/params\[2\].type = MPV_RENDER_PARAM_WL_DISPLAY;/,/params\[2\].data = native->nativeResourceForWindow("display", nullptr);/{
|
||||
/params\[2\].type = MPV_RENDER_PARAM_WL_DISPLAY;/a\#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0))\
|
||||
auto* waylandApp = qApp->nativeInterface<QNativeInterface::QWaylandApplication>();\
|
||||
params[2].data = waylandApp ? waylandApp->display() : nullptr;\
|
||||
#else
|
||||
/params\[2\].data = native->nativeResourceForWindow/a\#endif
|
||||
}' src/backend_mpv/MpvBackend.cpp
|
||||
'';
|
||||
|
||||
cmakeFlags = [
|
||||
|
||||
41
packages/wallpaper-engine-kde-plugin/qt6-mpv-backend.patch
Normal file
41
packages/wallpaper-engine-kde-plugin/qt6-mpv-backend.patch
Normal file
@@ -0,0 +1,41 @@
|
||||
diff --git a/src/backend_mpv/MpvBackend.cpp b/src/backend_mpv/MpvBackend.cpp
|
||||
index 1234567..abcdefg 100644
|
||||
--- a/src/backend_mpv/MpvBackend.cpp
|
||||
+++ b/src/backend_mpv/MpvBackend.cpp
|
||||
@@ -36,7 +36,9 @@
|
||||
# include <QX11Info> // IWYU pragma: keep
|
||||
#endif
|
||||
//#endif
|
||||
+#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0))
|
||||
# include <qpa/qplatformnativeinterface.h> // IWYU pragma: keep
|
||||
+#endif
|
||||
#endif
|
||||
|
||||
Q_LOGGING_CATEGORY(wekdeMpv, "wekde.mpv")
|
||||
@@ -81,19 +83,24 @@ int create_gl(MPVCLientAPI* mpv, mpv_render_context** mpv_gl, mpv_opengl_init_p
|
||||
#if defined(__linux__) || defined(__FreeBSD__)
|
||||
if (QGuiApplication::platformName().contains("xcb")) {
|
||||
params[2].type = MPV_RENDER_PARAM_X11_DISPLAY;
|
||||
#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0))
|
||||
- // TODO: QGuiApplication::nativeInterface<QNativeInterface::QX11Application>()::display();
|
||||
- // same for wayland
|
||||
- auto* native = QGuiApplication::platformNativeInterface();
|
||||
- params[2].data = native->nativeResourceForWindow("display", nullptr);
|
||||
+ auto* x11App = qApp->nativeInterface<QNativeInterface::QX11Application>();
|
||||
+ params[2].data = x11App ? x11App->display() : nullptr;
|
||||
#else
|
||||
params[2].data = QX11Info::display();
|
||||
#endif
|
||||
}
|
||||
if (QGuiApplication::platformName().contains("wayland")) {
|
||||
params[2].type = MPV_RENDER_PARAM_WL_DISPLAY;
|
||||
+#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0))
|
||||
+ auto* waylandApp = qApp->nativeInterface<QNativeInterface::QWaylandApplication>();
|
||||
+ params[2].data = waylandApp ? waylandApp->display() : nullptr;
|
||||
+#else
|
||||
auto* native = QGuiApplication::platformNativeInterface();
|
||||
params[2].data = native->nativeResourceForWindow("display", nullptr);
|
||||
+#endif
|
||||
}
|
||||
#endif
|
||||
int code = mpv_render_context_create(mpv_gl, mpv, params);
|
||||
Reference in New Issue
Block a user