diff options
author | Panu Matilainen <pmatilai@redhat.com> | 2010-03-22 11:05:17 +0200 |
---|---|---|
committer | Panu Matilainen <pmatilai@redhat.com> | 2010-03-22 11:05:17 +0200 |
commit | 7911e17982e1deb685163dc8294775466237db63 (patch) | |
tree | 78cb8ba299f3e2e38a98419f44f39d63eb179605 | |
parent | 457e2912533375cf84c5ca5a4428fd61b9f77cff (diff) | |
download | rpm-7911e17982e1deb685163dc8294775466237db63.tar.gz rpm-7911e17982e1deb685163dc8294775466237db63.tar.bz2 rpm-7911e17982e1deb685163dc8294775466237db63.zip |
Handle obsoletions within the added package set automatically
- similarly to skipping/replacing different versions of a package
getting added to transaction, detect obsoletion too and
skip/replace to avoid installing packages obsoleted by something
else in the set
-rw-r--r-- | lib/depends.c | 34 |
1 files changed, 28 insertions, 6 deletions
diff --git a/lib/depends.c b/lib/depends.c index 1cdf128dc..593062d67 100644 --- a/lib/depends.c +++ b/lib/depends.c @@ -180,28 +180,53 @@ static void addObsoleteErasures(rpmts ts, tsMembers tsmem, rpm_color_t tscolor, } /* - * Check for previously added versions with the same name and arch/os. + * Check for previously added versions and obsoletions. * Return index where to place this element, or -1 to skip. */ static int findPos(rpmts ts, rpm_color_t tscolor, Header h, int upgrade) { int oc; + int obsolete = 0; const char * arch = headerGetString(h, RPMTAG_ARCH); const char * os = headerGetString(h, RPMTAG_OS); rpmte p; rpmds oldChk = rpmdsThis(h, RPMTAG_REQUIRENAME, (RPMSENSE_LESS)); rpmds newChk = rpmdsThis(h, RPMTAG_REQUIRENAME, (RPMSENSE_GREATER)); rpmds sameChk = rpmdsThis(h, RPMTAG_REQUIRENAME, (RPMSENSE_EQUAL)); + rpmds obsChk = rpmdsNew(h, RPMTAG_OBSOLETENAME, 0); rpmtsi pi = rpmtsiInit(ts); /* XXX can't use rpmtsiNext() filter or oc will have wrong value. */ for (oc = 0; (p = rpmtsiNext(pi, 0)) != NULL; oc++) { - rpmds this; + rpmds this, obsoletes; /* Only added binary packages need checking */ if (rpmteType(p) == TR_REMOVED || rpmteIsSource(p)) continue; + /* Skip packages obsoleted by already added packages */ + obsoletes = rpmdsInit(rpmteDS(p, RPMTAG_OBSOLETENAME)); + while (rpmdsNext(obsoletes) >= 0) { + if (rpmdsCompare(obsoletes, sameChk)) { + obsolete = 1; + oc = -1; + break; + } + } + + /* Replace already added obsoleted packages by obsoleting package */ + this = rpmteDS(p, RPMTAG_NAME); + rpmdsInit(obsChk); + while (rpmdsNext(obsChk) >= 0) { + if (rpmdsCompare(obsChk, this)) { + obsolete = 1; + break; + } + } + + if (obsolete) + break; + if (tscolor) { const char * parch = rpmteA(p); const char * pos = rpmteO(p); @@ -212,10 +237,6 @@ static int findPos(rpmts ts, rpm_color_t tscolor, Header h, int upgrade) continue; } - /* OK, binary rpm's with same arch and os. Check NEVR. */ - if ((this = rpmteDS(p, RPMTAG_NAME)) == NULL) - continue; /* XXX can't happen */ - /* * Always skip identical NEVR. * On upgrade, if newer NEVR was previously added, skip adding older. @@ -246,6 +267,7 @@ static int findPos(rpmts ts, rpm_color_t tscolor, Header h, int upgrade) rpmdsFree(oldChk); rpmdsFree(newChk); rpmdsFree(sameChk); + rpmdsFree(obsChk); return oc; } |