From 9565eca5176eda7932cd7666e08d9fbe3751b629 Mon Sep 17 00:00:00 2001 From: konstin Date: Thu, 12 Dec 2024 13:22:29 +0100 Subject: [PATCH] Add context --- src/internal/partial_solution.rs | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/internal/partial_solution.rs b/src/internal/partial_solution.rs index d9c82dec..63b604b0 100644 --- a/src/internal/partial_solution.rs +++ b/src/internal/partial_solution.rs @@ -35,7 +35,9 @@ pub(crate) struct PartialSolution { /// Store for all known package decisions and package derivations. /// /// "assignment" refers to both packages with decisions and package with only derivations and - /// no decision yet. + /// no decision yet. We combine this in a single index map, where different sections (of + /// indexes) contain package with different level of information, and make a decision moves a + /// package from the derivations sections to the decisions section. /// /// `[..current_decision_level]`: Packages that have had a decision made, sorted by the /// `decision_level`. The section is can be seen as the partial solution, it contains a @@ -43,7 +45,7 @@ pub(crate) struct PartialSolution { /// extract the solution, and to backtrack to a particular decision level. The /// `AssignmentsIntersection` is always a `Decision`. /// - /// `[changed_this_decision_level..]`: Packages that are dependencies of some other package, + /// `[prioritize_decision_level..]`: Packages that are dependencies of some other package, /// but have not yet been decided. The `AssignmentsIntersection` is always a `Derivations`, the /// derivations store the obligations from the decided packages. This section has two /// subsections to optimize the number of `prioritize` calls: @@ -280,7 +282,7 @@ impl PartialSolution { *t = t.intersection(&dated_derivation.accumulated_intersection); dated_derivation.accumulated_intersection = t.clone(); if t.is_positive() { - // we can use `swap_indices` to make `changed_this_decision_level` only go down by 1 + // we can use `swap_indices` to make `prioritize_decision_level` only go down by 1 // but the copying is slower then the larger search self.prioritize_decision_level = std::cmp::min(self.prioritize_decision_level, idx);