From fb7fff4409cb9e1e52f8daf1ddaf6f8728020915 Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Fri, 9 Jun 2023 19:32:34 +0900 Subject: [PATCH] dag_walk: extract topo-order helper that doesn't reverse the result I'll add an iterator wrapper that pop()s the sorted result. --- lib/src/dag_walk.rs | 18 ++++++++++++++++-- lib/src/repo.rs | 7 +++---- 2 files changed, 19 insertions(+), 6 deletions(-) diff --git a/lib/src/dag_walk.rs b/lib/src/dag_walk.rs index cbfc39fe8..fc708421b 100644 --- a/lib/src/dag_walk.rs +++ b/lib/src/dag_walk.rs @@ -44,8 +44,7 @@ where }) } -/// Returns neighbors before the node itself. -pub fn topo_order_reverse( +pub fn topo_order_forward( start: II, id_fn: impl Fn(&T) -> ID, mut neighbors_fn: impl FnMut(&T) -> NI, @@ -75,6 +74,21 @@ where result.push(node); } } + result +} + +/// Returns neighbors before the node itself. +pub fn topo_order_reverse( + start: II, + id_fn: impl Fn(&T) -> ID, + neighbors_fn: impl FnMut(&T) -> NI, +) -> Vec +where + ID: Hash + Eq + Clone, + II: IntoIterator, + NI: IntoIterator, +{ + let mut result = topo_order_forward(start, id_fn, neighbors_fn); result.reverse(); result } diff --git a/lib/src/repo.rs b/lib/src/repo.rs index 4db798e6b..6902485cd 100644 --- a/lib/src/repo.rs +++ b/lib/src/repo.rs @@ -29,7 +29,6 @@ use self::dirty_cell::DirtyCell; use crate::backend::{Backend, BackendError, BackendResult, ChangeId, CommitId, ObjectId, TreeId}; use crate::commit::Commit; use crate::commit_builder::CommitBuilder; -use crate::dag_walk::topo_order_reverse; use crate::default_index_store::DefaultIndexStore; use crate::git_backend::GitBackend; use crate::index::{HexPrefix, Index, IndexStore, MutableIndex, PrefixResolution, ReadonlyIndex}; @@ -46,7 +45,7 @@ use crate::simple_op_store::SimpleOpStore; use crate::store::Store; use crate::transaction::Transaction; use crate::view::{RefName, View}; -use crate::{backend, op_store}; +use crate::{backend, dag_walk, op_store}; pub trait Repo { fn store(&self) -> &Arc; @@ -849,7 +848,7 @@ impl MutableRepo { self.view.get_mut().remove_head(parent_id); } } else { - let missing_commits = topo_order_reverse( + let missing_commits = dag_walk::topo_order_forward( vec![head.clone()], |commit: &Commit| commit.id().clone(), |commit: &Commit| -> Vec { @@ -860,7 +859,7 @@ impl MutableRepo { .collect() }, ); - for missing_commit in missing_commits.iter().rev() { + for missing_commit in &missing_commits { self.index.add_commit(missing_commit); } self.view.get_mut().add_head(head.id());