Backport PR #121 to fix build with Python 3.12
This commit is contained in:
parent
df6683dc36
commit
cfd194cc9e
261
0001-Update-the-py-compile-script-works-with-Python-3.12.patch
Normal file
261
0001-Update-the-py-compile-script-works-with-Python-3.12.patch
Normal file
@ -0,0 +1,261 @@
|
||||
From 00d42c89d97315594bb715805462826899e62bd0 Mon Sep 17 00:00:00 2001
|
||||
From: Adam Williamson <awilliam@redhat.com>
|
||||
Date: Tue, 4 Jul 2023 15:12:55 -0700
|
||||
Subject: [PATCH] Update the py-compile script (works with Python 3.12)
|
||||
|
||||
The version of automake's py-compile that lvm2 carries around in
|
||||
autoconf/ is ancient. Particularly, it assumes the 'imp' module
|
||||
exists, which as of Python 3.12 is no longer a safe assumption.
|
||||
This just updates lvm2's copy of the file to the latest version
|
||||
in upstream automake -
|
||||
https://raw.githubusercontent.com/autotools-mirror/automake/4bd4640e03670e267d9763d377f107c09b4f2202/lib/py-compile
|
||||
. From a quick look at the changes, the interface shouldn't have
|
||||
changed, this should just work better with modern Python.
|
||||
|
||||
Signed-off-by: Adam Williamson <awilliam@redhat.com>
|
||||
---
|
||||
autoconf/py-compile | 162 ++++++++++++++++++++++++++++++++------------
|
||||
1 file changed, 117 insertions(+), 45 deletions(-)
|
||||
|
||||
diff --git a/autoconf/py-compile b/autoconf/py-compile
|
||||
index bc2039140..d11962e96 100755
|
||||
--- a/autoconf/py-compile
|
||||
+++ b/autoconf/py-compile
|
||||
@@ -1,9 +1,9 @@
|
||||
#!/bin/sh
|
||||
# py-compile - Compile a Python program
|
||||
|
||||
-scriptversion=2011-06-08.12; # UTC
|
||||
+scriptversion=2023-03-30.00; # UTC
|
||||
|
||||
-# Copyright (C) 2000-2014 Free Software Foundation, Inc.
|
||||
+# Copyright (C) 2000-2023 Free Software Foundation, Inc.
|
||||
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
@@ -16,7 +16,7 @@ scriptversion=2011-06-08.12; # UTC
|
||||
# GNU General Public License for more details.
|
||||
|
||||
# You should have received a copy of the GNU General Public License
|
||||
-# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
+# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
# As a special exception to the GNU General Public License, if you
|
||||
# distribute this file as part of a program that contains a
|
||||
@@ -27,7 +27,7 @@ scriptversion=2011-06-08.12; # UTC
|
||||
# bugs to <bug-automake@gnu.org> or send patches to
|
||||
# <automake-patches@gnu.org>.
|
||||
|
||||
-if [ -z "$PYTHON" ]; then
|
||||
+if test -z "$PYTHON"; then
|
||||
PYTHON=python
|
||||
fi
|
||||
|
||||
@@ -62,13 +62,19 @@ while test $# -ne 0; do
|
||||
;;
|
||||
-h|--help)
|
||||
cat <<\EOF
|
||||
-Usage: py-compile [--help] [--version] [--basedir DIR] [--destdir DIR] FILES..."
|
||||
+Usage: py-compile [options] FILES...
|
||||
|
||||
Byte compile some python scripts FILES. Use --destdir to specify any
|
||||
leading directory path to the FILES that you don't want to include in the
|
||||
byte compiled file. Specify --basedir for any additional path information you
|
||||
do want to be shown in the byte compiled file.
|
||||
|
||||
+Options:
|
||||
+ --basedir DIR Prefix all FILES with DIR, and include in error messages.
|
||||
+ --destdir DIR Prefix all FILES with DIR before compiling.
|
||||
+ -v, --version Display version information.
|
||||
+ -h, --help This help screen.
|
||||
+
|
||||
Example:
|
||||
py-compile --destdir /tmp/pkg-root --basedir /usr/share/test test.py test2.py
|
||||
|
||||
@@ -94,77 +100,143 @@ EOF
|
||||
shift
|
||||
done
|
||||
|
||||
-files=$*
|
||||
-if test -z "$files"; then
|
||||
- usage_error "no files given"
|
||||
+if test $# -eq 0; then
|
||||
+ usage_error "no files given"
|
||||
fi
|
||||
|
||||
# if basedir was given, then it should be prepended to filenames before
|
||||
# byte compilation.
|
||||
-if [ -z "$basedir" ]; then
|
||||
- pathtrans="path = file"
|
||||
+if test -z "$basedir"; then
|
||||
+ pathtrans="path = file"
|
||||
else
|
||||
- pathtrans="path = os.path.join('$basedir', file)"
|
||||
+ pathtrans="path = os.path.join('$basedir', file)"
|
||||
fi
|
||||
|
||||
# if destdir was given, then it needs to be prepended to the filename to
|
||||
# byte compile but not go into the compiled file.
|
||||
-if [ -z "$destdir" ]; then
|
||||
- filetrans="filepath = path"
|
||||
+if test -z "$destdir"; then
|
||||
+ filetrans="filepath = path"
|
||||
else
|
||||
- filetrans="filepath = os.path.normpath('$destdir' + os.sep + path)"
|
||||
+ filetrans="filepath = os.path.normpath('$destdir' + os.sep + path)"
|
||||
fi
|
||||
|
||||
-$PYTHON -c "
|
||||
-import sys, os, py_compile, imp
|
||||
+python_major=`$PYTHON -c 'import sys; print(sys.version_info[0])'`
|
||||
+if test -z "$python_major"; then
|
||||
+ usage_error "could not determine $PYTHON major version"
|
||||
+fi
|
||||
|
||||
-files = '''$files'''
|
||||
+case $python_major in
|
||||
+[01])
|
||||
+ usage_error "python version 0.x and 1.x not supported"
|
||||
+ ;;
|
||||
+esac
|
||||
+
|
||||
+python_minor=`$PYTHON -c 'import sys; print(sys.version_info[1])'`
|
||||
+
|
||||
+# NB: When adding support for newer versions, prefer copying & adding new cases
|
||||
+# rather than try to keep things merged with shell variables.
|
||||
+
|
||||
+# First byte compile (no optimization) all the modules.
|
||||
+# This works for all currently known Python versions.
|
||||
+$PYTHON -c "
|
||||
+import sys, os, py_compile
|
||||
+
|
||||
+try:
|
||||
+ import importlib
|
||||
+except ImportError:
|
||||
+ importlib = None
|
||||
+
|
||||
+# importlib.util.cache_from_source was added in 3.4
|
||||
+if (
|
||||
+ hasattr(importlib, 'util')
|
||||
+ and hasattr(importlib.util, 'cache_from_source')
|
||||
+):
|
||||
+ destpath = importlib.util.cache_from_source
|
||||
+else:
|
||||
+ destpath = lambda filepath: filepath + 'c'
|
||||
|
||||
sys.stdout.write('Byte-compiling python modules...\n')
|
||||
-for file in files.split():
|
||||
+for file in sys.argv[1:]:
|
||||
$pathtrans
|
||||
$filetrans
|
||||
- if not os.path.exists(filepath) or not (len(filepath) >= 3
|
||||
- and filepath[-3:] == '.py'):
|
||||
- continue
|
||||
- sys.stdout.write(file)
|
||||
+ if (
|
||||
+ not os.path.exists(filepath)
|
||||
+ or not (len(filepath) >= 3 and filepath[-3:] == '.py')
|
||||
+ ):
|
||||
+ continue
|
||||
+ sys.stdout.write(file + ' ')
|
||||
sys.stdout.flush()
|
||||
- if hasattr(imp, 'get_tag'):
|
||||
- py_compile.compile(filepath, imp.cache_from_source(filepath), path)
|
||||
- else:
|
||||
- py_compile.compile(filepath, filepath + 'c', path)
|
||||
-sys.stdout.write('\n')" || exit $?
|
||||
+ py_compile.compile(filepath, destpath(filepath), path)
|
||||
+sys.stdout.write('\n')" "$@" || exit $?
|
||||
|
||||
-# this will fail for python < 1.5, but that doesn't matter ...
|
||||
+# Then byte compile w/optimization all the modules.
|
||||
$PYTHON -O -c "
|
||||
-import sys, os, py_compile, imp
|
||||
-
|
||||
-# pypy does not use .pyo optimization
|
||||
-if hasattr(sys, 'pypy_translation_info'):
|
||||
+import sys, os, py_compile
|
||||
+
|
||||
+try:
|
||||
+ import importlib
|
||||
+except ImportError:
|
||||
+ importlib = None
|
||||
+
|
||||
+# importlib.util.cache_from_source was added in 3.4
|
||||
+if (
|
||||
+ hasattr(importlib, 'util')
|
||||
+ and hasattr(importlib.util, 'cache_from_source')
|
||||
+):
|
||||
+ destpath = importlib.util.cache_from_source
|
||||
+else:
|
||||
+ destpath = lambda filepath: filepath + 'o'
|
||||
+
|
||||
+# pypy2 does not use .pyo optimization
|
||||
+if sys.version_info.major <= 2 and hasattr(sys, 'pypy_translation_info'):
|
||||
sys.exit(0)
|
||||
|
||||
-files = '''$files'''
|
||||
sys.stdout.write('Byte-compiling python modules (optimized versions) ...\n')
|
||||
-for file in files.split():
|
||||
+for file in sys.argv[1:]:
|
||||
+ $pathtrans
|
||||
+ $filetrans
|
||||
+ if (
|
||||
+ not os.path.exists(filepath)
|
||||
+ or not (len(filepath) >= 3 and filepath[-3:] == '.py')
|
||||
+ ):
|
||||
+ continue
|
||||
+ sys.stdout.write(file + ' ')
|
||||
+ sys.stdout.flush()
|
||||
+ py_compile.compile(filepath, destpath(filepath), path)
|
||||
+sys.stdout.write('\n')" "$@" 2>/dev/null || exit $?
|
||||
+
|
||||
+# Then byte compile w/more optimization.
|
||||
+# Only do this for Python 3.5+, see https://bugs.gnu.org/38043 for background.
|
||||
+case $python_major.$python_minor in
|
||||
+2.*|3.[0-4])
|
||||
+ ;;
|
||||
+*)
|
||||
+ $PYTHON -OO -c "
|
||||
+import sys, os, py_compile, importlib
|
||||
+
|
||||
+sys.stdout.write('Byte-compiling python modules (more optimized versions)'
|
||||
+ ' ...\n')
|
||||
+for file in sys.argv[1:]:
|
||||
$pathtrans
|
||||
$filetrans
|
||||
- if not os.path.exists(filepath) or not (len(filepath) >= 3
|
||||
- and filepath[-3:] == '.py'):
|
||||
- continue
|
||||
- sys.stdout.write(file)
|
||||
+ if (
|
||||
+ not os.path.exists(filepath)
|
||||
+ or not (len(filepath) >= 3 and filepath[-3:] == '.py')
|
||||
+ ):
|
||||
+ continue
|
||||
+ sys.stdout.write(file + ' ')
|
||||
sys.stdout.flush()
|
||||
- if hasattr(imp, 'get_tag'):
|
||||
- py_compile.compile(filepath, imp.cache_from_source(filepath, False), path)
|
||||
- else:
|
||||
- py_compile.compile(filepath, filepath + 'o', path)
|
||||
-sys.stdout.write('\n')" 2>/dev/null || :
|
||||
+ py_compile.compile(filepath, importlib.util.cache_from_source(filepath), path)
|
||||
+sys.stdout.write('\n')" "$@" 2>/dev/null || exit $?
|
||||
+ ;;
|
||||
+esac
|
||||
|
||||
# Local Variables:
|
||||
# mode: shell-script
|
||||
# sh-indentation: 2
|
||||
-# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||
+# eval: (add-hook 'before-save-hook 'time-stamp)
|
||||
# time-stamp-start: "scriptversion="
|
||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
||||
-# time-stamp-time-zone: "UTC"
|
||||
+# time-stamp-time-zone: "UTC0"
|
||||
# time-stamp-end: "; # UTC"
|
||||
# End:
|
||||
--
|
||||
2.41.0
|
||||
|
@ -49,10 +49,11 @@ Release: 3%{?dist}
|
||||
License: GPLv2
|
||||
URL: https://sourceware.org/lvm2/
|
||||
Source0: https://sourceware.org/pub/lvm2/releases/LVM2.%{version}.tgz
|
||||
# https://bugzilla.redhat.com/show_bug.cgi?id=2180557
|
||||
# https://github.com/lvmteam/lvm2/pull/114
|
||||
# Fix an invalid import which breaks lvm2-lvmdbusd.service and thus anaconda
|
||||
#Patch1: 0001-
|
||||
# update py-compile script to a modern version that works with Python
|
||||
# 3.12. byte compiling during install isn't even necessary on Fedora,
|
||||
# but fixing it is easier than dropping it
|
||||
# https://github.com/lvmteam/lvm2/pull/121
|
||||
Patch0: 0001-Update-the-py-compile-script-works-with-Python-3.12.patch
|
||||
|
||||
BuildRequires: make
|
||||
BuildRequires: gcc
|
||||
|
Loading…
Reference in New Issue
Block a user