Fix some remaining corner cases that cause bug #220341 to reappear
authorZac Medico <zmedico@gentoo.org>
Sun, 17 Aug 2008 19:22:41 +0000 (19:22 -0000)
committerZac Medico <zmedico@gentoo.org>
Sun, 17 Aug 2008 19:22:41 +0000 (19:22 -0000)
intermittently. Thanks to pva for reporting. (trunk r10768)

svn path=/main/branches/2.1.2/; revision=11427

bin/emerge

index f7cf923677b9d453dbe8951b4632d1dcb7bd05d3..88e1b94785964d44afd58c2e8453443abfd55339 100755 (executable)
@@ -3183,21 +3183,22 @@ class depgraph(object):
                                # the newly built package still won't have the expected slot.
                                # Therefore, assume that such SLOT dependencies are already
                                # satisfied rather than forcing a rebuild.
-                               if installed and not cpv_list and \
-                                       matched_packages and atom.slot:
-                                       for pkg in matched_packages:
-                                               if not vardb.cpv_exists(pkg.cpv):
+                               if installed and not cpv_list and atom.slot:
+                                       for cpv in db.match(atom.cp):
+                                               slot_available = False
+                                               for other_db, other_type, other_built, \
+                                                       other_installed, other_keys in dbs:
+                                                       try:
+                                                               if atom.slot == \
+                                                                       other_db.aux_get(cpv, ["SLOT"])[0]:
+                                                                       slot_available = True
+                                                                       break
+                                                       except KeyError:
+                                                               pass
+                                               if not slot_available:
                                                        continue
-                                               inst_pkg = self._pkg_cache.get(
-                                                       (pkg_type, root, pkg.cpv, "nomerge"))
-                                               if inst_pkg is None:
-                                                       metadata = izip(self._mydbapi_keys,
-                                                               vardb.aux_get(pkg.cpv, self._mydbapi_keys))
-                                                       inst_pkg = Package(built=built, cpv=pkg.cpv,
-                                                               installed=installed, metadata=metadata,
-                                                               onlydeps=onlydeps, root_config=root_config,
-                                                               type_name=pkg_type)
-                                                       self._pkg_cache[inst_pkg] = inst_pkg
+                                               inst_pkg = self._pkg(cpv, "installed",
+                                                       root_config, installed=installed)
                                                # Remove the slot from the atom and verify that
                                                # the package matches the resulting atom.
                                                atom_without_slot = portage_dep.remove_slot(atom)