aboutsummaryrefslogtreecommitdiffstats
path: root/URPM/Resolve.pm
diff options
context:
space:
mode:
Diffstat (limited to 'URPM/Resolve.pm')
-rw-r--r--URPM/Resolve.pm40
1 files changed, 23 insertions, 17 deletions
diff --git a/URPM/Resolve.pm b/URPM/Resolve.pm
index 155ec9f..bf33271 100644
--- a/URPM/Resolve.pm
+++ b/URPM/Resolve.pm
@@ -322,9 +322,9 @@ sub with_db_unsatisfied_requires {
});
}
+# used when a require is not available
sub backtrack_selected {
my ($urpm, $db, $state, $dep, %options) = @_;
- my @properties;
if (defined $dep->{required}) {
#- avoid deadlock here...
@@ -393,22 +393,13 @@ sub backtrack_selected {
}
}
+ my @properties;
if (defined $dep->{psel}) {
if ($options{keep}) {
- #- we shouldn't try to remove packages, so psel which leads to this need to be unselected.
- unless (exists $state->{rejected}{$dep->{psel}->fullname}) {
- #- package is not currently rejected, compute the closure now.
- my @l = disable_selected_unrequested_dependencies($urpm, $db, $state, $dep->{psel});
- foreach (@l) {
- #- disable all these packages in order to avoid selecting them again.
- $_->fullname eq $dep->{psel}->fullname or
- $state->{rejected}{$_->fullname}{backtrack}{closure}{$dep->{psel}->fullname} = undef;
- }
- }
+ backtrack_selected_psel_keep($urpm, $db, $state, $dep->{psel}, $dep->{keep});
+
#- the package is already rejected, we assume we can add another reason here!
defined $dep->{promote} and push @{$state->{rejected}{$dep->{psel}->fullname}{backtrack}{promote}}, $dep->{promote};
- #- to simplify, a reference to list or standalone elements may be set in keep.
- defined $dep->{keep} and push @{$state->{rejected}{$dep->{psel}->fullname}{backtrack}{keep}}, @{$dep->{keep}};
} else {
#- the backtrack need to examine diff_provides promotion on $n.
with_db_unsatisfied_requires($urpm, $db, $state, $dep->{promote}, sub {
@@ -427,6 +418,23 @@ sub backtrack_selected {
@properties;
}
+sub backtrack_selected_psel_keep {
+ my ($urpm, $db, $state, $psel, $keep) = @_;
+
+ #- we shouldn't try to remove packages, so psel which leads to this need to be unselected.
+ unless (exists $state->{rejected}{$psel->fullname}) {
+ #- package is not currently rejected, compute the closure now.
+ my @l = disable_selected_unrequested_dependencies($urpm, $db, $state, $psel);
+ foreach (@l) {
+ #- disable all these packages in order to avoid selecting them again.
+ $_->fullname eq $psel->fullname or
+ $state->{rejected}{$_->fullname}{backtrack}{closure}{$psel->fullname} = undef;
+ }
+ }
+ #- to simplify, a reference to list or standalone elements may be set in keep.
+ $keep and push @{$state->{rejected}{$psel->fullname}{backtrack}{keep}}, @$keep;
+}
+
sub resolve_rejected {
my ($urpm, $db, $state, $pkg, %options) = @_;
resolve_rejected_($urpm, $db, $state, $pkg, $options{unsatisfied}, %options);
@@ -679,7 +687,7 @@ sub resolve_requested__no_suggests_ {
#- keep existing package and therefore cancel current one.
if (@keep) {
- unshift @properties, backtrack_selected($urpm, $db, $state, +{ keep => \@keep, psel => $pkg }, %options);
+ unshift @properties, backtrack_selected_psel_keep($urpm, $db, $state, $pkg, \@keep);
}
}
if (my $diff = shift @diff_provides) {
@@ -873,9 +881,7 @@ sub _handle_diff_provides {
} else {
if ($options{keep}) {
unshift @$properties,
- backtrack_selected($urpm, $db, $state,
- { keep => [ scalar $p->fullname ], psel => $pkg },
- %options);
+ backtrack_selected_psel_keep($urpm, $db, $state, $pkg, [ scalar $p->fullname ]);
} else {
resolve_rejected_($urpm, $db, $state, $p, $properties,
removed => 1,