mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-18 18:27:38 +00:00
evolution: don't wrap State in Mutex<Option<>>
This commit is contained in:
parent
fce5ec21f6
commit
110c083e78
1 changed files with 10 additions and 33 deletions
|
@ -13,7 +13,7 @@
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
use std::collections::{HashMap, HashSet};
|
use std::collections::{HashMap, HashSet};
|
||||||
use std::sync::{Arc, Mutex, MutexGuard};
|
use std::sync::{Arc, Mutex};
|
||||||
|
|
||||||
use crate::commit::Commit;
|
use crate::commit::Commit;
|
||||||
use crate::commit_builder::CommitBuilder;
|
use crate::commit_builder::CommitBuilder;
|
||||||
|
@ -302,60 +302,43 @@ impl<'r> ReadonlyEvolution<'r> {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn start_modification<'m>(&self, repo: &'m MutableRepo<'r>) -> MutableEvolution<'r, 'm> {
|
pub fn start_modification<'m>(&self, repo: &'m MutableRepo<'r>) -> MutableEvolution<'r, 'm> {
|
||||||
let locked_state = self.state.lock().unwrap();
|
|
||||||
let state = locked_state.as_ref().map(|state| state.as_ref().clone());
|
|
||||||
MutableEvolution {
|
MutableEvolution {
|
||||||
repo,
|
repo,
|
||||||
state: Mutex::new(state),
|
state: self.get_state().as_ref().clone(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct MutableEvolution<'r, 'm: 'r> {
|
pub struct MutableEvolution<'r, 'm: 'r> {
|
||||||
repo: &'m MutableRepo<'r>,
|
repo: &'m MutableRepo<'r>,
|
||||||
state: Mutex<Option<State>>,
|
state: State,
|
||||||
}
|
}
|
||||||
|
|
||||||
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.locked_state().as_ref().unwrap().successors(commit_id)
|
self.state.successors(commit_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_obsolete(&self, commit_id: &CommitId) -> bool {
|
fn is_obsolete(&self, commit_id: &CommitId) -> bool {
|
||||||
self.locked_state().as_ref().unwrap().is_obsolete(commit_id)
|
self.state.is_obsolete(commit_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_orphan(&self, commit_id: &CommitId) -> bool {
|
fn is_orphan(&self, commit_id: &CommitId) -> bool {
|
||||||
self.locked_state().as_ref().unwrap().is_orphan(commit_id)
|
self.state.is_orphan(commit_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_divergent(&self, change_id: &ChangeId) -> bool {
|
fn is_divergent(&self, change_id: &ChangeId) -> bool {
|
||||||
self.locked_state()
|
self.state.is_divergent(change_id)
|
||||||
.as_ref()
|
|
||||||
.unwrap()
|
|
||||||
.is_divergent(change_id)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn new_parent(&self, old_parent_id: &CommitId) -> HashSet<CommitId> {
|
fn new_parent(&self, old_parent_id: &CommitId) -> HashSet<CommitId> {
|
||||||
self.locked_state()
|
self.state.new_parent(self.repo.store(), old_parent_id)
|
||||||
.as_ref()
|
|
||||||
.unwrap()
|
|
||||||
.new_parent(self.repo.store(), old_parent_id)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl MutableEvolution<'_, '_> {
|
impl MutableEvolution<'_, '_> {
|
||||||
fn locked_state(&self) -> MutexGuard<Option<State>> {
|
|
||||||
let mut locked_state = self.state.lock().unwrap();
|
|
||||||
if locked_state.is_none() {
|
|
||||||
locked_state.replace(State::calculate(self.repo.store(), self.repo.view()));
|
|
||||||
}
|
|
||||||
locked_state
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn invalidate(&mut self) {
|
pub fn invalidate(&mut self) {
|
||||||
let mut locked_state = self.state.lock();
|
self.state = State::calculate(self.repo.store(), self.repo.view());
|
||||||
locked_state.as_mut().unwrap().take();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -366,13 +349,7 @@ pub fn evolve(
|
||||||
) {
|
) {
|
||||||
let store = tx.store().clone();
|
let store = tx.store().clone();
|
||||||
// TODO: update the state in the transaction
|
// TODO: update the state in the transaction
|
||||||
let state = tx
|
let state = tx.as_repo_mut().evolution_mut().state.clone();
|
||||||
.as_repo_mut()
|
|
||||||
.evolution_mut()
|
|
||||||
.locked_state()
|
|
||||||
.as_ref()
|
|
||||||
.unwrap()
|
|
||||||
.clone();
|
|
||||||
|
|
||||||
// Resolving divergence can creates new orphans but not vice versa, so resolve
|
// Resolving divergence can creates new orphans but not vice versa, so resolve
|
||||||
// divergence first.
|
// divergence first.
|
||||||
|
|
Loading…
Reference in a new issue