From 5ecac4fc44694e872bc9bfa7f076f0b9fa5fdc62 Mon Sep 17 00:00:00 2001 From: Ilya Grigoriev Date: Fri, 23 Dec 2022 17:57:10 -0800 Subject: [PATCH] `jj resolve`: List remaining conflicts (if any) on success This can be prevented by the new `--quiet` option. --- CHANGELOG.md | 3 +++ src/commands.rs | 23 +++++++++++++++++++++-- tests/test_resolve_command.rs | 13 +++++++++++++ 3 files changed, 37 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index fe953c1cc..c6640bcf7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -29,6 +29,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 * `jj debug config-schema` command prints out JSON schema for the jj TOML config file format. +* `jj resolve` now notifies the user of remaining conflicts, if any, on success. + This can be prevented by the new `--quiet` option. + ### Fixed bugs * When sharing the working copy with a Git repo, we used to forget to export diff --git a/src/commands.rs b/src/commands.rs index 8171be75c..d6f9e1b24 100644 --- a/src/commands.rs +++ b/src/commands.rs @@ -532,6 +532,10 @@ struct ResolveArgs { // `diff --summary`, but should be more verbose. #[arg(long, short)] list: bool, + /// Do not print the list of remaining conflicts (if any) after resolving a + /// conflict + #[arg(long, short, conflicts_with = "list")] + quiet: bool, /// Restrict to these paths when searching for a conflict to resolve. We /// will attempt to resolve the first conflict we can find. You can use /// the `--list` argument to find paths to use here. @@ -2407,11 +2411,26 @@ fn cmd_resolve( commit.id().hex() )); let new_tree_id = workspace_command.run_mergetool(ui, &commit.tree(), repo_path)?; - tx.mut_repo() + let new_commit = tx + .mut_repo() .rewrite_commit(command.settings(), &commit) .set_tree(new_tree_id) .write()?; - workspace_command.finish_transaction(ui, tx) + workspace_command.finish_transaction(ui, tx)?; + + if !args.quiet { + let new_tree = new_commit.tree(); + let new_conflicts = new_tree.conflicts_matching(&EverythingMatcher); + if !new_conflicts.is_empty() { + ui.write("After this operation, some files at this revision still have conflicts:\n")?; + print_conflicted_files( + &new_conflicts, + ui.stdout_formatter().as_mut(), + &workspace_command, + )?; + } + }; + Ok(()) } fn print_conflicted_files( diff --git a/tests/test_resolve_command.rs b/tests/test_resolve_command.rs index 24de8ecf5..96cba4ac8 100644 --- a/tests/test_resolve_command.rs +++ b/tests/test_resolve_command.rs @@ -183,6 +183,8 @@ conflict @r###" Working copy now at: 0bb40c908c8b conflict Added 0 files, modified 1 files, removed 0 files + After this operation, some files at this revision still have conflicts: + file "###); insta::assert_snapshot!( std::fs::read_to_string(test_env.env_root().join("editor2")).unwrap(), @r###" @@ -537,6 +539,8 @@ fn test_multiple_conflicts() { test_env.jj_cmd_success(&repo_path, &["resolve", "file2"]), @r###" Working copy now at: 06cafc2b5489 conflict Added 0 files, modified 1 files, removed 0 files + After this operation, some files at this revision still have conflicts: + file1 "###); insta::assert_snapshot!(test_env.jj_cmd_success(&repo_path, &["diff"]), @r###" @@ -554,6 +558,15 @@ fn test_multiple_conflicts() { file1 "###); + // Repeat the above with the `--quiet` option. + test_env.jj_cmd_success(&repo_path, &["undo"]); + std::fs::write(&editor_script, "expect\n\0write\nresolution file2\n").unwrap(); + insta::assert_snapshot!( + test_env.jj_cmd_success(&repo_path, &["resolve", "--quiet", "file2"]), @r###" + Working copy now at: 02326c070aa4 conflict + Added 0 files, modified 1 files, removed 0 files + "###); + // For the rest of the test, we call `jj resolve` several times in a row to // resolve each conflict in the order it chooses. test_env.jj_cmd_success(&repo_path, &["undo"]);