revset: move RevsetCommitRef::VisibleHeads to RevsetExpression

I'm going to add RevsetExpression<State = Resolved|User> type parameter to
detect API misuse at compile time. VisibleHeads is similar to All, and appears
in generic expression substitution function where a concrete State type
shouldn't be known.
This commit is contained in:
Yuya Nishihara 2024-11-03 17:18:56 +09:00
parent e38f7b0594
commit 0e8f1ce579

View file

@ -131,7 +131,6 @@ pub enum RevsetCommitRef {
name: String, name: String,
remote: String, remote: String,
}, },
VisibleHeads,
Root, Root,
Bookmarks(StringPattern), Bookmarks(StringPattern),
RemoteBookmarks { RemoteBookmarks {
@ -183,6 +182,7 @@ pub enum RevsetFilterPredicate {
pub enum RevsetExpression { pub enum RevsetExpression {
None, None,
All, All,
VisibleHeads,
Commits(Vec<CommitId>), Commits(Vec<CommitId>),
CommitRef(RevsetCommitRef), CommitRef(RevsetCommitRef),
Ancestors { Ancestors {
@ -273,7 +273,7 @@ impl RevsetExpression {
} }
pub fn visible_heads() -> Rc<Self> { pub fn visible_heads() -> Rc<Self> {
Rc::new(Self::CommitRef(RevsetCommitRef::VisibleHeads)) Rc::new(Self::VisibleHeads)
} }
pub fn root() -> Rc<Self> { pub fn root() -> Rc<Self> {
@ -1162,6 +1162,7 @@ fn try_transform_expression<E>(
Ok(match expression.as_ref() { Ok(match expression.as_ref() {
RevsetExpression::None => None, RevsetExpression::None => None,
RevsetExpression::All => None, RevsetExpression::All => None,
RevsetExpression::VisibleHeads => None,
RevsetExpression::Commits(_) => None, RevsetExpression::Commits(_) => None,
RevsetExpression::CommitRef(_) => None, RevsetExpression::CommitRef(_) => None,
RevsetExpression::Ancestors { heads, generation } => transform_rec(heads, pre, post)? RevsetExpression::Ancestors { heads, generation } => transform_rec(heads, pre, post)?
@ -1904,7 +1905,6 @@ fn resolve_commit_ref(
let wc_commits = repo.view().wc_commit_ids().values().cloned().collect_vec(); let wc_commits = repo.view().wc_commit_ids().values().cloned().collect_vec();
Ok(wc_commits) Ok(wc_commits)
} }
RevsetCommitRef::VisibleHeads => Ok(repo.view().heads().iter().cloned().collect_vec()),
RevsetCommitRef::Root => Ok(vec![repo.store().root_commit_id().clone()]), RevsetCommitRef::Root => Ok(vec![repo.store().root_commit_id().clone()]),
RevsetCommitRef::Bookmarks(pattern) => { RevsetCommitRef::Bookmarks(pattern) => {
let commit_ids = repo let commit_ids = repo
@ -2040,6 +2040,7 @@ impl VisibilityResolutionContext<'_> {
match expression { match expression {
RevsetExpression::None => ResolvedExpression::Commits(vec![]), RevsetExpression::None => ResolvedExpression::Commits(vec![]),
RevsetExpression::All => self.resolve_all(), RevsetExpression::All => self.resolve_all(),
RevsetExpression::VisibleHeads => self.resolve_visible_heads(),
RevsetExpression::Commits(commit_ids) => { RevsetExpression::Commits(commit_ids) => {
ResolvedExpression::Commits(commit_ids.clone()) ResolvedExpression::Commits(commit_ids.clone())
} }
@ -2165,6 +2166,7 @@ impl VisibilityResolutionContext<'_> {
match expression { match expression {
RevsetExpression::None RevsetExpression::None
| RevsetExpression::All | RevsetExpression::All
| RevsetExpression::VisibleHeads
| RevsetExpression::Commits(_) | RevsetExpression::Commits(_)
| RevsetExpression::CommitRef(_) | RevsetExpression::CommitRef(_)
| RevsetExpression::Ancestors { .. } | RevsetExpression::Ancestors { .. }
@ -2783,13 +2785,13 @@ mod tests {
generation: 0..18446744073709551615, generation: 0..18446744073709551615,
} }
"###); "###);
insta::assert_debug_snapshot!(parse("foo..").unwrap(), @r###" insta::assert_debug_snapshot!(parse("foo..").unwrap(), @r#"
Range { Range {
roots: CommitRef(Symbol("foo")), roots: CommitRef(Symbol("foo")),
heads: CommitRef(VisibleHeads), heads: VisibleHeads,
generation: 0..18446744073709551615, generation: 0..18446744073709551615,
} }
"###); "#);
insta::assert_debug_snapshot!(parse("foo..bar").unwrap(), @r###" insta::assert_debug_snapshot!(parse("foo..bar").unwrap(), @r###"
Range { Range {
roots: CommitRef(Symbol("foo")), roots: CommitRef(Symbol("foo")),
@ -2798,13 +2800,13 @@ mod tests {
} }
"###); "###);
// Parse the nullary "range" operator // Parse the nullary "range" operator
insta::assert_debug_snapshot!(parse("..").unwrap(), @r###" insta::assert_debug_snapshot!(parse("..").unwrap(), @r"
Range { Range {
roots: CommitRef(Root), roots: CommitRef(Root),
heads: CommitRef(VisibleHeads), heads: VisibleHeads,
generation: 0..18446744073709551615, generation: 0..18446744073709551615,
} }
"###); ");
// Parse the "negate" operator // Parse the "negate" operator
insta::assert_debug_snapshot!( insta::assert_debug_snapshot!(
parse("~ foo").unwrap(), parse("~ foo").unwrap(),
@ -3357,13 +3359,13 @@ mod tests {
generation: 0..18446744073709551615, generation: 0..18446744073709551615,
} }
"###); "###);
insta::assert_debug_snapshot!(optimize(parse("foo..").unwrap()), @r###" insta::assert_debug_snapshot!(optimize(parse("foo..").unwrap()), @r#"
Range { Range {
roots: CommitRef(Symbol("foo")), roots: CommitRef(Symbol("foo")),
heads: CommitRef(VisibleHeads), heads: VisibleHeads,
generation: 0..18446744073709551615, generation: 0..18446744073709551615,
} }
"###); "#);
insta::assert_debug_snapshot!(optimize(parse("foo..bar").unwrap()), @r###" insta::assert_debug_snapshot!(optimize(parse("foo..bar").unwrap()), @r###"
Range { Range {
roots: CommitRef(Symbol("foo")), roots: CommitRef(Symbol("foo")),
@ -3407,35 +3409,35 @@ mod tests {
let _guard = settings.bind_to_scope(); let _guard = settings.bind_to_scope();
// '~(::foo)' is equivalent to 'foo..'. // '~(::foo)' is equivalent to 'foo..'.
insta::assert_debug_snapshot!(optimize(parse("~(::foo)").unwrap()), @r###" insta::assert_debug_snapshot!(optimize(parse("~(::foo)").unwrap()), @r#"
Range { Range {
roots: CommitRef(Symbol("foo")), roots: CommitRef(Symbol("foo")),
heads: CommitRef(VisibleHeads), heads: VisibleHeads,
generation: 0..18446744073709551615, generation: 0..18446744073709551615,
} }
"###); "#);
// '~(::foo-)' is equivalent to 'foo-..'. // '~(::foo-)' is equivalent to 'foo-..'.
insta::assert_debug_snapshot!(optimize(parse("~(::foo-)").unwrap()), @r###" insta::assert_debug_snapshot!(optimize(parse("~(::foo-)").unwrap()), @r#"
Range { Range {
roots: Ancestors { roots: Ancestors {
heads: CommitRef(Symbol("foo")), heads: CommitRef(Symbol("foo")),
generation: 1..2, generation: 1..2,
}, },
heads: CommitRef(VisibleHeads), heads: VisibleHeads,
generation: 0..18446744073709551615, generation: 0..18446744073709551615,
} }
"###); "#);
insta::assert_debug_snapshot!(optimize(parse("~(::foo--)").unwrap()), @r###" insta::assert_debug_snapshot!(optimize(parse("~(::foo--)").unwrap()), @r#"
Range { Range {
roots: Ancestors { roots: Ancestors {
heads: CommitRef(Symbol("foo")), heads: CommitRef(Symbol("foo")),
generation: 2..3, generation: 2..3,
}, },
heads: CommitRef(VisibleHeads), heads: VisibleHeads,
generation: 0..18446744073709551615, generation: 0..18446744073709551615,
} }
"###); "#);
// Bounded ancestors shouldn't be substituted. // Bounded ancestors shouldn't be substituted.
insta::assert_debug_snapshot!(optimize(parse("~ancestors(foo, 1)").unwrap()), @r###" insta::assert_debug_snapshot!(optimize(parse("~ancestors(foo, 1)").unwrap()), @r###"