mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-18 02:04:19 +00:00
Documentation for jj resolve
and merge tool config
This commit is contained in:
parent
e3fd49993e
commit
8222ba94cf
3 changed files with 78 additions and 2 deletions
|
@ -41,6 +41,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||
* The new `jj git remote rename` command allows git remotes to be renamed
|
||||
in-place.
|
||||
|
||||
* The new `jj resolve` command allows resolving simple conflicts with
|
||||
an external 3-way-merge tool.
|
||||
|
||||
* `jj git push` will search `@-` for branches to push if `@` has none.
|
||||
|
||||
* The new revset function `file(pattern..)` finds commits modifying the
|
||||
|
|
|
@ -113,6 +113,70 @@ to diff:
|
|||
merge-tools.kdiff3.edit-args = ["--merge", "--cs", "CreateBakFiles=0"]
|
||||
|
||||
|
||||
## 3-way merge tools for conflict resolution
|
||||
|
||||
The `ui.merge-editor` key specifies the tool used for three-way merge
|
||||
tools by `jj resolve`. For example:
|
||||
|
||||
ui.merge-editor = "meld" # Or "kdiff3" or "vimdiff"
|
||||
|
||||
The "meld", "kdiff3", and "vimdiff" tools can be used out of the box,
|
||||
as long as they are installed.
|
||||
|
||||
To use a different tool named `TOOL`, the arguments to pass to the tool
|
||||
MUST be specified in the `merge-tools.TOOL.merge-args` key. As an example
|
||||
of how to set this key and other tool configuration options, here is
|
||||
the out-of-the-box configuration of the three default tools. (There is
|
||||
no need to copy it to your config file verbatim, but you are welcome to
|
||||
customize it.)
|
||||
|
||||
# merge-tools.kdiff3.program = "kdiff3" # Defaults to the name of the tool if not specified
|
||||
merge-tools.kdiff3.merge-args = ["$base", "$left", "$right", "-o", "$output", "--auto"]
|
||||
merge-tools.meld.merge-args = ["$left", "$base", "$right", "-o", "$output", "--auto-merge"]
|
||||
|
||||
merge-tools.vimdiff.merge-args = ["-f", "-d", "$output", "-M",
|
||||
"$left", "$base", "$right",
|
||||
"-c", "wincmd J", "-c", "set modifiable",
|
||||
"-c", "set write"]
|
||||
merge-tools.vimdiff.program = "vim"
|
||||
merge-tools.vimdiff.merge-tool-edits-conflict-markers = true # See below for an explanation
|
||||
|
||||
`jj` replaces the following arguments with the appropriate file names:
|
||||
|
||||
- `$output` (REQUIRED) is replaced with the name of the file that the
|
||||
merge tool should output. `jj` will read this file after the merge tool
|
||||
exits.
|
||||
|
||||
- `$left` and `$right` are replaced with the paths to two files containing
|
||||
the content of each side of the conflict.
|
||||
|
||||
- `$base` is replaced with the path to a file containing the
|
||||
contents of the conflicted file in the last common ancestor of the two
|
||||
sides of the conflict.
|
||||
|
||||
### Editing conflict markers with a tool or a text editor
|
||||
|
||||
By default, the merge tool starts with an empty output file. If the tool
|
||||
puts anything into the output file, and exits with the 0 exit code,
|
||||
`jj` assumes that the conflict is fully resolved. This is appropriate
|
||||
for most graphical merge tools.
|
||||
|
||||
Some tools (e.g. `vimdiff`) can present a multi-way diff but
|
||||
don't resolve conflict themselves. When using such tools, `jj`
|
||||
can help you by populating the output file with conflict markers
|
||||
before starting the merge tool (instead of leaving the output file
|
||||
empty and letting the merge tool fill it in). To do that, set the
|
||||
`merge-tools.vimdiff.merge-tool-edits-conflict-markers = true` option.
|
||||
|
||||
With this option set, if the output file still contains conflict markers
|
||||
after the conflict is done, `jj` assumes that the conflict was only
|
||||
partially resolved and parses the conflict markers to get the new state
|
||||
of the conflict. The conflict is considered fully resolved when there
|
||||
are no conflict markers left.
|
||||
|
||||
|
||||
|
||||
|
||||
# Alternative ways to specify configuration settings
|
||||
|
||||
Instead of `~/.jjconfig.toml`, the config settings can be located at
|
||||
|
|
|
@ -13,6 +13,15 @@ ui.relative-timestamps = false # the default
|
|||
ui.editor = "pico" # the default
|
||||
# ui.editor = "vim"
|
||||
|
||||
ui.diff-editor = "meld" # default, requires meld to be installed
|
||||
# ui.diff-editor = "vimdiff"
|
||||
|
||||
diff-editor = "meld" # default, requires meld to be installed
|
||||
# diff-editor = "vimdiff"
|
||||
ui.merge-editor = "meld" # default
|
||||
# ui.merge-editor = "vimdiff"
|
||||
# ui.merge-editor = "kdiff3"
|
||||
|
||||
# The three merge tools above are pre-configured. For detailed information
|
||||
# about how to change the default configuration or how to configure another tool,
|
||||
# see documentation in config.md. An example:
|
||||
|
||||
# merge-tools.meld.program = "C:\\Program Files\\Meld\\meld.exe" # If not in PATH
|
||||
|
|
Loading…
Reference in a new issue