Rename a method and reduce a table to a set

Signed-off-by: Niels Thykier <niels@thykier.net>
ubuntu/rebased
Niels Thykier 6 years ago
parent 0eb8b5a201
commit 0b4f58315f
No known key found for this signature in database
GPG Key ID: A65B78DBE67C7AAC

@ -306,18 +306,19 @@ class InstallabilityTesterBuilder(object):
if b in reverse_package_table: if b in reverse_package_table:
del reverse_package_table[b] del reverse_package_table[b]
relations, eqv_table = self._build_eqv_packages_table(package_table, reverse_package_table) relations, eqv_set = self._build_relations_and_eqv_packages_set(package_table, reverse_package_table)
universe = BinaryPackageUniverse(relations, universe = BinaryPackageUniverse(relations,
intern_set(self._essentials), intern_set(self._essentials),
intern_set(broken), intern_set(broken),
intern_set(eqv_table)) intern_set(eqv_set))
solver = InstallabilityTester(universe, self._testing) solver = InstallabilityTester(universe, self._testing)
return universe, solver return universe, solver
def _build_eqv_packages_table(self, package_table, def _build_relations_and_eqv_packages_set(self,
package_table,
reverse_package_table, reverse_package_table,
frozenset=frozenset): frozenset=frozenset):
"""Attempt to build a table of equivalent packages """Attempt to build a table of equivalent packages
@ -370,8 +371,8 @@ class InstallabilityTesterBuilder(object):
# only finds the equivalence cases. Lets leave # only finds the equivalence cases. Lets leave
# substitutability for a future version. # substitutability for a future version.
find_eqv_table = defaultdict(list) find_eqv_set = defaultdict(list)
eqv_table = {} eqv_set = set()
relations = {} relations = {}
emptyset = frozenset() emptyset = frozenset()
intern_set = self._intern_set intern_set = self._intern_set
@ -384,18 +385,17 @@ class InstallabilityTesterBuilder(object):
continue continue
deps, con = package_table[pkg] deps, con = package_table[pkg]
ekey = (deps, con, rdeps) ekey = (deps, con, rdeps)
find_eqv_table[ekey].append(pkg) find_eqv_set[ekey].append(pkg)
for pkg_relations, pkg_list in find_eqv_table.items(): for pkg_relations, pkg_list in find_eqv_set.items():
rdeps = reverse_package_table[pkg_list[0]][0] rdeps = reverse_package_table[pkg_list[0]][0]
rel = BinaryPackageRelation(intern_set(pkg_list), pkg_relations[0], pkg_relations[1], rdeps) rel = BinaryPackageRelation(intern_set(pkg_list), pkg_relations[0], pkg_relations[1], rdeps)
if len(pkg_list) < 2: if len(pkg_list) < 2:
relations[pkg_list[0]] = rel relations[pkg_list[0]] = rel
continue continue
eqv_set = frozenset(pkg_list) eqv_set.update(pkg_list)
for pkg in pkg_list: for pkg in pkg_list:
eqv_table[pkg] = eqv_set
relations[pkg] = rel relations[pkg] = rel
for pkg, forward_relations in package_table.items(): for pkg, forward_relations in package_table.items():
@ -404,4 +404,4 @@ class InstallabilityTesterBuilder(object):
rel = BinaryPackageRelation(intern_set((pkg,)), forward_relations[0], forward_relations[1], emptyset) rel = BinaryPackageRelation(intern_set((pkg,)), forward_relations[0], forward_relations[1], emptyset)
relations[pkg] = rel relations[pkg] = rel
return relations, eqv_table return relations, eqv_set

Loading…
Cancel
Save