restore python distdeps generators by adding pythondistdeps.py and fileattrs/python* [release 4.17.1.1-5mamba;Sun Sep 11 2022]
This commit is contained in:
parent
22259b2ad2
commit
903a1efdaf
27
python.attr
Normal file
27
python.attr
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
%__python_provides() %{lua:
|
||||||
|
-- Match buildroot/payload paths of the form
|
||||||
|
-- /PATH/OF/BUILDROOT/usr/bin/pythonMAJOR.MINOR
|
||||||
|
-- generating a line of the form
|
||||||
|
-- python(abi) = MAJOR.MINOR
|
||||||
|
-- (Don't match against -config tools e.g. /usr/bin/python2.6-config)
|
||||||
|
local path = rpm.expand('%1')
|
||||||
|
if path:match('/usr/bin/python%d+%.%d+$') then
|
||||||
|
local provides = path:gsub('.*/usr/bin/python(%d+%.%d+)', 'python(abi) = %1')
|
||||||
|
print(provides)
|
||||||
|
end
|
||||||
|
}
|
||||||
|
|
||||||
|
%__python_requires() %{lua:
|
||||||
|
-- Match buildroot paths of the form
|
||||||
|
-- /PATH/OF/BUILDROOT/usr/lib/pythonMAJOR.MINOR/ and
|
||||||
|
-- /PATH/OF/BUILDROOT/usr/lib64/pythonMAJOR.MINOR/
|
||||||
|
-- generating a line of the form:
|
||||||
|
-- python(abi) = MAJOR.MINOR
|
||||||
|
local path = rpm.expand('%1')
|
||||||
|
if path:match('/usr/lib%d*/python%d+%.%d+/.*') then
|
||||||
|
local requires = path:gsub('.*/usr/lib%d*/python(%d+%.%d+)/.*', 'python(abi) = %1')
|
||||||
|
print(requires)
|
||||||
|
end
|
||||||
|
}
|
||||||
|
|
||||||
|
%__python_path ^((%{_prefix}/lib(64)?/python[[:digit:]]+\\.[[:digit:]]+/.*\\.(py[oc]?|so))|(%{_bindir}/python[[:digit:]]+\\.[[:digit:]]+))$
|
3
pythondist.attr
Normal file
3
pythondist.attr
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
%__pythondist_provides %{_rpmconfigdir}/pythondistdeps.py --provides --majorver-provides
|
||||||
|
%__pythondist_requires %{_rpmconfigdir}/pythondistdeps.py --requires
|
||||||
|
%__pythondist_path /lib(64)?/python[[:digit:]]\\.[[:digit:]]+/site-packages/[^/]+\\.(dist-info|egg-info|egg-link)$
|
428
pythondistdeps.py
Normal file
428
pythondistdeps.py
Normal file
@ -0,0 +1,428 @@
|
|||||||
|
#!/usr/bin/python3
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# Copyright 2010 Per Øyvind Karlsen <proyvind@moondrake.org>
|
||||||
|
# Copyright 2015 Neal Gompa <ngompa13@gmail.com>
|
||||||
|
# Copyright 2020 SUSE LLC
|
||||||
|
#
|
||||||
|
# This program is free software. It may be redistributed and/or modified under
|
||||||
|
# the terms of the LGPL version 2.1 (or later).
|
||||||
|
#
|
||||||
|
# RPM python dependency generator, using .egg-info/.egg-link/.dist-info data
|
||||||
|
#
|
||||||
|
|
||||||
|
# Please know:
|
||||||
|
# - Notes from an attempted rewrite from pkg_resources to importlib.metadata in
|
||||||
|
# 2020 can be found in the message of the commit that added this line.
|
||||||
|
|
||||||
|
from __future__ import print_function
|
||||||
|
import argparse
|
||||||
|
from os.path import basename, dirname, isdir, sep
|
||||||
|
from sys import argv, stdin, version
|
||||||
|
from distutils.sysconfig import get_python_lib
|
||||||
|
from warnings import warn
|
||||||
|
|
||||||
|
|
||||||
|
class RpmVersion():
|
||||||
|
def __init__(self, version_id):
|
||||||
|
version = parse_version(version_id)
|
||||||
|
if isinstance(version._version, str):
|
||||||
|
self.version = version._version
|
||||||
|
else:
|
||||||
|
self.epoch = version._version.epoch
|
||||||
|
self.version = list(version._version.release)
|
||||||
|
self.pre = version._version.pre
|
||||||
|
self.dev = version._version.dev
|
||||||
|
self.post = version._version.post
|
||||||
|
|
||||||
|
def increment(self):
|
||||||
|
self.version[-1] += 1
|
||||||
|
self.pre = None
|
||||||
|
self.dev = None
|
||||||
|
self.post = None
|
||||||
|
return self
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
if isinstance(self.version, str):
|
||||||
|
return self.version
|
||||||
|
if self.epoch:
|
||||||
|
rpm_epoch = str(self.epoch) + ':'
|
||||||
|
else:
|
||||||
|
rpm_epoch = ''
|
||||||
|
while len(self.version) > 1 and self.version[-1] == 0:
|
||||||
|
self.version.pop()
|
||||||
|
rpm_version = '.'.join(str(x) for x in self.version)
|
||||||
|
if self.pre:
|
||||||
|
rpm_suffix = '~{}'.format(''.join(str(x) for x in self.pre))
|
||||||
|
elif self.dev:
|
||||||
|
rpm_suffix = '~~{}'.format(''.join(str(x) for x in self.dev))
|
||||||
|
elif self.post:
|
||||||
|
rpm_suffix = '^post{}'.format(self.post[1])
|
||||||
|
else:
|
||||||
|
rpm_suffix = ''
|
||||||
|
return '{}{}{}'.format(rpm_epoch, rpm_version, rpm_suffix)
|
||||||
|
|
||||||
|
|
||||||
|
def convert_compatible(name, operator, version_id):
|
||||||
|
if version_id.endswith('.*'):
|
||||||
|
print('Invalid requirement: {} {} {}'.format(name, operator, version_id))
|
||||||
|
exit(65) # os.EX_DATAERR
|
||||||
|
version = RpmVersion(version_id)
|
||||||
|
if len(version.version) == 1:
|
||||||
|
print('Invalid requirement: {} {} {}'.format(name, operator, version_id))
|
||||||
|
exit(65) # os.EX_DATAERR
|
||||||
|
upper_version = RpmVersion(version_id)
|
||||||
|
upper_version.version.pop()
|
||||||
|
upper_version.increment()
|
||||||
|
return '({} >= {} with {} < {})'.format(
|
||||||
|
name, version, name, upper_version)
|
||||||
|
|
||||||
|
|
||||||
|
def convert_equal(name, operator, version_id):
|
||||||
|
if version_id.endswith('.*'):
|
||||||
|
version_id = version_id[:-2] + '.0'
|
||||||
|
return convert_compatible(name, '~=', version_id)
|
||||||
|
version = RpmVersion(version_id)
|
||||||
|
return '{} = {}'.format(name, version)
|
||||||
|
|
||||||
|
|
||||||
|
def convert_arbitrary_equal(name, operator, version_id):
|
||||||
|
if version_id.endswith('.*'):
|
||||||
|
print('Invalid requirement: {} {} {}'.format(name, operator, version_id))
|
||||||
|
exit(65) # os.EX_DATAERR
|
||||||
|
version = RpmVersion(version_id)
|
||||||
|
return '{} = {}'.format(name, version)
|
||||||
|
|
||||||
|
|
||||||
|
def convert_not_equal(name, operator, version_id):
|
||||||
|
if version_id.endswith('.*'):
|
||||||
|
version_id = version_id[:-2]
|
||||||
|
version = RpmVersion(version_id)
|
||||||
|
lower_version = RpmVersion(version_id).increment()
|
||||||
|
else:
|
||||||
|
version = RpmVersion(version_id)
|
||||||
|
lower_version = version
|
||||||
|
return '({} < {} or {} > {})'.format(
|
||||||
|
name, version, name, lower_version)
|
||||||
|
|
||||||
|
|
||||||
|
def convert_ordered(name, operator, version_id):
|
||||||
|
if version_id.endswith('.*'):
|
||||||
|
# PEP 440 does not define semantics for prefix matching
|
||||||
|
# with ordered comparisons
|
||||||
|
version_id = version_id[:-2]
|
||||||
|
version = RpmVersion(version_id)
|
||||||
|
if operator == '>':
|
||||||
|
# distutils will allow a prefix match with '>'
|
||||||
|
operator = '>='
|
||||||
|
if operator == '<=':
|
||||||
|
# distutils will not allow a prefix match with '<='
|
||||||
|
operator = '<'
|
||||||
|
else:
|
||||||
|
version = RpmVersion(version_id)
|
||||||
|
return '{} {} {}'.format(name, operator, version)
|
||||||
|
|
||||||
|
|
||||||
|
OPERATORS = {'~=': convert_compatible,
|
||||||
|
'==': convert_equal,
|
||||||
|
'===': convert_arbitrary_equal,
|
||||||
|
'!=': convert_not_equal,
|
||||||
|
'<=': convert_ordered,
|
||||||
|
'<': convert_ordered,
|
||||||
|
'>=': convert_ordered,
|
||||||
|
'>': convert_ordered}
|
||||||
|
|
||||||
|
|
||||||
|
def convert(name, operator, version_id):
|
||||||
|
try:
|
||||||
|
return OPERATORS[operator](name, operator, version_id)
|
||||||
|
except Exception as exc:
|
||||||
|
raise RuntimeError("Cannot process Python package version `{}` for name `{}`".
|
||||||
|
format(version_id, name)) from exc
|
||||||
|
|
||||||
|
|
||||||
|
def normalize_name(name):
|
||||||
|
"""https://www.python.org/dev/peps/pep-0503/#normalized-names"""
|
||||||
|
import re
|
||||||
|
return re.sub(r'[-_.]+', '-', name).lower()
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
"""To allow this script to be importable (and its classes/functions
|
||||||
|
reused), actions are performed only when run as a main script."""
|
||||||
|
|
||||||
|
parser = argparse.ArgumentParser(prog=argv[0])
|
||||||
|
group = parser.add_mutually_exclusive_group(required=True)
|
||||||
|
group.add_argument('-P', '--provides', action='store_true', help='Print Provides')
|
||||||
|
group.add_argument('-R', '--requires', action='store_true', help='Print Requires')
|
||||||
|
group.add_argument('-r', '--recommends', action='store_true', help='Print Recommends')
|
||||||
|
group.add_argument('-C', '--conflicts', action='store_true', help='Print Conflicts')
|
||||||
|
group.add_argument('-E', '--extras', action='store_true', help='Print Extras')
|
||||||
|
group_majorver = parser.add_mutually_exclusive_group()
|
||||||
|
group_majorver.add_argument('-M', '--majorver-provides', action='store_true', help='Print extra Provides with Python major version only')
|
||||||
|
group_majorver.add_argument('--majorver-provides-versions', action='append',
|
||||||
|
help='Print extra Provides with Python major version only for listed '
|
||||||
|
'Python VERSIONS (appended or comma separated without spaces, e.g. 2.7,3.9)')
|
||||||
|
parser.add_argument('-m', '--majorver-only', action='store_true', help='Print Provides/Requires with Python major version only')
|
||||||
|
parser.add_argument('-n', '--normalized-names-format', action='store',
|
||||||
|
default="legacy-dots", choices=["pep503", "legacy-dots"],
|
||||||
|
help='Format of normalized names according to pep503 or legacy format that allows dots [default]')
|
||||||
|
parser.add_argument('--normalized-names-provide-both', action='store_true',
|
||||||
|
help='Provide both `pep503` and `legacy-dots` format of normalized names (useful for a transition period)')
|
||||||
|
parser.add_argument('-L', '--legacy-provides', action='store_true', help='Print extra legacy pythonegg Provides')
|
||||||
|
parser.add_argument('-l', '--legacy', action='store_true', help='Print legacy pythonegg Provides/Requires instead')
|
||||||
|
parser.add_argument('files', nargs=argparse.REMAINDER)
|
||||||
|
args = parser.parse_args()
|
||||||
|
|
||||||
|
py_abi = args.requires
|
||||||
|
py_deps = {}
|
||||||
|
|
||||||
|
if args.majorver_provides_versions:
|
||||||
|
# Go through the arguments (can be specified multiple times),
|
||||||
|
# and parse individual versions (can be comma-separated)
|
||||||
|
args.majorver_provides_versions = [v for vstring in args.majorver_provides_versions
|
||||||
|
for v in vstring.split(",")]
|
||||||
|
|
||||||
|
# If normalized_names_require_pep503 is True we require the pep503
|
||||||
|
# normalized name, if it is False we provide the legacy normalized name
|
||||||
|
normalized_names_require_pep503 = args.normalized_names_format == "pep503"
|
||||||
|
|
||||||
|
# If normalized_names_provide_pep503/legacy is True we provide the
|
||||||
|
# pep503/legacy normalized name, if it is False we don't
|
||||||
|
normalized_names_provide_pep503 = \
|
||||||
|
args.normalized_names_format == "pep503" or args.normalized_names_provide_both
|
||||||
|
normalized_names_provide_legacy = \
|
||||||
|
args.normalized_names_format == "legacy-dots" or args.normalized_names_provide_both
|
||||||
|
|
||||||
|
# At least one type of normalization must be provided
|
||||||
|
assert normalized_names_provide_pep503 or normalized_names_provide_legacy
|
||||||
|
|
||||||
|
for f in (args.files or stdin.readlines()):
|
||||||
|
f = f.strip()
|
||||||
|
lower = f.lower()
|
||||||
|
name = 'python(abi)'
|
||||||
|
# add dependency based on path, versioned if within versioned python directory
|
||||||
|
if py_abi and (lower.endswith('.py') or lower.endswith('.pyc') or lower.endswith('.pyo')):
|
||||||
|
if name not in py_deps:
|
||||||
|
py_deps[name] = []
|
||||||
|
purelib = get_python_lib(standard_lib=0, plat_specific=0).split(version[:3])[0]
|
||||||
|
platlib = get_python_lib(standard_lib=0, plat_specific=1).split(version[:3])[0]
|
||||||
|
for lib in (purelib, platlib):
|
||||||
|
if lib in f:
|
||||||
|
spec = ('==', f.split(lib)[1].split(sep)[0])
|
||||||
|
if spec not in py_deps[name]:
|
||||||
|
py_deps[name].append(spec)
|
||||||
|
|
||||||
|
# XXX: hack to workaround RPM internal dependency generator not passing directories
|
||||||
|
lower_dir = dirname(lower)
|
||||||
|
if lower_dir.endswith('.egg') or \
|
||||||
|
lower_dir.endswith('.egg-info') or \
|
||||||
|
lower_dir.endswith('.dist-info'):
|
||||||
|
lower = lower_dir
|
||||||
|
f = dirname(f)
|
||||||
|
# Determine provide, requires, conflicts & recommends based on egg/dist metadata
|
||||||
|
if lower.endswith('.egg') or \
|
||||||
|
lower.endswith('.egg-info') or \
|
||||||
|
lower.endswith('.dist-info'):
|
||||||
|
# This import is very slow, so only do it if needed
|
||||||
|
# - Notes from an attempted rewrite from pkg_resources to
|
||||||
|
# importlib.metadata in 2020 can be found in the message of
|
||||||
|
# the commit that added this line.
|
||||||
|
from pkg_resources import Distribution, FileMetadata, PathMetadata, Requirement, parse_version
|
||||||
|
dist_name = basename(f)
|
||||||
|
if isdir(f):
|
||||||
|
path_item = dirname(f)
|
||||||
|
metadata = PathMetadata(path_item, f)
|
||||||
|
else:
|
||||||
|
path_item = f
|
||||||
|
metadata = FileMetadata(f)
|
||||||
|
dist = Distribution.from_location(path_item, dist_name, metadata)
|
||||||
|
# Check if py_version is defined in the metadata file/directory name
|
||||||
|
if not dist.py_version:
|
||||||
|
# Try to parse the Python version from the path the metadata
|
||||||
|
# resides at (e.g. /usr/lib/pythonX.Y/site-packages/...)
|
||||||
|
import re
|
||||||
|
res = re.search(r"/python(?P<pyver>\d+\.\d+)/", path_item)
|
||||||
|
if res:
|
||||||
|
dist.py_version = res.group('pyver')
|
||||||
|
else:
|
||||||
|
warn("Version for {!r} has not been found".format(dist), RuntimeWarning)
|
||||||
|
continue
|
||||||
|
|
||||||
|
# pkg_resources use platform.python_version to evaluate if a
|
||||||
|
# dependency is relevant based on environment markers [1],
|
||||||
|
# e.g. requirement `argparse;python_version<"2.7"`
|
||||||
|
#
|
||||||
|
# Since we're running this script on one Python version while
|
||||||
|
# possibly evaluating packages for different versions, we mock the
|
||||||
|
# platform.python_version function. Discussed upstream [2].
|
||||||
|
#
|
||||||
|
# [1] https://www.python.org/dev/peps/pep-0508/#environment-markers
|
||||||
|
# [2] https://github.com/pypa/setuptools/pull/1275
|
||||||
|
import platform
|
||||||
|
platform.python_version = lambda: dist.py_version
|
||||||
|
platform.python_version_tuple = lambda: tuple(dist.py_version.split('.'))
|
||||||
|
|
||||||
|
# This is the PEP 503 normalized name.
|
||||||
|
# It does also convert dots to dashes, unlike dist.key.
|
||||||
|
# See https://bugzilla.redhat.com/show_bug.cgi?id=1791530
|
||||||
|
normalized_name = normalize_name(dist.project_name)
|
||||||
|
|
||||||
|
if args.majorver_provides or args.majorver_provides_versions or \
|
||||||
|
args.majorver_only or args.legacy_provides or args.legacy:
|
||||||
|
# Get the Python major version
|
||||||
|
pyver_major = dist.py_version.split('.')[0]
|
||||||
|
if args.provides:
|
||||||
|
# If egg/dist metadata says package name is python, we provide python(abi)
|
||||||
|
if dist.key == 'python':
|
||||||
|
name = 'python(abi)'
|
||||||
|
if name not in py_deps:
|
||||||
|
py_deps[name] = []
|
||||||
|
py_deps[name].append(('==', dist.py_version))
|
||||||
|
if not args.legacy or not args.majorver_only:
|
||||||
|
if normalized_names_provide_legacy:
|
||||||
|
name = 'python{}dist({})'.format(dist.py_version, dist.key)
|
||||||
|
if name not in py_deps:
|
||||||
|
py_deps[name] = []
|
||||||
|
if normalized_names_provide_pep503:
|
||||||
|
name_ = 'python{}dist({})'.format(dist.py_version, normalized_name)
|
||||||
|
if name_ not in py_deps:
|
||||||
|
py_deps[name_] = []
|
||||||
|
if args.majorver_provides or args.majorver_only or \
|
||||||
|
(args.majorver_provides_versions and dist.py_version in args.majorver_provides_versions):
|
||||||
|
if normalized_names_provide_legacy:
|
||||||
|
pymajor_name = 'python{}dist({})'.format(pyver_major, dist.key)
|
||||||
|
if pymajor_name not in py_deps:
|
||||||
|
py_deps[pymajor_name] = []
|
||||||
|
if normalized_names_provide_pep503:
|
||||||
|
pymajor_name_ = 'python{}dist({})'.format(pyver_major, normalized_name)
|
||||||
|
if pymajor_name_ not in py_deps:
|
||||||
|
py_deps[pymajor_name_] = []
|
||||||
|
if args.legacy or args.legacy_provides:
|
||||||
|
legacy_name = 'pythonegg({})({})'.format(pyver_major, dist.key)
|
||||||
|
if legacy_name not in py_deps:
|
||||||
|
py_deps[legacy_name] = []
|
||||||
|
if dist.version:
|
||||||
|
version = dist.version
|
||||||
|
spec = ('==', version)
|
||||||
|
|
||||||
|
if normalized_names_provide_legacy:
|
||||||
|
if spec not in py_deps[name]:
|
||||||
|
py_deps[name].append(spec)
|
||||||
|
if args.majorver_provides or \
|
||||||
|
(args.majorver_provides_versions and dist.py_version in args.majorver_provides_versions):
|
||||||
|
py_deps[pymajor_name].append(spec)
|
||||||
|
if normalized_names_provide_pep503:
|
||||||
|
if spec not in py_deps[name_]:
|
||||||
|
py_deps[name_].append(spec)
|
||||||
|
if args.majorver_provides or \
|
||||||
|
(args.majorver_provides_versions and dist.py_version in args.majorver_provides_versions):
|
||||||
|
py_deps[pymajor_name_].append(spec)
|
||||||
|
if args.legacy or args.legacy_provides:
|
||||||
|
if spec not in py_deps[legacy_name]:
|
||||||
|
py_deps[legacy_name].append(spec)
|
||||||
|
if args.requires or (args.recommends and dist.extras):
|
||||||
|
name = 'python(abi)'
|
||||||
|
# If egg/dist metadata says package name is python, we don't add dependency on python(abi)
|
||||||
|
if dist.key == 'python':
|
||||||
|
py_abi = False
|
||||||
|
if name in py_deps:
|
||||||
|
py_deps.pop(name)
|
||||||
|
elif py_abi and dist.py_version:
|
||||||
|
if name not in py_deps:
|
||||||
|
py_deps[name] = []
|
||||||
|
spec = ('==', dist.py_version)
|
||||||
|
if spec not in py_deps[name]:
|
||||||
|
py_deps[name].append(spec)
|
||||||
|
deps = dist.requires()
|
||||||
|
if args.recommends:
|
||||||
|
depsextras = dist.requires(extras=dist.extras)
|
||||||
|
if not args.requires:
|
||||||
|
for dep in reversed(depsextras):
|
||||||
|
if dep in deps:
|
||||||
|
depsextras.remove(dep)
|
||||||
|
deps = depsextras
|
||||||
|
# console_scripts/gui_scripts entry points need pkg_resources from setuptools
|
||||||
|
if ((dist.get_entry_map('console_scripts') or
|
||||||
|
dist.get_entry_map('gui_scripts')) and
|
||||||
|
(lower.endswith('.egg') or
|
||||||
|
lower.endswith('.egg-info'))):
|
||||||
|
# stick them first so any more specific requirement overrides it
|
||||||
|
deps.insert(0, Requirement.parse('setuptools'))
|
||||||
|
# add requires/recommends based on egg/dist metadata
|
||||||
|
for dep in deps:
|
||||||
|
if normalized_names_require_pep503:
|
||||||
|
dep_normalized_name = normalize_name(dep.project_name)
|
||||||
|
else:
|
||||||
|
dep_normalized_name = dep.key
|
||||||
|
|
||||||
|
if args.legacy:
|
||||||
|
name = 'pythonegg({})({})'.format(pyver_major, dep.key)
|
||||||
|
else:
|
||||||
|
if args.majorver_only:
|
||||||
|
name = 'python{}dist({})'.format(pyver_major, dep_normalized_name)
|
||||||
|
else:
|
||||||
|
name = 'python{}dist({})'.format(dist.py_version, dep_normalized_name)
|
||||||
|
for spec in dep.specs:
|
||||||
|
if name not in py_deps:
|
||||||
|
py_deps[name] = []
|
||||||
|
if spec not in py_deps[name]:
|
||||||
|
py_deps[name].append(spec)
|
||||||
|
if not dep.specs:
|
||||||
|
py_deps[name] = []
|
||||||
|
# Unused, for automatic sub-package generation based on 'extras' from egg/dist metadata
|
||||||
|
# TODO: implement in rpm later, or...?
|
||||||
|
if args.extras:
|
||||||
|
deps = dist.requires()
|
||||||
|
extras = dist.extras
|
||||||
|
print(extras)
|
||||||
|
for extra in extras:
|
||||||
|
print('%%package\textras-{}'.format(extra))
|
||||||
|
print('Summary:\t{} extra for {} python package'.format(extra, dist.key))
|
||||||
|
print('Group:\t\tDevelopment/Python')
|
||||||
|
depsextras = dist.requires(extras=[extra])
|
||||||
|
for dep in reversed(depsextras):
|
||||||
|
if dep in deps:
|
||||||
|
depsextras.remove(dep)
|
||||||
|
deps = depsextras
|
||||||
|
for dep in deps:
|
||||||
|
for spec in dep.specs:
|
||||||
|
if spec[0] == '!=':
|
||||||
|
print('Conflicts:\t{} {} {}'.format(dep.key, '==', spec[1]))
|
||||||
|
else:
|
||||||
|
print('Requires:\t{} {} {}'.format(dep.key, spec[0], spec[1]))
|
||||||
|
print('%%description\t{}'.format(extra))
|
||||||
|
print('{} extra for {} python package'.format(extra, dist.key))
|
||||||
|
print('%%files\t\textras-{}\n'.format(extra))
|
||||||
|
if args.conflicts:
|
||||||
|
# Should we really add conflicts for extras?
|
||||||
|
# Creating a meta package per extra with recommends on, which has
|
||||||
|
# the requires/conflicts in stead might be a better solution...
|
||||||
|
for dep in dist.requires(extras=dist.extras):
|
||||||
|
name = dep.key
|
||||||
|
for spec in dep.specs:
|
||||||
|
if spec[0] == '!=':
|
||||||
|
if name not in py_deps:
|
||||||
|
py_deps[name] = []
|
||||||
|
spec = ('==', spec[1])
|
||||||
|
if spec not in py_deps[name]:
|
||||||
|
py_deps[name].append(spec)
|
||||||
|
|
||||||
|
names = list(py_deps.keys())
|
||||||
|
names.sort()
|
||||||
|
for name in names:
|
||||||
|
if py_deps[name]:
|
||||||
|
# Print out versioned provides, requires, recommends, conflicts
|
||||||
|
spec_list = []
|
||||||
|
for spec in py_deps[name]:
|
||||||
|
spec_list.append(convert(name, spec[0], spec[1]))
|
||||||
|
if len(spec_list) == 1:
|
||||||
|
print(spec_list[0])
|
||||||
|
else:
|
||||||
|
# Sort spec_list so that the results can be tested easily
|
||||||
|
#print('({})'.format(' with '.join(sorted(spec_list))))
|
||||||
|
for spec_req in spec_list:
|
||||||
|
print(spec_req)
|
||||||
|
else:
|
||||||
|
# Print out unversioned provides, requires, recommends, conflicts
|
||||||
|
print(name)
|
13
rpm.spec
13
rpm.spec
@ -17,7 +17,7 @@
|
|||||||
Name: rpm
|
Name: rpm
|
||||||
Epoch: 1
|
Epoch: 1
|
||||||
Version: 4.17.1.1
|
Version: 4.17.1.1
|
||||||
Release: 4mamba
|
Release: 5mamba
|
||||||
Summary: The RPM Package Manager (RPM) is a powerful package management system
|
Summary: The RPM Package Manager (RPM) is a powerful package management system
|
||||||
Group: System/Management
|
Group: System/Management
|
||||||
Vendor: openmamba
|
Vendor: openmamba
|
||||||
@ -27,6 +27,9 @@ URL: https://rpm.org/index.html
|
|||||||
Source: http://ftp.rpm.org/releases/rpm-%{majver}.x/rpm-%{version}.tar.bz2
|
Source: http://ftp.rpm.org/releases/rpm-%{majver}.x/rpm-%{version}.tar.bz2
|
||||||
Source2: rpm4-macros_openmamba
|
Source2: rpm4-macros_openmamba
|
||||||
Source3: rpmdb-rebuild.service
|
Source3: rpmdb-rebuild.service
|
||||||
|
Source4: python.attr
|
||||||
|
Source5: pythondist.attr
|
||||||
|
Source6: pythondistdeps.py
|
||||||
Patch0: rpm-4.14.2.1-fix-rebuilddb-from-rpm-5.2.patch
|
Patch0: rpm-4.14.2.1-fix-rebuilddb-from-rpm-5.2.patch
|
||||||
Patch1: rpm-4.14.2.1-fix-rebuilddb-from-rpm-5.2-better.patch
|
Patch1: rpm-4.14.2.1-fix-rebuilddb-from-rpm-5.2-better.patch
|
||||||
Patch2: rpm-4.14.2.1-fix-missing-translations-from-rpm4-segfault.patch
|
Patch2: rpm-4.14.2.1-fix-missing-translations-from-rpm4-segfault.patch
|
||||||
@ -193,6 +196,11 @@ sed -i "s|/libexec$|/%{_libexec}|" %{buildroot}%{_prefix}/lib/rpm/platform/x86_6
|
|||||||
sed -i "s|/libexec$|/%{_libexec}|" %{buildroot}%{_prefix}/lib/rpm/platform/aarch64-linux/macros
|
sed -i "s|/libexec$|/%{_libexec}|" %{buildroot}%{_prefix}/lib/rpm/platform/aarch64-linux/macros
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
|
# Install python distdeps scripts and fileattrs removed since 4.17 (in Fedora they are moved to python-rpm-generators)
|
||||||
|
install -m0644 %{SOURCE4} %{buildroot}%{_prefix}/lib/rpm/fileattrs/python.attr
|
||||||
|
install -m0644 %{SOURCE5} %{buildroot}%{_prefix}/lib/rpm/fileattrs/pythondist.attr
|
||||||
|
install -m0755 %{SOURCE6} %{buildroot}%{_prefix}/lib/rpm/pythondistdeps.py
|
||||||
|
|
||||||
rm -f %{buildroot}%{_libdir}/librpm*.la
|
rm -f %{buildroot}%{_libdir}/librpm*.la
|
||||||
|
|
||||||
%clean
|
%clean
|
||||||
@ -294,6 +302,9 @@ rm -f %{buildroot}%{_libdir}/librpm*.la
|
|||||||
%{python3_sitearch}/rpm/*
|
%{python3_sitearch}/rpm/*
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Sun Sep 11 2022 Silvan Calarco <silvan.calarco@mambasoft.it> 4.17.1.1-5mamba
|
||||||
|
- restore python distdeps generators by adding pythondistdeps.py and fileattrs/python*
|
||||||
|
|
||||||
* Sun Sep 04 2022 Silvan Calarco <silvan.calarco@mambasoft.it> 4.17.1.1-4mamba
|
* Sun Sep 04 2022 Silvan Calarco <silvan.calarco@mambasoft.it> 4.17.1.1-4mamba
|
||||||
- use a triggerpostun script to enable rpmdb-rebuild on upgrade
|
- use a triggerpostun script to enable rpmdb-rebuild on upgrade
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user