Import rpm: ab10c83f6cc730cb98e0365b632b26e89f9b4182
This commit is contained in:
		
						commit
						08f63a539b
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| SOURCES/Python-3.9.13.tar.xz | ||||
							
								
								
									
										30
									
								
								00001-rpath.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								00001-rpath.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | ||||
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | ||||
| From: David Malcolm <dmalcolm@redhat.com> | ||||
| Date: Wed, 13 Jan 2010 21:25:18 +0000 | ||||
| Subject: [PATCH] 00001: Fixup distutils/unixccompiler.py to remove standard | ||||
|  library path from rpath Was Patch0 in ivazquez' python3000 specfile | ||||
| 
 | ||||
| ---
 | ||||
|  Lib/distutils/unixccompiler.py | 9 +++++++++ | ||||
|  1 file changed, 9 insertions(+) | ||||
| 
 | ||||
| diff --git a/Lib/distutils/unixccompiler.py b/Lib/distutils/unixccompiler.py
 | ||||
| index f0792de74a..4d837936c6 100644
 | ||||
| --- a/Lib/distutils/unixccompiler.py
 | ||||
| +++ b/Lib/distutils/unixccompiler.py
 | ||||
| @@ -82,6 +82,15 @@ class UnixCCompiler(CCompiler):
 | ||||
|      if sys.platform == "cygwin": | ||||
|          exe_extension = ".exe" | ||||
|   | ||||
| +    def _fix_lib_args(self, libraries, library_dirs, runtime_library_dirs):
 | ||||
| +        """Remove standard library path from rpath"""
 | ||||
| +        libraries, library_dirs, runtime_library_dirs = super()._fix_lib_args(
 | ||||
| +            libraries, library_dirs, runtime_library_dirs)
 | ||||
| +        libdir = sysconfig.get_config_var('LIBDIR')
 | ||||
| +        if runtime_library_dirs and (libdir in runtime_library_dirs):
 | ||||
| +            runtime_library_dirs.remove(libdir)
 | ||||
| +        return libraries, library_dirs, runtime_library_dirs
 | ||||
| +
 | ||||
|      def preprocess(self, source, output_file=None, macros=None, | ||||
|                     include_dirs=None, extra_preargs=None, extra_postargs=None): | ||||
|          fixed_args = self._fix_compile_args(None, macros, include_dirs) | ||||
							
								
								
									
										75
									
								
								00111-no-static-lib.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								00111-no-static-lib.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,75 @@ | ||||
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | ||||
| From: David Malcolm <dmalcolm@redhat.com> | ||||
| Date: Mon, 18 Jan 2010 17:59:07 +0000 | ||||
| Subject: [PATCH] 00111: Don't try to build a libpythonMAJOR.MINOR.a | ||||
| MIME-Version: 1.0 | ||||
| Content-Type: text/plain; charset=UTF-8 | ||||
| Content-Transfer-Encoding: 8bit | ||||
| 
 | ||||
| Downstream only: not appropriate for upstream. | ||||
| 
 | ||||
| See https://bugzilla.redhat.com/show_bug.cgi?id=556092 | ||||
| 
 | ||||
| Co-authored-by: David Malcolm <dmalcolm@redhat.com> | ||||
| Co-authored-by: Bohuslav Kabrda <bkabrda@redhat.com> | ||||
| Co-authored-by: Matej Stuchlik <mstuchli@redhat.com> | ||||
| Co-authored-by: Robert Kuska <rkuska@redhat.com> | ||||
| Co-authored-by: Charalampos Stratakis <cstratak@redhat.com> | ||||
| Co-authored-by: Miro Hrončok <miro@hroncok.cz> | ||||
| ---
 | ||||
|  Makefile.pre.in | 21 ++------------------- | ||||
|  1 file changed, 2 insertions(+), 19 deletions(-) | ||||
| 
 | ||||
| diff --git a/Makefile.pre.in b/Makefile.pre.in
 | ||||
| index f128444b98..22f25e159d 100644
 | ||||
| --- a/Makefile.pre.in
 | ||||
| +++ b/Makefile.pre.in
 | ||||
| @@ -586,7 +586,7 @@ clinic: check-clean-src $(srcdir)/Modules/_blake2/blake2s_impl.c
 | ||||
|  	$(PYTHON_FOR_REGEN) $(srcdir)/Tools/clinic/clinic.py --make --srcdir $(srcdir) | ||||
|   | ||||
|  # Build the interpreter | ||||
| -$(BUILDPYTHON):	Programs/python.o $(LIBRARY) $(LDLIBRARY) $(PY3LIBRARY) $(EXPORTSYMS)
 | ||||
| +$(BUILDPYTHON):	Programs/python.o $(LDLIBRARY) $(PY3LIBRARY) $(EXPORTSYMS)
 | ||||
|  	$(LINKCC) $(PY_CORE_LDFLAGS) $(LINKFORSHARED) -o $@ Programs/python.o $(BLDLIBRARY) $(LIBS) $(MODLIBS) $(SYSLIBS) | ||||
|   | ||||
|  platform: $(BUILDPYTHON) pybuilddir.txt | ||||
| @@ -634,12 +634,6 @@ sharedmods: $(BUILDPYTHON) pybuilddir.txt Modules/_math.o
 | ||||
|  		_TCLTK_INCLUDES='$(TCLTK_INCLUDES)' _TCLTK_LIBS='$(TCLTK_LIBS)' \ | ||||
|  		$(PYTHON_FOR_BUILD) $(srcdir)/setup.py $$quiet build | ||||
|   | ||||
| -
 | ||||
| -# Build static library
 | ||||
| -$(LIBRARY): $(LIBRARY_OBJS)
 | ||||
| -	-rm -f $@
 | ||||
| -	$(AR) $(ARFLAGS) $@ $(LIBRARY_OBJS)
 | ||||
| -
 | ||||
|  libpython$(LDVERSION).so: $(LIBRARY_OBJS) $(DTRACE_OBJS) | ||||
|  	if test $(INSTSONAME) != $(LDLIBRARY); then \ | ||||
|  		$(BLDSHARED) -Wl,-h$(INSTSONAME) -o $(INSTSONAME) $(LIBRARY_OBJS) $(MODLIBS) $(SHLIBS) $(LIBC) $(LIBM); \ | ||||
| @@ -721,7 +715,7 @@ Makefile Modules/config.c: Makefile.pre \
 | ||||
|  	@echo "The Makefile was updated, you may need to re-run make." | ||||
|   | ||||
|   | ||||
| -Programs/_testembed: Programs/_testembed.o $(LIBRARY) $(LDLIBRARY) $(PY3LIBRARY) $(EXPORTSYMS)
 | ||||
| +Programs/_testembed: Programs/_testembed.o $(LDLIBRARY) $(PY3LIBRARY) $(EXPORTSYMS)
 | ||||
|  	$(LINKCC) $(PY_CORE_LDFLAGS) $(LINKFORSHARED) -o $@ Programs/_testembed.o $(BLDLIBRARY) $(LIBS) $(MODLIBS) $(SYSLIBS) | ||||
|   | ||||
|  ############################################################################ | ||||
| @@ -1631,17 +1625,6 @@ libainstall:	@DEF_MAKE_RULE@ python-config
 | ||||
|  		else	true; \ | ||||
|  		fi; \ | ||||
|  	done | ||||
| -	@if test -d $(LIBRARY); then :; else \
 | ||||
| -		if test "$(PYTHONFRAMEWORKDIR)" = no-framework; then \
 | ||||
| -			if test "$(SHLIB_SUFFIX)" = .dll; then \
 | ||||
| -				$(INSTALL_DATA) $(LDLIBRARY) $(DESTDIR)$(LIBPL) ; \
 | ||||
| -			else \
 | ||||
| -				$(INSTALL_DATA) $(LIBRARY) $(DESTDIR)$(LIBPL)/$(LIBRARY) ; \
 | ||||
| -			fi; \
 | ||||
| -		else \
 | ||||
| -			echo Skip install of $(LIBRARY) - use make frameworkinstall; \
 | ||||
| -		fi; \
 | ||||
| -	fi
 | ||||
|  	$(INSTALL_DATA) Modules/config.c $(DESTDIR)$(LIBPL)/config.c | ||||
|  	$(INSTALL_DATA) Programs/python.o $(DESTDIR)$(LIBPL)/python.o | ||||
|  	$(INSTALL_DATA) $(srcdir)/Modules/config.c.in $(DESTDIR)$(LIBPL)/config.c.in | ||||
							
								
								
									
										78
									
								
								00189-use-rpm-wheels.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								00189-use-rpm-wheels.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,78 @@ | ||||
| From 2c91575950d4de95d308e30cc4ab20d032b1aceb Mon Sep 17 00:00:00 2001 | ||||
| From: =?UTF-8?q?Miro=20Hron=C4=8Dok?= <miro@hroncok.cz> | ||||
| Date: Wed, 15 Aug 2018 15:36:29 +0200 | ||||
| Subject: [PATCH] 00189: Instead of bundled wheels, use our RPM packaged wheels | ||||
| 
 | ||||
| We keep them in /usr/share/python-wheels | ||||
| 
 | ||||
| Downstream only: upstream bundles | ||||
| We might eventually pursuit upstream support, but it's low prio | ||||
| ---
 | ||||
|  Lib/ensurepip/__init__.py | 37 ++++++++++++++++++++++++++----------- | ||||
|  1 file changed, 26 insertions(+), 11 deletions(-) | ||||
| 
 | ||||
| diff --git a/Lib/ensurepip/__init__.py b/Lib/ensurepip/__init__.py
 | ||||
| index e510cc7..8de2e55 100644
 | ||||
| --- a/Lib/ensurepip/__init__.py
 | ||||
| +++ b/Lib/ensurepip/__init__.py
 | ||||
| @@ -1,3 +1,5 @@
 | ||||
| +import distutils.version
 | ||||
| +import glob
 | ||||
|  import os | ||||
|  import os.path | ||||
|  import sys | ||||
| @@ -6,13 +8,29 @@ import tempfile
 | ||||
|  import subprocess | ||||
|  from importlib import resources | ||||
|   | ||||
| -from . import _bundled
 | ||||
| -
 | ||||
|   | ||||
|   | ||||
|  __all__ = ["version", "bootstrap"] | ||||
| -_SETUPTOOLS_VERSION = "58.1.0"
 | ||||
| -_PIP_VERSION = "22.0.4"
 | ||||
| +
 | ||||
| +_WHEEL_DIR = "/usr/share/python39-wheels/"
 | ||||
| +
 | ||||
| +_wheels = {}
 | ||||
| +
 | ||||
| +def _get_most_recent_wheel_version(pkg):
 | ||||
| +    prefix = os.path.join(_WHEEL_DIR, "{}-".format(pkg))
 | ||||
| +    _wheels[pkg] = {}
 | ||||
| +    for suffix in "-py2.py3-none-any.whl", "-py3-none-any.whl":
 | ||||
| +        pattern = "{}*{}".format(prefix, suffix)
 | ||||
| +        for path in glob.glob(pattern):
 | ||||
| +            version_str = path[len(prefix):-len(suffix)]
 | ||||
| +            _wheels[pkg][version_str] = os.path.basename(path)
 | ||||
| +    return str(max(_wheels[pkg], key=distutils.version.LooseVersion))
 | ||||
| +
 | ||||
| +
 | ||||
| +_SETUPTOOLS_VERSION = _get_most_recent_wheel_version("setuptools")
 | ||||
| +
 | ||||
| +_PIP_VERSION = _get_most_recent_wheel_version("pip")
 | ||||
| +
 | ||||
|  _PROJECTS = [ | ||||
|      ("setuptools", _SETUPTOOLS_VERSION, "py3"), | ||||
|      ("pip", _PIP_VERSION, "py3"), | ||||
| @@ -101,13 +119,10 @@ def _bootstrap(*, root=None, upgrade=False, user=False,
 | ||||
|          # additional paths that need added to sys.path | ||||
|          additional_paths = [] | ||||
|          for project, version, py_tag in _PROJECTS: | ||||
| -            wheel_name = "{}-{}-{}-none-any.whl".format(project, version, py_tag)
 | ||||
| -            whl = resources.read_binary(
 | ||||
| -                _bundled,
 | ||||
| -                wheel_name,
 | ||||
| -            )
 | ||||
| -            with open(os.path.join(tmpdir, wheel_name), "wb") as fp:
 | ||||
| -                fp.write(whl)
 | ||||
| +            wheel_name = _wheels[project][version]
 | ||||
| +            with open(os.path.join(_WHEEL_DIR, wheel_name), "rb") as sfp:
 | ||||
| +                with open(os.path.join(tmpdir, wheel_name), "wb") as fp:
 | ||||
| +                    fp.write(sfp.read())
 | ||||
|   | ||||
|              additional_paths.append(os.path.join(tmpdir, wheel_name)) | ||||
|   | ||||
| -- 
 | ||||
| 2.35.3 | ||||
| 
 | ||||
							
								
								
									
										62
									
								
								00251-change-user-install-location.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								00251-change-user-install-location.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,62 @@ | ||||
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | ||||
| From: Michal Cyprian <m.cyprian@gmail.com> | ||||
| Date: Mon, 26 Jun 2017 16:32:56 +0200 | ||||
| Subject: [PATCH] 00251: Change user install location | ||||
| 
 | ||||
| Set values of prefix and exec_prefix in distutils install command | ||||
| to /usr/local if executable is /usr/bin/python* and RPM build | ||||
| is not detected to make pip and distutils install into separate location. | ||||
| 
 | ||||
| Fedora Change: https://fedoraproject.org/wiki/Changes/Making_sudo_pip_safe | ||||
| Downstream only: Awaiting resources to work on upstream PEP | ||||
| ---
 | ||||
|  Lib/distutils/command/install.py | 15 +++++++++++++-- | ||||
|  Lib/site.py                      |  9 ++++++++- | ||||
|  2 files changed, 21 insertions(+), 3 deletions(-) | ||||
| 
 | ||||
| diff --git a/Lib/distutils/command/install.py b/Lib/distutils/command/install.py
 | ||||
| index aaa300efa9..f8d453912a 100644
 | ||||
| --- a/Lib/distutils/command/install.py
 | ||||
| +++ b/Lib/distutils/command/install.py
 | ||||
| @@ -419,8 +419,19 @@ class install(Command):
 | ||||
|                      raise DistutilsOptionError( | ||||
|                            "must not supply exec-prefix without prefix") | ||||
|   | ||||
| -                self.prefix = os.path.normpath(sys.prefix)
 | ||||
| -                self.exec_prefix = os.path.normpath(sys.exec_prefix)
 | ||||
| +                # self.prefix is set to sys.prefix + /local/
 | ||||
| +                # if neither RPM build nor virtual environment is
 | ||||
| +                # detected to make pip and distutils install packages
 | ||||
| +                # into the separate location.
 | ||||
| +                if (not (hasattr(sys, 'real_prefix') or
 | ||||
| +                    sys.prefix != sys.base_prefix) and
 | ||||
| +                    'RPM_BUILD_ROOT' not in os.environ):
 | ||||
| +                    addition = "/local"
 | ||||
| +                else:
 | ||||
| +                    addition = ""
 | ||||
| +
 | ||||
| +                self.prefix = os.path.normpath(sys.prefix) + addition
 | ||||
| +                self.exec_prefix = os.path.normpath(sys.exec_prefix) + addition
 | ||||
|   | ||||
|              else: | ||||
|                  if self.exec_prefix is None: | ||||
| diff --git a/Lib/site.py b/Lib/site.py
 | ||||
| index 9e617afb00..db14f715f9 100644
 | ||||
| --- a/Lib/site.py
 | ||||
| +++ b/Lib/site.py
 | ||||
| @@ -353,7 +353,14 @@ def getsitepackages(prefixes=None):
 | ||||
|      return sitepackages | ||||
|   | ||||
|  def addsitepackages(known_paths, prefixes=None): | ||||
| -    """Add site-packages to sys.path"""
 | ||||
| +    """Add site-packages to sys.path
 | ||||
| +
 | ||||
| +    '/usr/local' is included in PREFIXES if RPM build is not detected
 | ||||
| +    to make packages installed into this location visible.
 | ||||
| +
 | ||||
| +    """
 | ||||
| +    if ENABLE_USER_SITE and 'RPM_BUILD_ROOT' not in os.environ:
 | ||||
| +        PREFIXES.insert(0, "/usr/local")
 | ||||
|      for sitedir in getsitepackages(prefixes): | ||||
|          if os.path.isdir(sitedir): | ||||
|              addsitedir(sitedir, known_paths) | ||||
							
								
								
									
										54
									
								
								00328-pyc-timestamp-invalidation-mode.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								00328-pyc-timestamp-invalidation-mode.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,54 @@ | ||||
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | ||||
| From: =?UTF-8?q?Miro=20Hron=C4=8Dok?= <miro@hroncok.cz> | ||||
| Date: Thu, 11 Jul 2019 13:44:13 +0200 | ||||
| Subject: [PATCH] 00328: Restore pyc to TIMESTAMP invalidation mode as default | ||||
|  in rpmbuild | ||||
| 
 | ||||
| Since Fedora 31, the $SOURCE_DATE_EPOCH is set in rpmbuild to the latest | ||||
| %changelog date. This makes Python default to the CHECKED_HASH pyc | ||||
| invalidation mode, bringing more reproducible builds traded for an import | ||||
| performance decrease. To avoid that, we don't default to CHECKED_HASH | ||||
| when $RPM_BUILD_ROOT is set (i.e. when we are building RPM packages). | ||||
| 
 | ||||
| See https://src.fedoraproject.org/rpms/redhat-rpm-config/pull-request/57#comment-27426 | ||||
| Downstream only: only used when building RPM packages | ||||
| Ideally, we should talk to upstream and explain why we don't want this | ||||
| ---
 | ||||
|  Lib/py_compile.py           | 3 ++- | ||||
|  Lib/test/test_py_compile.py | 2 ++ | ||||
|  2 files changed, 4 insertions(+), 1 deletion(-) | ||||
| 
 | ||||
| diff --git a/Lib/py_compile.py b/Lib/py_compile.py
 | ||||
| index a81f493731..bba3642bf2 100644
 | ||||
| --- a/Lib/py_compile.py
 | ||||
| +++ b/Lib/py_compile.py
 | ||||
| @@ -70,7 +70,8 @@ class PycInvalidationMode(enum.Enum):
 | ||||
|   | ||||
|   | ||||
|  def _get_default_invalidation_mode(): | ||||
| -    if os.environ.get('SOURCE_DATE_EPOCH'):
 | ||||
| +    if (os.environ.get('SOURCE_DATE_EPOCH') and not
 | ||||
| +            os.environ.get('RPM_BUILD_ROOT')):
 | ||||
|          return PycInvalidationMode.CHECKED_HASH | ||||
|      else: | ||||
|          return PycInvalidationMode.TIMESTAMP | ||||
| diff --git a/Lib/test/test_py_compile.py b/Lib/test/test_py_compile.py
 | ||||
| index e6791c6916..b2d3dcf7fb 100644
 | ||||
| --- a/Lib/test/test_py_compile.py
 | ||||
| +++ b/Lib/test/test_py_compile.py
 | ||||
| @@ -19,6 +19,7 @@ def without_source_date_epoch(fxn):
 | ||||
|      def wrapper(*args, **kwargs): | ||||
|          with support.EnvironmentVarGuard() as env: | ||||
|              env.unset('SOURCE_DATE_EPOCH') | ||||
| +            env.unset('RPM_BUILD_ROOT')
 | ||||
|              return fxn(*args, **kwargs) | ||||
|      return wrapper | ||||
|   | ||||
| @@ -29,6 +30,7 @@ def with_source_date_epoch(fxn):
 | ||||
|      def wrapper(*args, **kwargs): | ||||
|          with support.EnvironmentVarGuard() as env: | ||||
|              env['SOURCE_DATE_EPOCH'] = '123456789' | ||||
| +            env.unset('RPM_BUILD_ROOT')
 | ||||
|              return fxn(*args, **kwargs) | ||||
|      return wrapper | ||||
|   | ||||
							
								
								
									
										2175
									
								
								00329-fips.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2175
									
								
								00329-fips.patch
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										97
									
								
								00353-architecture-names-upstream-downstream.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								00353-architecture-names-upstream-downstream.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,97 @@ | ||||
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | ||||
| From: Lumir Balhar <lbalhar@redhat.com> | ||||
| Date: Tue, 4 Aug 2020 12:04:03 +0200 | ||||
| Subject: [PATCH] 00353: Original names for architectures with different names | ||||
|  downstream | ||||
| MIME-Version: 1.0 | ||||
| Content-Type: text/plain; charset=UTF-8 | ||||
| Content-Transfer-Encoding: 8bit | ||||
| 
 | ||||
| https://fedoraproject.org/wiki/Changes/Python_Upstream_Architecture_Names | ||||
| 
 | ||||
| Pythons in RHEL/Fedora used different names for some architectures | ||||
| than upstream and other distros (for example ppc64 vs. powerpc64). | ||||
| This was patched in patch 274, now it is sedded if %with legacy_archnames. | ||||
| 
 | ||||
| That meant that an extension built with the default upstream settings | ||||
| (on other distro or as an manylinux wheel) could not been found by Python | ||||
| on RHEL/Fedora because it had a different suffix. | ||||
| This patch adds the legacy names to importlib so Python is able | ||||
| to import extensions with a legacy architecture name in its | ||||
| file name. | ||||
| It work both ways, so it support both %with and %without legacy_archnames. | ||||
| 
 | ||||
| WARNING: This patch has no effect on Python built with bootstrap | ||||
| enabled because Python/importlib_external.h is not regenerated | ||||
| and therefore Python during bootstrap contains importlib from | ||||
| upstream without this feature. It's possible to include | ||||
| Python/importlib_external.h to this patch but it'd make rebasing | ||||
| a nightmare because it's basically a binary file. | ||||
| 
 | ||||
| Co-authored-by: Miro Hrončok <miro@hroncok.cz> | ||||
| ---
 | ||||
|  Lib/importlib/_bootstrap_external.py | 40 ++++++++++++++++++++++++++-- | ||||
|  1 file changed, 38 insertions(+), 2 deletions(-) | ||||
| 
 | ||||
| diff --git a/Lib/importlib/_bootstrap_external.py b/Lib/importlib/_bootstrap_external.py
 | ||||
| index 25a3f8c0e0..a2edbebc88 100644
 | ||||
| --- a/Lib/importlib/_bootstrap_external.py
 | ||||
| +++ b/Lib/importlib/_bootstrap_external.py
 | ||||
| @@ -1566,7 +1566,7 @@ def _get_supported_file_loaders():
 | ||||
|   | ||||
|      Each item is a tuple (loader, suffixes). | ||||
|      """ | ||||
| -    extensions = ExtensionFileLoader, _imp.extension_suffixes()
 | ||||
| +    extensions = ExtensionFileLoader, _alternative_architectures(_imp.extension_suffixes())
 | ||||
|      source = SourceFileLoader, SOURCE_SUFFIXES | ||||
|      bytecode = SourcelessFileLoader, BYTECODE_SUFFIXES | ||||
|      return [extensions, source, bytecode] | ||||
| @@ -1622,7 +1622,7 @@ def _setup(_bootstrap_module):
 | ||||
|   | ||||
|      # Constants | ||||
|      setattr(self_module, '_relax_case', _make_relax_case()) | ||||
| -    EXTENSION_SUFFIXES.extend(_imp.extension_suffixes())
 | ||||
| +    EXTENSION_SUFFIXES.extend(_alternative_architectures(_imp.extension_suffixes()))
 | ||||
|      if builtin_os == 'nt': | ||||
|          SOURCE_SUFFIXES.append('.pyw') | ||||
|          if '_d.pyd' in EXTENSION_SUFFIXES: | ||||
| @@ -1635,3 +1635,39 @@ def _install(_bootstrap_module):
 | ||||
|      supported_loaders = _get_supported_file_loaders() | ||||
|      sys.path_hooks.extend([FileFinder.path_hook(*supported_loaders)]) | ||||
|      sys.meta_path.append(PathFinder) | ||||
| +
 | ||||
| +
 | ||||
| +_ARCH_MAP = {
 | ||||
| +    "-arm-linux-gnueabi.": "-arm-linux-gnueabihf.",
 | ||||
| +    "-armeb-linux-gnueabi.": "-armeb-linux-gnueabihf.",
 | ||||
| +    "-mips64-linux-gnu.": "-mips64-linux-gnuabi64.",
 | ||||
| +    "-mips64el-linux-gnu.": "-mips64el-linux-gnuabi64.",
 | ||||
| +    "-ppc-linux-gnu.": "-powerpc-linux-gnu.",
 | ||||
| +    "-ppc-linux-gnuspe.": "-powerpc-linux-gnuspe.",
 | ||||
| +    "-ppc64-linux-gnu.": "-powerpc64-linux-gnu.",
 | ||||
| +    "-ppc64le-linux-gnu.": "-powerpc64le-linux-gnu.",
 | ||||
| +    # The above, but the other way around:
 | ||||
| +    "-arm-linux-gnueabihf.": "-arm-linux-gnueabi.",
 | ||||
| +    "-armeb-linux-gnueabihf.": "-armeb-linux-gnueabi.",
 | ||||
| +    "-mips64-linux-gnuabi64.": "-mips64-linux-gnu.",
 | ||||
| +    "-mips64el-linux-gnuabi64.": "-mips64el-linux-gnu.",
 | ||||
| +    "-powerpc-linux-gnu.": "-ppc-linux-gnu.",
 | ||||
| +    "-powerpc-linux-gnuspe.": "-ppc-linux-gnuspe.",
 | ||||
| +    "-powerpc64-linux-gnu.": "-ppc64-linux-gnu.",
 | ||||
| +    "-powerpc64le-linux-gnu.": "-ppc64le-linux-gnu.",
 | ||||
| +}
 | ||||
| +
 | ||||
| +
 | ||||
| +def _alternative_architectures(suffixes):
 | ||||
| +    """Add a suffix with an alternative architecture name
 | ||||
| +    to the list of suffixes so an extension built with
 | ||||
| +    the default (upstream) setting is loadable with our Pythons
 | ||||
| +    """
 | ||||
| +
 | ||||
| +    for suffix in suffixes:
 | ||||
| +        for original, alternative in _ARCH_MAP.items():
 | ||||
| +            if original in suffix:
 | ||||
| +                suffixes.append(suffix.replace(original, alternative))
 | ||||
| +                return suffixes
 | ||||
| +
 | ||||
| +    return suffixes
 | ||||
							
								
								
									
										47
									
								
								00378-support-expat-2-4-5.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								00378-support-expat-2-4-5.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,47 @@ | ||||
| From db083095e3bdb93e4f8170d814664c482b1e94da Mon Sep 17 00:00:00 2001 | ||||
| From: rpm-build <rpm-build> | ||||
| Date: Tue, 14 Jun 2022 06:38:43 +0200 | ||||
| Subject: [PATCH] Fix test suite for Expat >= 2.4.5 | ||||
| 
 | ||||
| ---
 | ||||
|  Lib/test/test_minidom.py | 17 +++++------------ | ||||
|  1 file changed, 5 insertions(+), 12 deletions(-) | ||||
| 
 | ||||
| diff --git a/Lib/test/test_minidom.py b/Lib/test/test_minidom.py
 | ||||
| index 9762025..5f52ed1 100644
 | ||||
| --- a/Lib/test/test_minidom.py
 | ||||
| +++ b/Lib/test/test_minidom.py
 | ||||
| @@ -1149,14 +1149,10 @@ class MinidomTest(unittest.TestCase):
 | ||||
|   | ||||
|          # Verify that character decoding errors raise exceptions instead | ||||
|          # of crashing | ||||
| -        if pyexpat.version_info >= (2, 4, 5):
 | ||||
| -            self.assertRaises(ExpatError, parseString,
 | ||||
| -                    b'<fran\xe7ais></fran\xe7ais>')
 | ||||
| -            self.assertRaises(ExpatError, parseString,
 | ||||
| -                    b'<franais>Comment \xe7a va ? Tr\xe8s bien ?</franais>')
 | ||||
| -        else:
 | ||||
| -            self.assertRaises(UnicodeDecodeError, parseString,
 | ||||
| -                b'<fran\xe7ais>Comment \xe7a va ? Tr\xe8s bien ?</fran\xe7ais>')
 | ||||
| +        self.assertRaises(ExpatError, parseString,
 | ||||
| +                b'<fran\xe7ais></fran\xe7ais>')
 | ||||
| +        self.assertRaises(ExpatError, parseString,
 | ||||
| +                b'<franais>Comment \xe7a va ? Tr\xe8s bien ?</franais>')
 | ||||
|   | ||||
|          doc.unlink() | ||||
|   | ||||
| @@ -1617,10 +1613,7 @@ class MinidomTest(unittest.TestCase):
 | ||||
|          self.confirm(doc2.namespaceURI == xml.dom.EMPTY_NAMESPACE) | ||||
|   | ||||
|      def testExceptionOnSpacesInXMLNSValue(self): | ||||
| -        if pyexpat.version_info >= (2, 4, 5):
 | ||||
| -            context = self.assertRaisesRegex(ExpatError, 'syntax error')
 | ||||
| -        else:
 | ||||
| -            context = self.assertRaisesRegex(ValueError, 'Unsupported syntax')
 | ||||
| +        context = self.assertRaisesRegex(ExpatError, 'syntax error')
 | ||||
|   | ||||
|          with context: | ||||
|              parseString('<element xmlns:abc="http:abc.com/de f g/hi/j k"><abc:foo /></element>') | ||||
| -- 
 | ||||
| 2.35.3 | ||||
| 
 | ||||
							
								
								
									
										150
									
								
								00382-cve-2015-20107.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										150
									
								
								00382-cve-2015-20107.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,150 @@ | ||||
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | ||||
| From: Petr Viktorin <encukou@gmail.com> | ||||
| Date: Fri, 3 Jun 2022 11:43:35 +0200 | ||||
| Subject: [PATCH] 00382: CVE-2015-20107 | ||||
| 
 | ||||
| Make mailcap refuse to match unsafe filenames/types/params (GH-91993) | ||||
| 
 | ||||
| Upstream: https://github.com/python/cpython/issues/68966 | ||||
| 
 | ||||
| Tracker bug: https://bugzilla.redhat.com/show_bug.cgi?id=2075390 | ||||
| ---
 | ||||
|  Doc/library/mailcap.rst                       | 12 +++++++++ | ||||
|  Lib/mailcap.py                                | 26 +++++++++++++++++-- | ||||
|  Lib/test/test_mailcap.py                      |  8 ++++-- | ||||
|  ...2-04-27-18-25-30.gh-issue-68966.gjS8zs.rst |  4 +++ | ||||
|  4 files changed, 46 insertions(+), 4 deletions(-) | ||||
|  create mode 100644 Misc/NEWS.d/next/Security/2022-04-27-18-25-30.gh-issue-68966.gjS8zs.rst | ||||
| 
 | ||||
| diff --git a/Doc/library/mailcap.rst b/Doc/library/mailcap.rst
 | ||||
| index a22b5b9c9e..7aa3380fec 100644
 | ||||
| --- a/Doc/library/mailcap.rst
 | ||||
| +++ b/Doc/library/mailcap.rst
 | ||||
| @@ -60,6 +60,18 @@ standard.  However, mailcap files are supported on most Unix systems.
 | ||||
|     use) to determine whether or not the mailcap line applies.  :func:`findmatch` | ||||
|     will automatically check such conditions and skip the entry if the check fails. | ||||
|   | ||||
| +   .. versionchanged:: 3.11
 | ||||
| +
 | ||||
| +      To prevent security issues with shell metacharacters (symbols that have
 | ||||
| +      special effects in a shell command line), ``findmatch`` will refuse
 | ||||
| +      to inject ASCII characters other than alphanumerics and ``@+=:,./-_``
 | ||||
| +      into the returned command line.
 | ||||
| +
 | ||||
| +      If a disallowed character appears in *filename*, ``findmatch`` will always
 | ||||
| +      return ``(None, None)`` as if no entry was found.
 | ||||
| +      If such a character appears elsewhere (a value in *plist* or in *MIMEtype*),
 | ||||
| +      ``findmatch`` will ignore all mailcap entries which use that value.
 | ||||
| +      A :mod:`warning <warnings>` will be raised in either case.
 | ||||
|   | ||||
|  .. function:: getcaps() | ||||
|   | ||||
| diff --git a/Lib/mailcap.py b/Lib/mailcap.py
 | ||||
| index ae416a8e9f..444c6408b5 100644
 | ||||
| --- a/Lib/mailcap.py
 | ||||
| +++ b/Lib/mailcap.py
 | ||||
| @@ -2,6 +2,7 @@
 | ||||
|   | ||||
|  import os | ||||
|  import warnings | ||||
| +import re
 | ||||
|   | ||||
|  __all__ = ["getcaps","findmatch"] | ||||
|   | ||||
| @@ -13,6 +14,11 @@ def lineno_sort_key(entry):
 | ||||
|      else: | ||||
|          return 1, 0 | ||||
|   | ||||
| +_find_unsafe = re.compile(r'[^\xa1-\U0010FFFF\w@+=:,./-]').search
 | ||||
| +
 | ||||
| +class UnsafeMailcapInput(Warning):
 | ||||
| +    """Warning raised when refusing unsafe input"""
 | ||||
| +
 | ||||
|   | ||||
|  # Part 1: top-level interface. | ||||
|   | ||||
| @@ -165,15 +171,22 @@ def findmatch(caps, MIMEtype, key='view', filename="/dev/null", plist=[]):
 | ||||
|      entry to use. | ||||
|   | ||||
|      """ | ||||
| +    if _find_unsafe(filename):
 | ||||
| +        msg = "Refusing to use mailcap with filename %r. Use a safe temporary filename." % (filename,)
 | ||||
| +        warnings.warn(msg, UnsafeMailcapInput)
 | ||||
| +        return None, None
 | ||||
|      entries = lookup(caps, MIMEtype, key) | ||||
|      # XXX This code should somehow check for the needsterminal flag. | ||||
|      for e in entries: | ||||
|          if 'test' in e: | ||||
|              test = subst(e['test'], filename, plist) | ||||
| +            if test is None:
 | ||||
| +                continue
 | ||||
|              if test and os.system(test) != 0: | ||||
|                  continue | ||||
|          command = subst(e[key], MIMEtype, filename, plist) | ||||
| -        return command, e
 | ||||
| +        if command is not None:
 | ||||
| +            return command, e
 | ||||
|      return None, None | ||||
|   | ||||
|  def lookup(caps, MIMEtype, key=None): | ||||
| @@ -206,6 +219,10 @@ def subst(field, MIMEtype, filename, plist=[]):
 | ||||
|              elif c == 's': | ||||
|                  res = res + filename | ||||
|              elif c == 't': | ||||
| +                if _find_unsafe(MIMEtype):
 | ||||
| +                    msg = "Refusing to substitute MIME type %r into a shell command." % (MIMEtype,)
 | ||||
| +                    warnings.warn(msg, UnsafeMailcapInput)
 | ||||
| +                    return None
 | ||||
|                  res = res + MIMEtype | ||||
|              elif c == '{': | ||||
|                  start = i | ||||
| @@ -213,7 +230,12 @@ def subst(field, MIMEtype, filename, plist=[]):
 | ||||
|                      i = i+1 | ||||
|                  name = field[start:i] | ||||
|                  i = i+1 | ||||
| -                res = res + findparam(name, plist)
 | ||||
| +                param = findparam(name, plist)
 | ||||
| +                if _find_unsafe(param):
 | ||||
| +                    msg = "Refusing to substitute parameter %r (%s) into a shell command" % (param, name)
 | ||||
| +                    warnings.warn(msg, UnsafeMailcapInput)
 | ||||
| +                    return None
 | ||||
| +                res = res + param
 | ||||
|              # XXX To do: | ||||
|              # %n == number of parts if type is multipart/* | ||||
|              # %F == list of alternating type and filename for parts | ||||
| diff --git a/Lib/test/test_mailcap.py b/Lib/test/test_mailcap.py
 | ||||
| index c08423c670..920283d9a2 100644
 | ||||
| --- a/Lib/test/test_mailcap.py
 | ||||
| +++ b/Lib/test/test_mailcap.py
 | ||||
| @@ -121,7 +121,8 @@ class HelperFunctionTest(unittest.TestCase):
 | ||||
|              (["", "audio/*", "foo.txt"], ""), | ||||
|              (["echo foo", "audio/*", "foo.txt"], "echo foo"), | ||||
|              (["echo %s", "audio/*", "foo.txt"], "echo foo.txt"), | ||||
| -            (["echo %t", "audio/*", "foo.txt"], "echo audio/*"),
 | ||||
| +            (["echo %t", "audio/*", "foo.txt"], None),
 | ||||
| +            (["echo %t", "audio/wav", "foo.txt"], "echo audio/wav"),
 | ||||
|              (["echo \\%t", "audio/*", "foo.txt"], "echo %t"), | ||||
|              (["echo foo", "audio/*", "foo.txt", plist], "echo foo"), | ||||
|              (["echo %{total}", "audio/*", "foo.txt", plist], "echo 3") | ||||
| @@ -205,7 +206,10 @@ class FindmatchTest(unittest.TestCase):
 | ||||
|               ('"An audio fragment"', audio_basic_entry)), | ||||
|              ([c, "audio/*"], | ||||
|               {"filename": fname}, | ||||
| -             ("/usr/local/bin/showaudio audio/*", audio_entry)),
 | ||||
| +             (None, None)),
 | ||||
| +            ([c, "audio/wav"],
 | ||||
| +             {"filename": fname},
 | ||||
| +             ("/usr/local/bin/showaudio audio/wav", audio_entry)),
 | ||||
|              ([c, "message/external-body"], | ||||
|               {"plist": plist}, | ||||
|               ("showexternal /dev/null default john python.org     /tmp foo bar", message_entry)) | ||||
| diff --git a/Misc/NEWS.d/next/Security/2022-04-27-18-25-30.gh-issue-68966.gjS8zs.rst b/Misc/NEWS.d/next/Security/2022-04-27-18-25-30.gh-issue-68966.gjS8zs.rst
 | ||||
| new file mode 100644 | ||||
| index 0000000000..da81a1f699
 | ||||
| --- /dev/null
 | ||||
| +++ b/Misc/NEWS.d/next/Security/2022-04-27-18-25-30.gh-issue-68966.gjS8zs.rst
 | ||||
| @@ -0,0 +1,4 @@
 | ||||
| +The deprecated mailcap module now refuses to inject unsafe text (filenames,
 | ||||
| +MIME types, parameters) into shell commands. Instead of using such text, it
 | ||||
| +will warn and act as if a match was not found (or for test commands, as if
 | ||||
| +the test failed).
 | ||||
							
								
								
									
										16
									
								
								Python-3.9.13.tar.xz.asc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								Python-3.9.13.tar.xz.asc
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,16 @@ | ||||
| -----BEGIN PGP SIGNATURE----- | ||||
| 
 | ||||
| iQIzBAABCgAdFiEE4/8oOcBIslwITevpsmmV4xAlBWgFAmKDr+sACgkQsmmV4xAl | ||||
| BWib8A/+I+Gm2Gjf1lTFasrDIQb68gus7q9MjgjWG7HRY64gGqDBq6VcNrhVg+3g | ||||
| lGL0Xr6QHkFCIJVlobDAL4UgmNkO0+I2fNhUybKPGT6BOVa4IXHkuWlJX0OBRjY+ | ||||
| uOw7nCEyLzEA/FbwZXb+0PKJm74s3opjUbu9/9uY7QIqWIiD77UfQ61SDsnRLaQW | ||||
| oEULPWFNLbdpMhTn7M/WVUwcxbyrCzjeFJ8rDiEbux3C1AhagTW49NTxOVW722yS | ||||
| 3mzjuYeyfXBIfaaU9ZHW6Z7B1hbuNVF0AvOcI3nKFUjHYs5hhchM7QnZhdFG6mMN | ||||
| 7REmBhssGkzWBtsWVbyChHhgVIqv81qUv6tywYMWaZtKfmrgzx2UNg9rx609c5gs | ||||
| 1dzXWBrh2PFWLUf8U1noSOEz/Q6/fbgdHFj4AUsr+c3zr74FNABbH5VOHS6QP79X | ||||
| ic0a9+zBirrSVnLlsHkEO+aXju9ITcU/DUxPIUZxgmOImL4Vx1lsjYaw00csMzA3 | ||||
| YItkoMwp4Hi7+Tvr/jGaTpKpmW+r00LyQfTfQmst7STDVY9EjlC3Mk2hzqgtFx5Z | ||||
| hzb4EtMQNSjwPCvSXVWFFZWsLRu70n81uWfnXRBX7tRAWZoxC44jiOGjEhTJwzs4 | ||||
| sZAhimk17t3agM0Jf0fTFMPly0mVLQMjbE7OK8GIgv/q4O5R5lc= | ||||
| =RYbS | ||||
| -----END PGP SIGNATURE----- | ||||
							
								
								
									
										55
									
								
								check-pyc-timestamps.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								check-pyc-timestamps.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | ||||
| """Checks if all *.pyc files have later mtime than their *.py files.""" | ||||
| 
 | ||||
| import os | ||||
| import sys | ||||
| from importlib.util import cache_from_source | ||||
| from pathlib import Path | ||||
| 
 | ||||
| 
 | ||||
| RPM_BUILD_ROOT = os.environ.get('RPM_BUILD_ROOT', '') | ||||
| 
 | ||||
| # ...cpython-3X.pyc | ||||
| # ...cpython-3X.opt-1.pyc | ||||
| # ...cpython-3X.opt-2.pyc | ||||
| LEVELS = (None, 1, 2) | ||||
| 
 | ||||
| # list of globs of test and other files that we expect not to have bytecode | ||||
| not_compiled = [ | ||||
|     '/usr/bin/*', | ||||
|     '*/test/bad_coding.py', | ||||
|     '*/test/bad_coding2.py', | ||||
|     '*/test/badsyntax_*.py', | ||||
|     '*/lib2to3/tests/data/bom.py', | ||||
|     '*/lib2to3/tests/data/crlf.py', | ||||
|     '*/lib2to3/tests/data/different_encoding.py', | ||||
|     '*/lib2to3/tests/data/false_encoding.py', | ||||
|     '*/lib2to3/tests/data/py2_test_grammar.py', | ||||
|     '*.debug-gdb.py', | ||||
| ] | ||||
| 
 | ||||
| 
 | ||||
| def bytecode_expected(path): | ||||
|     path = Path(path[len(RPM_BUILD_ROOT):]) | ||||
|     for glob in not_compiled: | ||||
|         if path.match(glob): | ||||
|             return False | ||||
|     return True | ||||
| 
 | ||||
| 
 | ||||
| failed = 0 | ||||
| compiled = (path for path in sys.argv[1:] if bytecode_expected(path)) | ||||
| for path in compiled: | ||||
|     to_check = (cache_from_source(path, optimization=opt) for opt in LEVELS) | ||||
|     f_mtime = os.path.getmtime(path) | ||||
|     for pyc in to_check: | ||||
|         c_mtime = os.path.getmtime(pyc) | ||||
|         if c_mtime < f_mtime: | ||||
|             print('Failed bytecompilation timestamps check: ' | ||||
|                   f'Bytecode file {pyc} is older than source file {path}', | ||||
|                   file=sys.stderr) | ||||
|             failed += 1 | ||||
| 
 | ||||
| if failed: | ||||
|     print(f'\n{failed} files failed bytecompilation timestamps check.', | ||||
|           file=sys.stderr) | ||||
|     sys.exit(1) | ||||
							
								
								
									
										35
									
								
								idle3.appdata.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								idle3.appdata.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,35 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| 
 | ||||
| <!-- Copyright 2017 Zbigniew Jędrzejewski-Szmek --> | ||||
| <application> | ||||
|   <id type="desktop">idle3.desktop</id> | ||||
|   <name>IDLE3</name> | ||||
|   <metadata_licence>CC0</metadata_licence> | ||||
|   <project_license>Python-2.0</project_license> | ||||
|   <summary>Python 3 Integrated Development and Learning Environment</summary> | ||||
|   <description> | ||||
|     <p> | ||||
|       IDLE is Python’s Integrated Development and Learning Environment. | ||||
|       The GUI is uniform between Windows, Unix, and Mac OS X. | ||||
|       IDLE provides an easy way to start writing, running, and debugging | ||||
|       Python code. | ||||
|     </p> | ||||
|     <p> | ||||
|       IDLE is written in pure Python, and uses the tkinter GUI toolkit. | ||||
|       It provides: | ||||
|     </p> | ||||
|     <ul> | ||||
|        <li>a Python shell window (interactive interpreter) with colorizing of code input, output, and error messages,</li> | ||||
|        <li>a multi-window text editor with multiple undo, Python colorizing, smart indent, call tips, auto completion, and other features,</li> | ||||
|        <li>search within any window, replace within editor windows, and search through multiple files (grep),</li> | ||||
|        <li>a debugger with persistent breakpoints, stepping, and viewing of global and local namespaces.</li> | ||||
|     </ul> | ||||
|   </description> | ||||
|   <url type="homepage">https://docs.python.org/3/library/idle.html</url> | ||||
|   <screenshots> | ||||
|     <screenshot type="default">http://in.waw.pl/~zbyszek/fedora/idle3-appdata/idle3-main-window.png</screenshot> | ||||
|     <screenshot>http://in.waw.pl/~zbyszek/fedora/idle3-appdata/idle3-class-browser.png</screenshot> | ||||
|     <screenshot>http://in.waw.pl/~zbyszek/fedora/idle3-appdata/idle3-code-viewer.png</screenshot> | ||||
|   </screenshots> | ||||
|   <update_contact>zbyszek@in.waw.pl</update_contact> | ||||
| </application> | ||||
							
								
								
									
										11
									
								
								idle3.desktop
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								idle3.desktop
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| [Desktop Entry] | ||||
| Version=1.0 | ||||
| Name=IDLE 3 | ||||
| Comment=Python 3 Integrated Development and Learning Environment | ||||
| Exec=idle3 %F | ||||
| TryExec=idle3 | ||||
| Terminal=false | ||||
| Type=Application | ||||
| Icon=idle3 | ||||
| Categories=Development;IDE; | ||||
| MimeType=text/x-python; | ||||
							
								
								
									
										32
									
								
								macros.python39
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								macros.python39
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,32 @@ | ||||
| %__python3 /usr/bin/python3.9 | ||||
| %python3_pkgversion 39 | ||||
| %__pytest /usr/bin/pytest-3.9 | ||||
| 
 | ||||
| # The following are macros from macros.python3 in Fedora that are newer/different than those in the python3-rpm-macros package in RHEL. | ||||
| # These macros overwrite/supercede some of the macros in the python3-rpm-macros package in RHEL. | ||||
| 
 | ||||
| %python3_version %(%{__python3} -Ic "import sys; sys.stdout.write('{0.major}.{0.minor}'.format(sys.version_info))") | ||||
| %python3_version_nodots %(%{__python3} -Ic "import sys; sys.stdout.write('{0.major}{0.minor}'.format(sys.version_info))") | ||||
| 
 | ||||
| %py3_install() %{expand:\\\ | ||||
|   CFLAGS="${CFLAGS:-${RPM_OPT_FLAGS}}" LDFLAGS="${LDFLAGS:-${RPM_LD_FLAGS}}"\\\ | ||||
|   %{__python3} %{py_setup} %{?py_setup_args} install -O1 --skip-build --root %{buildroot} %{?*} | ||||
|   rm -rfv %{buildroot}%{_bindir}/__pycache__ | ||||
| } | ||||
| 
 | ||||
| %py3_install_egg() %{expand:\\\ | ||||
|   mkdir -p %{buildroot}%{python3_sitelib} | ||||
|   CFLAGS="%{optflags}" %{__python3} -m easy_install -m --prefix %{buildroot}%{_prefix} -Z dist/*-py%{python3_version}.egg %{?*} | ||||
|   rm -rfv %{buildroot}%{_bindir}/__pycache__ | ||||
| } | ||||
| 
 | ||||
| %py3_install_wheel() %{expand:\\\ | ||||
|   CFLAGS="%{optflags}" %{__python3} -m pip install -I dist/%{1} --root %{buildroot} --no-deps --no-index --no-warn-script-location | ||||
|   rm -rfv %{buildroot}%{_bindir}/__pycache__ | ||||
|   for distinfo in %{buildroot}%{python3_sitelib}/*.dist-info %{buildroot}%{python3_sitearch}/*.dist-info; do | ||||
|     if [ -f ${distinfo}/direct_url.json ]; then | ||||
|       rm -fv ${distinfo}/direct_url.json | ||||
|       sed -i '/direct_url.json/d' ${distinfo}/RECORD | ||||
|     fi | ||||
|   done | ||||
| } | ||||
							
								
								
									
										11542
									
								
								pubkeys.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11542
									
								
								pubkeys.txt
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										2185
									
								
								python39.spec
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2185
									
								
								python39.spec
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	Block a user