mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-12 07:14:38 +00:00
merge_tools: pass MergeTree
to run_mergetool_external()
This commit is contained in:
parent
a7e5ea06c0
commit
54b9ecce68
2 changed files with 25 additions and 19 deletions
|
@ -7,12 +7,12 @@ use std::sync::Arc;
|
|||
|
||||
use config::ConfigError;
|
||||
use itertools::Itertools;
|
||||
use jj_lib::backend::{FileId, TreeId, TreeValue};
|
||||
use jj_lib::backend::{FileId, MergedTreeId, TreeId, TreeValue};
|
||||
use jj_lib::conflicts::{self, materialize_merge_result};
|
||||
use jj_lib::gitignore::GitIgnoreFile;
|
||||
use jj_lib::matchers::{EverythingMatcher, Matcher};
|
||||
use jj_lib::merge::Merge;
|
||||
use jj_lib::merged_tree::MergedTree;
|
||||
use jj_lib::merged_tree::{MergedTree, MergedTreeBuilder};
|
||||
use jj_lib::repo_path::RepoPath;
|
||||
use jj_lib::settings::UserSettings;
|
||||
use jj_lib::store::Store;
|
||||
|
@ -289,11 +289,11 @@ fn check_out_trees(
|
|||
pub fn run_mergetool_external(
|
||||
editor: &ExternalMergeTool,
|
||||
file_merge: Merge<Option<FileId>>,
|
||||
content: jj_lib::merge::Merge<jj_lib::files::ContentHunk>,
|
||||
content: Merge<jj_lib::files::ContentHunk>,
|
||||
repo_path: &RepoPath,
|
||||
conflict: jj_lib::merge::Merge<Option<TreeValue>>,
|
||||
tree: &Tree,
|
||||
) -> Result<TreeId, ConflictResolveError> {
|
||||
conflict: Merge<Option<TreeValue>>,
|
||||
tree: &MergedTree,
|
||||
) -> Result<MergedTreeId, ConflictResolveError> {
|
||||
let initial_output_content: Vec<u8> = if editor.merge_tool_edits_conflict_markers {
|
||||
let mut materialized_conflict = vec![];
|
||||
materialize_merge_result(&content, &mut materialized_conflict)
|
||||
|
@ -371,19 +371,16 @@ pub fn run_mergetool_external(
|
|||
Merge::normal(new_file_id)
|
||||
};
|
||||
let new_tree_value = match new_file_ids.into_resolved() {
|
||||
Ok(new_file_id) => TreeValue::File {
|
||||
Ok(new_file_id) => Merge::normal(TreeValue::File {
|
||||
id: new_file_id.unwrap(),
|
||||
executable: false,
|
||||
},
|
||||
Err(new_file_ids) => {
|
||||
let new_conflict = conflict.with_new_file_ids(&new_file_ids);
|
||||
let new_conflict_id = tree.store().write_conflict(repo_path, &new_conflict)?;
|
||||
TreeValue::Conflict(new_conflict_id)
|
||||
}
|
||||
}),
|
||||
Err(new_file_ids) => conflict.with_new_file_ids(&new_file_ids),
|
||||
};
|
||||
let mut tree_builder = tree.store().tree_builder(tree.id().clone());
|
||||
tree_builder.set(repo_path.clone(), new_tree_value);
|
||||
Ok(tree_builder.write_tree())
|
||||
let mut tree_builder = MergedTreeBuilder::new(tree.store().clone(), tree.id());
|
||||
tree_builder.set_or_remove(repo_path.clone(), new_tree_value);
|
||||
let new_tree = tree_builder.write_tree()?;
|
||||
Ok(new_tree)
|
||||
}
|
||||
|
||||
// Not interested in $UPPER_CASE_VARIABLES
|
||||
|
|
|
@ -20,6 +20,7 @@ use config::ConfigError;
|
|||
use jj_lib::backend::{TreeId, TreeValue};
|
||||
use jj_lib::conflicts::extract_as_single_hunk;
|
||||
use jj_lib::gitignore::GitIgnoreFile;
|
||||
use jj_lib::merged_tree::MergedTree;
|
||||
use jj_lib::repo_path::RepoPath;
|
||||
use jj_lib::settings::{ConfigResultExt as _, UserSettings};
|
||||
use jj_lib::tree::Tree;
|
||||
|
@ -109,9 +110,17 @@ pub fn run_mergetool(
|
|||
let editor = get_merge_tool_from_settings(ui, settings)?;
|
||||
match editor {
|
||||
MergeTool::Internal => unimplemented!("run_mergetool with internal mergetool"),
|
||||
MergeTool::External(editor) => external::run_mergetool_external(
|
||||
&editor, file_merge, content, repo_path, conflict, tree,
|
||||
),
|
||||
MergeTool::External(editor) => {
|
||||
let new_tree_id = external::run_mergetool_external(
|
||||
&editor,
|
||||
file_merge,
|
||||
content,
|
||||
repo_path,
|
||||
conflict,
|
||||
&MergedTree::Legacy(tree.clone()),
|
||||
)?;
|
||||
Ok(new_tree_id.to_legacy_tree_id())
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue