commit:     acf04e5ee236c13d4ee5c44dfb26aa887d768e74
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 30 15:54:15 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 30 16:56:50 2022 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=acf04e5e

dev-python/pyside2: add Python 3.11 compatibility

Signed-off-by: Sam James <sam <AT> gentoo.org>

 .../files/pyside2-5.15.2-python311-fixups.patch    |  54 ++++++
 .../pyside2/files/pyside2-5.15.2-python311.patch   |  41 ++++
 dev-python/pyside2/pyside2-5.15.2-r2.ebuild        | 216 +++++++++++++++++++++
 3 files changed, 311 insertions(+)

diff --git a/dev-python/pyside2/files/pyside2-5.15.2-python311-fixups.patch 
b/dev-python/pyside2/files/pyside2-5.15.2-python311-fixups.patch
new file mode 100644
index 000000000000..d91b0b6806ca
--- /dev/null
+++ b/dev-python/pyside2/files/pyside2-5.15.2-python311-fixups.patch
@@ -0,0 +1,54 @@
+The Fedora / upstream fixes (shiboken2-5.15.2-python311.patch) end up breaking
+Python 3.8 compatibility (maybe 3.9 too, but didn't get that far).
+
+Wrap them with PY_VERSION_HEX for Python 3.11.
+--- a/libpyside/pysideqflags.cpp
++++ b/libpyside/pysideqflags.cpp
+@@ -187,7 +187,12 @@ namespace QFlags
+         }
+         newspec.slots = SbkNewQFlagsType_spec.slots;
+         PyTypeObject *type = (PyTypeObject *)SbkType_FromSpec(&newspec);
+-        Py_SET_TYPE(type, &PyType_Type);
++
++        #if PY_VERSION_HEX < 0x030B00A1
++            Py_TYPE(type) = &PyType_Type;
++        #else
++            Py_SET_TYPE(type, &PyType_Type);
++        #endif
+ 
+         PySideQFlagsType *flagsType = reinterpret_cast<PySideQFlagsType 
*>(type);
+         PepType_PFTP(flagsType)->converterPtr = 
&PepType_PFTP(flagsType)->converter;
+--- a/libpyside/pysidesignal.cpp
++++ b/libpyside/pysidesignal.cpp
+@@ -162,7 +162,13 @@ PyTypeObject *PySideSignalTypeF(void)
+     if (!type) {
+         type = reinterpret_cast<PyTypeObject 
*>(SbkType_FromSpec(&PySideSignalType_spec));
+         PyTypeObject *hold = Py_TYPE(type);
+-        Py_SET_TYPE(type, PySideMetaSignalTypeF());
++
++        #if PY_VERSION_HEX < 0x030B00A1
++            Py_TYPE(type) = PySideMetaSignalTypeF();
++        #else
++            Py_SET_TYPE(type, PySideMetaSignalTypeF());
++        #endif
++
+         Py_INCREF(Py_TYPE(type));
+         Py_DECREF(hold);
+     }
+--- a/libpyside/pysideweakref.cpp
++++ b/libpyside/pysideweakref.cpp
+@@ -90,7 +90,13 @@ PyObject *create(PyObject *obj, PySideWeakRefFunction func, 
void *userData)
+ 
+     if (Py_TYPE(PySideCallableObjectTypeF()) == 0)
+     {
+-        Py_SET_TYPE(PySideCallableObjectTypeF(), &PyType_Type);
++
++        #if PY_VERSION_HEX < 0x030B00A1
++            Py_TYPE(PySideCallableObjectTypeF()) = &PyType_Type;
++        #else
++            Py_SET_TYPE(PySideCallableObjectTypeF(), &PyType_Type);
++        #endif
++
+         PyType_Ready(PySideCallableObjectTypeF());
+     }
+ 

diff --git a/dev-python/pyside2/files/pyside2-5.15.2-python311.patch 
b/dev-python/pyside2/files/pyside2-5.15.2-python311.patch
new file mode 100644
index 000000000000..70b07c4800fd
--- /dev/null
+++ b/dev-python/pyside2/files/pyside2-5.15.2-python311.patch
@@ -0,0 +1,41 @@
+https://src.fedoraproject.org/fork/pviktori/rpms/python-pyside2/raw/5da9902bd8732b49eb722d71f306d4ab197c84b8/f/python3.11.patch
+
+From 77fdd690ca14e97b4c800c4127362ca0c83a716a Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Miro=20Hron=C4=8Dok?= <[email protected]>
+Date: Thu, 9 Jun 2022 13:45:07 +0200
+Subject: [PATCH] Fix usage of Py_TYPE() for Python 3.11
+
+The macro was changed to a function, no longer allowing for assignment.
+--- a/libpyside/pysideqflags.cpp
++++ b/libpyside/pysideqflags.cpp
+@@ -187,7 +187,7 @@ namespace QFlags
+         }
+         newspec.slots = SbkNewQFlagsType_spec.slots;
+         PyTypeObject *type = (PyTypeObject *)SbkType_FromSpec(&newspec);
+-        Py_TYPE(type) = &PyType_Type;
++        Py_SET_TYPE(type, &PyType_Type);
+ 
+         PySideQFlagsType *flagsType = reinterpret_cast<PySideQFlagsType 
*>(type);
+         PepType_PFTP(flagsType)->converterPtr = 
&PepType_PFTP(flagsType)->converter;
+--- a/libpyside/pysidesignal.cpp
++++ b/libpyside/pysidesignal.cpp
+@@ -162,7 +162,7 @@ PyTypeObject *PySideSignalTypeF(void)
+     if (!type) {
+         type = reinterpret_cast<PyTypeObject 
*>(SbkType_FromSpec(&PySideSignalType_spec));
+         PyTypeObject *hold = Py_TYPE(type);
+-        Py_TYPE(type) = PySideMetaSignalTypeF();
++        Py_SET_TYPE(type, PySideMetaSignalTypeF());
+         Py_INCREF(Py_TYPE(type));
+         Py_DECREF(hold);
+     }
+--- a/libpyside/pysideweakref.cpp
++++ b/libpyside/pysideweakref.cpp
+@@ -90,7 +90,7 @@ PyObject *create(PyObject *obj, PySideWeakRefFunction func, 
void *userData)
+ 
+     if (Py_TYPE(PySideCallableObjectTypeF()) == 0)
+     {
+-        Py_TYPE(PySideCallableObjectTypeF()) = &PyType_Type;
++        Py_SET_TYPE(PySideCallableObjectTypeF(), &PyType_Type);
+         PyType_Ready(PySideCallableObjectTypeF());
+     }
+ 

diff --git a/dev-python/pyside2/pyside2-5.15.2-r2.ebuild 
b/dev-python/pyside2/pyside2-5.15.2-r2.ebuild
new file mode 100644
index 000000000000..1956ebcc9ea0
--- /dev/null
+++ b/dev-python/pyside2/pyside2-5.15.2-r2.ebuild
@@ -0,0 +1,216 @@
+# Copyright 1999-2022 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+# TODO: Add PyPy once officially supported. See also:
+#     https://bugreports.qt.io/browse/PYSIDE-535
+PYTHON_COMPAT=( python3_{8..11} )
+
+inherit cmake python-r1 virtualx
+
+# TODO: Add conditional support for "QtRemoteObjects" via a new "remoteobjects"
+# USE flag after an external "dev-qt/qtremoteobjects" package has been created.
+# TODO: Add conditional support for apidoc generation via a new "doc" USE flag.
+# Note that doing so requires the Qt source tree, sphinx, and graphviz. Once
+# ready, pass the ${QT_SRC_DIR} variable to cmake to enable this support.
+# TODO: Disable GLES support if the "gles2-only" USE flag is disabled. Note
+# that the "PySide2/QtGui/CMakeLists.txt" and
+# "PySide2/QtOpenGLFunctions/CMakeLists.txt" files test for GLES support by
+# testing whether the "Qt5::Gui" list property defined by
+# "/usr/lib64/cmake/Qt5Gui/Qt5GuiConfig.cmake" at "dev-qt/qtgui" installation
+# time contains the substring "opengles2". Since cmake does not permit
+# properties to be overridden from the command line, these files must instead
+# be conditionally patched to avoid these tests. An issue should be filed with
+# upstream requesting a CLI-settable variable to control this.
+
+MY_P=pyside-setup-opensource-src-${PV}
+
+DESCRIPTION="Python bindings for the Qt framework"
+HOMEPAGE="https://wiki.qt.io/PySide2";
+SRC_URI="https://download.qt.io/official_releases/QtForPython/pyside2/PySide2-${PV}-src/${MY_P}.tar.xz";
+S="${WORKDIR}/${MY_P}/sources/pyside2"
+
+# See "sources/pyside2/PySide2/licensecomment.txt" for licensing details.
+LICENSE="|| ( GPL-2 GPL-3+ LGPL-3 )"
+SLOT="0"
+KEYWORDS="~amd64 ~arm ~arm64 ~x86"
+IUSE="
+       3d charts concurrent datavis designer gles2-only +gui help location
+       multimedia +network positioning printsupport qml quick script 
scripttools
+       scxml sensors speech sql svg test testlib webchannel webengine 
websockets
+       +widgets x11extras xml xmlpatterns
+"
+
+# Manually reextract these requirements on version bumps by running the
+# following one-liner from within "${S}":
+#     $ grep 'set.*_deps' PySide2/Qt*/CMakeLists.txt
+# Note that the "designer" USE flag corresponds to the "Qt5UiTools" module.
+REQUIRED_USE="${PYTHON_REQUIRED_USE}
+       3d? ( gui network )
+       charts? ( widgets )
+       datavis? ( gui )
+       designer? ( widgets xml )
+       gles2-only? ( gui )
+       help? ( widgets )
+       location? ( positioning )
+       multimedia? ( gui network )
+       printsupport? ( widgets )
+       qml? ( gui network )
+       quick? ( qml )
+       scripttools? ( gui script widgets )
+       speech? ( multimedia )
+       sql? ( widgets )
+       svg? ( widgets )
+       testlib? ( widgets )
+       webengine? (
+               location quick
+               widgets? ( gui network printsupport webchannel )
+       )
+       websockets? ( network )
+       widgets? ( gui )
+       x11extras? ( gui )
+"
+
+# Tests fail pretty bad and I'm not fixing them right now
+RESTRICT="test"
+
+# Minimal supported version of Qt.
+QT_PV="$(ver_cut 1-2):5"
+
+RDEPEND="${PYTHON_DEPS}
+       >=dev-python/shiboken2-${PV}[${PYTHON_USEDEP}]
+       dev-qt/qtcore:5=
+       dev-qt/qtopengl:5=
+       dev-qt/qtserialport:5=
+       3d? ( >=dev-qt/qt3d-${QT_PV}[qml?] )
+       charts? ( >=dev-qt/qtcharts-${QT_PV}[qml?] )
+       concurrent? ( >=dev-qt/qtconcurrent-${QT_PV} )
+       datavis? ( >=dev-qt/qtdatavis3d-${QT_PV}[qml?] )
+       designer? ( >=dev-qt/designer-${QT_PV} )
+       gui? ( >=dev-qt/qtgui-${QT_PV}[jpeg,gles2-only?] )
+       help? ( >=dev-qt/qthelp-${QT_PV} )
+       location? ( >=dev-qt/qtlocation-${QT_PV} )
+       multimedia? ( >=dev-qt/qtmultimedia-${QT_PV}[qml?,widgets?] )
+       network? ( >=dev-qt/qtnetwork-${QT_PV} )
+       positioning? ( >=dev-qt/qtpositioning-${QT_PV}[qml?] )
+       printsupport? ( >=dev-qt/qtprintsupport-${QT_PV} )
+       qml? ( >=dev-qt/qtdeclarative-${QT_PV}[widgets?] )
+       script? ( >=dev-qt/qtscript-${QT_PV} )
+       scxml? ( >=dev-qt/qtscxml-${QT_PV} )
+       sensors? ( >=dev-qt/qtsensors-${QT_PV}[qml?] )
+       speech? ( >=dev-qt/qtspeech-${QT_PV} )
+       sql? ( >=dev-qt/qtsql-${QT_PV} )
+       svg? ( >=dev-qt/qtsvg-${QT_PV} )
+       testlib? ( >=dev-qt/qttest-${QT_PV} )
+       webchannel? ( >=dev-qt/qtwebchannel-${QT_PV}[qml?] )
+       webengine? ( >=dev-qt/qtwebengine-${QT_PV}[widgets?] )
+       websockets? ( >=dev-qt/qtwebsockets-${QT_PV}[qml?] )
+       widgets? ( >=dev-qt/qtwidgets-${QT_PV} )
+       x11extras? ( >=dev-qt/qtx11extras-${QT_PV} )
+       xml? ( >=dev-qt/qtxml-${QT_PV} )
+       xmlpatterns? ( >=dev-qt/qtxmlpatterns-${QT_PV}[qml?] )
+"
+DEPEND="${RDEPEND}
+       test? ( x11-misc/xvfb-run )
+"
+
+PATCHES=(
+       "${FILESDIR}/${P}-python310.patch"
+       "${FILESDIR}/${P}-python311.patch"
+       "${FILESDIR}"/${PN}-5.15.2-python311-fixups.patch
+)
+
+src_configure() {
+       # See COLLECT_MODULE_IF_FOUND macros in CMakeLists.txt
+       local mycmakeargs=(
+               -DBUILD_TESTS=$(usex test)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt53DAnimation=$(usex !3d)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt53DCore=$(usex !3d)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt53DExtras=$(usex !3d)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt53DInput=$(usex !3d)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt53DLogic=$(usex !3d)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt53DRender=$(usex !3d)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Charts=$(usex !charts)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Concurrent=$(usex !concurrent)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5DataVisualization=$(usex 
!datavis)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Designer=$(usex !designer)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Gui=$(usex !gui)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Help=$(usex !help)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Location=$(usex !location)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Multimedia=$(usex !multimedia)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5MultimediaWidgets=$(usex 
!multimedia yes $(usex !widgets))
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Network=$(usex !network)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Positioning=$(usex !positioning)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5PrintSupport=$(usex 
!printsupport)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Qml=$(usex !qml)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Quick=$(usex !quick)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5QuickWidgets=$(usex !quick yes 
$(usex !widgets))
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Script=$(usex !script)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5ScriptTools=$(usex !scripttools)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Scxml=$(usex !scxml)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Sensors=$(usex !sensors)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5TextToSpeech=$(usex !speech)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Sql=$(usex !sql)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Svg=$(usex !svg)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Test=$(usex !testlib)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5UiTools=$(usex !designer)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5WebChannel=$(usex !webchannel)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5WebEngine=$(usex !webengine)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5WebEngineCore=$(usex !webengine)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5WebEngineWidgets=$(usex 
!webengine yes $(usex !widgets))
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5WebSockets=$(usex !websockets)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Widgets=$(usex !widgets)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5X11Extras=$(usex !x11extras)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5Xml=$(usex !xml)
+               -DCMAKE_DISABLE_FIND_PACKAGE_Qt5XmlPatterns=$(usex !xmlpatterns)
+       )
+
+       pyside2_configure() {
+               local mycmakeargs=(
+                       "${mycmakeargs[@]}"
+                       -DPYTHON_CONFIG_SUFFIX="-${EPYTHON}"
+                       -DPYTHON_EXECUTABLE="${PYTHON}"
+                       -DPYTHON_SITE_PACKAGES="$(python_get_sitedir)"
+                       -DSHIBOKEN_PYTHON_SHARED_LIBRARY_SUFFIX="-${EPYTHON}"
+               )
+               cmake_src_configure
+       }
+       python_foreach_impl pyside2_configure
+}
+
+src_compile() {
+       python_foreach_impl cmake_src_compile
+}
+
+src_test() {
+       local -x PYTHONDONTWRITEBYTECODE
+       python_foreach_impl virtx cmake_src_test
+}
+
+src_install() {
+       pyside2_install() {
+               cmake_src_install
+               python_optimize
+
+               # Uniquify the shiboken2 pkgconfig dependency in the PySide2 
pkgconfig
+               # file for the current Python target. See also:
+               #     https://github.com/leycec/raiagent/issues/73
+               sed -i -e 's~^Requires: shiboken2$~&-'${EPYTHON}'~' \
+                       "${ED}/usr/$(get_libdir)"/pkgconfig/${PN}.pc || die
+
+               # Uniquify the PySide2 pkgconfig file for the current Python 
target,
+               # preserving an unversioned "pyside2.pc" file arbitrarily 
associated
+               # with the last Python target. (See the previously linked 
issue.)
+               cp "${ED}/usr/$(get_libdir)"/pkgconfig/${PN}{,-${EPYTHON}}.pc 
|| die
+       }
+       python_foreach_impl pyside2_install
+
+       # CMakeLists.txt installs a "PySide2Targets-gentoo.cmake" file forcing
+       # downstream consumers (e.g., pyside2-tools) to target one
+       # "libpyside2-*.so" library linked to one Python interpreter. See also:
+       #     https://bugreports.qt.io/browse/PYSIDE-1053
+       #     https://github.com/leycec/raiagent/issues/74
+       sed -i -e 
's~pyside2-python[[:digit:]]\+\.[[:digit:]]\+~pyside2${PYTHON_CONFIG_SUFFIX}~g' 
\
+               
"${ED}/usr/$(get_libdir)/cmake/PySide2-${PV}/PySide2Targets-${CMAKE_BUILD_TYPE,,}.cmake"
 || die
+}

Reply via email to