ok/jj
1
0
Fork 0
forked from mirrors/jj

cli: inline CommandHelper::workspace_helper_internal()

The control flow is pretty simple. We don't need a inner function that
implements the both.
This commit is contained in:
Yuya Nishihara 2024-01-11 19:46:57 +09:00
parent a66e2a0a6d
commit 650c1f6521

View file

@ -591,31 +591,25 @@ impl CommandHelper {
self.maybe_workspace_loader.as_ref().map_err(Clone::clone) self.maybe_workspace_loader.as_ref().map_err(Clone::clone)
} }
/// Loads workspace and repo, then snapshots the working copy if allowed.
#[instrument(skip(self, ui))] #[instrument(skip(self, ui))]
fn workspace_helper_internal( pub fn workspace_helper(&self, ui: &mut Ui) -> Result<WorkspaceCommandHelper, CommandError> {
&self, let mut workspace_command = self.workspace_helper_no_snapshot(ui)?;
ui: &mut Ui, workspace_command.snapshot(ui)?;
snapshot: bool,
) -> Result<WorkspaceCommandHelper, CommandError> {
let workspace = self.load_workspace()?;
let op_head = self.resolve_operation(ui, workspace.repo_loader())?;
let repo = workspace.repo_loader().load_at(&op_head)?;
let mut workspace_command = self.for_loaded_repo(ui, workspace, repo)?;
if snapshot {
workspace_command.snapshot(ui)?;
}
Ok(workspace_command) Ok(workspace_command)
} }
pub fn workspace_helper(&self, ui: &mut Ui) -> Result<WorkspaceCommandHelper, CommandError> { /// Loads workspace and repo, but never snapshots the working copy. Most
self.workspace_helper_internal(ui, true) /// commands should use `workspace_helper()` instead.
} #[instrument(skip(self, ui))]
pub fn workspace_helper_no_snapshot( pub fn workspace_helper_no_snapshot(
&self, &self,
ui: &mut Ui, ui: &mut Ui,
) -> Result<WorkspaceCommandHelper, CommandError> { ) -> Result<WorkspaceCommandHelper, CommandError> {
self.workspace_helper_internal(ui, false) let workspace = self.load_workspace()?;
let op_head = self.resolve_operation(ui, workspace.repo_loader())?;
let repo = workspace.repo_loader().load_at(&op_head)?;
self.for_loaded_repo(ui, workspace, repo)
} }
#[instrument(skip_all)] #[instrument(skip_all)]