yifengyou / rpms / yum

Forked from rpms/yum 3 years ago
Clone

Blame SOURCES/BZ-1330423-skipbroken-installonly-limit-fix.patch

5e9bef
commit 3c89608a67ee9fd35d1860c183951dde76464cd0
5e9bef
Author: Michal Domonkos <mdomonko@redhat.com>
5e9bef
Date:   Fri May 6 13:25:25 2016 +0200
5e9bef
5e9bef
    skipbroken: don't installonly_limit if new pkg fails. BZ 1330423
5e9bef
    
5e9bef
    This is a fix up for commit f8c1528.
5e9bef
    - Add po instead of txmbr to txmbr.depends_on
5e9bef
    - Make sure the depending po is not whatever was last stored in m
5e9bef
5e9bef
diff --git a/yum/__init__.py b/yum/__init__.py
5e9bef
index 764e97d..cd66396 100644
5e9bef
--- a/yum/__init__.py
5e9bef
+++ b/yum/__init__.py
5e9bef
@@ -6459,15 +6459,15 @@ much more problems).
5e9bef
                 continue
5e9bef
 
5e9bef
             if m.name not in found:
5e9bef
-                found[m.name] = 1
5e9bef
+                found[m.name] = [m.po]
5e9bef
             else:
5e9bef
-                found[m.name] += 1
5e9bef
+                found[m.name].append(m.po)
5e9bef
 
5e9bef
         for name in found:
5e9bef
             installed = self.rpmdb.searchNevra(name=name)
5e9bef
             installed = _sort_and_filter_installonly(installed)
5e9bef
 
5e9bef
-            total = len(installed) + found[name]
5e9bef
+            total = len(installed) + len(found[name])
5e9bef
             if total <= self.conf.installonly_limit:
5e9bef
                 continue # Not adding enough to trigger.
5e9bef
 
5e9bef
@@ -6479,14 +6479,20 @@ much more problems).
5e9bef
                     continue
5e9bef
                 if numleft == 0:
5e9bef
                     break
5e9bef
-                toremove.append((po,m))
5e9bef
+                toremove.append((po, found[name]))
5e9bef
                 numleft -= 1
5e9bef
                         
5e9bef
-        for po,rel in toremove:
5e9bef
+        for po, newpos in toremove:
5e9bef
             txmbr = self.tsInfo.addErase(po)
5e9bef
-            # Add a dep relation to the new version of the package, causing this one to be erased
5e9bef
-            # this way skipbroken, should clean out the old one, if the new one is skipped
5e9bef
-            txmbr.depends_on.append(rel)
5e9bef
+            # Add a dep relation to the new version of the package that causes
5e9bef
+            # this one to be erased.  This way skipbroken should drop the old
5e9bef
+            # one from the transaction if the new one is skipped.  Note that we
5e9bef
+            # can only do this for one new version, as skipbroken won't drop
5e9bef
+            # deps that are shared with some other packages.  For consistency,
5e9bef
+            # let's give up completely if we are installing multiple new
5e9bef
+            # versions (which is rather uncommon anyway).
5e9bef
+            if len(newpos) == 1:
5e9bef
+                txmbr.depends_on.append(newpos[0])
5e9bef
 
5e9bef
     def processTransaction(self, callback=None,rpmTestDisplay=None, rpmDisplay=None):
5e9bef
         """Process the current transaction.  This involves the