|
|
@ -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
|
|
|
|