diff options
Diffstat (limited to 'media-tv/mythtv/files/mythtv-33.1-python3.12.patch')
-rw-r--r-- | media-tv/mythtv/files/mythtv-33.1-python3.12.patch | 279 |
1 files changed, 279 insertions, 0 deletions
diff --git a/media-tv/mythtv/files/mythtv-33.1-python3.12.patch b/media-tv/mythtv/files/mythtv-33.1-python3.12.patch new file mode 100644 index 000000000000..48a97b09623d --- /dev/null +++ b/media-tv/mythtv/files/mythtv-33.1-python3.12.patch @@ -0,0 +1,279 @@ +From f1848eb41bf35d57b63b3a8cb19763c5b4656717 Mon Sep 17 00:00:00 2001 +From: Eli Schwartz <eschwartz93@gmail.com> +Date: Thu, 4 Jan 2024 16:18:00 -0500 +Subject: [PATCH 1/2] hardwareprofile: remove external dependency on simplejson + +This uses the requests module and converts requests responses to json +using requests' own `.json()` method on responses. For incomprehensible +reasons, requests has spent about a decade using either simplejson or +the standard library's json module more or less at will, and returning +either one or the other exception types. They don't know why they use +simplejson, we don't know why they use simplejson. In requests 3 (which +will be released in the Year Of The Linux Desktop or when pigs fly, +whichever one comes later) simplejson is dropped entirely. + +There are innumerable issues discussing the problem on the requests +bugtracker, with the general consensus being that it's better to +randomly return either one of two different libraries and two different +library return types in errors -- because it was historically done that +way and people might be depending on it. ?????? + +Bugs: + +https://github.com/psf/requests/pull/710 +https://github.com/psf/requests/pull/2516 +https://github.com/psf/requests/issues/3052 +https://github.com/psf/requests/issues/4169 +https://github.com/psf/requests/issues/4842 +https://github.com/psf/requests/issues/5794 +https://github.com/psf/requests/issues/6084 + +The awkward workaround is to guarantee that requests' silent behavior of +using simplejson *if it is installed* is forcibly triggered by forcibly +depending on simplejson, and then catching the simplejson exception. + +The better solution here is pretty simple: do not rely on the requests +module's automatic json conversion, this is as simple as using the +already-imported json module and calling json.loads() on the retrieved +content. + +Fixes: 1df343e9ab7defa284a73390210a65cf2112f17e +Reimplements: bb154a843b737cc3ad8c1a45fa04a1a3609aff05 +(cherry picked from commit 6348dc01a45af6ed63c09326ec94cd425db1d6d7) +--- + .github/workflows/buildmaster.yml | 2 +- + mythtv/configure | 1 - + mythtv/programs/scripts/hardwareprofile/smolt.py | 5 ++--- + 3 files changed, 3 insertions(+), 5 deletions(-) + +diff --git a/.github/workflows/buildmaster.yml b/.github/workflows/buildmaster.yml +index eea6e9fc2a..325cc7da64 100644 +--- a/.github/workflows/buildmaster.yml ++++ b/.github/workflows/buildmaster.yml +@@ -48,7 +48,7 @@ jobs: + sudo apt install ccache qt5-qmake qtscript5-dev nasm libsystemd-dev libfreetype6-dev libmp3lame-dev libx264-dev libx265-dev libxrandr-dev libxml2-dev + sudo apt install libavahi-compat-libdnssd-dev libasound2-dev liblzo2-dev libhdhomerun-dev libsamplerate0-dev libva-dev libdrm-dev libvdpau-dev + sudo apt install libass-dev libpulse-dev libcec-dev libssl-dev libtag1-dev libbluray-dev libbluray-bdj libgnutls28-dev libqt5webkit5-dev +- sudo apt install libvpx-dev python3-mysqldb python3-lxml python3-simplejson python3-future python3-setuptools libdbi-perl libdbd-mysql-perl libnet-upnp-perl ++ sudo apt install libvpx-dev python3-mysqldb python3-lxml python3-future python3-setuptools libdbi-perl libdbd-mysql-perl libnet-upnp-perl + sudo apt install libio-socket-inet6-perl libxml-simple-perl libqt5sql5-mysql libwayland-dev qtbase5-private-dev libzip-dev libsoundtouch-dev + if: runner.os == 'Linux' + +diff --git a/mythtv/configure b/mythtv/configure +index 7e966ef817..3429c208e2 100755 +--- a/mythtv/configure ++++ b/mythtv/configure +@@ -6555,7 +6555,6 @@ if enabled bindings_python; then + check_py_lib MySQLdb || disable_bindings_python "MySQLdb" + check_py_lib lxml || disable_bindings_python "lxml" + check_py_lib requests || disable_bindings_python "requests" +- check_py_lib simplejson || disable_bindings_python "simplejson" + check_py_lib future || disable_bindings_python "future" + fi + +diff --git a/mythtv/programs/scripts/hardwareprofile/smolt.py b/mythtv/programs/scripts/hardwareprofile/smolt.py +index 1bcc8060d0..464f068d6f 100644 +--- a/mythtv/programs/scripts/hardwareprofile/smolt.py ++++ b/mythtv/programs/scripts/hardwareprofile/smolt.py +@@ -50,7 +50,6 @@ except ImportError: + from urlparse import urlparse + import json + from json import JSONEncoder +-from simplejson import errors as sje + import datetime + import logging + +@@ -790,8 +789,8 @@ class _HardwareProfile: + sys.exit(1) + + try: +- admin_obj = admin_token.json() +- except sje.JSONDecodeError: ++ admin_obj = json.loads(admin_token.content) ++ except json.JSONDecodeError: + self.session.close() + error(_('Incorrect server response. Expected a JSON string')) + return (1, None, None) +-- +2.41.0 + + +From 13f65c0015d3e0d82d01a1dd5c15afe0ff1e8029 Mon Sep 17 00:00:00 2001 +From: Eli Schwartz <eschwartz93@gmail.com> +Date: Wed, 13 Dec 2023 23:11:11 -0500 +Subject: [PATCH 2/2] hardwareprofile: remove ancient "future" compatibility + library for python2 + +Ironically, for a package that was intended to provide portability +between python2 and python3, it is broken with python 3.12. A better +library to use in all cases is "six". + +However, mythtv requires python 3.8 for a while now. Using +"future.standard_library" is a no-op other than costing a pointless +import and being troublesome to actually install. + +The hacky copy of six.with_metaclass included in "future" is rewritten +to use the pure python3 form of a metaclass. + +(cherry picked from commit 4a1ea331bb2b106e7ae7e7e9bb7970f71b8a84b3) +--- + mythtv/configure | 1 - + .../scripts/hardwareprofile/MultipartPostHandler.py | 2 -- + .../hardwareprofile/distros/mythtv_data/request.py | 2 -- + .../scripts/hardwareprofile/distros/mythtv_data/uuiddb.py | 2 -- + mythtv/programs/scripts/hardwareprofile/hwdata.py | 8 +++----- + mythtv/programs/scripts/hardwareprofile/os_detect.py | 5 ++--- + mythtv/programs/scripts/hardwareprofile/request.py | 2 -- + mythtv/programs/scripts/hardwareprofile/scan.py | 2 -- + mythtv/programs/scripts/hardwareprofile/uuiddb.py | 2 -- + 9 files changed, 5 insertions(+), 21 deletions(-) + +diff --git a/mythtv/configure b/mythtv/configure +index 3429c208e2..4bfbbd8c64 100755 +--- a/mythtv/configure ++++ b/mythtv/configure +@@ -6555,7 +6555,6 @@ if enabled bindings_python; then + check_py_lib MySQLdb || disable_bindings_python "MySQLdb" + check_py_lib lxml || disable_bindings_python "lxml" + check_py_lib requests || disable_bindings_python "requests" +- check_py_lib future || disable_bindings_python "future" + fi + + # Check for perl dependencies +diff --git a/mythtv/programs/scripts/hardwareprofile/MultipartPostHandler.py b/mythtv/programs/scripts/hardwareprofile/MultipartPostHandler.py +index 51619096b8..6ff2443d2e 100644 +--- a/mythtv/programs/scripts/hardwareprofile/MultipartPostHandler.py ++++ b/mythtv/programs/scripts/hardwareprofile/MultipartPostHandler.py +@@ -41,8 +41,6 @@ Further Example: + """ + from __future__ import print_function + +-from future import standard_library +-standard_library.install_aliases() + from builtins import object + from email.generator import _make_boundary + import mimetypes +diff --git a/mythtv/programs/scripts/hardwareprofile/distros/mythtv_data/request.py b/mythtv/programs/scripts/hardwareprofile/distros/mythtv_data/request.py +index 2ae4fd3fdd..81362ba8b7 100644 +--- a/mythtv/programs/scripts/hardwareprofile/distros/mythtv_data/request.py ++++ b/mythtv/programs/scripts/hardwareprofile/distros/mythtv_data/request.py +@@ -21,8 +21,6 @@ + # providing the base url, user agent, and proxy information. + # The object returned is slightly modified, with a shortcut to urlopen. + +-from future import standard_library +-standard_library.install_aliases() + from builtins import object + import urllib.request, urllib.error, urllib.parse + import urllib.parse +diff --git a/mythtv/programs/scripts/hardwareprofile/distros/mythtv_data/uuiddb.py b/mythtv/programs/scripts/hardwareprofile/distros/mythtv_data/uuiddb.py +index 6960f8705a..9d22556c04 100644 +--- a/mythtv/programs/scripts/hardwareprofile/distros/mythtv_data/uuiddb.py ++++ b/mythtv/programs/scripts/hardwareprofile/distros/mythtv_data/uuiddb.py +@@ -16,8 +16,6 @@ + # along with this program; if not, write to the Free Software + # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. + +-from future import standard_library +-standard_library.install_aliases() + from builtins import map + from builtins import str + from builtins import object +diff --git a/mythtv/programs/scripts/hardwareprofile/hwdata.py b/mythtv/programs/scripts/hardwareprofile/hwdata.py +index ba297bf24f..0770d32b96 100644 +--- a/mythtv/programs/scripts/hardwareprofile/hwdata.py ++++ b/mythtv/programs/scripts/hardwareprofile/hwdata.py +@@ -25,8 +25,6 @@ from __future__ import division + from __future__ import absolute_import + from builtins import int + from builtins import open +-from future import standard_library +-standard_library.install_aliases() + from builtins import object + from smolt_config import get_config_attr + +@@ -71,9 +69,9 @@ class DeviceMap(object): + pass + else: + raise Exception('Hardware data file not found. Please set the location HWDATA_DIR in config.py') +- +- +- ++ ++ ++ + vendors = {} + curvendor = None + curdevice = None +diff --git a/mythtv/programs/scripts/hardwareprofile/os_detect.py b/mythtv/programs/scripts/hardwareprofile/os_detect.py +index 7d0edee00e..beabf7d865 100644 +--- a/mythtv/programs/scripts/hardwareprofile/os_detect.py ++++ b/mythtv/programs/scripts/hardwareprofile/os_detect.py +@@ -26,7 +26,6 @@ + from __future__ import print_function + from builtins import object + import os +-from future.utils import with_metaclass + + class OrderedType( type ): + # provide global sequencing for OS class and subclasses to ensure +@@ -37,7 +36,7 @@ class OrderedType( type ): + mcs.nextorder += 1 + return type.__new__(mcs, name, bases, attrs) + +-class OS( with_metaclass(OrderedType, object) ): ++class OS(metaclass=OrderedType): + _requires_func = True + def __init__(self, ostype=-1, func=None, inst=None): + if callable(ostype): +@@ -189,7 +188,7 @@ class OSInfoType( type ): + # fall through to Unknown + return 'Unknown' + +-class get_os_info( with_metaclass(OSInfoType, object) ): ++class get_os_info(metaclass=OSInfoType): + @OS('nt') + def windows(self): + win_version = { +diff --git a/mythtv/programs/scripts/hardwareprofile/request.py b/mythtv/programs/scripts/hardwareprofile/request.py +index 6e6a20b9e7..d6668cef3d 100644 +--- a/mythtv/programs/scripts/hardwareprofile/request.py ++++ b/mythtv/programs/scripts/hardwareprofile/request.py +@@ -21,8 +21,6 @@ + # providing the base url, user agent, and proxy information. + # The object returned is slightly modified, with a shortcut to urlopen. + +-from future import standard_library +-standard_library.install_aliases() + from builtins import object + + try: +diff --git a/mythtv/programs/scripts/hardwareprofile/scan.py b/mythtv/programs/scripts/hardwareprofile/scan.py +index 1389400ece..d100bfe692 100644 +--- a/mythtv/programs/scripts/hardwareprofile/scan.py ++++ b/mythtv/programs/scripts/hardwareprofile/scan.py +@@ -18,8 +18,6 @@ + # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. + + from __future__ import print_function +-from future import standard_library +-standard_library.install_aliases() + import smolt + import json + +diff --git a/mythtv/programs/scripts/hardwareprofile/uuiddb.py b/mythtv/programs/scripts/hardwareprofile/uuiddb.py +index e7ba3891ec..3c2fc16d86 100644 +--- a/mythtv/programs/scripts/hardwareprofile/uuiddb.py ++++ b/mythtv/programs/scripts/hardwareprofile/uuiddb.py +@@ -16,8 +16,6 @@ + # along with this program; if not, write to the Free Software + # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. + +-from future import standard_library +-standard_library.install_aliases() + from builtins import object + import configparser + import logging +-- +2.41.0 + |