repos: Better heuristics for repo 64-bitness

This commit is contained in:
Ivan A. Melnikov 2023-07-24 17:46:24 +04:00
parent 4469729bc1
commit e39256876e

View File

@ -137,14 +137,11 @@ class Binary:
class Repository: class Repository:
def __init__(self, repo_name, sources, binaries, bits=None): def __init__(self, repo_name, sources, binaries, bits):
self.name = repo_name self.name = repo_name
self.sources = sources self.sources = sources
self.binaries = binaries self.binaries = binaries
if bits is not None: self.bits = bits
self.bits = bits
else:
self.bits = 64 if ('64' in self.name) else 32
self.reverse_prov = {} # name -> [(provide, binary)] self.reverse_prov = {} # name -> [(provide, binary)]
self.update_indexes() self.update_indexes()
@ -165,6 +162,8 @@ class Repository:
def load(cls, repo_name, path, arch, components=('classic',)): def load(cls, repo_name, path, arch, components=('classic',)):
src_list, bin_list = lists.read_pkglist_heders_for_repo( src_list, bin_list = lists.read_pkglist_heders_for_repo(
path, arch, components) path, arch, components)
# xxx: not the very best heuristics
bits = 64 if any('64' in a for a in arch) else 32
sources = {} sources = {}
for header in src_list: for header in src_list:
name = header[rpm.RPMTAG_NAME] name = header[rpm.RPMTAG_NAME]
@ -179,7 +178,7 @@ class Repository:
else: else:
LOG.warning('Duplicate binaries: %s %s', found, LOG.warning('Duplicate binaries: %s %s', found,
header.format('%{NAME}-%{EVR}:%{DISTTAG})')) header.format('%{NAME}-%{EVR}:%{DISTTAG})'))
return cls(repo_name, sources, binaries) return cls(repo_name, sources, binaries, bits=bits)
@classmethod @classmethod
def load_from_config(cls, repo_name, config): def load_from_config(cls, repo_name, config):