diff --git a/cli/src/cli_util.rs b/cli/src/cli_util.rs index 784d3ddb4f0..2363a6a31f6 100644 --- a/cli/src/cli_util.rs +++ b/cli/src/cli_util.rs @@ -1408,9 +1408,8 @@ See https://github.com/martinvonz/jj/blob/main/docs/working-copy.md#stale-workin // are millions of commits added to the repo, assuming the revset engine can // efficiently skip non-conflicting commits. Filter out empty commits mostly so // `jj new ` doesn't result in a message about new conflicts. - let conflicts = RevsetExpression::filter(RevsetFilterPredicate::HasConflict).intersection( - &RevsetExpression::filter(RevsetFilterPredicate::File(FilesetExpression::all())), - ); + let conflicts = RevsetExpression::filter(RevsetFilterPredicate::HasConflict) + .filtered(RevsetFilterPredicate::File(FilesetExpression::all())); let removed_conflicts_expr = new_heads.range(&old_heads).intersection(&conflicts); let added_conflicts_expr = old_heads.range(&new_heads).intersection(&conflicts); diff --git a/cli/src/commands/status.rs b/cli/src/commands/status.rs index 788cd5b6402..7eb3eb4f3d2 100644 --- a/cli/src/commands/status.rs +++ b/cli/src/commands/status.rs @@ -95,8 +95,10 @@ pub(crate) fn cmd_status( // Ancestors with conflicts, excluding the current working copy commit. let ancestors_conflicts = workspace_command .attach_revset_evaluator( - RevsetExpression::filter(RevsetFilterPredicate::HasConflict) - .intersection(&wc_revset.parents().ancestors()) + wc_revset + .parents() + .ancestors() + .filtered(RevsetFilterPredicate::HasConflict) .minus(&revset_util::parse_immutable_expression( &workspace_command.revset_parse_context(), )?), diff --git a/lib/src/revset.rs b/lib/src/revset.rs index 0241024c808..ddf5dc397ee 100644 --- a/lib/src/revset.rs +++ b/lib/src/revset.rs @@ -353,6 +353,13 @@ impl RevsetExpression { }) } + /// Filter all commits by `predicate` in `self`. + pub fn filtered( + self: &Rc, + predicate: RevsetFilterPredicate, + ) -> Rc { + self.intersection(&RevsetExpression::filter(predicate)) + } /// Commits that are descendants of `self` and ancestors of `heads`, both /// inclusive. pub fn dag_range_to(