From 2955bc4a2961dcd39dc770f7c321f1d95460cdb2 Mon Sep 17 00:00:00 2001 From: Martin von Zweigbergk Date: Wed, 10 Mar 2021 15:48:32 -0800 Subject: [PATCH] repo: let repo types directly have an OpStore I'd like to make `ReadonlyView` and `MutableView` focused on just the state of the view (i.e. the set of heads, git refs, etc.). The responsibility for managing the `.jj/view/op_heads/` directory should be moved out of it. This prepares for that. --- lib/src/repo.rs | 32 ++++++++++++++++++++++------- lib/src/view.rs | 17 ++++----------- lib/tests/test_bad_locking.rs | 6 +----- lib/tests/test_commit_concurrent.rs | 5 ++--- src/commands.rs | 2 +- 5 files changed, 33 insertions(+), 29 deletions(-) diff --git a/lib/src/repo.rs b/lib/src/repo.rs index 1cce18657..dccc46528 100644 --- a/lib/src/repo.rs +++ b/lib/src/repo.rs @@ -77,6 +77,13 @@ impl<'a, 'r> RepoRef<'a, 'r> { } } + pub fn op_store(&self) -> &'a Arc { + match self { + RepoRef::Readonly(repo) => repo.op_store(), + RepoRef::Mutable(repo) => repo.op_store(), + } + } + pub fn index(&self) -> IndexRef { match self { RepoRef::Readonly(repo) => IndexRef::Readonly(repo.index()), @@ -103,6 +110,7 @@ pub struct ReadonlyRepo { repo_path: PathBuf, wc_path: PathBuf, store: Arc, + op_store: Arc, settings: RepoSettings, index_store: Arc, index: Mutex>>, @@ -208,7 +216,7 @@ impl ReadonlyRepo { let view = ReadonlyView::init( store.clone(), - op_store, + op_store.clone(), index_store.clone(), repo_path.join("view"), checkout_commit.id().clone(), @@ -218,6 +226,7 @@ impl ReadonlyRepo { repo_path, wc_path, store, + op_store, settings: repo_settings, index_store, index: Mutex::new(None), @@ -278,8 +287,8 @@ impl ReadonlyRepo { let mut locked_index = self.index.lock().unwrap(); if locked_index.is_none() { let op_id = self.view.op_id().clone(); - let op = self.view.op_store().read_operation(&op_id).unwrap(); - let op = Operation::new(self.view.op_store().clone(), op_id, op); + let op = self.op_store.read_operation(&op_id).unwrap(); + let op = Operation::new(self.op_store.clone(), op_id, op); locked_index.replace(self.index_store.get_index_at_op(&op, self.store.as_ref())); } locked_index.as_ref().unwrap().clone() @@ -306,6 +315,10 @@ impl ReadonlyRepo { &self.store } + pub fn op_store(&self) -> &Arc { + &self.op_store + } + pub fn index_store(&self) -> &Arc { &self.index_store } @@ -433,6 +446,7 @@ impl RepoLoader { repo_path: self.repo_path, wc_path: self.wc_path, store: self.store, + op_store: self.op_store, settings: self.repo_settings, index_store: self.index_store, index: Mutex::new(None), @@ -485,16 +499,20 @@ impl<'r> MutableRepo<'r> { RepoRef::Mutable(&self) } + pub fn base_repo(&self) -> &'r ReadonlyRepo { + self.repo + } + pub fn store(&self) -> &Arc { self.repo.store() } - pub fn index(&self) -> &MutableIndex { - &self.index + pub fn op_store(&self) -> &Arc { + self.repo.op_store() } - pub fn base_repo(&self) -> &'r ReadonlyRepo { - self.repo + pub fn index(&self) -> &MutableIndex { + &self.index } pub fn view(&self) -> &MutableView { diff --git a/lib/src/view.rs b/lib/src/view.rs index 6f978487d..5880fe208 100644 --- a/lib/src/view.rs +++ b/lib/src/view.rs @@ -36,7 +36,6 @@ pub enum ViewRef<'a> { Mutable(&'a MutableView), } -// TODO: Move OpStore out of View? impl<'a> ViewRef<'a> { pub fn checkout(&self) -> &'a CommitId { match self { @@ -66,10 +65,10 @@ impl<'a> ViewRef<'a> { } } - pub fn op_store(&self) -> Arc { + fn op_store(&self) -> &Arc { match self { - ViewRef::Readonly(view) => view.op_store(), - ViewRef::Mutable(view) => view.op_store(), + ViewRef::Readonly(view) => &view.op_store, + ViewRef::Mutable(view) => &view.op_store, } } @@ -80,7 +79,7 @@ impl<'a> ViewRef<'a> { } } - pub fn get_operation(&self, id: &OperationId) -> OpStoreResult { + fn get_operation(&self, id: &OperationId) -> OpStoreResult { let data = self.op_store().read_operation(id)?; Ok(Operation::new(self.op_store().clone(), id.clone(), data)) } @@ -490,10 +489,6 @@ impl ReadonlyView { &self.data.git_refs } - pub fn op_store(&self) -> Arc { - self.op_store.clone() - } - pub fn op_id(&self) -> &OperationId { &self.op_id } @@ -520,10 +515,6 @@ impl MutableView { &self.data.git_refs } - pub fn op_store(&self) -> Arc { - self.op_store.clone() - } - pub fn base_op_id(&self) -> &OperationId { &self.base_op_id } diff --git a/lib/tests/test_bad_locking.rs b/lib/tests/test_bad_locking.rs index 2c5b0faed..377d10a9e 100644 --- a/lib/tests/test_bad_locking.rs +++ b/lib/tests/test_bad_locking.rs @@ -131,11 +131,7 @@ fn test_bad_locking_children(use_git: bool) { assert!(merged_repo.view().heads().contains(child1.id())); assert!(merged_repo.view().heads().contains(child2.id())); let op_id = merged_repo.view().op_id().clone(); - let op = merged_repo - .view() - .op_store() - .read_operation(&op_id) - .unwrap(); + let op = merged_repo.op_store().read_operation(&op_id).unwrap(); assert_eq!(op.parents.len(), 2); } diff --git a/lib/tests/test_commit_concurrent.rs b/lib/tests/test_commit_concurrent.rs index fd0a2aea5..f8652b207 100644 --- a/lib/tests/test_commit_concurrent.rs +++ b/lib/tests/test_commit_concurrent.rs @@ -21,9 +21,8 @@ use std::sync::Arc; use test_case::test_case; fn count_non_merge_operations(repo: &ReadonlyRepo) -> u32 { - let view = repo.view(); - let op_store = view.op_store(); - let op_id = view.op_id().clone(); + let op_store = repo.op_store(); + let op_id = repo.view().op_id().clone(); let mut num_ops = 0; for op_id in dag_walk::bfs( diff --git a/src/commands.rs b/src/commands.rs index d4e4ec8c4..85ffbc43b 100644 --- a/src/commands.rs +++ b/src/commands.rs @@ -207,7 +207,7 @@ fn resolve_single_op(repo: &ReadonlyRepo, op_str: &str) -> Result