jj resolve: List remaining conflicts (if any) on success

This can be prevented by the new `--quiet` option.
This commit is contained in:
Ilya Grigoriev 2022-12-23 17:57:10 -08:00
parent b8ba78b996
commit 5ecac4fc44
3 changed files with 37 additions and 2 deletions

View file

@ -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 * `jj debug config-schema` command prints out JSON schema for the jj TOML config
file format. 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 ### Fixed bugs
* When sharing the working copy with a Git repo, we used to forget to export * When sharing the working copy with a Git repo, we used to forget to export

View file

@ -532,6 +532,10 @@ struct ResolveArgs {
// `diff --summary`, but should be more verbose. // `diff --summary`, but should be more verbose.
#[arg(long, short)] #[arg(long, short)]
list: bool, 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 /// 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 /// will attempt to resolve the first conflict we can find. You can use
/// the `--list` argument to find paths to use here. /// the `--list` argument to find paths to use here.
@ -2407,11 +2411,26 @@ fn cmd_resolve(
commit.id().hex() commit.id().hex()
)); ));
let new_tree_id = workspace_command.run_mergetool(ui, &commit.tree(), repo_path)?; 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) .rewrite_commit(command.settings(), &commit)
.set_tree(new_tree_id) .set_tree(new_tree_id)
.write()?; .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( fn print_conflicted_files(

View file

@ -183,6 +183,8 @@ conflict
@r###" @r###"
Working copy now at: 0bb40c908c8b conflict Working copy now at: 0bb40c908c8b conflict
Added 0 files, modified 1 files, removed 0 files Added 0 files, modified 1 files, removed 0 files
After this operation, some files at this revision still have conflicts:
file
"###); "###);
insta::assert_snapshot!( insta::assert_snapshot!(
std::fs::read_to_string(test_env.env_root().join("editor2")).unwrap(), @r###" 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###" test_env.jj_cmd_success(&repo_path, &["resolve", "file2"]), @r###"
Working copy now at: 06cafc2b5489 conflict Working copy now at: 06cafc2b5489 conflict
Added 0 files, modified 1 files, removed 0 files 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"]), insta::assert_snapshot!(test_env.jj_cmd_success(&repo_path, &["diff"]),
@r###" @r###"
@ -554,6 +558,15 @@ fn test_multiple_conflicts() {
file1 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 // For the rest of the test, we call `jj resolve` several times in a row to
// resolve each conflict in the order it chooses. // resolve each conflict in the order it chooses.
test_env.jj_cmd_success(&repo_path, &["undo"]); test_env.jj_cmd_success(&repo_path, &["undo"]);