mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-03 18:24:19 +00:00
docs: format config.md
This commit is contained in:
parent
780e257b89
commit
d4ed8f32b3
1 changed files with 69 additions and 81 deletions
146
docs/config.md
146
docs/config.md
|
@ -2,30 +2,29 @@
|
||||||
|
|
||||||
These are the config settings available to jj/Jujutsu.
|
These are the config settings available to jj/Jujutsu.
|
||||||
|
|
||||||
The config settings are loaded from the following locations. Less common ways
|
The config settings are loaded from the following locations. Less common ways to
|
||||||
to specify `jj` config settings are discussed in a later section.
|
specify `jj` config settings are discussed in a later section.
|
||||||
|
|
||||||
* `~/.jjconfig.toml` (global)
|
* `~/.jjconfig.toml` (global)
|
||||||
* `.jj/repo/config.toml` (per-repository)
|
* `.jj/repo/config.toml` (per-repository)
|
||||||
|
|
||||||
See the [TOML site](https://toml.io/en/) for more on syntax.
|
See the [TOML site](https://toml.io/en/) for more on syntax. One thing to
|
||||||
One thing to remember is that anything under a heading can be dotted
|
remember is that anything under a heading can be dotted
|
||||||
e.g. `user.name = "YOUR NAME"` is equivalent to:
|
e.g. `user.name = "YOUR NAME"` is equivalent to:
|
||||||
|
|
||||||
[user]
|
[user]
|
||||||
name = "YOUR NAME"
|
name = "YOUR NAME"
|
||||||
|
|
||||||
Headings only need to be set once in the real config file but Jujutsu
|
Headings only need to be set once in the real config file but Jujutsu favors the
|
||||||
favors the dotted style in these instructions, if only because it's
|
dotted style in these instructions, if only because it's easier to write down in
|
||||||
easier to write down in an unconfusing way. If you are confident with
|
an unconfusing way. If you are confident with TOML then use whichever suits you
|
||||||
TOML then use whichever suits you in your config. If you mix the styles,
|
in your config. If you mix the styles, put the dotted keys before the first
|
||||||
put the dotted keys before the first heading.
|
heading.
|
||||||
|
|
||||||
The other thing to remember is that the value of a setting (the part
|
|
||||||
to the right of the `=` sign) should be surrounded in quotes if it's
|
|
||||||
a string. That's probably enough TOML to keep you out of trouble but
|
|
||||||
the syntax guide is very short if you ever need to check.
|
|
||||||
|
|
||||||
|
The other thing to remember is that the value of a setting (the part to the
|
||||||
|
right of the `=` sign) should be surrounded in quotes if it's a string. That's
|
||||||
|
probably enough TOML to keep you out of trouble but the syntax guide is very
|
||||||
|
short if you ever need to check.
|
||||||
|
|
||||||
## User settings
|
## User settings
|
||||||
|
|
||||||
|
@ -34,7 +33,6 @@ the syntax guide is very short if you ever need to check.
|
||||||
|
|
||||||
Don't forget to change these to your own details!
|
Don't forget to change these to your own details!
|
||||||
|
|
||||||
|
|
||||||
## UI settings
|
## UI settings
|
||||||
|
|
||||||
### Colorizing output
|
### Colorizing output
|
||||||
|
@ -50,8 +48,8 @@ This setting overrides the `NO_COLOR` environment variable (if set).
|
||||||
|
|
||||||
ui.unique-prefixes = "none"
|
ui.unique-prefixes = "none"
|
||||||
|
|
||||||
Whether to highlight a unique prefix for commit & change ids. Possible
|
Whether to highlight a unique prefix for commit & change ids. Possible values
|
||||||
values are `brackets` and `none` (default: `brackets`).
|
are `brackets` and `none` (default: `brackets`).
|
||||||
|
|
||||||
### Relative timestamps
|
### Relative timestamps
|
||||||
|
|
||||||
|
@ -60,28 +58,26 @@ values are `brackets` and `none` (default: `brackets`).
|
||||||
False by default, but setting to true will change timestamps to be rendered
|
False by default, but setting to true will change timestamps to be rendered
|
||||||
as `x days/hours/seconds ago` instead of being rendered as a full timestamp.
|
as `x days/hours/seconds ago` instead of being rendered as a full timestamp.
|
||||||
|
|
||||||
|
|
||||||
## Pager
|
## Pager
|
||||||
|
|
||||||
The default pager is can be set via `ui.pager` or the `PAGER` environment
|
The default pager is can be set via `ui.pager` or the `PAGER` environment
|
||||||
variable.
|
variable. The priority is as follows (environment variables are marked with
|
||||||
The priority is as follows (environment variables are marked with a `$`):
|
a `$`):
|
||||||
|
|
||||||
`ui.pager` > `$PAGER`
|
`ui.pager` > `$PAGER`
|
||||||
|
|
||||||
`less -FRX` is the default pager in the absence of any other setting.
|
`less -FRX` is the default pager in the absence of any other setting.
|
||||||
|
|
||||||
|
|
||||||
## Editor
|
## Editor
|
||||||
|
|
||||||
The default editor is set via `ui.editor`, though there are several
|
The default editor is set via `ui.editor`, though there are several places to
|
||||||
places to set it. The priority is as follows (environment variables
|
set it. The priority is as follows (environment variables are marked with
|
||||||
are marked with a `$`):
|
a `$`):
|
||||||
|
|
||||||
`$JJ_EDITOR` > `ui.editor` > `$VISUAL` > `$EDITOR`
|
`$JJ_EDITOR` > `ui.editor` > `$VISUAL` > `$EDITOR`
|
||||||
|
|
||||||
Pico is the default editor in the absence of any other setting, but you
|
Pico is the default editor in the absence of any other setting, but you could
|
||||||
could set it explicitly too.
|
set it explicitly too.
|
||||||
|
|
||||||
ui.editor = "pico"
|
ui.editor = "pico"
|
||||||
|
|
||||||
|
@ -101,48 +97,46 @@ For GUI editors you possibly need to use a `-w` or `--wait`. Some examples:
|
||||||
|
|
||||||
Obviously, you would only set one line, don't copy them all in!
|
Obviously, you would only set one line, don't copy them all in!
|
||||||
|
|
||||||
|
|
||||||
## Editing diffs
|
## Editing diffs
|
||||||
|
|
||||||
The `ui.diff-editor` setting affects the tool used for editing diffs (e.g.
|
The `ui.diff-editor` setting affects the tool used for editing diffs (e.g.
|
||||||
`jj split`, `jj amend -i`). The default is `meld`. The left and right
|
`jj split`, `jj amend -i`). The default is `meld`. The left and right
|
||||||
directories to diff are passed as the first and second argument respectively.
|
directories to diff are passed as the first and second argument respectively.
|
||||||
|
|
||||||
For example:
|
For example:
|
||||||
|
|
||||||
ui.diff-editor = "kdiff3"
|
ui.diff-editor = "kdiff3"
|
||||||
|
|
||||||
Custom arguments can be added, and will be inserted before the paths
|
Custom arguments can be added, and will be inserted before the paths to diff:
|
||||||
to diff:
|
|
||||||
|
|
||||||
# merge-tools.kdiff3.program = "kdiff3" # Defaults to the name of the tool if not specified
|
# merge-tools.kdiff3.program = "kdiff3" # Defaults to the name of the tool if not specified
|
||||||
merge-tools.kdiff3.edit-args = ["--merge", "--cs", "CreateBakFiles=0"]
|
merge-tools.kdiff3.edit-args = ["--merge", "--cs", "CreateBakFiles=0"]
|
||||||
|
|
||||||
### Using Vim as a diff editor
|
### Using Vim as a diff editor
|
||||||
|
|
||||||
Using `ui.diff-editor = "vimdiff"` is possible but not recommended.
|
Using `ui.diff-editor = "vimdiff"` is possible but not recommended. For a better
|
||||||
For a better experience, you can follow these [instructions] to
|
experience, you can follow these [instructions] to configure
|
||||||
configure the [`DirDiff` Vim plugin].
|
the [`DirDiff` Vim plugin].
|
||||||
|
|
||||||
[instructions]: https://gist.github.com/ilyagr/5d6339fb7dac5e7ab06fe1561ec62d45
|
[instructions]: https://gist.github.com/ilyagr/5d6339fb7dac5e7ab06fe1561ec62d45
|
||||||
|
|
||||||
[`DirDiff` Vim plugin]: https://github.com/will133/vim-dirdiff
|
[`DirDiff` Vim plugin]: https://github.com/will133/vim-dirdiff
|
||||||
|
|
||||||
## 3-way merge tools for conflict resolution
|
## 3-way merge tools for conflict resolution
|
||||||
|
|
||||||
The `ui.merge-editor` key specifies the tool used for three-way merge
|
The `ui.merge-editor` key specifies the tool used for three-way merge tools
|
||||||
tools by `jj resolve`. For example:
|
by `jj resolve`. For example:
|
||||||
|
|
||||||
ui.merge-editor = "meld" # Or "kdiff3" or "vimdiff"
|
ui.merge-editor = "meld" # Or "kdiff3" or "vimdiff"
|
||||||
|
|
||||||
The "meld", "kdiff3", and "vimdiff" tools can be used out of the box,
|
The "meld", "kdiff3", and "vimdiff" tools can be used out of the box, as long as
|
||||||
as long as they are installed.
|
they are installed.
|
||||||
|
|
||||||
To use a different tool named `TOOL`, the arguments to pass to the tool
|
To use a different tool named `TOOL`, the arguments to pass to the tool MUST be
|
||||||
MUST be specified in the `merge-tools.TOOL.merge-args` key. As an example
|
specified in the `merge-tools.TOOL.merge-args` key. As an example of how to set
|
||||||
of how to set this key and other tool configuration options, here is
|
this key and other tool configuration options, here is the out-of-the-box
|
||||||
the out-of-the-box configuration of the three default tools. (There is
|
configuration of the three default tools. (There is no need to copy it to your
|
||||||
no need to copy it to your config file verbatim, but you are welcome to
|
config file verbatim, but you are welcome to customize it.)
|
||||||
customize it.)
|
|
||||||
|
|
||||||
# merge-tools.kdiff3.program = "kdiff3" # Defaults to the name of the tool if not specified
|
# 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.kdiff3.merge-args = ["$base", "$left", "$right", "-o", "$output", "--auto"]
|
||||||
|
@ -157,64 +151,58 @@ customize it.)
|
||||||
|
|
||||||
`jj` replaces the following arguments with the appropriate file names:
|
`jj` replaces the following arguments with the appropriate file names:
|
||||||
|
|
||||||
- `$output` (REQUIRED) is replaced with the name of the file that the
|
- `$output` (REQUIRED) is replaced with the name of the file that the merge tool
|
||||||
merge tool should output. `jj` will read this file after the merge tool
|
should output. `jj` will read this file after the merge tool exits.
|
||||||
exits.
|
|
||||||
|
|
||||||
- `$left` and `$right` are replaced with the paths to two files containing
|
- `$left` and `$right` are replaced with the paths to two files containing the
|
||||||
the content of each side of the conflict.
|
content of each side of the conflict.
|
||||||
|
|
||||||
- `$base` is replaced with the path to a file containing the
|
- `$base` is replaced with the path to a file containing the contents of the
|
||||||
contents of the conflicted file in the last common ancestor of the two
|
conflicted file in the last common ancestor of the two sides of the conflict.
|
||||||
sides of the conflict.
|
|
||||||
|
|
||||||
### Editing conflict markers with a tool or a text editor
|
### Editing conflict markers with a tool or a text editor
|
||||||
|
|
||||||
By default, the merge tool starts with an empty output file. If the tool
|
By default, the merge tool starts with an empty output file. If the tool puts
|
||||||
puts anything into the output file, and exits with the 0 exit code,
|
anything into the output file, and exits with the 0 exit code,
|
||||||
`jj` assumes that the conflict is fully resolved. This is appropriate
|
`jj` assumes that the conflict is fully resolved. This is appropriate for most
|
||||||
for most graphical merge tools.
|
graphical merge tools.
|
||||||
|
|
||||||
Some tools (e.g. `vimdiff`) can present a multi-way diff but
|
Some tools (e.g. `vimdiff`) can present a multi-way diff but don't resolve
|
||||||
don't resolve conflict themselves. When using such tools, `jj`
|
conflict themselves. When using such tools, `jj`
|
||||||
can help you by populating the output file with conflict markers
|
can help you by populating the output file with conflict markers before starting
|
||||||
before starting the merge tool (instead of leaving the output file
|
the merge tool (instead of leaving the output file empty and letting the merge
|
||||||
empty and letting the merge tool fill it in). To do that, set the
|
tool fill it in). To do that, set the
|
||||||
`merge-tools.vimdiff.merge-tool-edits-conflict-markers = true` option.
|
`merge-tools.vimdiff.merge-tool-edits-conflict-markers = true` option.
|
||||||
|
|
||||||
With this option set, if the output file still contains conflict markers
|
With this option set, if the output file still contains conflict markers after
|
||||||
after the conflict is done, `jj` assumes that the conflict was only
|
the conflict is done, `jj` assumes that the conflict was only partially resolved
|
||||||
partially resolved and parses the conflict markers to get the new state
|
and parses the conflict markers to get the new state of the conflict. The
|
||||||
of the conflict. The conflict is considered fully resolved when there
|
conflict is considered fully resolved when there are no conflict markers left.
|
||||||
are no conflict markers left.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Alternative ways to specify configuration settings
|
# Alternative ways to specify configuration settings
|
||||||
|
|
||||||
Instead of `~/.jjconfig.toml`, the config settings can be located at
|
Instead of `~/.jjconfig.toml`, the config settings can be located at
|
||||||
`$XDG_CONFIG_HOME/jj/config.toml` as per the [XDG specification].
|
`$XDG_CONFIG_HOME/jj/config.toml` as per the [XDG specification]. It is an error
|
||||||
It is an error for both of these files to exist.
|
for both of these files to exist.
|
||||||
|
|
||||||
[XDG specification]: https://specifications.freedesktop.org/basedir-spec/basedir-spec-latest.html
|
[XDG specification]: https://specifications.freedesktop.org/basedir-spec/basedir-spec-latest.html
|
||||||
|
|
||||||
The location of the `jj` config file can also be overriden with the
|
The location of the `jj` config file can also be overriden with the
|
||||||
`JJ_CONFIG` environment variable. If it is not empty, it should contain
|
`JJ_CONFIG` environment variable. If it is not empty, it should contain the path
|
||||||
the path to a TOML file that will be used instead of any configuration
|
to a TOML file that will be used instead of any configuration file in the
|
||||||
file in the default locations. For example,
|
default locations. For example,
|
||||||
|
|
||||||
env JJ_CONFIG=/dev/null jj log # Ignores any settings specified in the config file.
|
env JJ_CONFIG=/dev/null jj log # Ignores any settings specified in the config file.
|
||||||
|
|
||||||
You can use one or more `--config-toml` options on the command line to
|
You can use one or more `--config-toml` options on the command line to specify
|
||||||
specify additional configuration settings. This overrides settings
|
additional configuration settings. This overrides settings defined in config
|
||||||
defined in config files or environment variables. For example,
|
files or environment variables. For example,
|
||||||
|
|
||||||
jj --config-toml='ui.color="always"' --config-toml='ui.difftool="kdiff3"' split
|
jj --config-toml='ui.color="always"' --config-toml='ui.difftool="kdiff3"' split
|
||||||
|
|
||||||
Config specified this way must be valid TOML. In particular, string
|
Config specified this way must be valid TOML. In particular, string values must
|
||||||
values must be surrounded by quotes. To pass these quotes to `jj`, most
|
be surrounded by quotes. To pass these quotes to `jj`, most shells require
|
||||||
shells require surrounding those quotes with single quotes as shown above.
|
surrounding those quotes with single quotes as shown above.
|
||||||
|
|
||||||
In `sh`-compatible shells, `--config-toml` can be used to merge entire TOML
|
In `sh`-compatible shells, `--config-toml` can be used to merge entire TOML
|
||||||
files with the config specified in `.jjconfig.toml`:
|
files with the config specified in `.jjconfig.toml`:
|
||||||
|
|
Loading…
Reference in a new issue