forked from mirrors/jj
evolution: move shared implementation onto the State struct
There was some duplicate between `ReadonlyEvolution` and `MutableEvolution` that could be extracted. It will help to have this shared code on the `State` object for the next few patches.
This commit is contained in:
parent
88e7f4a30c
commit
648ec34a4c
1 changed files with 27 additions and 16 deletions
|
@ -115,6 +115,25 @@ impl State {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn successors(&self, commit_id: &CommitId) -> HashSet<CommitId> {
|
||||||
|
self.successors
|
||||||
|
.get(commit_id)
|
||||||
|
.cloned()
|
||||||
|
.unwrap_or_else(HashSet::new)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn is_obsolete(&self, commit_id: &CommitId) -> bool {
|
||||||
|
self.obsolete_commits.contains(commit_id)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn is_orphan(&self, commit_id: &CommitId) -> bool {
|
||||||
|
self.orphan_commits.contains(commit_id)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn is_divergent(&self, change_id: &ChangeId) -> bool {
|
||||||
|
self.divergent_changes.contains_key(change_id)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn new_parent(&self, store: &StoreWrapper, old_parent_id: &CommitId) -> HashSet<CommitId> {
|
pub fn new_parent(&self, store: &StoreWrapper, old_parent_id: &CommitId) -> HashSet<CommitId> {
|
||||||
let mut new_parents = HashSet::new();
|
let mut new_parents = HashSet::new();
|
||||||
if let Some(successor_ids) = self.successors.get(old_parent_id) {
|
if let Some(successor_ids) = self.successors.get(old_parent_id) {
|
||||||
|
@ -242,23 +261,19 @@ pub trait EvolveListener {
|
||||||
|
|
||||||
impl Evolution for ReadonlyEvolution<'_> {
|
impl Evolution for ReadonlyEvolution<'_> {
|
||||||
fn successors(&self, commit_id: &CommitId) -> HashSet<CommitId> {
|
fn successors(&self, commit_id: &CommitId) -> HashSet<CommitId> {
|
||||||
self.get_state()
|
self.get_state().successors(commit_id)
|
||||||
.successors
|
|
||||||
.get(commit_id)
|
|
||||||
.cloned()
|
|
||||||
.unwrap_or_else(HashSet::new)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_obsolete(&self, commit_id: &CommitId) -> bool {
|
fn is_obsolete(&self, commit_id: &CommitId) -> bool {
|
||||||
self.get_state().obsolete_commits.contains(commit_id)
|
self.get_state().is_obsolete(commit_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_orphan(&self, commit_id: &CommitId) -> bool {
|
fn is_orphan(&self, commit_id: &CommitId) -> bool {
|
||||||
self.get_state().orphan_commits.contains(commit_id)
|
self.get_state().is_orphan(commit_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_divergent(&self, change_id: &ChangeId) -> bool {
|
fn is_divergent(&self, change_id: &ChangeId) -> bool {
|
||||||
self.get_state().divergent_changes.contains_key(change_id)
|
self.get_state().is_divergent(change_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn new_parent(&self, old_parent_id: &CommitId) -> HashSet<CommitId> {
|
fn new_parent(&self, old_parent_id: &CommitId) -> HashSet<CommitId> {
|
||||||
|
@ -301,23 +316,19 @@ pub struct MutableEvolution<'r, 'm: 'r> {
|
||||||
|
|
||||||
impl Evolution for MutableEvolution<'_, '_> {
|
impl Evolution for MutableEvolution<'_, '_> {
|
||||||
fn successors(&self, commit_id: &CommitId) -> HashSet<CommitId> {
|
fn successors(&self, commit_id: &CommitId) -> HashSet<CommitId> {
|
||||||
self.get_state()
|
self.get_state().successors(commit_id)
|
||||||
.successors
|
|
||||||
.get(commit_id)
|
|
||||||
.cloned()
|
|
||||||
.unwrap_or_else(HashSet::new)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_obsolete(&self, commit_id: &CommitId) -> bool {
|
fn is_obsolete(&self, commit_id: &CommitId) -> bool {
|
||||||
self.get_state().obsolete_commits.contains(commit_id)
|
self.get_state().is_obsolete(commit_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_orphan(&self, commit_id: &CommitId) -> bool {
|
fn is_orphan(&self, commit_id: &CommitId) -> bool {
|
||||||
self.get_state().orphan_commits.contains(commit_id)
|
self.get_state().is_orphan(commit_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_divergent(&self, change_id: &ChangeId) -> bool {
|
fn is_divergent(&self, change_id: &ChangeId) -> bool {
|
||||||
self.get_state().divergent_changes.contains_key(change_id)
|
self.get_state().is_divergent(change_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn new_parent(&self, old_parent_id: &CommitId) -> HashSet<CommitId> {
|
fn new_parent(&self, old_parent_id: &CommitId) -> HashSet<CommitId> {
|
||||||
|
|
Loading…
Reference in a new issue