Blame SOURCES/BZ-1193871-updateinfo-notice-when-arch-changed.patch

d2a170
diff --git a/yum/update_md.py b/yum/update_md.py
d2a170
--- a/yum/update_md.py	2015-01-19 07:44:35.567107008 -0500
d2a170
+++ b/yum/update_md.py	2015-01-19 08:57:31.576489424 -0500
d2a170
@@ -398,6 +399,9 @@ class UpdateMetadata(object):
d2a170
             except Errors.RepoMDError:
d2a170
                 continue # No metadata found for this repo
d2a170
 
d2a170
+        self.arch_storage = ArchStorage()
d2a170
+        self.archlist = self.arch_storage.archlist
d2a170
+
d2a170
     def get_notices(self, name=None):
d2a170
         """ Return all notices. """
d2a170
         if name is None:
d2a170
@@ -434,16 +438,29 @@ class UpdateMetadata(object):
d2a170
         name = oldpkgtup[0]
d2a170
         arch = oldpkgtup[1]
d2a170
         ret = []
d2a170
+        other_arch_list = []
d2a170
+        notices = set()
d2a170
         for notice in self.get_notices(name):
d2a170
             for upkg in notice['pkglist']:
d2a170
                 for pkg in upkg['packages']:
d2a170
+                    other_arch = False
d2a170
                     if pkg['name'] != name or pkg['arch'] != arch:
d2a170
-                        continue
d2a170
+                        if (notice not in notices and pkg['name'] == name and pkg['arch'] in self.archlist):
d2a170
+                            other_arch = True
d2a170
+                        else:
d2a170
+                            continue
d2a170
                     pkgtup = (pkg['name'], pkg['arch'], pkg['epoch'] or '0',
d2a170
                               pkg['version'], pkg['release'])
d2a170
                     if _rpm_tup_vercmp(pkgtup, oldpkgtup) <= 0:
d2a170
                         continue
d2a170
-                    ret.append((pkgtup, notice))
d2a170
+                    if other_arch:
d2a170
+                        other_arch_list.append((pkgtup, notice))
d2a170
+                    else:
d2a170
+                        ret.append((pkgtup, notice))
d2a170
+                        notices.add(notice)
d2a170
+        for pkgtup, notice in other_arch_list:
d2a170
+            if notice not in notices:
d2a170
+                ret.append((pkgtup, notice))
d2a170
         ret.sort(cmp=_rpm_tup_vercmp, key=lambda x: x[0], reverse=True)
d2a170
         return ret
d2a170
 
d2a170
diff -up yum-3.4.3/yum/update_md.py.old yum-3.4.3/yum/update_md.py
d2a170
--- yum-3.4.3/yum/update_md.py.old	2015-05-28 19:23:35.589691937 +0200
d2a170
+++ yum-3.4.3/yum/update_md.py	2015-05-28 19:24:05.971806965 +0200
d2a170
@@ -33,6 +33,7 @@ import Errors
d2a170
 import logginglevels
d2a170
 
d2a170
 import rpmUtils.miscutils
d2a170
+from rpmUtils.arch import ArchStorage
d2a170
 
d2a170
 
d2a170
 def safe_iterparse(filename, logger=None):