mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-23 20:53:56 +00:00
jj resolve
: List remaining conflicts (if any) on success
This can be prevented by the new `--quiet` option.
This commit is contained in:
parent
b8ba78b996
commit
5ecac4fc44
3 changed files with 37 additions and 2 deletions
|
@ -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
|
||||||
|
|
|
@ -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(
|
||||||
|
|
|
@ -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"]);
|
||||||
|
|
Loading…
Reference in a new issue