docs: format config.md

This commit is contained in:
Martin von Zweigbergk 2023-01-26 14:45:00 -08:00 committed by Martin von Zweigbergk
parent 780e257b89
commit d4ed8f32b3

View file

@ -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,13 +33,12 @@ 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
Possible values are `always`, `never` and `auto` (default: `auto`). Possible values are `always`, `never` and `auto` (default: `auto`).
`auto` will use color only when writing to a terminal. `auto` will use color only when writing to a terminal.
This setting overrides the `NO_COLOR` environment variable (if set). This setting overrides the `NO_COLOR` environment variable (if set).
@ -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`: