From f5a336664dd4055df9111d561fc60a34bb7ffab6 Mon Sep 17 00:00:00 2001 From: Evan Mesterhazy Date: Fri, 1 Mar 2024 12:28:22 -0500 Subject: [PATCH] Replace NewRepoData with ReadonlyRepo in the UnpublishedOperation struct `NewRepoData` is just a container that holds data used to construct a `ReadonlyRepo`. The `ReaonlyRepo` is always constructed before the `UnpublishedOperation` is dropped, so we can simply construct the `ReadonlyRepo` upfront and delete the `NewRepoData` type. --- lib/src/transaction.rs | 35 +++++++++-------------------------- 1 file changed, 9 insertions(+), 26 deletions(-) diff --git a/lib/src/transaction.rs b/lib/src/transaction.rs index 92855c367e..aace3b55eb 100644 --- a/lib/src/transaction.rs +++ b/lib/src/transaction.rs @@ -147,12 +147,6 @@ pub fn create_op_metadata( } } -struct NewRepoData { - operation: Operation, - view: View, - index: Box, -} - /// An Operation which has been written to the operation store but not /// published. The repo can be loaded at an unpublished Operation, but the /// Operation will not be visible in the op log if the repo is loaded at head. @@ -162,7 +156,7 @@ struct NewRepoData { #[must_use = "Either publish() or leave_unpublished() must be called to finish the operation."] pub struct UnpublishedOperation { repo_loader: RepoLoader, - data: NewRepoData, + repo: Arc, } impl UnpublishedOperation { @@ -172,34 +166,23 @@ impl UnpublishedOperation { view: View, index: Box, ) -> Self { - UnpublishedOperation { - repo_loader, - data: NewRepoData { - operation, - view, - index, - }, - } + let repo = repo_loader.create_from(operation, view, index); + UnpublishedOperation { repo_loader, repo } } pub fn operation(&self) -> &Operation { - &self.data.operation + self.repo.operation() } pub fn publish(self) -> Arc { - let data = self.data; - { - let _lock = self.repo_loader.op_heads_store().lock(); - self.repo_loader - .op_heads_store() - .update_op_heads(data.operation.parent_ids(), data.operation.id()); - } + let _lock = self.repo_loader.op_heads_store().lock(); self.repo_loader - .create_from(data.operation, data.view, data.index) + .op_heads_store() + .update_op_heads(self.operation().parent_ids(), self.operation().id()); + self.repo } pub fn leave_unpublished(self) -> Arc { - self.repo_loader - .create_from(self.data.operation, self.data.view, self.data.index) + self.repo } }