From 97d44b5a002b61c7b95303bb8616f1caa6556bca Mon Sep 17 00:00:00 2001 From: Timo Teräs Date: Fri, 24 Feb 2012 16:27:51 +0200 Subject: solver: unallowed pinning is worse than changing installed package --- src/solver.c | 17 +++++++---------- test/pinning10.test | 10 ++++++++++ 2 files changed, 17 insertions(+), 10 deletions(-) create mode 100644 test/pinning10.test diff --git a/src/solver.c b/src/solver.c index f8bd4fd..9875dda 100644 --- a/src/solver.c +++ b/src/solver.c @@ -350,7 +350,7 @@ static int get_topology_score( unsigned int repos; unsigned short preferred_pinning, allowed_pinning; unsigned int preferred_repos, allowed_repos; - int score_locked = TRUE; + int score_locked = TRUE, sticky_installed = FALSE; score = (struct apk_score) { .conflicts = ps->conflicts, @@ -375,6 +375,8 @@ static int get_topology_score( /* not upgrading: it is not preferred to change package */ if (pkg->ipkg == NULL && ns->originally_installed) score.non_preferred_actions++; + else + sticky_installed = TRUE; } else { score_locked = FALSE; } @@ -389,16 +391,11 @@ static int get_topology_score( if (ns->locked || (ns->allowed_pinning | ns->maybe_pinning) == ns->allowed_pinning) { allowed_pinning = ns->allowed_pinning | preferred_pinning | APK_DEFAULT_PINNING_MASK; allowed_repos = get_pinning_mask_repos(ss->db, allowed_pinning); - if (!(repos & allowed_repos)) + if (!(repos & allowed_repos)) { + if (sticky_installed) + score.non_preferred_actions++; score.non_preferred_pinnings += 16; - -#if 0 - if (allowed_pinning & ~APK_DEFAULT_PINNING_MASK) - fprintf(stdout, PKG_VER_FMT": allow: %x, in: %x, reallyin: %x. score="SCORE_FMT"\n", - PKG_VER_PRINTF(pkg), - allowed_repos, repos, pkg->repos, - SCORE_PRINTF(&score)); -#endif + } } else { score_locked = FALSE; } diff --git a/test/pinning10.test b/test/pinning10.test new file mode 100644 index 0000000..31a01c2 --- /dev/null +++ b/test/pinning10.test @@ -0,0 +1,10 @@ +@ARGS +--test-repo basic.repo +--test-repo testing:pinning.repo +--test-instdb pinning.installed +--test-world "a@testing" +add a +@EXPECT +(1/2) Downgrading a (3 -> 2) +(2/2) Purging c (3) +OK: 0 MiB in 3 packages -- cgit v1.2.3-70-g09d2