From f12ae43911de04d5cf07b0c7eabec0c081803d7c Mon Sep 17 00:00:00 2001 From: Essien Ita Essien <34972+essiene@users.noreply.github.com> Date: Fri, 16 Aug 2024 01:10:44 +0100 Subject: [PATCH] Fetch descendants more correctly. See context in [this discussion](https://github.com/martinvonz/jj/pull/3935#discussion_r1649520967) Fixes #3947 --- cli/src/movement_util.rs | 24 +++++++++++++++--------- 1 file changed, 15 insertions(+), 9 deletions(-) diff --git a/cli/src/movement_util.rs b/cli/src/movement_util.rs index da66fe82bb8..623e601eabb 100644 --- a/cli/src/movement_util.rs +++ b/cli/src/movement_util.rs @@ -121,17 +121,23 @@ impl Direction { start_revset: &Rc, args: &MovementArgsInternal, ) -> Result, CommandError> { - let target_revset = match (self, args.conflict) { - (Direction::Next, true) => start_revset + let target_revset = match (self, args.should_edit, args.conflict) { + (Direction::Next, true, false) => start_revset.descendants_at(args.offset), + (Direction::Next, true, true) => start_revset + .descendants() + .filtered(RevsetFilterPredicate::HasConflict) + .roots(), + (Direction::Next, false, false) => start_revset + .children() + .minus(working_revset) + .descendants_at(args.offset), + (Direction::Next, false, true) => start_revset .children() + .minus(working_revset) .descendants() .filtered(RevsetFilterPredicate::HasConflict) - .roots() - .minus(working_revset), - (Direction::Next, false) => start_revset - .descendants_at(args.offset) - .minus(working_revset), - (Direction::Prev, true) => + .roots(), + (Direction::Prev, _, true) => // If people desire to move to the root conflict, replace the `heads()` below // with `roots(). But let's wait for feedback. { @@ -141,7 +147,7 @@ impl Direction { .filtered(RevsetFilterPredicate::HasConflict) .heads() } - (Direction::Prev, false) => start_revset.ancestors_at(args.offset), + (Direction::Prev, _, false) => start_revset.ancestors_at(args.offset), }; Ok(target_revset)