Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FR: Add a always edit mode to prev/next #3947

Closed
PhilipMetzger opened this issue Jun 22, 2024 · 14 comments · Fixed by #4286
Closed

FR: Add a always edit mode to prev/next #3947

PhilipMetzger opened this issue Jun 22, 2024 · 14 comments · Fixed by #4286
Assignees
Labels
good first issue Good for newcomers polish🪒🐃 Make existing features more convenient and more consistent

Comments

@PhilipMetzger
Copy link
Contributor

Some people don't use the new + squash workflow and always want to edit their commits which would match the behavior of sl next/prev.

@PhilipMetzger PhilipMetzger added good first issue Good for newcomers polish🪒🐃 Make existing features more convenient and more consistent labels Jun 22, 2024
@martinvonz
Copy link
Member

Reminder to address #3935 (comment) if we add a config for edit mode (and presumably stop making it implied in some cases then).

@essiene
Copy link
Contributor

essiene commented Aug 11, 2024

I don't really use the new+squash workflow myself.

What would be a good config flag name for this?

[ui]
prev-always-edit = true|false
next-always-edit = true|false

thoughts?

@essiene essiene self-assigned this Aug 11, 2024
@bnjmnt4n
Copy link
Member

Would this conflict with the decision of not allowing default configuration for commands to avoid inconsistent behavior in #1509?

@essiene
Copy link
Contributor

essiene commented Aug 12, 2024

Would this conflict with the decision of not allowing default configuration for commands to avoid inconsistent behavior in #1509?

Hmmm... I'm not certain, though my own reading of the conclusion of #1509 is that allowing arbitrary defaults for any commands is the undesirable thing. This issue, IIUC, doesn't change the default for the --edit flag, it sets a default behaviour which should hold in the absence of the flag and will still respect the flag if set in either direction.

so if ui.prev-always-edit = true, but I run jj prev --edit=false I expect this to respect the commandline flag. Conversely ui.prev-always-edit = false (the intended default) with jj prev --edit should behave as expected too.

I'd like to get other opinions though, before proceeding in case I've interpreted that wrong.

@yuja
Copy link
Contributor

yuja commented Aug 12, 2024

Would this conflict with the decision of not allowing default configuration for commands

Suppose edit/squash workflow is user preference, config knob seems good. It might be also okay to remove or deprecate the --edit flag.

I personally want a config to never continue editing by jj new --insert-before && jj prev.

@joyously
Copy link

Since there is an --edit flag, wouldn't the solution be an alias, so that it follows 1509?

@PhilipMetzger
Copy link
Contributor Author

Since this a FR based on this comment #2126 (comment), I always thought of having a ui.movement.always_edit flag, which responds to passing jj next/prev --edit.

Would this conflict with the decision of not allowing default configuration for commands

Suppose edit/squash workflow is user preference, config knob seems good.

Yes, that was always my goal here.

It might be also okay to remove or deprecate the --edit flag.

But I don't think we should deprecate it, as usually use edit to move along the stack and then use the new + squash version for dealing with conflicts.

@essiene
Copy link
Contributor

essiene commented Aug 12, 2024

To summarize the conversation:

  • We agree that this should be done.
  • Add a ui.movement.always_edit config flag that controls next/prev behaviour.
  • The --edit flag should stay and have precedence over the config.

sg?

@yuja
Copy link
Contributor

yuja commented Aug 13, 2024

  • Add a ui.movement.always_edit config flag that controls next/prev behaviour.

I don't have naming suggestion, but I think the flag should be tristate.

  • always: equivalent to --edit
  • auto: the current default (= deduce from wc)
  • never: don't deduce

essiene added a commit that referenced this issue Aug 15, 2024
The code in both cli/src/commands/{next,prev}.rs is identical except
for the direction of movement. This no-op PR pull the parts that make
sense out into cli/src/movement_util.rs so it's easier to see the
differences.

Part of #3947
essiene added a commit that referenced this issue Aug 15, 2024
The code in both cli/src/commands/{next,prev}.rs is identical except
for the direction of movement. This no-op PR pull the parts that make
sense out into cli/src/movement_util.rs so it's easier to see the
differences.

Part of #3947
essiene added a commit that referenced this issue Aug 15, 2024
The code in both cli/src/commands/{next,prev}.rs is identical except
for the direction of movement. This no-op PR pull the parts that make
sense out into cli/src/movement_util.rs so it's easier to see the
differences.

Part of #3947
essiene added a commit that referenced this issue Aug 15, 2024
The flag is a tristate flag where:
  - Auto - Maintain current behaviour. This edits if
    the wc parent is not a head commit. Else, it will
    create a new commit on the parent of the wc in
    the direction of movement.
  - Always - Always edit
  - Never - Never edit, prefer the new+squash workflow.

Part of #3947
essiene added a commit that referenced this issue Aug 15, 2024
The flag is a tristate flag where:
  - Auto - Maintain current behaviour. This edits if
    the wc parent is not a head commit. Else, it will
    create a new commit on the parent of the wc in
    the direction of movement.
  - Always - Always edit
  - Never - Never edit, prefer the new+squash workflow.

Part of #3947
essiene added a commit that referenced this issue Aug 15, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Part of #3947
essiene added a commit that referenced this issue Aug 15, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant|ancestor...' helps make it clear what
`jj` is really looking for.

Part of #3947
@bnjmnt4n
Copy link
Member

Hmmm... I'm not certain, though my own reading of the conclusion of #1509 is that allowing arbitrary defaults for any commands is the undesirable thing. This issue, IIUC, doesn't change the default for the --edit flag, it sets a default behaviour which should hold in the absence of the flag and will still respect the flag if set in either direction.

My understanding of #1509 is that we should avoid configuration which can change the default behavior of commands (although I'm not sure if that's an ideal which can be met). To me this change looks like it will conflict with that description, in that it changes the default behavior of the command when no flags are specified, so different iterations of the command on different machines can have differing behavior.

essiene added a commit that referenced this issue Aug 15, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant|ancestor...' helps make it clear what
`jj` is really looking for.

Part of #3947
essiene added a commit that referenced this issue Aug 15, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant|ancestor...' helps make it clear what
`jj` is really looking for.

Part of #3947
@martinvonz
Copy link
Member

I don't have naming suggestion, but I think the flag should be tristate.

  • always: equivalent to --edit
  • auto: the current default (= deduce from wc)
  • never: don't deduce

I feel like the current behavior was just to make it more convenient for the "edit" folks without making it less convenient for the "squash" folks. If we have a config, I hope it's enough to make it a boolean. Do you think the auto mode will be useful?

@essiene
Copy link
Contributor

essiene commented Aug 16, 2024

I feel like the current behavior was just to make it more convenient for the "edit" folks without making it less convenient for the "squash" folks. If we have a config, I hope it's enough to make it a boolean. Do you think the auto mode will be useful?

fwiw, I think the auto mode and by extension, the current behaviour is rather confusing because it doesn't explicitly follow one workflow (new+squash vs inplace-edit). This personally obscured probably the most important thing about the new+squash work flow for me. I'll illustrate below.

# simple linear tree.
$ jj log -T builtin_log_oneline                                                                                 
○  ntqwupxt 34972+essiene 2024-08-15 14:31:12 5ea02047 (empty) third                                                                              
○  ntryxzss 34972+essiene 2024-08-15 14:31:08 affcd6ce (empty) second                                                                             
@  wwyttuku 34972+essiene 2024-08-15 14:31:04 b406e1b4 (empty) first                                                                              
◆  zzzzzzzz root() 00000000

# Current behaviour via config
# next and prev will happily navigate this tree.                                                                                                                     
$ jj config set --repo ui.movement.edit auto                                                                            
$ jj next                                                                                                               
Working copy now at: ntryxzss affcd6ce (empty) second                                                                                             
Parent commit      : wwyttuku b406e1b4 (empty) first
$ jj log -T builtin_log_oneline                 
○  ntqwupxt 34972+essiene 2024-08-15 14:31:12 5ea02047 (empty) third
@  ntryxzss 34972+essiene 2024-08-15 14:31:08 affcd6ce (empty) second
○  wwyttuku 34972+essiene 2024-08-15 14:31:04 b406e1b4 (empty) first
◆  zzzzzzzz root() 00000000
$ jj prev  
Working copy now at: wwyttuku b406e1b4 (empty) first
Parent commit      : zzzzzzzz 00000000 (empty) (no description set)
$ jj log -T builtin_log_oneline
○  ntqwupxt 34972+essiene 2024-08-15 14:31:12 5ea02047 (empty) third
○  ntryxzss 34972+essiene 2024-08-15 14:31:08 affcd6ce (empty) second
@  wwyttuku 34972+essiene 2024-08-15 14:31:04 b406e1b4 (empty) first
◆  zzzzzzzz root() 00000000

# Switch to `never` mode, so force the new+squash workflow.
$ jj config set --repo ui.movement.edit never
$ jj log -T builtin_log_oneline                 
○  ntqwupxt 34972+essiene 2024-08-15 14:31:12 5ea02047 (empty) third
○  ntryxzss 34972+essiene 2024-08-15 14:31:08 affcd6ce (empty) second
@  wwyttuku 34972+essiene 2024-08-15 14:31:04 b406e1b4 (empty) first
◆  zzzzzzzz root() 00000000
$ jj next
Error: No other descendant found 1 commit forward from zzzzzzzzzzzz

My first reaction was wth??!!! Actually, the original error message was more confusing: Error: No descendant found 1 commit forward which made no sense since I could see that the WC had a descendant which the auto mode happily navigated to.

Folks that have internalized the new+squash workflow intuitively know that the problem is that when navigating in the new+squash workflow, you actually navigate using the parent of the WC, not the WC itself. The UI could help with a visual hint to draw the eye more to the WC parent when in new+squash mode. So:

# Once we add a new child of the current node...
$ jj new
Working copy now at: lsuwqswy 2c7181c8 (empty) (no description set)
Parent commit      : wwyttuku b406e1b4 (empty) first
$ jj log -T builtin_log_oneline
@  lsuwqswy 34972+essiene 2024-08-16 16:13:03 2c7181c8 (empty) (no description set)
│ ○  ntqwupxt 34972+essiene 2024-08-15 14:31:12 5ea02047 (empty) third
│ ○  ntryxzss 34972+essiene 2024-08-15 14:31:08 affcd6ce (empty) second
├─╯
○  wwyttuku 34972+essiene 2024-08-15 14:31:04 b406e1b4 (empty) first
◆  zzzzzzzz root() 00000000

# Everything works now, since the new+squash workflow uses the parent as the movement anchor.
$ jj next
Working copy now at: lpttowwx aa7966fb (empty) (no description set)
Parent commit      : ntryxzss affcd6ce (empty) second
$ jj log -T builtin_log_oneline
@  lpttowwx 34972+essiene 2024-08-16 16:13:07 aa7966fb (empty) (no description set)
│ ○  ntqwupxt 34972+essiene 2024-08-15 14:31:12 5ea02047 (empty) third
├─╯
○  ntryxzss 34972+essiene 2024-08-15 14:31:08 affcd6ce (empty) second
○  wwyttuku 34972+essiene 2024-08-15 14:31:04 b406e1b4 (empty) first
◆  zzzzzzzz root() 00000000
$ 

All that to say that the current behaviour obscures this and though it is a convenience, it not consistent behaviour.

Sorry for the wall of text! 😄

essiene added a commit that referenced this issue Aug 16, 2024
Add gratuitous `jj log` output to more points in the tests.
This makes it easier to understand the intended changes
by literally visualizing the commit tree we are after each movement.

This is at least useful for me since I find the new+squash workflow
confusing.

Test behaviour is not changed.

Part of #3947
essiene added a commit that referenced this issue Aug 23, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant...' helps make it clear what
`jj` is really looking for.

Part of #3947
essiene added a commit that referenced this issue Aug 23, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant...' helps make it clear what
`jj` is really looking for.

Part of #3947
essiene added a commit that referenced this issue Aug 23, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Aug 23, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Aug 23, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant...' helps make it clear what
`jj` is really looking for.

Part of #3947
essiene added a commit that referenced this issue Aug 23, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Aug 24, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant...' helps make it clear what
`jj` is really looking for.

Part of #3947
essiene added a commit that referenced this issue Aug 24, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant...' helps make it clear what
`jj` is really looking for.

Part of #3947
essiene added a commit that referenced this issue Aug 24, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Aug 24, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Aug 24, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant...' helps make it clear what
`jj` is really looking for.

Part of #3947
essiene added a commit that referenced this issue Aug 24, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant...' helps make it clear what
`jj` is really looking for.

Part of #3947
essiene added a commit that referenced this issue Aug 24, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Aug 25, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant...' helps make it clear what
`jj` is really looking for.

Part of #3947
essiene added a commit that referenced this issue Aug 25, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Aug 25, 2024
If movement commands don't find a target commit, they fail. However,
it's usually not intuitive why they fail because in non-edit mode the
start commit is the parent of the working commit.

Adding the start commit change hash to the error message makes it easier
for the user to figure out what is going on.

Also, specifying 'No **other** descendant...' helps make it clear what
`jj` is really looking for.

Part of #3947
essiene added a commit that referenced this issue Aug 25, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Aug 27, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Sep 12, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Sep 15, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Sep 16, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Sep 16, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Sep 16, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Sep 16, 2024
See context in [this discussion](#3935 (comment))

Fixes #3947
essiene added a commit that referenced this issue Sep 17, 2024
essiene added a commit that referenced this issue Sep 17, 2024
@logistic-bot
Copy link

This is a really great feature!

I think there is an issue when using the dynamic autocompletions when trying to set the config value: the config string "ui.mo" offers no completions.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
good first issue Good for newcomers polish🪒🐃 Make existing features more convenient and more consistent
Projects
None yet
Development

Successfully merging a pull request may close this issue.

7 participants