.ie \n(.g .ds Aq \(aq .el .ds Aq ' .TH jj-log 1 "log " .SH NAME jj\-log \- Show revision history .SH SYNOPSIS \fBjj log\fR [\fB\-r\fR|\fB\-\-revisions\fR] [\fB\-n\fR|\fB\-\-limit\fR] [\fB\-\-reversed\fR] [\fB\-\-no\-graph\fR] [\fB\-T\fR|\fB\-\-template\fR] [\fB\-p\fR|\fB\-\-patch\fR] [\fB\-s\fR|\fB\-\-summary\fR] [\fB\-\-stat\fR] [\fB\-\-types\fR] [\fB\-\-name\-only\fR] [\fB\-\-git\fR] [\fB\-\-color\-words\fR] [\fB\-\-tool\fR] [\fB\-\-context\fR] [\fB\-\-ignore\-all\-space\fR] [\fB\-\-ignore\-space\-change\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 Show revision history .PP Renders a graphical view of the project\*(Aqs history, ordered with children before parents. By default, the output only includes mutable revisions, along with some additional revisions for context. Use `jj log \-r ::` to see all revisions. See [`jj help \-k revsets`] for information about the syntax. .PP [`jj help \-k revsets`]: https://jj\-vcs.github.io/jj/latest/revsets/ .PP Spans of revisions that are not included in the graph per `\-\-revisions` are rendered as a synthetic node labeled "(elided revisions)". .PP The working\-copy commit is indicated by a `@` symbol in the graph. [Immutable revisions] have a `◆` symbol. Other commits have a `○` symbol. All of these symbols can be [customized]. .PP [Immutable revisions]: https://jj\-vcs.github.io/jj/latest/config/#set\-of\-immutable\-commits .PP [customized]: https://jj\-vcs.github.io/jj/latest/config/#node\-style .SH OPTIONS .TP \fB\-r\fR, \fB\-\-revisions\fR=\fIREVSETS\fR Which revisions to show If no paths nor revisions are specified, this defaults to the `revsets.log` setting. .TP \fB\-n\fR, \fB\-\-limit\fR=\fILIMIT\fR Limit number of revisions to show Applied after revisions are filtered and reordered topologically, but before being reversed. .TP \fB\-\-reversed\fR Show revisions in the opposite order (older revisions first) .TP \fB\-\-no\-graph\fR Don\*(Aqt show the graph, show a flat list of revisions .TP \fB\-T\fR, \fB\-\-template\fR=\fITEMPLATE\fR Render each revision using the given template Run `jj log \-T` to list the built\-in templates. You can also specify arbitrary [template expressions] using the [built\-in keywords]. If not specified, this defaults to the `templates.log` setting. [template expression]: https://jj\-vcs.github.io/jj/latest/templates/ [built\-in keywords]: https://jj\-vcs.github.io/jj/latest/templates/#commit\-keywords .TP \fB\-p\fR, \fB\-\-patch\fR Show patch .TP \fB\-s\fR, \fB\-\-summary\fR For each path, show only whether it was modified, added, or deleted .TP \fB\-\-stat\fR Show a histogram of the changes .TP \fB\-\-types\fR For each path, show only its type before and after The diff is shown as two letters. The first letter indicates the type before and the second letter indicates the type after. \*(Aq\-\*(Aq indicates that the path was not present, \*(AqF\*(Aq represents a regular file, `L\*(Aq represents a symlink, \*(AqC\*(Aq represents a conflict, and \*(AqG\*(Aq represents a Git submodule. .TP \fB\-\-name\-only\fR For each path, show only its path Typically useful for shell commands like: `jj diff \-r @\- \-\-name\-only | xargs perl \-pi \-e\*(Aqs/OLD/NEW/g` .TP \fB\-\-git\fR Show a Git\-format diff .TP \fB\-\-color\-words\fR Show a word\-level diff with changes indicated only by color .TP \fB\-\-tool\fR=\fITOOL\fR Generate diff by external command .TP \fB\-\-context\fR=\fICONTEXT\fR Number of lines of context to show .TP \fB\-\-ignore\-all\-space\fR Ignore whitespace when comparing lines .TP \fB\-\-ignore\-space\-change\fR Ignore changes in amount of whitespace when comparing lines .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] Show revisions modifying the given paths