mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-19 19:08:08 +00:00
docs: add more detail to section about stale working copies
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
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.
This commit is contained in:
parent
786860e802
commit
c7cd014fe6
1 changed files with 25 additions and 6 deletions
|
@ -91,10 +91,29 @@ 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
|
||||
## Stale working copy
|
||||
|
||||
When you modify workspace A's working-copy commit from workspace B, workspace
|
||||
A's working copy will become stale. By "stale", we mean that the files in the
|
||||
working copy don't match the desired commit indicated by the `@` symbol in
|
||||
`jj log`. When that happens, use `jj workspace update-stale` to update the files
|
||||
in the 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.
|
||||
|
|
Loading…
Reference in a new issue