From b48e06a94b30cf1eec92679665a34a51691ee138 Mon Sep 17 00:00:00 2001 From: Martin von Zweigbergk Date: Fri, 28 May 2021 10:50:46 -0700 Subject: [PATCH] cli: make `jj status` get the working copy commit from the view This prepares `jj status` for working better on an old repo state (with `--at-op`). When looking at an old repo state, the "working copy" should reflect the state from that state, i.e. the view's "checkout", not the current working copy. --- src/commands.rs | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/commands.rs b/src/commands.rs index 7e7548067..d0c334b3e 100644 --- a/src/commands.rs +++ b/src/commands.rs @@ -298,13 +298,12 @@ impl RepoCommandHelper { Ok(()) } - fn commit_working_copy(&mut self) -> Commit { - let (reloaded_repo, commit) = self + fn commit_working_copy(&mut self) { + let (reloaded_repo, _) = self .repo .working_copy_locked() .commit(&self.settings, self.repo.clone()); self.repo = reloaded_repo; - commit } fn start_transaction(&self, description: &str) -> Transaction { @@ -1149,8 +1148,9 @@ fn cmd_status( _sub_matches: &ArgMatches, ) -> Result<(), CommandError> { let mut repo_command = command.repo_helper(ui)?; - let commit = repo_command.commit_working_copy(); + repo_command.commit_working_copy(); let repo = repo_command.repo(); + let commit = repo.store().get_commit(repo.view().checkout()).unwrap(); ui.write("Parent commit: ")?; ui.write_commit_summary(repo.as_repo_ref(), &commit.parents()[0])?; ui.write("\n")?;