mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-12 23:23:20 +00:00
c7cd014fe6
Some checks are pending
binaries / Build binary artifacts (linux-aarch64-gnu, ubuntu-24.04, aarch64-unknown-linux-gnu) (push) Waiting to run
binaries / Build binary artifacts (linux-aarch64-musl, ubuntu-24.04, aarch64-unknown-linux-musl) (push) Waiting to run
binaries / Build binary artifacts (linux-x86_64-gnu, ubuntu-24.04, x86_64-unknown-linux-gnu) (push) Waiting to run
binaries / Build binary artifacts (linux-x86_64-musl, ubuntu-24.04, x86_64-unknown-linux-musl) (push) Waiting to run
binaries / Build binary artifacts (macos-aarch64, macos-14, aarch64-apple-darwin) (push) Waiting to run
binaries / Build binary artifacts (macos-x86_64, macos-13, x86_64-apple-darwin) (push) Waiting to run
binaries / Build binary artifacts (win-x86_64, windows-2022, x86_64-pc-windows-msvc) (push) Waiting to run
nix / flake check (macos-14) (push) Waiting to run
nix / flake check (ubuntu-latest) (push) Waiting to run
build / build (, macos-13) (push) Waiting to run
build / build (, macos-14) (push) Waiting to run
build / build (, ubuntu-latest) (push) Waiting to run
build / build (, windows-latest) (push) Waiting to run
build / build (--all-features, ubuntu-latest) (push) Waiting to run
build / Build jj-lib without Git support (push) Waiting to run
build / Check protos (push) Waiting to run
build / Check formatting (push) Waiting to run
build / Check that MkDocs can build the docs (push) Waiting to run
build / Check that MkDocs can build the docs with Poetry 1.8 (push) Waiting to run
build / cargo-deny (advisories) (push) Waiting to run
build / cargo-deny (bans licenses sources) (push) Waiting to run
build / Clippy check (push) Waiting to run
Codespell / Codespell (push) Waiting to run
website / prerelease-docs-build-deploy (ubuntu-latest) (push) Waiting to run
Scorecards supply-chain security / Scorecards analysis (push) Waiting to run
We only explained that working copies can become stale when updating a commit from another workspace, but there are other cases too. I also tried to better explain what the state actually means.
119 lines
5.7 KiB
Markdown
119 lines
5.7 KiB
Markdown
# Working copy
|
|
|
|
|
|
## Introduction
|
|
|
|
The working copy is where the current working-copy commit's files are written so
|
|
you can interact with them. It is also where files are read from in order to
|
|
create new commits (though there are many other ways of creating new commits).
|
|
|
|
Unlike most other VCSs, Jujutsu will automatically create commits from the
|
|
working-copy contents when they have changed. Most `jj` commands you run will
|
|
commit the working-copy changes if they have changed. The resulting revision
|
|
will replace the previous working-copy revision.
|
|
|
|
Also unlike most other VCSs, added files are implicitly tracked by default. That
|
|
means that if you add a new file to the working copy, it will be automatically
|
|
committed once you run e.g. `jj st`. Similarly, if you remove a file from the
|
|
working copy, it will implicitly be untracked.
|
|
|
|
The `snapshot.auto-track` config option controls which paths get automatically
|
|
tracked when they're added to the working copy. See the
|
|
[fileset documentation](filesets.md) for the syntax. Files with paths matching
|
|
[ignore files](#ignored-files) are never tracked automatically.
|
|
|
|
You can use `jj file untrack` to untrack a file while keeping it in the working
|
|
copy. However, first [ignore](#ignored-files) them or remove them from the
|
|
`snapshot.auto-track` patterns; otherwise they will be immediately tracked again.
|
|
|
|
|
|
## Conflicts
|
|
|
|
When you check out a commit with conflicts, those conflicts need to be
|
|
represented in the working copy somehow. However, the file system doesn't
|
|
understand conflicts. Jujutsu's solution is to add conflict markers to
|
|
conflicted files when it writes them to the working copy. It also keeps track of
|
|
the (typically 3) different parts involved in the conflict. Whenever it scans
|
|
the working copy thereafter, it parses the conflict markers and recreates the
|
|
conflict state from them. You can resolve conflicts by replacing the conflict
|
|
markers by the resolved text. You don't need to resolve all conflicts at once.
|
|
You can even resolve part of a conflict by updating the different parts of the
|
|
conflict marker.
|
|
|
|
To resolve conflicts in a commit, use `jj new <commit>` to create a working-copy
|
|
commit on top. You would then have the same conflicts in the working-copy
|
|
commit. Once you have resolved the conflicts, you can inspect the conflict
|
|
resolutions with `jj diff`. Then run `jj squash` to move the conflict
|
|
resolutions into the conflicted commit. Alternatively, you can edit the commit
|
|
with conflicts directly in the working copy by using `jj edit <commit>`. The
|
|
main disadvantage of that is that it's harder to inspect the conflict
|
|
resolutions.
|
|
|
|
With the `jj resolve` command, you can use an external merge tool to resolve
|
|
conflicts that have 2 sides and a base. There is not yet a good way of
|
|
resolving conflicts between directories, files, and symlinks
|
|
(https://github.com/martinvonz/jj/issues/19). You can use `jj restore` to choose
|
|
one side of the conflict, but there's no way to even see where the involved
|
|
parts came from.
|
|
|
|
|
|
## Ignored files
|
|
|
|
You probably don't want build outputs and temporary files to be under version
|
|
control. You can tell Jujutsu to not automatically track certain files by using
|
|
`.gitignore` files (there's no such thing as `.jjignore` yet).
|
|
See https://git-scm.com/docs/gitignore for details about the format.
|
|
`.gitignore` files are supported in any directory in the working copy, as well
|
|
as in `$HOME/.gitignore` and `$GIT_DIR/info/exclude`.
|
|
|
|
Ignored files are never tracked automatically (regardless of the value of
|
|
`snapshot.auto-track`), but they can still end up being tracked for a few reasons:
|
|
|
|
* if they were tracked in the parent commit
|
|
* because of an explicit `jj file track` command
|
|
|
|
You can untrack such files with the jj file untrack command.
|
|
|
|
|
|
## Workspaces
|
|
|
|
You can have multiple working copies backed by a single repo. Use
|
|
`jj workspace add` to create a new working copy. The working copy will have a
|
|
`.jj/` directory linked to the main repo. The working copy and the `.jj/`
|
|
directory together is called a "workspace". Each workspace can have a different
|
|
commit checked out.
|
|
|
|
Having multiple workspaces can be useful for running long-running tests in a one
|
|
while you continue developing in another, for example. If needed,
|
|
`jj workspace root` prints the root path of the current workspace.
|
|
|
|
When you're done using a workspace, use `jj workspace forget` to make the repo
|
|
forget about it. The files can be deleted from disk separately (either before or
|
|
after).
|
|
|
|
## Stale working copy
|
|
|
|
Almost all commands go through three main steps:
|
|
|
|
1. Snapshot the working copy (which gets recorded as an operation)
|
|
2. Create new commits etc. "in memory" and record that as a new operation
|
|
3. Update the working copy to match the new operation, i.e. to the commit that
|
|
the operation says that `@` should point to
|
|
|
|
If step 3 doesn't happen for some reason, the working copy is considered
|
|
"stale". We can detect that because the working copy (`.jj/working_copy/`)
|
|
keeps track of which operation it was last updated to. When the working copy is
|
|
stale, use `jj workspace update-stale` to update the files in the working copy.
|
|
|
|
A common reason that step 3 doesn't happen for a working copy is that you
|
|
rewrote the commit from another workspace. When you modify workspace A's
|
|
working-copy commit from workspace B, workspace A's working copy will become
|
|
stale.
|
|
|
|
A working copy can also become stale because some error, such as `^C` prevented
|
|
step 3 from completing. It's also possible that it was successfully updated in
|
|
step 3 but the operation has then been lost (e.g. by `jj op abandon` or
|
|
"spontaneously" by certain storage backends). If the operation has been lost,
|
|
then `jj workspace update-stale` will create a recovery commit with the
|
|
contents of the working copy but parented to the current operation's
|
|
working-copy commit.
|