forked from mirrors/jj
docs: add FAQ for why to use new-then-amend over edit
This commit is contained in:
parent
289b9bc71f
commit
3bbc3e5715
3 changed files with 18 additions and 0 deletions
|
@ -25,6 +25,8 @@ use crate::ui::Ui;
|
||||||
///
|
///
|
||||||
/// Note: it is generally recommended to instead use `jj new` and `jj
|
/// Note: it is generally recommended to instead use `jj new` and `jj
|
||||||
/// squash`.
|
/// squash`.
|
||||||
|
///
|
||||||
|
/// For more information, see https://martinvonz.github.io/jj/latest/FAQ#how-do-i-resume-working-on-an-existing-change
|
||||||
#[derive(clap::Args, Clone, Debug)]
|
#[derive(clap::Args, Clone, Debug)]
|
||||||
pub(crate) struct EditArgs {
|
pub(crate) struct EditArgs {
|
||||||
/// The commit to edit
|
/// The commit to edit
|
||||||
|
|
|
@ -710,6 +710,8 @@ Sets the specified revision as the working-copy revision
|
||||||
|
|
||||||
Note: it is generally recommended to instead use `jj new` and `jj squash`.
|
Note: it is generally recommended to instead use `jj new` and `jj squash`.
|
||||||
|
|
||||||
|
For more information, see https://martinvonz.github.io/jj/latest/FAQ#how-do-i-resume-working-on-an-existing-change
|
||||||
|
|
||||||
**Usage:** `jj edit <REVISION>`
|
**Usage:** `jj edit <REVISION>`
|
||||||
|
|
||||||
###### **Arguments:**
|
###### **Arguments:**
|
||||||
|
|
14
docs/FAQ.md
14
docs/FAQ.md
|
@ -136,6 +136,20 @@ commit, then run `jj restore --from Y --to @-` to restore the parent commit
|
||||||
to the old state, and `jj restore --from X` to restore the new working-copy
|
to the old state, and `jj restore --from X` to restore the new working-copy
|
||||||
commit to the new state.
|
commit to the new state.
|
||||||
|
|
||||||
|
### How do I resume working on an existing change?
|
||||||
|
|
||||||
|
There are two ways to resume working on an earlier change: `jj new` then `jj squash`,
|
||||||
|
and `jj edit`. The first is generally recommended, but `jj edit` can be useful. When
|
||||||
|
you use `jj edit`, the revision is directly amended with your new changes, making it
|
||||||
|
difficult to tell what exactly you change. You should avoid using `jj edit` when the
|
||||||
|
revision has a conflict, as you may accidentally break the plain-text annotations on
|
||||||
|
your state without realising.
|
||||||
|
|
||||||
|
To start, use `jj new <rev>` to create a change based on that earlier revision. Make
|
||||||
|
your edits, then use `jj squash` to update the earlier revision with those edits.
|
||||||
|
For when you would use git stashing, use `jj edit <rev>` for expected behaviour.
|
||||||
|
Other workflows may prefer `jj edit` as well.
|
||||||
|
|
||||||
### How do I deal with divergent changes ('??' after the [change ID])?
|
### How do I deal with divergent changes ('??' after the [change ID])?
|
||||||
|
|
||||||
A [divergent change][glossary_divergent_change] represents a change that has two
|
A [divergent change][glossary_divergent_change] represents a change that has two
|
||||||
|
|
Loading…
Reference in a new issue