Mask binary packages if their CHOST does not match the one
authorZac Medico <zmedico@gentoo.org>
Wed, 26 Sep 2007 04:23:11 +0000 (04:23 -0000)
committerZac Medico <zmedico@gentoo.org>
Wed, 26 Sep 2007 04:23:11 +0000 (04:23 -0000)
defined in make.conf. (trunk r7792)

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

bin/emerge
pym/portage.py

index 535dd10766bfbd1feaa37496d49864bed63b84a5..3fa56ee69fdefaf478eebbd6b86d8fab0bdfbdc4 100755 (executable)
@@ -1844,12 +1844,19 @@ class depgraph:
                                        "--usepkg" in self.myopts:
                                        # The next line assumes the binarytree has been populated.
                                        # XXX: Need to work out how we use the binary tree with roots.
-                                       myeb_pkg_matches = bindb.match(x)
-                                       if "--usepkgonly" not in self.myopts:
-                                               # Remove any binary package entries that are masked in the portage tree (#55871)
-                                               myeb_pkg_matches = [pkg for pkg in myeb_pkg_matches \
-                                                       if pkg in myeb_matches or  \
-                                                       not portdb.cpv_exists(pkg)]
+                                       usepkgonly = "--usepkgonly" in self.myopts
+                                       chost = pkgsettings["CHOST"]
+                                       myeb_pkg_matches = []
+                                       for pkg in bindb.match(x):
+                                               if chost != bindb.aux_get(pkg, ["CHOST"])[0]:
+                                                       continue
+                                               # Remove any binary package entries that are
+                                               # masked in the portage tree (#55871).
+                                               if not usepkgonly and \
+                                                       not (pkg in myeb_matches or \
+                                                       not portdb.cpv_exists(pkg)):
+                                                       continue
+                                               myeb_pkg_matches.append(pkg)
                                        if myeb_pkg_matches:
                                                myeb_pkg = portage.best(myeb_pkg_matches)
                                                # For best performance, try to reuse an exising node
@@ -1964,6 +1971,15 @@ class depgraph:
                                                        print "For more information, see MASKED PACKAGES section in the emerge man page or "
                                                        print "refer to the Gentoo Handbook."
                                                else:
+                                                       alleb = bindb.match(x)
+                                                       if alleb:
+                                                               chost = pkgsettings["CHOST"]
+                                                               for p in alleb:
+                                                                       mreasons = []
+                                                                       pkg_chost =  bindb.aux_get(p, ["CHOST"])[0]
+                                                                       if chost != pkg_chost:
+                                                                               mreasons.append("CHOST: %s" % pkg_chost)
+                                                                       print "- "+p+" (masked by: "+", ".join(mreasons)+")"
                                                        print "\n!!! "+red("There are no packages available to satisfy: ")+green(xinfo)
                                                        print "!!! Either add a suitable binary package or compile from an ebuild."
                                        else:
index 28e54af7b908d568ee039a5dad255535fa599e50..bc3b72411fb5080d05686549a3c91db41c408096 100644 (file)
@@ -5260,7 +5260,7 @@ class bindbapi(fakedbapi):
                self.settings = settings
                self._match_cache = {}
                # Selectively cache metadata in order to optimize dep matching.
-               self._aux_cache_keys = set(["SLOT"])
+               self._aux_cache_keys = set(["CHOST","SLOT"])
                self._aux_cache = {}
 
        def match(self, *pargs, **kwargs):