.ie \n(.g .ds Aq \(aq .el .ds Aq ' .TH jj-fix 1 "fix " .SH NAME jj\-fix \- Update files with formatting fixes or other changes .SH SYNOPSIS \fBjj fix\fR [\fB\-s\fR|\fB\-\-source\fR] [\fB\-\-include\-unchanged\-files\fR] [\fB\-R\fR|\fB\-\-repository\fR] [\fB\-\-ignore\-working\-copy\fR] [\fB\-\-ignore\-immutable\fR] [\fB\-\-at\-operation\fR] [\fB\-\-debug\fR] [\fB\-\-color\fR] [\fB\-\-quiet\fR] [\fB\-\-no\-pager\fR] [\fB\-\-config\fR] [\fB\-\-config\-file\fR] [\fB\-h\fR|\fB\-\-help\fR] [\fIFILESETS\fR] .SH DESCRIPTION Update files with formatting fixes or other changes .PP The primary use case for this command is to apply the results of automatic code formatting tools to revisions that may not be properly formatted yet. It can also be used to modify files with other tools like `sed` or `sort`. .PP The changed files in the given revisions will be updated with any fixes determined by passing their file content through any external tools the user has configured for those files. Descendants will also be updated by passing their versions of the same files through the same tools, which will ensure that the fixes are not lost. This will never result in new conflicts. Files with existing conflicts will be updated on all sides of the conflict, which can potentially increase or decrease the number of conflict markers. .PP The external tools must accept the current file content on standard input, and return the updated file content on standard output. A tool\*(Aqs output will not be used unless it exits with a successful exit code. Output on standard error will be passed through to the terminal. .PP Tools are defined in a table where the keys are arbitrary identifiers and the values have the following properties: \- `command`: The arguments used to run the tool. The first argument is the path to an executable file. Arguments can contain the substring `$path`, which will be replaced with the repo\-relative path of the file being fixed. It is useful to provide the path to tools that include the path in error messages, or behave differently based on the directory or file name. \- `patterns`: Determines which files the tool will affect. If this list is empty, no files will be affected by the tool. If there are multiple patterns, the tool is applied only once to each file in the union of the patterns. \- `enabled`: Enables or disables the tool. If omitted, the tool is enabled. This is useful for defining disabled tools in user configuration that can be enabled in individual repositories with one config setting. .PP For example, the following configuration defines how two code formatters (`clang\-format` and `black`) will apply to three different file extensions (`.cc`, `.h`, and `.py`): .PP ```toml [fix.tools.clang\-format] command = ["/usr/bin/clang\-format", "\-\-assume\-filename=$path"] patterns = ["glob:\*(Aq**/*.cc\*(Aq", "glob:\*(Aq**/*.h\*(Aq"] .PP [fix.tools.black] command = ["/usr/bin/black", "\-", "\-\-stdin\-filename=$path"] patterns = ["glob:\*(Aq**/*.py\*(Aq"] ``` .PP Execution order of tools that affect the same file is deterministic, but currently unspecified, and may change between releases. If two tools affect the same file, the second tool to run will receive its input from the output of the first tool. .SH OPTIONS .TP \fB\-s\fR, \fB\-\-source\fR=\fIREVSETS\fR Fix files in the specified revision(s) and their descendants. If no revisions are specified, this defaults to the `revsets.fix` setting, or `reachable(@, mutable())` if it is not set .TP \fB\-\-include\-unchanged\-files\fR Fix unchanged files in addition to changed ones. If no paths are specified, all files in the repo will be fixed .TP \fB\-R\fR, \fB\-\-repository\fR=\fIREPOSITORY\fR Path to repository to operate on By default, Jujutsu searches for the closest .jj/ directory in an ancestor of the current working directory. .TP \fB\-\-ignore\-working\-copy\fR Don\*(Aqt snapshot the working copy, and don\*(Aqt update it By default, Jujutsu snapshots the working copy at the beginning of every command. The working copy is also updated at the end of the command, if the command modified the working\-copy commit (`@`). If you want to avoid snapshotting the working copy and instead see a possibly stale working\-copy commit, you can use `\-\-ignore\-working\-copy`. This may be useful e.g. in a command prompt, especially if you have another process that commits the working copy. Loading the repository at a specific operation with `\-\-at\-operation` implies `\-\-ignore\-working\-copy`. .TP \fB\-\-ignore\-immutable\fR Allow rewriting immutable commits By default, Jujutsu prevents rewriting commits in the configured set of immutable commits. This option disables that check and lets you rewrite any commit but the root commit. This option only affects the check. It does not affect the `immutable_heads()` revset or the `immutable` template keyword. .TP \fB\-\-at\-operation\fR=\fIAT_OPERATION\fR Operation to load the repo at Operation to load the repo at. By default, Jujutsu loads the repo at the most recent operation, or at the merge of the divergent operations if any. You can use `\-\-at\-op=` to see what the repo looked like at an earlier operation. For example `jj \-\-at\-op= st` will show you what `jj st` would have shown you when the given operation had just finished. `\-\-at\-op=@` is pretty much the same as the default except that divergent operations will never be merged. Use `jj op log` to find the operation ID you want. Any unambiguous prefix of the operation ID is enough. When loading the repo at an earlier operation, the working copy will be ignored, as if `\-\-ignore\-working\-copy` had been specified. It is possible to run mutating commands when loading the repo at an earlier operation. Doing that is equivalent to having run concurrent commands starting at the earlier operation. There\*(Aqs rarely a reason to do that, but it is possible. .TP \fB\-\-debug\fR Enable debug logging .TP \fB\-\-color\fR=\fIWHEN\fR When to colorize output .br .br [\fIpossible values: \fRalways, never, debug, auto] .TP \fB\-\-quiet\fR Silence non\-primary command output For example, `jj file list` will still list files, but it won\*(Aqt tell you if the working copy was snapshotted or if descendants were rebased. Warnings and errors will still be printed. .TP \fB\-\-no\-pager\fR Disable the pager .TP \fB\-\-config\fR=\fINAME=VALUE\fR Additional configuration options (can be repeated) The name should be specified as TOML dotted keys. The value should be specified as a TOML expression. If string value doesn\*(Aqt contain any TOML constructs (such as array notation), quotes can be omitted. .TP \fB\-\-config\-file\fR=\fIPATH\fR Additional configuration files (can be repeated) .TP \fB\-h\fR, \fB\-\-help\fR Print help (see a summary with \*(Aq\-h\*(Aq) .TP [\fIFILESETS\fR] Fix only these paths