The following commit has been merged in the master branch:
commit 1863d6460975abf7a9f6259e1facbff130db55ae
Author: Ian Jackson <[EMAIL PROTECTED]>
Date: Thu Nov 1 19:57:26 2007 +0000
Correct broken dselect logic for self-conflicting packages
The previous code seems to have had some confusion over the precedence
of '&&' vs ':'. The new rule is that a Conflicts is violated if the
target package is installed or to be error-preserved ie
would_like_to_install() != 0 - except that we disregard packages which
directly Conflict with themselves.
diff --git a/ChangeLog b/ChangeLog
index 680d44d..927e2e6 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+2008-03-09 Ian Jackson <[EMAIL PROTECTED]>
+
+ * dselect/pkgdepcon.cc (packagelist::deppossatisfied): The new rule
+ is that a Conflicts is violated if the target package is installed
+ or to be error-preserved ie would_like_to_install() != 0 - except
+ that we disregard packages which directly Conflict with themselves.
+
2008-03-07 Raphael Hertzog <[EMAIL PROTECTED]>
* scripts/Dpkg/Fields.pm: Import Dpkg::Gettext since we use _g().
diff --git a/debian/changelog b/debian/changelog
index e0d2a09..49262d2 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -19,6 +19,8 @@ dpkg (1.14.17) UNRELEASED; urgency=low
package when debsig-verify is installed. Closes: #311843
* Fix some small memory leaks. Closes: #469520
Thanks to Sean Finney.
+ * Correct broken dselect logic for self-conflicting packages.
+ Thanks to Ian Jackson.
[ Raphael Hertzog ]
* Add a warning displayed by dpkg-genchanges if the current version is
diff --git a/dselect/pkgdepcon.cc b/dselect/pkgdepcon.cc
index 70e6bda..72232bd 100644
--- a/dselect/pkgdepcon.cc
+++ b/dselect/pkgdepcon.cc
@@ -353,6 +353,8 @@ int packagelist::resolvedepcon(dependency *depends) {
}
int packagelist::deppossatisfied(deppossi *possi, perpackagestate
**fixbyupgrade) {
+ // `satisfied' here for Conflicts and Breaks means that the
+ // restriction is violated ie that the target package is wanted
int would;
pkginfo::pkgwant want= pkginfo::want_purge;
@@ -363,8 +365,9 @@ int packagelist::deppossatisfied(deppossi *possi,
perpackagestate **fixbyupgrade
would= 0;
}
- if (!(possi->up->type == dep_conflicts && possi->up->up == possi->ed) &&
- possi->up->type == dep_conflicts ? (would != 0) : (would > 0)) {
+ if (possi->up->type == dep_conflicts
+ ? possi->up->up != possi->ed && would != 0
+ : would > 0) {
// If it's to be installed or left installed, then either it's of
// the right version, and therefore OK, or a version must have
// been specified, in which case we don't need to look at the rest
--
dpkg's main repository
--
To UNSUBSCRIBE, email to [EMAIL PROTECTED]
with a subject of "unsubscribe". Trouble? Contact [EMAIL PROTECTED]